| 1 | |
|---|
| 2 | |
|---|
| 3 | import qualified Data.Vector.Unboxed as V |
|---|
| 4 | |
|---|
| 5 | |
|---|
| 6 | |
|---|
| 7 | |
|---|
| 8 | type Name = String |
|---|
| 9 | type Time = (V.Vector Double) |
|---|
| 10 | type Vect = (V.Vector Double) |
|---|
| 11 | type Unit = String |
|---|
| 12 | |
|---|
| 13 | |
|---|
| 14 | newtype Signal = Signal (Name, Time, Vect, Unit) |
|---|
| 15 | |
|---|
| 16 | |
|---|
| 17 | getName :: Signal -> String |
|---|
| 18 | getName (Signal (n,t,v,u)) = n |
|---|
| 19 | |
|---|
| 20 | getTime :: Signal -> Vect |
|---|
| 21 | getTime (Signal (n,t,v,u)) = t |
|---|
| 22 | |
|---|
| 23 | getVect :: Signal -> Vect |
|---|
| 24 | getVect (Signal (n,t,v,u)) = v |
|---|
| 25 | |
|---|
| 26 | getUnit :: Signal -> Unit |
|---|
| 27 | getUnit (Signal (n,t,v,u)) = u |
|---|
| 28 | |
|---|
| 29 | |
|---|
| 30 | snegate s1 = smap negate s1 "negate" |
|---|
| 31 | |
|---|
| 32 | |
|---|
| 33 | instance Show Signal where |
|---|
| 34 | show s = "TimeSignal time: " ++ show (getName s) ++ " val:" ++ show (getVect s) ++ show (getUnit s) |
|---|
| 35 | |
|---|
| 36 | |
|---|
| 37 | |
|---|
| 38 | smap :: (Double -> Double) -> Signal -> String -> Signal |
|---|
| 39 | smap f s1 fstr = Signal (n,t,v,u) |
|---|
| 40 | where |
|---|
| 41 | n = getName s1 |
|---|
| 42 | t = getTime s1 |
|---|
| 43 | vdata = getVect s1 |
|---|
| 44 | u = getUnit s1 |
|---|
| 45 | v = V.map f v |
|---|
| 46 | |
|---|
| 47 | |
|---|
| 48 | |
|---|
| 49 | |
|---|
| 50 | vnegate :: V.Vector Double -> V.Vector Double |
|---|
| 51 | vnegate v = V.map negate v |
|---|
| 52 | |
|---|
| 53 | |
|---|
| 54 | |
|---|
| 55 | |
|---|
| 56 | main = do |
|---|
| 57 | |
|---|
| 58 | let v=V.fromList([0..10]) |
|---|
| 59 | |
|---|
| 60 | |
|---|
| 61 | let vn = vnegate v |
|---|
| 62 | |
|---|
| 63 | |
|---|
| 64 | putStrLn "VectorTests" |
|---|
| 65 | putStrLn (show v) |
|---|
| 66 | putStrLn (show vn) |
|---|
| 67 | |
|---|
| 68 | |
|---|
| 69 | let s = Signal("name",v,v,"N") |
|---|
| 70 | |
|---|
| 71 | |
|---|
| 72 | let sn = Signal("name",vn,vn,"N") |
|---|
| 73 | |
|---|
| 74 | |
|---|
| 75 | let sn2 = snegate s |
|---|
| 76 | |
|---|
| 77 | |
|---|
| 78 | putStrLn "SignalTests" |
|---|
| 79 | putStrLn (show s) |
|---|
| 80 | putStrLn (show sn) |
|---|
| 81 | |
|---|
| 82 | |
|---|
| 83 | putStrLn "uuups" |
|---|
| 84 | putStrLn (show sn2) |
|---|
| 85 | |
|---|
| 86 | |
|---|
| 87 | putStrLn (show "test") |
|---|
| 88 | |
|---|
| 89 | |
|---|