| 1 | // LAF Base Library | 
|---|
| 2 | // Copyright (c) 2019  Igara Studio S.A. | 
|---|
| 3 | // Copyright (c) 2015-2016 David Capello | 
|---|
| 4 | // | 
|---|
| 5 | // This file is released under the terms of the MIT license. | 
|---|
| 6 | // Read LICENSE.txt for more information. | 
|---|
| 7 |  | 
|---|
| 8 | #ifndef BASE_PI_H_INCLUDED | 
|---|
| 9 | #define BASE_PI_H_INCLUDED | 
|---|
| 10 | #pragma once | 
|---|
| 11 |  | 
|---|
| 12 | #ifndef PI | 
|---|
| 13 | #define PI            3.14159265358979323846 | 
|---|
| 14 | #endif | 
|---|
| 15 |  | 
|---|
| 16 | #include <cmath> | 
|---|
| 17 |  | 
|---|
| 18 | namespace base { | 
|---|
| 19 |  | 
|---|
| 20 | // Puts the angle in the -PI to PI range. | 
|---|
| 21 | inline double fmod_radians(double angle) { | 
|---|
| 22 | if (angle < -PI) { | 
|---|
| 23 | if (angle < -2.0*PI) | 
|---|
| 24 | angle = -std::fmod(-angle, 2.0*PI); | 
|---|
| 25 | angle += 2.0*PI; | 
|---|
| 26 | } | 
|---|
| 27 | if (angle > 2.0*PI) | 
|---|
| 28 | angle = std::fmod(angle, 2.0*PI); | 
|---|
| 29 | if (angle > PI) | 
|---|
| 30 | angle -= 2.0*PI; | 
|---|
| 31 | return angle; | 
|---|
| 32 | } | 
|---|
| 33 |  | 
|---|
| 34 | } | 
|---|
| 35 |  | 
|---|
| 36 | #endif | 
|---|
| 37 |  | 
|---|