summaryrefslogtreecommitdiff
path: root/packages/base/src
diff options
context:
space:
mode:
authorSidharth Kapur <sidharthkapur1@gmail.com>2016-01-27 16:48:10 -0600
committerSidharth Kapur <sidharthkapur1@gmail.com>2016-01-27 16:48:10 -0600
commitef9b4f76fa3a8dccfc08c8c87799945cef98ba54 (patch)
treed77e62ea8930e597e8f0fad2ae7da74da3c6455e /packages/base/src
parenta7c1ccf2f1f69982076ad2acc1029abc95460430 (diff)
Add Num, Fractional, Floating instances for Sym
Diffstat (limited to 'packages/base/src')
-rw-r--r--packages/base/src/Numeric/LinearAlgebra/Static.hs37
1 files changed, 37 insertions, 0 deletions
diff --git a/packages/base/src/Numeric/LinearAlgebra/Static.hs b/packages/base/src/Numeric/LinearAlgebra/Static.hs
index e18ba0c..84a623b 100644
--- a/packages/base/src/Numeric/LinearAlgebra/Static.hs
+++ b/packages/base/src/Numeric/LinearAlgebra/Static.hs
@@ -786,3 +786,40 @@ instance (KnownNat m, KnownNat n) => Normed (L m n)
786 norm_1 m = norm_1 (extract m) 786 norm_1 m = norm_1 (extract m)
787 norm_2 m = norm_2 (extract m) 787 norm_2 m = norm_2 (extract m)
788 norm_Inf m = norm_Inf (extract m) 788 norm_Inf m = norm_Inf (extract m)
789
790mkSym f = Sym . f . unSym
791mkSym2 f x y = Sym (f (unSym x) (unSym y))
792
793instance KnownNat n => Num (Sym n)
794 where
795 (+) = mkSym2 (+)
796 (*) = mkSym2 (*)
797 (-) = mkSym2 (-)
798 abs = mkSym abs
799 signum = mkSym signum
800 negate = mkSym negate
801 fromInteger = Sym . fromInteger
802
803instance KnownNat n => Fractional (Sym n)
804 where
805 fromRational = Sym . L . Dim . Dim . fromRational
806 (/) = mkSym2 (/)
807
808instance KnownNat n => Floating (Sym n) where
809 sin = mkSym sin
810 cos = mkSym cos
811 tan = mkSym tan
812 asin = mkSym asin
813 acos = mkSym acos
814 atan = mkSym atan
815 sinh = mkSym sinh
816 cosh = mkSym cosh
817 tanh = mkSym tanh
818 asinh = mkSym asinh
819 acosh = mkSym acosh
820 atanh = mkSym atanh
821 exp = mkSym exp
822 log = mkSym log
823 sqrt = mkSym sqrt
824 (**) = mkSym2 (**)
825 pi = Sym pi