File: Matrix.hs

package info (click to toggle)
haskell-diagrams-lib 1.4.6.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,256 kB
  • sloc: haskell: 8,263; makefile: 2
file content (26 lines) | stat: -rw-r--r-- 716 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
{-# LANGUAGE ScopedTypeVariables #-}

-- |

module Diagrams.Test.Transform.Matrix where


import           Test.Tasty
import           Test.Tasty.QuickCheck
import           Diagrams.Transform.Matrix
import           Diagrams.Prelude
import           Data.Distributive (distribute)

import Instances

tests :: TestTree
tests = testGroup "Transform.Matrix"
  [
    testProperty "mkMat column vectors (2D)" $
      \(Blind (t :: T2 Double)) -> distribute (mkMat t) =~ V2 (transform t unitX) (transform t unitY)
  , testProperty "mkMat / fromMat22" $
      \(m :: V2 (V2 Double)) -> mkMat (fromMat22 m zero) =~ m

  , testProperty "mkMat / fromMat33" $
      \(m :: V3 (V3 Double)) -> mkMat (fromMat33 m zero) =~ m
  ]