module Data.Geo.Jord.RotationSpec ( spec ) where import Data.Geo.Jord import Test.Hspec spec :: Spec spec = do describe "r2xyz" $ it "computes the 3 angles about new axes in the xyz-order from rotation matrix" $ do let xyz = [decimalDegrees 45, decimalDegrees 45, decimalDegrees 5] let rm = [ Vector3d 0.7044160264027587 (-6.162841671621935e-2) 0.7071067811865475 , Vector3d 0.559725765762092 0.6608381550289296 (-0.5) , Vector3d (-0.43646893232965345) 0.7479938977765876 0.5000000000000001 ] r2xyz rm `shouldBe` xyz describe "r2xyz" $ it "computes the 3 angles about new axes in the zyx-order from rotation matrix" $ do let zyx = [decimalDegrees 10, decimalDegrees 20, decimalDegrees 30] let rm = [ Vector3d 0.9254165783983234 1.802831123629725e-2 0.37852230636979245 , Vector3d 0.16317591116653482 0.8825641192593856 (-0.44096961052988237) , Vector3d (-0.3420201433256687) 0.46984631039295416 0.8137976813493738 ] r2zyx rm `shouldBe` zyx describe "xyz2r" $ it "computes the rotation matrix from 3 angles about new axes in the xyz-order" $ do let x = decimalDegrees 45 let y = decimalDegrees 45 let z = decimalDegrees 5 let rm = [ Vector3d 0.7044160264027587 (-6.162841671621935e-2) 0.7071067811865475 , Vector3d 0.559725765762092 0.6608381550289296 (-0.5) , Vector3d (-0.43646893232965345) 0.7479938977765876 0.5000000000000001 ] xyz2r x y z `shouldBe` rm describe "zyx2r" $ it "computes the rotation matrix from 3 angles about new axes in the zyx-order" $ do let x = decimalDegrees 10 let y = decimalDegrees 20 let z = decimalDegrees 30 let rm = [ Vector3d 0.9254165783983234 1.802831123629725e-2 0.37852230636979245 , Vector3d 0.16317591116653482 0.8825641192593856 (-0.44096961052988237) , Vector3d (-0.3420201433256687) 0.46984631039295416 0.8137976813493738 ] zyx2r x y z `shouldBe` rm