From c76595e453d39109b763f597716276a17cd1491d Mon Sep 17 00:00:00 2001 From: Jeffrey Rosenbluth Date: Mon, 10 Mar 2014 17:43:55 -0400 Subject: [PATCH] move avgScale to core --- src/Diagrams/TwoD/Transform.hs | 41 +--------------------------------- 1 file changed, 1 insertion(+), 40 deletions(-) diff --git a/src/Diagrams/TwoD/Transform.hs b/src/Diagrams/TwoD/Transform.hs index 49e7fe39..9f71c4e4 100644 --- a/src/Diagrams/TwoD/Transform.hs +++ b/src/Diagrams/TwoD/Transform.hs @@ -47,7 +47,6 @@ module Diagrams.TwoD.Transform -- * Utilities , onBasis - , avgScale ) where import Diagrams.Core @@ -248,42 +247,4 @@ shearY = transform . shearingY -- is mostly useful for implementing backends. onBasis :: Transformation R2 -> ((R2, R2), R2) onBasis t = ((x, y), v) - where ((x:y:[]), v) = T.onBasis t - --- | Compute the \"average\" amount of scaling performed by a --- transformation. Satisfies the properties --- --- @ --- avgScale (scaling k) == k --- avgScale (t1 <> t2) == avgScale t1 * avgScale t2 --- @ --- --- Backends which do not support stroking in the context of an --- arbitrary transformation may instead call 'avgScale' on --- \"frozen\" transformations and multiply the line width by the --- resulting value. -avgScale :: T2 -> Double -avgScale t = sqrt (abs (x1*y2 - y1*x2)) - where ((unr2 -> (x1,y1), unr2 -> (x2,y2)), _) = onBasis t - -{- - -avgScale is computed as the square root of the positive -determinant. Proofs for the specified properties: - -1. sqrt (|det (scaling k)|) = sqrt (k^2) = k -2. sqrt (|det t1|) * sqrt (|det t2|) - = sqrt (|det t1| * |det t2|) - = sqrt (|det t1 * det t2|) - = sqrt (|det (t1 * t2)|) - -From wikipedia: - - A geometric interpretation can be given to the value of the - determinant of a square matrix with real entries: the absolute - value of the determinant gives the scale factor by which area or - volume (or a higher dimensional analogue) is multiplied under the - associated linear transformation, while its sign indicates whether - the transformation preserves orientation. - --} + where ((x:y:[]), v) = T.onBasis t \ No newline at end of file