VEC: use ViewPatterns for pattern matching on P2

This commit is contained in:
hasufell 2014-12-18 00:31:43 +01:00
parent 3727ae620f
commit 1545861e5b
No known key found for this signature in database
GPG Key ID: 220CD1C5BDEED020

View File

@ -1,10 +1,12 @@
{-# OPTIONS_HADDOCK ignore-exports #-} {-# OPTIONS_HADDOCK ignore-exports #-}
{-# LANGUAGE ViewPatterns #-}
module Algebra.Vector where module Algebra.Vector where
import Control.Applicative import Control.Applicative
import Control.Arrow ((***)) import Control.Arrow ((***))
import Data.List (sortBy) import Data.List (sortBy)
import Diagrams.Coordinates
import Diagrams.TwoD.Types import Diagrams.TwoD.Types
import Graphics.Gloss.Geometry.Line import Graphics.Gloss.Geometry.Line
import GHC.Float import GHC.Float
@ -37,13 +39,11 @@ dimToSquare (x1, x2) (y1, y2) = ((x1, y1), (x2, y2))
inRange :: Square -- ^ the square: ((xmin, ymin), (xmax, ymax)) inRange :: Square -- ^ the square: ((xmin, ymin), (xmax, ymax))
-> PT -- ^ Coordinate -> PT -- ^ Coordinate
-> Bool -- ^ result -> Bool -- ^ result
inRange ((xmin, ymin), (xmax, ymax)) p inRange ((xmin, ymin), (xmax, ymax)) (coords -> x :& y)
= x >= min xmin xmax = x >= min xmin xmax
&& x <= max xmin xmax && x <= max xmin xmax
&& y >= min ymin ymax && y >= min ymin ymax
&& y <= max ymin ymax && y <= max ymin ymax
where
(x, y) = unp2 p
-- |Get the angle between two vectors. -- |Get the angle between two vectors.
@ -92,15 +92,8 @@ vp2 a b = pt2Vec b - pt2Vec a
-- |Computes the determinant of 3 points. -- |Computes the determinant of 3 points.
det :: PT -> PT -> PT -> Double det :: PT -> PT -> PT -> Double
det a b c = det (coords -> ax :& ay) (coords -> bx :& by) (coords -> cx :& cy) =
(bx - ax) * (bx - ax) * (cy - ay) - (by - ay) * (cx - ax)
(cy - ay) -
(by - ay) *
(cx - ax)
where
(ax, ay) = unp2 a
(bx, by) = unp2 b
(cx, cy) = unp2 c
-- |Get the point where two lines intesect, if any. -- |Get the point where two lines intesect, if any.
@ -163,12 +156,14 @@ onPT f = p2 . f . unp2
-- |Compare the y-coordinate of two points. -- |Compare the y-coordinate of two points.
ptCmpY :: PT -> PT -> Ordering ptCmpY :: PT -> PT -> Ordering
ptCmpY p1' p2' = compare ((snd . unp2) p1') ((snd . unp2) p2') ptCmpY (coords -> _ :& y1) (coords -> _ :& y2) =
compare y1 y2
-- |Compare the x-coordinate of two points. -- |Compare the x-coordinate of two points.
ptCmpX :: PT -> PT -> Ordering ptCmpX :: PT -> PT -> Ordering
ptCmpX p1' p2' = compare ((fst . unp2) p1') ((fst . unp2) p2') ptCmpX (coords -> x1 :& _) (coords -> x2 :& _) =
compare x1 x2
posInfPT :: PT posInfPT :: PT