numhask-0.2.3.1: numeric classes

Safe HaskellNone
LanguageHaskell2010

NumHask.Data.Complex

Contents

Synopsis

Documentation

data Complex a Source #

Complex numbers are an algebraic type.

For a complex number z, abs z is a number with the magnitude of z, but oriented in the positive real direction, whereas sign z has the phase of z, but unit magnitude.

The Foldable and Traversable instances traverse the real part first.

Constructors

!a :+ !a infix 6

forms a complex number from its real and imaginary rectangular components.

Instances

Functor Complex Source # 

Methods

fmap :: (a -> b) -> Complex a -> Complex b #

(<$) :: a -> Complex b -> Complex a #

Foldable Complex Source # 

Methods

fold :: Monoid m => Complex m -> m #

foldMap :: Monoid m => (a -> m) -> Complex a -> m #

foldr :: (a -> b -> b) -> b -> Complex a -> b #

foldr' :: (a -> b -> b) -> b -> Complex a -> b #

foldl :: (b -> a -> b) -> b -> Complex a -> b #

foldl' :: (b -> a -> b) -> b -> Complex a -> b #

foldr1 :: (a -> a -> a) -> Complex a -> a #

foldl1 :: (a -> a -> a) -> Complex a -> a #

toList :: Complex a -> [a] #

null :: Complex a -> Bool #

length :: Complex a -> Int #

elem :: Eq a => a -> Complex a -> Bool #

maximum :: Ord a => Complex a -> a #

minimum :: Ord a => Complex a -> a #

sum :: Num a => Complex a -> a #

product :: Num a => Complex a -> a #

Traversable Complex Source # 

Methods

traverse :: Applicative f => (a -> f b) -> Complex a -> f (Complex b) #

sequenceA :: Applicative f => Complex (f a) -> f (Complex a) #

mapM :: Monad m => (a -> m b) -> Complex a -> m (Complex b) #

sequence :: Monad m => Complex (m a) -> m (Complex a) #

Eq a => Eq (Complex a) Source # 

Methods

(==) :: Complex a -> Complex a -> Bool #

(/=) :: Complex a -> Complex a -> Bool #

Data a => Data (Complex a) Source # 

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Complex a -> c (Complex a) #

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c (Complex a) #

toConstr :: Complex a -> Constr #

dataTypeOf :: Complex a -> DataType #

dataCast1 :: Typeable (* -> *) t => (forall d. Data d => c (t d)) -> Maybe (c (Complex a)) #

dataCast2 :: Typeable (* -> * -> *) t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c (Complex a)) #

gmapT :: (forall b. Data b => b -> b) -> Complex a -> Complex a #

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Complex a -> r #

