module Main where import Data.Ratio ( (%) ) import Math.Algebra.Hspray ( (^+^), (*^), Spray , evalSpray, isSymmetricSpray ) import Math.Algebra.Jack ( jack, zonal, schur ) import Math.Algebra.Jack.HypergeoPQ ( hypergeoPQ ) import Math.Algebra.JackPol ( zonalPol, jackPol, schurPol ) import Math.HypergeoMatrix ( hypergeomat ) import Test.Tasty ( defaultMain , testGroup ) import Test.Tasty.HUnit ( assertEqual , assertBool , testCase ) main :: IO () main = defaultMain $ testGroup "Tests" [ testCase "jackPol" $ do let jp = jackPol 2 [3, 1] (2 % 1) :: Spray Rational v = evalSpray jp [1, 1] assertEqual "" v (48 % 1) , testCase "jackPol is symmetric" $ do let jp = jackPol 3 [3, 2, 1] (2 % 1) :: Spray Rational assertBool "" (isSymmetricSpray jp) , testCase "jack" $ do assertEqual "" (jack [1, 1] [3, 1] (2 % 1)) (48 % 1 :: Rational) , testCase "schurPol" $ do let sp1 = schurPol 4 [4] sp2 = schurPol 4 [3, 1] sp3 = schurPol 4 [2, 2] sp4 = schurPol 4 [2, 1, 1] sp5 = schurPol 4 [1, 1, 1, 1] :: Spray Int v = evalSpray (sp1 ^+^ 3 *^ sp2 ^+^ 2 *^ sp3 ^+^ 3 *^ sp4 ^+^ sp5) [2, 2, 2, 2] assertEqual "" v 4096 , testCase "schurPol is symmetric" $ do let sp = schurPol 3 [3, 2, 1] :: Spray Rational assertBool "" (isSymmetricSpray sp) , testCase "schur" $ do let sp1 = schur [1, 1, 1, 1] [4] sp2 = schur [1, 1, 1, 1] [3, 1] sp3 = schur [1, 1, 1, 1] [2, 2] sp4 = schur [1, 1, 1, 1] [2, 1, 1] sp5 = schur [1, 1, 1, 1] [1, 1, 1, 1] :: Int assertEqual "" (sp1 + 3 * sp2 + 2 * sp3 + 3 * sp4 + sp5) 256 , testCase "zonalPol" $ do let zp1 = zonalPol 4 [3] :: Spray Rational zp2 = zonalPol 4 [2, 1] :: Spray Rational zp3 = zonalPol 4 [1, 1, 1] :: Spray Rational v = evalSpray (zp1 ^+^ zp2 ^+^ zp3) [2, 2, 2, 2] assertEqual "" v 512 , testCase "zonal" $ do let zp1 = zonal [2 % 1, 2 % 1, 2 % 1, 2 % 1] [3] zp2 = zonal [2 % 1, 2 % 1, 2 % 1, 2 % 1] [2, 1] zp3 = zonal [2 % 1, 2 % 1, 2 % 1, 2 % 1] [1, 1, 1] :: Rational assertEqual "" (zp1 + zp2 + zp3) 512 , testCase "hypergeometric function" $ do let a = [1 % 1, 2 % 1] b = [3 % 1] x = [1 % 5, 1 % 2] h1 = hypergeoPQ 10 a b x :: Rational h2 <- hypergeomat 10 2 a b x assertEqual "" h1 h2 ]