summaryrefslogtreecommitdiff
path: root/packages/hmatrix
diff options
context:
space:
mode:
authorAlberto Ruiz <aruiz@um.es>2014-05-16 09:28:57 +0200
committerAlberto Ruiz <aruiz@um.es>2014-05-16 09:28:57 +0200
commit5d15d765c0204854b587b03232b20336ddf91ced (patch)
tree18d481c0452f7e26fb4683000f6bc7fa55434efe /packages/hmatrix
parent0ab93b8eb934167e16dbae193c4fd2b5359a184b (diff)
move rand, randn
Diffstat (limited to 'packages/hmatrix')
-rw-r--r--packages/hmatrix/src/Numeric/HMatrix.hs2
-rw-r--r--packages/hmatrix/src/Numeric/LinearAlgebra/Util.hs27
-rw-r--r--packages/hmatrix/src/Numeric/Random.hs30
3 files changed, 31 insertions, 28 deletions
diff --git a/packages/hmatrix/src/Numeric/HMatrix.hs b/packages/hmatrix/src/Numeric/HMatrix.hs
index c8742c4..36fcf70 100644
--- a/packages/hmatrix/src/Numeric/HMatrix.hs
+++ b/packages/hmatrix/src/Numeric/HMatrix.hs
@@ -134,4 +134,6 @@ import Numeric.Vector()
134import Numeric.Container 134import Numeric.Container
135import Numeric.LinearAlgebra.Algorithms 135import Numeric.LinearAlgebra.Algorithms
136import Numeric.LinearAlgebra.Util 136import Numeric.LinearAlgebra.Util
137import Numeric.Random
138
137 139
diff --git a/packages/hmatrix/src/Numeric/LinearAlgebra/Util.hs b/packages/hmatrix/src/Numeric/LinearAlgebra/Util.hs
index 7d134bf..fb2d54c 100644
--- a/packages/hmatrix/src/Numeric/LinearAlgebra/Util.hs
+++ b/packages/hmatrix/src/Numeric/LinearAlgebra/Util.hs
@@ -22,7 +22,6 @@ module Numeric.LinearAlgebra.Util(
22 col, 22 col,
23 (&), (¦), (——), (#), 23 (&), (¦), (——), (#),
24 (?), (¿), 24 (?), (¿),
25 rand, randn,
26 cross, 25 cross,
27 norm, 26 norm,
28 unitary, 27 unitary,
@@ -60,7 +59,6 @@ import Numeric.LinearAlgebra.Algorithms hiding (i)
60import Numeric.Matrix() 59import Numeric.Matrix()
61import Numeric.Vector() 60import Numeric.Vector()
62 61
63import System.Random(randomIO)
64import Numeric.LinearAlgebra.Util.Convolution 62import Numeric.LinearAlgebra.Util.Convolution
65import Graphics.Plot 63import Graphics.Plot
66 64
@@ -77,31 +75,6 @@ disp :: Int -> Matrix Double -> IO ()
77 75
78disp n = putStrLn . dispf n 76disp n = putStrLn . dispf n
79 77
80-- | pseudorandom matrix with uniform elements between 0 and 1
81randm :: RandDist
82 -> Int -- ^ rows
83 -> Int -- ^ columns
84 -> IO (Matrix Double)
85randm d r c = do
86 seed <- randomIO
87 return (reshape c $ randomVector seed d (r*c))
88
89-- | pseudorandom matrix with uniform elements between 0 and 1
90rand :: Int -> Int -> IO (Matrix Double)
91rand = randm Uniform
92
93{- | pseudorandom matrix with normal elements
94
95>>> x <- randn 3 5
96>>> disp 3 x
973x5
980.386 -1.141 0.491 -0.510 1.512
990.069 -0.919 1.022 -0.181 0.745
1000.313 -0.670 -0.097 -1.575 -0.583
101
102-}
103randn :: Int -> Int -> IO (Matrix Double)
104randn = randm Gaussian
105 78
106{- | create a real diagonal matrix from a list 79{- | create a real diagonal matrix from a list
107 80
diff --git a/packages/hmatrix/src/Numeric/Random.hs b/packages/hmatrix/src/Numeric/Random.hs
index b4c6cde..7bf9e8b 100644
--- a/packages/hmatrix/src/Numeric/Random.hs
+++ b/packages/hmatrix/src/Numeric/Random.hs
@@ -16,13 +16,15 @@ module Numeric.Random (
16 RandDist(..), 16 RandDist(..),
17 randomVector, 17 randomVector,
18 gaussianSample, 18 gaussianSample,
19 uniformSample 19 uniformSample,
20 rand, randn
20) where 21) where
21 22
22import Numeric.GSL.Vector 23import Numeric.GSL.Vector
23import Data.Packed 24import Data.Packed
24import Data.Packed.Numeric 25import Data.Packed.Numeric
25import Numeric.LinearAlgebra.Algorithms 26import Numeric.LinearAlgebra.Algorithms
27import System.Random(randomIO)
26 28
27 29
28type Seed = Int 30type Seed = Int
@@ -55,3 +57,29 @@ uniformSample seed n rgs = m where
55 am = konst' 1 n `outer` a 57 am = konst' 1 n `outer` a
56 m = fromColumns (zipWith scale cs dat) `add` am 58 m = fromColumns (zipWith scale cs dat) `add` am
57 59
60-- | pseudorandom matrix with uniform elements between 0 and 1
61randm :: RandDist
62 -> Int -- ^ rows
63 -> Int -- ^ columns
64 -> IO (Matrix Double)
65randm d r c = do
66 seed <- randomIO
67 return (reshape c $ randomVector seed d (r*c))
68
69-- | pseudorandom matrix with uniform elements between 0 and 1
70rand :: Int -> Int -> IO (Matrix Double)
71rand = randm Uniform
72
73{- | pseudorandom matrix with normal elements
74
75>>> x <- randn 3 5
76>>> disp 3 x
773x5
780.386 -1.141 0.491 -0.510 1.512
790.069 -0.919 1.022 -0.181 0.745
800.313 -0.670 -0.097 -1.575 -0.583
81
82-}
83randn :: Int -> Int -> IO (Matrix Double)
84randn = randm Gaussian
85