gmapQr :: (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Complex a -> r #

gmapQ :: (forall d. Data d => d -> u) -> Complex a -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Complex a -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Complex a -> m (Complex a) #

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Complex a -> m (Complex a) #

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Complex a -> m (Complex a) #

Read a => Read (Complex a) Source # 
Show a => Show (Complex a) Source # 

Methods

showsPrec :: Int -> Complex a -> ShowS #

show :: Complex a -> String #

showList :: [Complex a] -> ShowS #

Generic (Complex a) Source # 

Associated Types

type Rep (Complex a) :: * -> * #

Methods

from :: Complex a -> Rep (Complex a) x #

to :: Rep (Complex a) x -> Complex a #

AdditiveGroup a => AdditiveGroup (Complex a) Source # 

Methods

(-) :: Complex a -> Complex a -> Complex a Source #

Additive a => Additive (Complex a) Source # 

Methods

(+) :: Complex a -> Complex a -> Complex a Source #

AdditiveInvertible a => AdditiveInvertible (Complex a) Source # 

Methods

negate :: Complex a -> Complex a Source #

AdditiveCommutative a => AdditiveCommutative (Complex a) Source # 
AdditiveAssociative a => AdditiveAssociative (Complex a) Source # 
AdditiveUnital a => AdditiveUnital (Complex a) Source # 

Methods

zero :: Complex a Source #

AdditiveMagma a => AdditiveMagma (Complex a) Source # 

Methods

plus :: Complex a -> Complex a -> Complex a Source #

(MultiplicativeUnital a, MultiplicativeAssociative a, MultiplicativeInvertible a, AdditiveGroup a) => MultiplicativeGroup (Complex a) Source # 

Methods

(/) :: Complex a -> Complex a -> Complex a Source #

(MultiplicativeUnital a, MultiplicativeAssociative a, AdditiveGroup a) => Multiplicative (Complex a) Source # 

Methods

(*) :: Complex a -> Complex a -> Complex a Source #

(AdditiveGroup a, MultiplicativeInvertible a) => MultiplicativeInvertible (Complex a) Source # 

Methods

recip :: Complex a -> Complex a Source #

(MultiplicativeMagma a, AdditiveGroup a) => MultiplicativeCommutative (Complex a) Source # 
(AdditiveGroup a, MultiplicativeAssociative a) => MultiplicativeAssociative (Complex a) Source # 
(AdditiveUnital a, AdditiveGroup a, MultiplicativeUnital a) => MultiplicativeUnital (Complex a) Source # 

Methods

one :: Complex a Source #

(MultiplicativeMagma a, AdditiveGroup a) => MultiplicativeMagma (Complex a) Source # 

Methods

times :: Complex a -> Complex a -> Complex a Source #

(Distribution a, AdditiveGroup a) => Distribution (Complex a) Source # 
(Semiring a, AdditiveGroup a) => InvolutiveRing (Complex a) Source # 

Methods

adj :: Complex a -> Complex a Source #

(MultiplicativeAssociative a, MultiplicativeUnital a, AdditiveGroup a, Semiring a) => CRing (Complex a) Source # 
(Semiring a, AdditiveGroup a) => Ring (Complex a) Source # 
(Semiring a, AdditiveGroup a) => Semiring (Complex a) Source # 
(Ord a, TrigField a, ExpField a) => ExpField (Complex a) Source #

todo: bottom is here somewhere???

(MultiplicativeGroup a, AdditiveGroup a, Semiring a) => Field (Complex a) Source # 
Generic1 * Complex Source # 

Associated Types

type Rep1 Complex (f :: Complex -> *) :: k -> * #

Methods

from1 :: f a -> Rep1 Complex f a #

to1 :: Rep1 Complex f a -> f a #

(Multiplicative a, ExpField a, Normed a a) => Metric (Complex a) a Source # 

Methods

distanceL1 :: Complex a -> Complex a -> a Source #

distanceL2 :: Complex a -> Complex a -> a Source #

distanceLp :: a -> Complex a -> Complex a -> a Source #

(Multiplicative a, ExpField a, Normed a a) => Normed (Complex a) a Source # 

Methods

normL1 :: Complex a -> a Source #

normL2 :: Complex a -> a Source #

normLp :: a -> Complex a -> a Source #

type Rep (Complex a) Source # 
type Rep (Complex a) = D1 * (MetaData "Complex" "NumHask.Data.Complex" "numhask-0.2.3.1-5X1V1rZSUVsE9M1b0C2H1i" False) (C1 * (MetaCons ":+" (InfixI NotAssociative 6) False) ((:*:) * (S1 * (MetaSel (Nothing Symbol) NoSourceUnpackedness SourceStrict DecidedStrict) (Rec0 * a)) (S1 * (MetaSel (Nothing Symbol) NoSourceUnpackedness SourceStrict DecidedStrict) (Rec0 * a))))
type Rep1 * Complex Source # 

realPart :: Complex a -> a Source #

Extracts the real part of a complex number.

imagPart :: Complex a -> a Source #

Extracts the imaginary part of a complex number.

Helpers from Data.Complex

mkPolar :: TrigField a => a -> a -> Complex a Source #

cis :: TrigField a => a -> Complex a Source #

cis t is a complex value with magnitude 1 and phase t (modulo 2*pi).

polar :: (RealFloat a, ExpField a) => Complex a -> (a, a) Source #

The function polar takes a complex number and returns a (magnitude, phase) pair in canonical form: the magnitude is nonnegative, and the phase in the range (-pi, pi]; if the magnitude is zero, then so is the phase.

magnitude :: (ExpField a, RealFloat a) => Complex a -> a Source #

The nonnegative magnitude of a complex number.

phase :: RealFloat a => Complex a -> a Source #

The phase of a complex number, in the range (-pi, pi]. If the magnitude is zero, then so is the phase.