module Data.Geo.Jord.TransformSpec ( spec ) where import Data.Geo.Jord import Test.Hspec spec :: Spec spec = do describe "Ellipsoidal transformation between coordinates systems" $ do it "transforms NVector position to ECEF position" $ do let p = nvector 0.5 0.5 0.7071 toEcef p wgs84 `shouldBe` ecefMetres 3194434.411 3194434.411 4487326.819 it "transforms angular position to ECEF position" $ do let refAngular = [ decimalLatLongHeight 39.379 (-48.013) (metres 4702059.834) , decimalLatLongHeight 45.0 45.0 zero , decimalLatLongHeight 48.8562 2.3508 (metres 67.36972232195099) ] let refEcefs = [ ecefMetres 5733855.775 (-6370998.38) 7008137.511 , ecefMetres 3194419.145 3194419.145 4487348.409 , ecefMetres 4200996.77 172460.321 4780102.808 ] mapM_ (\(a, e) -> toEcef a wgs84 `shouldBe` e) (zip refAngular refEcefs) it "transforms ECEF position to angular position" $ do let refAngular = [ decimalLatLongHeight 39.379 (-48.013) (metres 4702059.834050887) , decimalLatLongHeight 45.0 45.0 zero , decimalLatLongHeight 48.8562 2.3508 (metres 67.36990469945641) ] let refEcefs = [ ecefMetres 5733855.774881717 (-6370998.380260889) 7008137.510624695 , ecefMetres 3194419.145121972 3194419.145121971 4487348.408606014 , ecefMetres 4200996.769831858 172460.320727757 4780102.807914356 ] mapM_ (\(a, e) -> fromEcef e wgs84 `shouldBe` a) (zip refAngular refEcefs) describe "Spherical transformation between coordinates systems" $ do it "transforms NVector position to ECEF position" $ do let p = nvector 0.5 0.5 0.7071 toEcef p s84 `shouldBe` ecefMetres 3185519.660103391 3185519.660103391 4504961.903318216 it "transforms angular position to ECEF position" $ do let refAngular = [ decimalLatLongHeight 39.379 (-48.013) (metres 4702059.834) , decimalLatLongHeight 45.0 45.0 zero , decimalLatLongHeight 48.8562 2.3508 (metres 67.36972232195099) , latLongHeight (readLatLong "531914N0014347W") (metres 15000.0) , decimalLatLongHeight 53.1882691 0.1332744 (metres 15000.0) ] let refEcefs = [ ecefMetres 5725717.354041086 (-6361955.622990872) 7025277.913631903 , ecefMetres 3185504.385500001 3185504.3855 4504983.504973072 , ecefMetres 4188328.8912726147 171940.27595767862 4797806.669141033 , ecefMetres 3812864.094233316 (-115142.863124558) 5121515.160893968 , ecefMetres 3826406.4642097903 8900.535428827865 5112694.238306408 ] mapM_ (\(a, e) -> toEcef a s84 `shouldBe` e) (zip refAngular refEcefs) it "transforms ECEF position to angular position" $ do let refAngular = [ decimalLatLongHeight 39.379 (-48.013) (metres 4702059.834217537) , decimalLatLongHeight 45.0 45.0 (metres 1e-3) , decimalLatLongHeight 48.8562 2.3508 (metres 67.36972232195099) ] let refEcefs = [ ecefMetres 5725717.354 (-6361955.623) 7025277.914 , ecefMetres 3185504.386 3185504.386 4504983.505 , ecefMetres 4188328.891 171940.276 4797806.669 ] mapM_ (\(a, e) -> fromEcef e s84 `shouldBe` a) (zip refAngular refEcefs)