{-# LANGUAGE EmptyDataDecls #-}
module Perform.Signal (
Signal, Sample(..)
, X, Y, x_to_y, y_to_x, y_to_score, y_to_nn, nn_to_y
, Tempo, Warp, Control, NoteNumber, Display
, from_sample, from_pairs, from_segments
, to_samples, to_pairs, to_pairs_desc
, to_segments, to_vector
, constant, constant_val, constant_val_from
, zero_or_below
, beginning
, prepend
, unfoldr
, coerce
, to_piecewise_constant
, with_ptr
, null
, at, at_maybe, segment_at
, head, last
, minimum, maximum
, find
, drop_after, drop_before
, clip_after, clip_before, clip_before_segments, clip_before_pairs
, clip_after_keep_last
, shift
, invert, sig_add, sig_subtract, sig_multiply, sig_scale
, scale, scale_invert
, drop_discontinuity_at
, scalar_max
, scalar_add, scalar_subtract, scalar_multiply, scalar_divide
, scalar_scale
, map_x, map_y, map_y_linear, map_err
, integrate_inverse, integrate, tempo_srate
) where
import Prelude hiding (head, last, maximum, minimum, null, drop)
import qualified Control.DeepSeq as DeepSeq
import qualified Data.Vector.Storable as Vector
import qualified Foreign
import qualified Util.Lists as Lists
import qualified Util.Num as Num
import qualified Util.Pretty as Pretty
import qualified Util.Segment as Segment
import Util.Segment (Sample(..), X)
import qualified Util.Serialize as Serialize
import qualified Util.TimeVector as TimeVector
import qualified Perform.Pitch as Pitch
import qualified Perform.RealTime as RealTime
import qualified Ui.ScoreTime as ScoreTime
import Global
import Types
newtype Signal kind = Signal Segment.NumSignal
deriving (Int -> Signal kind -> ShowS
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
forall k (kind :: k). Int -> Signal kind -> ShowS
forall k (kind :: k). [Signal kind] -> ShowS
forall k (kind :: k). Signal kind -> String
showList :: [Signal kind] -> ShowS
$cshowList :: forall k (kind :: k). [Signal kind] -> ShowS
show :: Signal kind -> String
$cshow :: forall k (kind :: k). Signal kind -> String
showsPrec :: Int -> Signal kind -> ShowS
$cshowsPrec :: forall k (kind :: k). Int -> Signal kind -> ShowS
Show, Signal kind -> Signal kind -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
forall k (kind :: k). Signal kind -> Signal kind -> Bool
/= :: Signal kind -> Signal kind -> Bool
$c/= :: forall k (kind :: k). Signal kind -> Signal kind -> Bool
== :: Signal kind -> Signal kind -> Bool
$c== :: forall k (kind :: k). Signal kind -> Signal kind -> Bool
Eq, Signal kind -> ()
forall a. (a -> ()) -> NFData a
forall k (kind :: k). Signal kind -> ()
rnf :: Signal kind -> ()
$crnf :: forall k (kind :: k). Signal kind -> ()
DeepSeq.NFData, Get (Signal kind)
Putter (Signal kind)
forall a. Putter a -> Get a -> Serialize a
forall k (kind :: k). Get (Signal kind)
forall k (kind :: k). Putter (Signal kind)
get :: Get (Signal kind)
$cget :: forall k (kind :: k). Get (Signal kind)
put :: Putter (Signal kind)
$cput :: forall k (kind :: k). Putter (Signal kind)
Serialize.Serialize)
instance Pretty (Signal kind) where
format :: Signal kind -> Doc
format Signal kind
sig = case forall {k} (kind :: k). Signal kind -> Maybe Y
constant_val Signal kind
sig of
Just Y
y -> Doc
"Signal.constant" Doc -> Doc -> Doc
Pretty.<+> forall a. Pretty a => a -> Doc
Pretty.format Y
y
Maybe Y
Nothing -> forall a. Pretty a => a -> Doc
Pretty.format (forall {k} (kind :: k). Signal kind -> NumSignal
_signal Signal kind
sig)
_signal :: Signal kind -> Segment.NumSignal
_signal :: forall {k} (kind :: k). Signal kind -> NumSignal
_signal (Signal NumSignal
sig) = NumSignal
sig
modify :: (Segment.NumSignal -> Segment.NumSignal) -> Signal kind -> Signal kind
modify :: forall {k} (kind :: k).
(NumSignal -> NumSignal) -> Signal kind -> Signal kind
modify NumSignal -> NumSignal
f = forall {k} (kind :: k). NumSignal -> Signal kind
Signal forall b c a. (b -> c) -> (a -> b) -> a -> c
. NumSignal -> NumSignal
f forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
type Y = Double
instance Semigroup (Signal kind) where
Signal kind
s1 <> :: Signal kind -> Signal kind -> Signal kind
<> Signal kind
s2
| forall {k} (kind :: k). Signal kind -> Bool
null Signal kind
s1 = Signal kind
s2
| forall {k} (kind :: k). Signal kind -> Bool
null Signal kind
s2 = Signal kind
s1
| Bool
otherwise = forall a. Monoid a => [a] -> a
mconcat [Signal kind
s1, Signal kind
s2]
instance Monoid (Signal kind) where
mempty :: Signal kind
mempty = forall {k} (kind :: k). NumSignal -> Signal kind
Signal forall (v :: * -> *) a. Vector v a => Signal (v a)
Segment.empty
mappend :: Signal kind -> Signal kind -> Signal kind
mappend = forall a. Semigroup a => a -> a -> a
(<>)
mconcat :: [Signal kind] -> Signal kind
mconcat = forall {k} (kind :: k). NumSignal -> Signal kind
Signal forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (v :: * -> *) y.
Vector v (Sample y) =>
Maybe (y -> y -> Bool)
-> Interpolate y -> [SignalS v y] -> SignalS v y
Segment.concat (forall a. a -> Maybe a
Just forall a. Eq a => a -> a -> Bool
(==)) Interpolate Y
Segment.num_interpolate
forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a b. (a -> b) -> [a] -> [b]
map forall {k} (kind :: k). Signal kind -> NumSignal
_signal forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. (a -> Bool) -> [a] -> [a]
filter (Bool -> Bool
not forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> Bool
null)
type Control = Signal ControlSig
data ControlSig
type Tempo = Signal TempoSig
data TempoSig
type Warp = Signal WarpSig
data WarpSig
type NoteNumber = Signal NoteNumberSig
data NoteNumberSig
type Display = Signal DisplaySig
data DisplaySig
x_to_y :: X -> Y
x_to_y :: RealTime -> Y
x_to_y = RealTime -> Y
RealTime.to_seconds
y_to_x :: Y -> X
y_to_x :: Y -> RealTime
y_to_x = Y -> RealTime
RealTime.seconds
y_to_score :: Y -> ScoreTime
y_to_score :: Y -> ScoreTime
y_to_score = Y -> ScoreTime
ScoreTime.from_double
y_to_nn :: Y -> Pitch.NoteNumber
y_to_nn :: Y -> NoteNumber
y_to_nn = Y -> NoteNumber
Pitch.NoteNumber
nn_to_y :: Pitch.NoteNumber -> Y
nn_to_y :: NoteNumber -> Y
nn_to_y (Pitch.NoteNumber Y
nn) = Y
nn
from_sample :: X -> Y -> Signal kind
from_sample :: forall {k} (kind :: k). RealTime -> Y -> Signal kind
from_sample RealTime
x Y
y = forall {k} (kind :: k). [(RealTime, Y)] -> Signal kind
from_pairs [(RealTime
x, Y
y)]
from_pairs :: [(X, Y)] -> Signal kind
from_pairs :: forall {k} (kind :: k). [(RealTime, Y)] -> Signal kind
from_pairs = forall {k} (kind :: k). NumSignal -> Signal kind
Signal forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (v :: * -> *) y.
Vector v (Sample y) =>
[(RealTime, y)] -> SignalS v y
Segment.from_pairs
from_segments :: [Segment.Segment Y] -> Signal kind
from_segments :: forall {k} (kind :: k). [Segment Y] -> Signal kind
from_segments = forall {k} (kind :: k). NumSignal -> Signal kind
Signal forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (v :: * -> *) y.
Vector v (Sample y) =>
[Segment y] -> SignalS v y
Segment.from_segments
to_samples :: Signal kind -> [Sample Y]
to_samples :: forall {k} (kind :: k). Signal kind -> [Sample Y]
to_samples = forall (v :: * -> *) y.
Vector v (Sample y) =>
SignalS v y -> [Sample y]
Segment.to_samples forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
to_pairs :: Signal kind -> [(X, Y)]
to_pairs :: forall {k} (kind :: k). Signal kind -> [(RealTime, Y)]
to_pairs = forall k a. Eq k => (a -> k) -> [a] -> [a]
Lists.dropDups forall a. a -> a
id forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (v :: * -> *) y.
Vector v (Sample y) =>
SignalS v y -> [(RealTime, y)]
Segment.to_pairs forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
to_pairs_desc :: Signal kind -> [(X, Y)]
to_pairs_desc :: forall {k} (kind :: k). Signal kind -> [(RealTime, Y)]
to_pairs_desc = forall k a. Eq k => (a -> k) -> [a] -> [a]
Lists.dropDups forall a. a -> a
id forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (v :: * -> *) y.
Vector v (Sample y) =>
SignalS v y -> [(RealTime, y)]
Segment.to_pairs_desc forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
to_segments :: Signal kind -> [Segment.Segment Y]
to_segments :: forall {k} (kind :: k). Signal kind -> [Segment Y]
to_segments = forall (v :: * -> *) y.
Vector v (Sample y) =>
SignalS v y -> [Segment y]
Segment.to_segments forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
to_vector :: Signal kind -> Vector.Vector (Sample Y)
to_vector :: forall {k} (kind :: k). Signal kind -> Vector (Sample Y)
to_vector = forall (v :: * -> *) y.
Vector v (Sample y) =>
SignalS v y -> v (Sample y)
Segment.to_vector forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
constant :: Y -> Signal kind
constant :: forall {k} (kind :: k). Y -> Signal kind
constant = forall {k} (kind :: k). NumSignal -> Signal kind
Signal forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (v :: * -> *) y. Vector v (Sample y) => y -> SignalS v y
Segment.constant
constant_val :: Signal kind -> Maybe Y
constant_val :: forall {k} (kind :: k). Signal kind -> Maybe Y
constant_val = RealTime -> NumSignal -> Maybe Y
Segment.constant_val_num (-RealTime
RealTime.large) forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
constant_val_from :: X -> Signal kind -> Maybe Y
constant_val_from :: forall {k} (kind :: k). RealTime -> Signal kind -> Maybe Y
constant_val_from RealTime
x = RealTime -> NumSignal -> Maybe Y
Segment.constant_val_num RealTime
x forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
zero_or_below :: Signal kind -> Bool
zero_or_below :: forall {k} (kind :: k). Signal kind -> Bool
zero_or_below Signal kind
signal = case forall {k} (kind :: k). Signal kind -> Maybe (RealTime, Y)
head Signal kind
signal of
Maybe (RealTime, Y)
Nothing -> Bool
True
Just (RealTime
x, Y
_)
| RealTime
x forall a. Ord a => a -> a -> Bool
> RealTime
0 -> Bool
True
| Bool
otherwise -> Bool -> Bool
not forall a b. (a -> b) -> a -> b
$ (Y -> Bool) -> NumSignal -> Bool
Segment.all_y (forall a. Ord a => a -> a -> Bool
>Y
0) (forall {k} (kind :: k). Signal kind -> NumSignal
_signal Signal kind
signal)
beginning :: RealTime
beginning :: RealTime
beginning = RealTime
Segment.beginning
prepend :: Signal kind -> Signal kind -> Signal kind
prepend :: forall k (kind :: k). Signal kind -> Signal kind -> Signal kind
prepend Signal kind
sig1 Signal kind
sig2 = forall {k} (kind :: k). NumSignal -> Signal kind
Signal forall a b. (a -> b) -> a -> b
$
forall (v :: * -> *) y.
Vector v (Sample y) =>
Maybe (y -> y -> Bool)
-> Interpolate y -> SignalS v y -> SignalS v y -> SignalS v y
Segment.prepend (forall a. a -> Maybe a
Just forall a. Eq a => a -> a -> Bool
(==)) Interpolate Y
Segment.num_interpolate
(forall {k} (kind :: k). Signal kind -> NumSignal
_signal Signal kind
sig1) (forall {k} (kind :: k). Signal kind -> NumSignal
_signal Signal kind
sig2)
unfoldr :: (state -> Maybe ((X, Y), state)) -> state -> Signal kind
unfoldr :: forall {k} state (kind :: k).
(state -> Maybe ((RealTime, Y), state)) -> state -> Signal kind
unfoldr state -> Maybe ((RealTime, Y), state)
gen state
state = forall {k} (kind :: k). NumSignal -> Signal kind
Signal forall a b. (a -> b) -> a -> b
$ forall (v :: * -> *) y state.
Vector v (Sample y) =>
(state -> Maybe ((RealTime, y), state)) -> state -> SignalS v y
Segment.unfoldr state -> Maybe ((RealTime, Y), state)
gen state
state
coerce :: Signal kind1 -> Signal kind2
coerce :: forall {k} {k} (kind1 :: k) (kind2 :: k).
Signal kind1 -> Signal kind2
coerce (Signal NumSignal
vec) = forall {k} (kind :: k). NumSignal -> Signal kind
Signal NumSignal
vec
to_piecewise_constant :: X -> Signal kind -> TimeVector.Unboxed
to_piecewise_constant :: forall {k} (kind :: k).
RealTime -> Signal kind -> Vector (Sample Y)
to_piecewise_constant RealTime
srate = RealTime -> NumSignal -> Vector (Sample Y)
Segment.to_piecewise_constant RealTime
srate forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
with_ptr :: Display -> (X -> Foreign.Ptr (Sample Y) -> Int -> IO a) -> IO a
with_ptr :: forall a.
Display -> (RealTime -> Ptr (Sample Y) -> Int -> IO a) -> IO a
with_ptr Display
sig = forall a b.
Storable a =>
Signal (Vector a) -> (RealTime -> Ptr a -> Int -> IO b) -> IO b
Segment.with_ptr (forall {k} (kind :: k). Signal kind -> NumSignal
_signal Display
sig)
null :: Signal kind -> Bool
null :: forall {k} (kind :: k). Signal kind -> Bool
null = forall (v :: * -> *) y. Vector v (Sample y) => SignalS v y -> Bool
Segment.null forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
at :: Signal kind -> X -> Y
at :: forall {k} (kind :: k). Signal kind -> RealTime -> Y
at Signal kind
sig = forall a. a -> Maybe a -> a
fromMaybe Y
0 forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> RealTime -> Maybe Y
at_maybe Signal kind
sig
at_maybe :: Signal kind -> X -> Maybe Y
at_maybe :: forall {k} (kind :: k). Signal kind -> RealTime -> Maybe Y
at_maybe = forall (v :: * -> *) y.
Vector v (Sample y) =>
Interpolate y -> SignalS v y -> RealTime -> Maybe y
Segment.at Interpolate Y
Segment.num_interpolate forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
segment_at :: Signal kind -> X -> Maybe (Segment.Segment Y)
segment_at :: forall {k} (kind :: k).
Signal kind -> RealTime -> Maybe (Segment Y)
segment_at = forall (v :: * -> *) y.
Vector v (Sample y) =>
SignalS v y -> RealTime -> Maybe (Segment y)
Segment.segment_at forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
head, last :: Signal kind -> Maybe (X, Y)
head :: forall {k} (kind :: k). Signal kind -> Maybe (RealTime, Y)
head = forall (v :: * -> *) y.
Vector v (Sample y) =>
SignalS v y -> Maybe (RealTime, y)
Segment.head forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
last :: forall {k} (kind :: k). Signal kind -> Maybe (RealTime, Y)
last = forall (v :: * -> *) y.
Vector v (Sample y) =>
SignalS v y -> Maybe (RealTime, y)
Segment.last forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
drop_after, drop_before :: X -> Signal kind -> Signal kind
drop_after :: forall {k} (kind :: k). RealTime -> Signal kind -> Signal kind
drop_after RealTime
x = forall {k} (kind :: k).
(NumSignal -> NumSignal) -> Signal kind -> Signal kind
modify forall a b. (a -> b) -> a -> b
$ forall (v :: * -> *) y.
Vector v (Sample y) =>
RealTime -> SignalS v y -> SignalS v y
Segment.drop_after RealTime
x
drop_before :: forall {k} (kind :: k). RealTime -> Signal kind -> Signal kind
drop_before RealTime
x = forall {k} (kind :: k).
(NumSignal -> NumSignal) -> Signal kind -> Signal kind
modify forall a b. (a -> b) -> a -> b
$ forall (v :: * -> *) y.
Vector v (Sample y) =>
RealTime -> SignalS v y -> SignalS v y
Segment.drop_before RealTime
x
clip_after, clip_before :: X -> Signal kind -> Signal kind
clip_after :: forall {k} (kind :: k). RealTime -> Signal kind -> Signal kind
clip_after RealTime
x = forall {k} (kind :: k).
(NumSignal -> NumSignal) -> Signal kind -> Signal kind
modify forall a b. (a -> b) -> a -> b
$ Bool -> RealTime -> NumSignal -> NumSignal
Segment.num_clip_after Bool
False RealTime
x
clip_before :: forall {k} (kind :: k). RealTime -> Signal kind -> Signal kind
clip_before RealTime
x = forall {k} (kind :: k).
(NumSignal -> NumSignal) -> Signal kind -> Signal kind
modify forall a b. (a -> b) -> a -> b
$ forall (v :: * -> *) y.
Vector v (Sample y) =>
Interpolate y -> RealTime -> SignalS v y -> SignalS v y
Segment.clip_before Interpolate Y
Segment.num_interpolate RealTime
x
clip_before_segments :: X -> Signal kind -> [Segment.Segment Y]
clip_before_segments :: forall {k} (kind :: k). RealTime -> Signal kind -> [Segment Y]
clip_before_segments RealTime
x = forall y. [Sample y] -> [Segment y]
Segment.samples_to_segments
forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (v :: * -> *) y.
Vector v (Sample y) =>
Interpolate y -> RealTime -> SignalS v y -> [Sample y]
Segment.clip_before_samples Interpolate Y
Segment.num_interpolate RealTime
x
forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
clip_before_pairs :: X -> Signal kind -> [(X, Y)]
clip_before_pairs :: forall {k} (kind :: k). RealTime -> Signal kind -> [(RealTime, Y)]
clip_before_pairs RealTime
x =
forall a b. (a -> b) -> [a] -> [b]
map forall y. Sample y -> (RealTime, y)
TimeVector.to_pair
forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (v :: * -> *) y.
Vector v (Sample y) =>
Interpolate y -> RealTime -> SignalS v y -> [Sample y]
Segment.clip_before_samples Interpolate Y
Segment.num_interpolate RealTime
x
forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
clip_after_keep_last :: X -> Signal kind -> Signal kind
clip_after_keep_last :: forall {k} (kind :: k). RealTime -> Signal kind -> Signal kind
clip_after_keep_last RealTime
x = forall {k} (kind :: k).
(NumSignal -> NumSignal) -> Signal kind -> Signal kind
modify forall a b. (a -> b) -> a -> b
$ Bool -> RealTime -> NumSignal -> NumSignal
Segment.num_clip_after Bool
True RealTime
x
shift :: X -> Signal kind -> Signal kind
shift :: forall {k} (kind :: k). RealTime -> Signal kind -> Signal kind
shift RealTime
x = forall {k} (kind :: k).
(NumSignal -> NumSignal) -> Signal kind -> Signal kind
modify (forall v. RealTime -> Signal v -> Signal v
Segment.shift RealTime
x)
invert :: Signal kind -> Signal kind
invert :: forall {k} (kind :: k). Signal kind -> Signal kind
invert = forall {k} (kind :: k).
(NumSignal -> NumSignal) -> Signal kind -> Signal kind
modify NumSignal -> NumSignal
Segment.invert
sig_add, sig_multiply :: Control -> Control -> Control
sig_add :: Control -> Control -> Control
sig_add = forall {k} (kind :: k).
Maybe Y
-> (Y -> Y -> Y) -> Signal kind -> Signal kind -> Signal kind
linear_operator (forall a. a -> Maybe a
Just Y
0) forall a. Num a => a -> a -> a
(+)
sig_multiply :: Control -> Control -> Control
sig_multiply = forall {k} (kind :: k).
Maybe Y
-> (Y -> Y -> Y) -> Signal kind -> Signal kind -> Signal kind
linear_operator (forall a. a -> Maybe a
Just Y
1) forall a. Num a => a -> a -> a
(*)
sig_subtract :: Control -> Control -> Control
sig_subtract :: Control -> Control -> Control
sig_subtract Control
sig1 Control
sig2
| Just Y
v <- forall {k} (kind :: k). Signal kind -> Maybe Y
constant_val Control
sig2, Y
v forall a. Eq a => a -> a -> Bool
== Y
0 = Control
sig1
| Bool
otherwise = forall {k} (kind :: k).
Maybe Y
-> (Y -> Y -> Y) -> Signal kind -> Signal kind -> Signal kind
linear_operator forall a. Maybe a
Nothing (-) Control
sig1 Control
sig2
sig_scale :: Control -> Control -> Control
sig_scale :: Control -> Control -> Control
sig_scale = forall {k} (kind :: k).
Maybe Y
-> (Y -> Y -> Y) -> Signal kind -> Signal kind -> Signal kind
linear_operator (forall a. a -> Maybe a
Just Y
1) Y -> Y -> Y
scale
scale :: Y -> Y -> Y
scale :: Y -> Y -> Y
scale Y
x Y
v
| Y
v forall a. Ord a => a -> a -> Bool
>= Y
0 = forall a. (Eq a, Num a) => a -> a -> a -> a
Num.scale Y
x Y
1 Y
v
| Bool
otherwise = forall a. (Eq a, Num a) => a -> a -> a -> a
Num.scale Y
0 Y
x (Y
v forall a. Num a => a -> a -> a
+ Y
1)
scale_invert :: Y -> Y -> Y
scale_invert :: Y -> Y -> Y
scale_invert Y
old Y
new
| Y
new forall a. Ord a => a -> a -> Bool
>= Y
old = forall a. (Eq a, Fractional a) => a -> a -> a -> a
Num.normalize Y
old Y
1 Y
new
| Bool
otherwise = forall a. (Eq a, Fractional a) => a -> a -> a -> a
Num.normalize Y
0 Y
old Y
new forall a. Num a => a -> a -> a
- Y
1
linear_operator :: Maybe Y
-> (Y -> Y -> Y) -> Signal kind -> Signal kind -> Signal kind
linear_operator :: forall {k} (kind :: k).
Maybe Y
-> (Y -> Y -> Y) -> Signal kind -> Signal kind -> Signal kind
linear_operator (Just Y
identity) Y -> Y -> Y
_ Signal kind
sig1 Signal kind
sig2
| Just Y
v <- forall {k} (kind :: k). Signal kind -> Maybe Y
constant_val Signal kind
sig1, Y
v forall a. Eq a => a -> a -> Bool
== Y
identity = Signal kind
sig2
| Just Y
v <- forall {k} (kind :: k). Signal kind -> Maybe Y
constant_val Signal kind
sig2, Y
v forall a. Eq a => a -> a -> Bool
== Y
identity = Signal kind
sig1
linear_operator Maybe Y
_ Y -> Y -> Y
op Signal kind
sig1 Signal kind
sig2 =
forall {k} (kind :: k). NumSignal -> Signal kind
Signal forall a b. (a -> b) -> a -> b
$ (Y -> Y -> Y) -> NumSignal -> NumSignal -> NumSignal
Segment.linear_operator Y -> Y -> Y
op (forall {k} (kind :: k). Signal kind -> NumSignal
_signal Signal kind
sig1) (forall {k} (kind :: k). Signal kind -> NumSignal
_signal Signal kind
sig2)
drop_discontinuity_at :: X -> Control -> Control
drop_discontinuity_at :: RealTime -> Control -> Control
drop_discontinuity_at RealTime
x = forall {k} (kind :: k).
(NumSignal -> NumSignal) -> Signal kind -> Signal kind
modify forall a b. (a -> b) -> a -> b
$ forall (v :: * -> *) y.
Vector v (Sample y) =>
RealTime -> SignalS v y -> SignalS v y
Segment.drop_discontinuity_at RealTime
x
scalar_add, scalar_subtract, scalar_multiply, scalar_divide ::
Y -> Signal kind -> Signal kind
scalar_add :: forall {k} (kind :: k). Y -> Signal kind -> Signal kind
scalar_add Y
n = forall {k} (kind :: k). (Y -> Y) -> Signal kind -> Signal kind
map_y_linear (forall a. Num a => a -> a -> a
+Y
n)
scalar_subtract :: forall {k} (kind :: k). Y -> Signal kind -> Signal kind
scalar_subtract Y
n = forall {k} (kind :: k). (Y -> Y) -> Signal kind -> Signal kind
map_y_linear (forall a. Num a => a -> a -> a
subtract Y
n)
scalar_multiply :: forall {k} (kind :: k). Y -> Signal kind -> Signal kind
scalar_multiply Y
n = forall {k} (kind :: k). (Y -> Y) -> Signal kind -> Signal kind
map_y_linear (forall a. Num a => a -> a -> a
*Y
n)
scalar_divide :: forall {k} (kind :: k). Y -> Signal kind -> Signal kind
scalar_divide Y
n = forall {k} (kind :: k). (Y -> Y) -> Signal kind -> Signal kind
map_y_linear (forall a. Fractional a => a -> a -> a
/Y
n)
scalar_scale :: Y -> Signal kind -> Signal kind
scalar_scale :: forall {k} (kind :: k). Y -> Signal kind -> Signal kind
scalar_scale Y
n = forall {k} (kind :: k). (Y -> Y) -> Signal kind -> Signal kind
map_y_linear (Y -> Y -> Y
scale Y
n)
scalar_max :: Y -> Signal kind -> Signal kind
scalar_max :: forall {k} (kind :: k). Y -> Signal kind -> Signal kind
scalar_max Y
val Signal kind
sig
| forall {k} (kind :: k). Signal kind -> Y
minimum Signal kind
sig forall a. Ord a => a -> a -> Bool
>= Y
val = Signal kind
sig
| Bool
otherwise = forall {k} (kind :: k).
(NumSignal -> NumSignal) -> Signal kind -> Signal kind
modify (forall (v :: * -> *) y.
Vector v (Sample y) =>
([Sample y] -> [Sample y]) -> SignalS v y -> SignalS v y
Segment.transform_samples [Sample Y] -> [Sample Y]
go) Signal kind
sig
where
go :: [Sample Y] -> [Sample Y]
go [] = []
go [Sample RealTime
x Y
y] = [forall y. RealTime -> y -> Sample y
Sample RealTime
x (forall a. Ord a => a -> a -> a
max Y
val Y
y)]
go (s1 :: Sample Y
s1@(Sample RealTime
x1 Y
y1) : s2s :: [Sample Y]
s2s@(Sample RealTime
x2 Y
y2 : [Sample Y]
sn))
| Y
y1 forall a. Ord a => a -> a -> Bool
< Y
val Bool -> Bool -> Bool
&& Y
y2 forall a. Ord a => a -> a -> Bool
< Y
val = forall y. RealTime -> y -> Sample y
Sample RealTime
x1 Y
val forall a. a -> [a] -> [a]
: [Sample Y] -> [Sample Y]
below (Sample Y
s1 forall a. a -> [a] -> [a]
: [Sample Y]
s2s)
| Y
y1 forall a. Ord a => a -> a -> Bool
>= Y
val Bool -> Bool -> Bool
&& Y
y2 forall a. Ord a => a -> a -> Bool
>= Y
val = Sample Y
s1 forall a. a -> [a] -> [a]
: [Sample Y] -> [Sample Y]
go [Sample Y]
s2s
| Bool
otherwise = case RealTime -> Y -> RealTime -> Y -> Y -> Maybe RealTime
TimeVector.x_at RealTime
x1 Y
y1 RealTime
x2 Y
y2 Y
val of
Maybe RealTime
Nothing
| Y
y1 forall a. Ord a => a -> a -> Bool
< Y
val -> forall y. RealTime -> y -> Sample y
Sample RealTime
x1 Y
val forall a. a -> [a] -> [a]
: [Sample Y] -> [Sample Y]
go (forall y. RealTime -> y -> Sample y
Sample RealTime
x2 Y
val forall a. a -> [a] -> [a]
: [Sample Y]
sn)
| Bool
otherwise -> Sample Y
s1 forall a. a -> [a] -> [a]
: [Sample Y] -> [Sample Y]
go [Sample Y]
s2s
Just RealTime
x_val
| Y
y1 forall a. Ord a => a -> a -> Bool
< Y
val -> forall y. RealTime -> y -> Sample y
Sample RealTime
x1 Y
val forall a. a -> [a] -> [a]
: [Sample Y] -> [Sample Y]
go (forall y. RealTime -> y -> Sample y
Sample RealTime
x_val Y
val forall a. a -> [a] -> [a]
: [Sample Y]
s2s)
| Bool
otherwise -> Sample Y
s1 forall a. a -> [a] -> [a]
: forall y. RealTime -> y -> Sample y
Sample RealTime
x_val Y
val forall a. a -> [a] -> [a]
: [Sample Y] -> [Sample Y]
below [Sample Y]
s2s
below :: [Sample Y] -> [Sample Y]
below (Sample RealTime
x1 Y
y1 : s2s :: [Sample Y]
s2s@(Sample RealTime
x2 Y
y2 : [Sample Y]
_))
| Y
y2 forall a. Ord a => a -> a -> Bool
< Y
val = [Sample Y] -> [Sample Y]
below [Sample Y]
s2s
| Y
y2 forall a. Eq a => a -> a -> Bool
== Y
val = [Sample Y] -> [Sample Y]
go [Sample Y]
s2s
| Bool
otherwise = case RealTime -> Y -> RealTime -> Y -> Y -> Maybe RealTime
TimeVector.x_at RealTime
x1 Y
y1 RealTime
x2 Y
y2 Y
val of
Maybe RealTime
Nothing -> [Sample Y] -> [Sample Y]
below [Sample Y]
s2s
Just RealTime
x_val -> [Sample Y] -> [Sample Y]
go (forall y. RealTime -> y -> Sample y
Sample RealTime
x_val Y
val forall a. a -> [a] -> [a]
: [Sample Y]
s2s)
below [Sample Y
_] = []
below [] = []
minimum, maximum :: Signal kind -> Y
minimum :: forall {k} (kind :: k). Signal kind -> Y
minimum = forall a. a -> Maybe a -> a
fromMaybe Y
0 forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (v :: * -> *) a.
(Vector v (Sample a), Ord a) =>
SignalS v a -> Maybe a
Segment.minimum forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
maximum :: forall {k} (kind :: k). Signal kind -> Y
maximum = forall a. a -> Maybe a -> a
fromMaybe Y
0 forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (v :: * -> *) a.
(Vector v (Sample a), Ord a) =>
SignalS v a -> Maybe a
Segment.maximum forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
find :: (X -> Y -> Bool) -> Signal kind -> Maybe (X, Y)
find :: forall {k} (kind :: k).
(RealTime -> Y -> Bool) -> Signal kind -> Maybe (RealTime, Y)
find RealTime -> Y -> Bool
f = forall (v :: * -> *) y.
Vector v (Sample y) =>
(RealTime -> y -> Bool)
-> Signal (v (Sample y)) -> Maybe (RealTime, y)
Segment.find RealTime -> Y -> Bool
f forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
{-# SCC map_x #-}
map_x :: (X -> X) -> Signal kind -> Signal kind
map_x :: forall {k} (kind :: k).
(RealTime -> RealTime) -> Signal kind -> Signal kind
map_x = forall {k} (kind :: k).
(NumSignal -> NumSignal) -> Signal kind -> Signal kind
modify forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (v :: * -> *) y.
Vector v (Sample y) =>
(RealTime -> RealTime) -> SignalS v y -> SignalS v y
Segment.map_x
{-# SCC map_y #-}
map_y :: X -> (Y -> Y) -> Signal kind -> Signal kind
map_y :: forall {k} (kind :: k).
RealTime -> (Y -> Y) -> Signal kind -> Signal kind
map_y RealTime
srate = forall {k} (kind :: k).
(NumSignal -> NumSignal) -> Signal kind -> Signal kind
modify forall b c a. (b -> c) -> (a -> b) -> a -> c
. RealTime -> (Y -> Y) -> NumSignal -> NumSignal
Segment.map_y RealTime
srate
{-# SCC map_y_linear #-}
map_y_linear :: (Y -> Y) -> Signal kind -> Signal kind
map_y_linear :: forall {k} (kind :: k). (Y -> Y) -> Signal kind -> Signal kind
map_y_linear = forall {k} (kind :: k).
(NumSignal -> NumSignal) -> Signal kind -> Signal kind
modify forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (v :: * -> *) y.
Vector v (Sample y) =>
(y -> y) -> SignalS v y -> SignalS v y
Segment.map_y_linear
map_err :: (Sample Y -> Either err (Sample Y)) -> Signal kind
-> (Signal kind, [err])
map_err :: forall {k} err (kind :: k).
(Sample Y -> Either err (Sample Y))
-> Signal kind -> (Signal kind, [err])
map_err Sample Y -> Either err (Sample Y)
f = forall (p :: * -> * -> *) a b c.
Bifunctor p =>
(a -> b) -> p a c -> p b c
first forall {k} (kind :: k). NumSignal -> Signal kind
Signal forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (v :: * -> *) y err.
Vector v (Sample y) =>
(Sample y -> Either err (Sample y))
-> SignalS v y -> (SignalS v y, [err])
Segment.map_err Sample Y -> Either err (Sample Y)
f forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
integrate_inverse :: Tempo -> Warp
integrate_inverse :: Tempo -> Warp
integrate_inverse = Tempo -> Warp
integrate forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k).
RealTime -> (Y -> Y) -> Signal kind -> Signal kind
map_y RealTime
tempo_srate (Y
1/)
integrate :: Tempo -> Warp
integrate :: Tempo -> Warp
integrate = forall {k} (kind :: k). NumSignal -> Signal kind
Signal forall b c a. (b -> c) -> (a -> b) -> a -> c
. RealTime -> NumSignal -> NumSignal
Segment.integrate RealTime
tempo_srate forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
tempo_srate :: X
tempo_srate :: RealTime
tempo_srate = Y -> RealTime
RealTime.seconds Y
10
_flat_duration :: Warp -> ScoreTime
_flat_duration :: Warp -> ScoreTime
_flat_duration =
RealTime -> ScoreTime
RealTime.to_score forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a b. (a, b) -> a
fst forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall b a. Storable b => (a -> b -> a) -> a -> Vector b -> a
Vector.foldl' forall {a}.
Eq a =>
(RealTime, Sample a) -> Sample a -> (RealTime, Sample a)
go (RealTime
0, forall y. RealTime -> y -> Sample y
Segment.Sample RealTime
0 Y
0)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (v :: * -> *) y.
Vector v (Sample y) =>
SignalS v y -> v (Sample y)
Segment.to_vector forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (kind :: k). Signal kind -> NumSignal
_signal
where
go :: (RealTime, Sample a) -> Sample a -> (RealTime, Sample a)
go (!RealTime
acc, Segment.Sample RealTime
x0 a
y0) sample :: Sample a
sample@(Segment.Sample RealTime
x a
y)
| a
y forall a. Eq a => a -> a -> Bool
== a
y0 = (RealTime
acc forall a. Num a => a -> a -> a
+ (RealTime
x forall a. Num a => a -> a -> a
- RealTime
x0), Sample a
sample)
| Bool
otherwise = (RealTime
acc, Sample a
sample)