Safe Haskell | Safe-Inferred |
---|---|
Language | Haskell2010 |
Envelope generators.
Synopsis
- data Envelope_Curve a
- type Envelope_Curve_2 a = T2 (Envelope_Curve a)
- type Envelope_Curve_3 a = T3 (Envelope_Curve a)
- type Envelope_Curve_4 a = T4 (Envelope_Curve a)
- env_curve_shape :: Num a => Envelope_Curve a -> a
- env_curve_value :: Num a => Envelope_Curve a -> a
- env_curve_interpolation_f :: (Ord t, Floating t) => Envelope_Curve t -> Interpolation_f t
- env_curve_map :: (a -> b) -> Envelope_Curve a -> Envelope_Curve b
- data Envelope a = Envelope {
- env_levels :: [a]
- env_times :: [a]
- env_curves :: [Envelope_Curve a]
- env_release_node :: Maybe Int
- env_loop_node :: Maybe Int
- env_offset :: a
- envelope_map :: (a -> b) -> Envelope a -> Envelope b
- envelope :: Num a => [a] -> [a] -> [Envelope_Curve a] -> Envelope a
- envelope_duration :: Num n => Envelope n -> n
- envelope_n_segments :: Integral i => Envelope n -> i
- envelope_segment_ix :: (Ord a, Num a) => Envelope a -> a -> Maybe Int
- type Envelope_Segment t = (t, t, t, t, Envelope_Curve t)
- envelope_segment :: Num t => Envelope t -> Int -> Envelope_Segment t
- envelope_segments :: Num t => Envelope t -> [Envelope_Segment t]
- pack_envelope_segments :: Num t => [Envelope_Segment t] -> ([t], [t], [Envelope_Curve t])
- envelope_is_normal :: (Eq n, Num n) => Envelope n -> Bool
- envelope_normalise :: (Num a, Ord a) => Envelope a -> Envelope a
- envelope_at :: (Ord t, Floating t) => Envelope t -> t -> t
- envelope_render :: (Ord t, Floating t, Enum t) => Int -> Envelope t -> [(t, t)]
- envelope_table :: (Ord t, Floating t, Enum t) => Int -> Envelope t -> [t]
- envelope_curves :: Envelope a -> [Envelope_Curve a]
- envelope_sc3_array :: Num a => Envelope a -> Maybe [a]
- envelope_sc3_ienvgen_array :: Num a => Envelope a -> Maybe [a]
- env_is_sustained :: Envelope a -> Bool
- env_delay :: Envelope a -> a -> Envelope a
- env_circle_z :: Fractional a => a -> a -> Envelope_Curve a -> Envelope a -> Envelope a
- env_circle_0 :: Fractional a => Envelope a -> Envelope a
- envTrapezoid_f :: Num t => (t -> t -> t, t -> t -> t) -> t -> t -> t -> t -> Envelope t
- envCoord :: Num n => [(n, n)] -> n -> n -> Envelope_Curve n -> Envelope n
- envPairs :: (Num n, Ord n) => [(n, n)] -> Envelope_Curve n -> Envelope n
- envPerc_c :: Num a => a -> a -> a -> Envelope_Curve_2 a -> Envelope a
- envPerc :: Num a => a -> a -> Envelope a
- envTriangle :: Fractional a => a -> a -> Envelope a
- envSine :: Fractional a => a -> a -> Envelope a
- data Linen a = Linen {
- linen_attackTime :: a
- linen_sustainTime :: a
- linen_releaseTime :: a
- linen_level :: a
- linen_curve :: Envelope_Curve_3 a
- linen_def :: Fractional t => Linen t
- envLinen_r :: Num a => Linen a -> Envelope a
- envLinen_c :: Num a => a -> a -> a -> a -> Envelope_Curve_3 a -> Envelope a
- envLinen :: Num a => a -> a -> a -> a -> Envelope a
- data Adsr a = Adsr {
- adsr_attackTime :: a
- adsr_decayTime :: a
- adsr_sustainLevel :: a
- adsr_releaseTime :: a
- adsr_peakLevel :: a
- adsr_curve :: Envelope_Curve_3 a
- adsr_bias :: a
- adsr_def :: Fractional n => Adsr n
- envAdsr :: Num a => a -> a -> a -> a -> a -> Envelope_Curve a -> a -> Envelope a
- envAdsr_def :: Num a => a -> a -> a -> a -> Envelope a
- envAdsr_r :: Num a => Adsr a -> Envelope a
- data Adssr a = Adssr {
- adssr_attackTime :: a
- adssr_attackLevel :: a
- adssr_decayTime :: a
- adssr_decayLevel :: a
- adssr_slopeTime :: a
- adssr_sustainLevel :: a
- adssr_releaseTime :: a
- adssr_curve :: Envelope_Curve_4 a
- adssr_bias :: a
- envAdssr :: Num a => a -> a -> a -> a -> a -> a -> a -> Envelope_Curve a -> a -> Envelope a
- envAdssr_r :: Num a => Adssr a -> Envelope a
- data Asr a = Asr {
- asr_attackTime :: a
- asr_sustainLevel :: a
- asr_releaseTime :: a
- asr_curve :: Envelope_Curve_2 a
- asr_def :: Fractional t => Asr t
- envAsr_c :: Num a => a -> a -> a -> Envelope_Curve_2 a -> Envelope a
- envAsr :: Num a => a -> a -> a -> Envelope_Curve a -> Envelope a
- envAsr_r :: Num a => Asr a -> Envelope a
- envStep :: Num a => [a] -> [a] -> Maybe Int -> Maybe Int -> Envelope a
- envXyc :: Num n => [(n, n, Envelope_Curve n)] -> Envelope n
- envXyc_sort :: (Num n, Ord n) => [(n, n, Envelope_Curve n)] -> Envelope n
Curve
data Envelope_Curve a Source #
Envelope curve indicator input.
Instances
Show a => Show (Envelope_Curve a) Source # | |
Defined in Sound.Sc3.Common.Envelope showsPrec :: Int -> Envelope_Curve a -> ShowS # show :: Envelope_Curve a -> String # showList :: [Envelope_Curve a] -> ShowS # | |
Eq a => Eq (Envelope_Curve a) Source # | |
Defined in Sound.Sc3.Common.Envelope (==) :: Envelope_Curve a -> Envelope_Curve a -> Bool # (/=) :: Envelope_Curve a -> Envelope_Curve a -> Bool # |
type Envelope_Curve_2 a = T2 (Envelope_Curve a) Source #
Envelope curve pair.
type Envelope_Curve_3 a = T3 (Envelope_Curve a) Source #
Envelope curve triple.
type Envelope_Curve_4 a = T4 (Envelope_Curve a) Source #
Envelope curve quadruple.
env_curve_shape :: Num a => Envelope_Curve a -> a Source #
Convert Envelope_Curve
to shape value.
>>>
map env_curve_shape [EnvSin,EnvSqr]
[3,6]
env_curve_value :: Num a => Envelope_Curve a -> a Source #
The value of EnvCurve
is non-zero for EnvNum
.
>>>
map env_curve_value [EnvWelch,EnvNum 2]
[0,2]
env_curve_interpolation_f :: (Ord t, Floating t) => Envelope_Curve t -> Interpolation_f t Source #
Interpolation_f
of Envelope_Curve
.
env_curve_map :: (a -> b) -> Envelope_Curve a -> Envelope_Curve b Source #
Apply f to EnvNum
value.
Envelope
Sc3 envelope segment model
Envelope | |
|
envelope :: Num a => [a] -> [a] -> [Envelope_Curve a] -> Envelope a Source #
Variant without release and loop node inputs (defaulting to nil).
Sound.Sc3.Plot.plotEnvelope [envelope [0,1,0] [3,2] [EnvSin,EnvSin]]
envelope_n_segments :: Integral i => Envelope n -> i Source #
envelope_segment_ix :: (Ord a, Num a) => Envelope a -> a -> Maybe Int Source #
Determine which envelope segment a given time t falls in.
type Envelope_Segment t = (t, t, t, t, Envelope_Curve t) Source #
A set of start time, start level, end time, end level and curve.
envelope_segment :: Num t => Envelope t -> Int -> Envelope_Segment t Source #
Extract envelope segment given at index i.
envelope_segments :: Num t => Envelope t -> [Envelope_Segment t] Source #
Extract all segments.
pack_envelope_segments :: Num t => [Envelope_Segment t] -> ([t], [t], [Envelope_Curve t]) Source #
Transform list of Envelope_Segment
s into lists (env_levels
,env_times
,env_curves
).
envelope_is_normal :: (Eq n, Num n) => Envelope n -> Bool Source #
An envelope is normal if it has no segments with zero duration.
envelope_normalise :: (Num a, Ord a) => Envelope a -> Envelope a Source #
Normalise envelope by deleting segments of zero duration.
envelope_at :: (Ord t, Floating t) => Envelope t -> t -> t Source #
Get value for Envelope
at time t, or zero if t is out of
range. By convention if the envelope has a segment of zero
duration we give the rightmost value.
envelope_render :: (Ord t, Floating t, Enum t) => Int -> Envelope t -> [(t, t)] Source #
Render Envelope
to breakpoint set of n equi-distant places.
envelope_table :: (Ord t, Floating t, Enum t) => Int -> Envelope t -> [t] Source #
Contruct a lookup table of n places from Envelope
.
envelope_curves :: Envelope a -> [Envelope_Curve a] Source #
Variant on env_curves
that expands the, possibly empty, user
list by cycling (if not empty) or by filling with EnvLin
.
envelope_sc3_array :: Num a => Envelope a -> Maybe [a] Source #
Linear Sc3 form of Envelope
data.
Form is: l0 #t reset loop l1 t0 c0 c0' ...
>>>
envelope_sc3_array (envelope [0,1] [0.1] [EnvLin])
Just [0.0,1.0,-99.0,-99.0,1.0,0.1,1.0,0.0]
>>>
let l = [0,0.6,0.3,1.0,0]
>>>
let t = [0.1,0.02,0.4,1.1]
>>>
let c = [EnvLin,EnvExp,EnvNum (-6),EnvSin]
>>>
envelope_sc3_array (Envelope l t c Nothing Nothing 0)
Just [0.0,4.0,-99.0,-99.0,0.6,0.1,1.0,0.0,0.3,2.0e-2,2.0,0.0,1.0,0.4,5.0,-6.0,0.0,1.1,3.0,0.0]
envelope_sc3_ienvgen_array :: Num a => Envelope a -> Maybe [a] Source #
IEnvGen
Sc3 form of Envelope
data.
>>>
let l = [0,0.6,0.3,1.0,0]
>>>
let t = [0.1,0.02,0.4,1.1]
>>>
let c = [EnvLin,EnvExp,EnvNum (-6),EnvSin]
>>>
let e = Envelope l t c Nothing Nothing 0
>>>
envelope_sc3_ienvgen_array e
Just [0.0,0.0,4.0,1.62,0.1,1.0,0.0,0.6,2.0e-2,2.0,0.0,0.3,0.4,5.0,-6.0,1.0,1.1,3.0,0.0,0.0]
env_is_sustained :: Envelope a -> Bool Source #
True
if env_release_node
is not Nothing
.
env_delay :: Envelope a -> a -> Envelope a Source #
Delay the onset of the envelope (add initial segment).
env_circle_z :: Fractional a => a -> a -> Envelope_Curve a -> Envelope a -> Envelope a Source #
Connect releaseNode (or end) to first node of envelope. z is a value that is first zero and thereafter one. tc & cc are time and curve from first to last.
env_circle_0 :: Fractional a => Envelope a -> Envelope a Source #
env_circle_z with cycle time of zero.
Construct
envTrapezoid_f :: Num t => (t -> t -> t, t -> t -> t) -> t -> t -> t -> t -> Envelope t Source #
Trapezoidal envelope generator.
Requires (and (=) functions returning 1
for true and 0
for false.
The arguments are: 1. shape
determines the sustain time as a
proportion of dur
, zero is a triangular envelope, one a rectangular
envelope; 2. skew
determines the attack/decay ratio, zero is an
immediate attack and a slow decay, one a slow attack and an immediate
decay; 3. duration
in seconds; 4. amplitude
as linear gain.
envCoord :: Num n => [(n, n)] -> n -> n -> Envelope_Curve n -> Envelope n Source #
Coordinate based static envelope generator. Points are (time,value) pairs.
>>>
let e = envCoord [(0,0),(1/4,1),(1,0)] 1 1 EnvLin
>>>
envelope_sc3_array e
Just [0.0,2.0,-99.0,-99.0,1.0,0.25,1.0,0.0,0.0,0.75,1.0,0.0]
import Sound.Sc3.Plot {\- hsc3-plot -\} plotEnvelope [envCoord [(0,0),(1/4,1),(1,0)] 1 1 EnvLin]
envPairs :: (Num n, Ord n) => [(n, n)] -> Envelope_Curve n -> Envelope n Source #
Segments given as pairs of (time,level). The input is sorted by time before processing.
>>>
env_levels (envPairs [(0, 1), (3, 1.4), (2.1, 0.5)] EnvSin)
[1.0,0.5,1.4]
envPerc_c :: Num a => a -> a -> a -> Envelope_Curve_2 a -> Envelope a Source #
Percussive envelope, with attack, release, level and curve inputs.
envPerc :: Num a => a -> a -> Envelope a Source #
Percussive envelope, with attack and release inputs.
envTriangle :: Fractional a => a -> a -> Envelope a Source #
Triangular envelope, with duration and level inputs.
>>>
let e = envTriangle 1 0.1
>>>
envelope_sc3_array e
Just [0.0,2.0,-99.0,-99.0,0.1,0.5,1.0,0.0,0.0,0.5,1.0,0.0]
envSine :: Fractional a => a -> a -> Envelope a Source #
Sine envelope, with duration and level inputs.
>>>
envelope_sc3_array (envSine 0 0.1)
Just [0.0,2.0,-99.0,-99.0,0.1,0.0,3.0,0.0,0.0,0.0,3.0,0.0]
Parameters for Linen envelopes.
Linen | |
|
linen_def :: Fractional t => Linen t Source #
Sc3 defaults for Linen.
envLinen_c :: Num a => a -> a -> a -> a -> Envelope_Curve_3 a -> Envelope a Source #
Variant of envLinen
with user specified 'Envelope_Curve a'.
envLinen :: Num a => a -> a -> a -> a -> Envelope a Source #
Linear envelope parameter constructor.
>>>
let e = envLinen 0 1 0 1
>>>
let s = envelope_segments e
>>>
let p = pack_envelope_segments s
>>>
p == (env_levels e,env_times e,env_curves e)
True
Parameters for Adsr envelopes. The sustain level is given as a proportion of the peak level.
Adsr | |
|
adsr_def :: Fractional n => Adsr n Source #
Sc3 defaults for Adsr.
envAdsr :: Num a => a -> a -> a -> a -> a -> Envelope_Curve a -> a -> Envelope a Source #
Attack, decay, sustain, release envelope parameter constructor.
envAdsr_def :: Num a => a -> a -> a -> a -> Envelope a Source #
Variant with defaults for pL, c and b.
Parameters for Roland type Adssr envelopes.
Adssr | |
|
envAdssr :: Num a => a -> a -> a -> a -> a -> a -> a -> Envelope_Curve a -> a -> Envelope a Source #
Attack, decay, slope, sustain, release envelope parameter constructor.
Parameters for Asr envelopes.
Asr | |
|
asr_def :: Fractional t => Asr t Source #
Sc3 default values for Asr.
envAsr_c :: Num a => a -> a -> a -> Envelope_Curve_2 a -> Envelope a Source #
Sc3 .asr has singular curve argument, hence _c suffix.
envAsr :: Num a => a -> a -> a -> Envelope_Curve a -> Envelope a Source #
Attack, sustain, release envelope parameter constructor.
>>>
envelope_sc3_array (envAsr 3 0.1 2 EnvSin)
Just [0.0,2.0,1.0,-99.0,0.1,3.0,3.0,0.0,0.0,2.0,3.0,0.0]
envStep :: Num a => [a] -> [a] -> Maybe Int -> Maybe Int -> Envelope a Source #
All segments are horizontal lines.
envXyc :: Num n => [(n, n, Envelope_Curve n)] -> Envelope n Source #
Segments given as triples of (time,level,curve). The final curve is ignored.
>>>
env_levels (envXyc [(0, 1, EnvSin), (2.1, 0.5, EnvLin), (3, 1.4, EnvLin)])
[1.0,0.5,1.4]
envXyc_sort :: (Num n, Ord n) => [(n, n, Envelope_Curve n)] -> Envelope n Source #
Variant where the input is sorted by time before processing.
>>>
env_levels (envXyc_sort [(0, 1, EnvSin), (3, 1.4, EnvLin), (2.1, 0.5, EnvLin)])
[1.0,0.5,1.4]