-- | -- Module: Data.Geo.Jord.Internal -- Copyright: (c) 2020 Cedric Liegeois -- License: BSD3 -- Maintainer: Cedric Liegeois -- Stability: experimental -- Portability: portable -- -- internal functions. -- module Data.Geo.Jord.Internal ( angleRadians , signedAngleRadians , llEq ) where import Data.Geo.Jord.Position -- | angle in __radians__ between 2 vectors. angleRadians :: Vector3d -> Vector3d -> Double angleRadians v1 v2 = signedAngleRadians v1 v2 Nothing -- | Signed angle in __radians__ between 2 vectors. -- If @n@ is 'Nothing', the angle is always in [0..pi], otherwise it is in [-pi, +pi], -- signed + if @v1@ is clockwise looking along @n@, - in opposite direction. signedAngleRadians :: Vector3d -> Vector3d -> Maybe Vector3d -> Double signedAngleRadians v1 v2 n = atan2 sinO cosO where sign = maybe 1 (signum . vdot (vcross v1 v2)) n sinO = sign * vnorm (vcross v1 v2) cosO = vdot v1 v2 -- | both position have same latitude and longitude irrespective of model ? llEq :: Position a -> Position a -> Bool llEq p1 p2 = latitude p1 == latitude p2 && longitude p1 == longitude p2