| Safe Haskell | Safe-Inferred | 
|---|---|
| Language | Haskell2010 | 
Sound.Tidal.Time
Synopsis
- type Time = Rational
- data ArcF a = Arc {}
- type Arc = ArcF Time
- sam :: Time -> Time
- toTime :: Real a => a -> Rational
- fromTime :: Fractional a => Time -> a
- nextSam :: Time -> Time
- cyclePos :: Time -> Time
- hull :: Arc -> Arc -> Arc
- subArc :: Arc -> Arc -> Maybe Arc
- subMaybeArc :: Maybe Arc -> Maybe Arc -> Maybe (Maybe Arc)
- sect :: Arc -> Arc -> Arc
- timeToCycleArc :: Time -> Arc
- cycleArc :: Arc -> Arc
- cyclesInArc :: Integral a => Arc -> [a]
- cycleArcsInArc :: Arc -> [Arc]
- arcCycles :: Arc -> [Arc]
- arcCyclesZW :: Arc -> [Arc]
- mapCycle :: (Time -> Time) -> Arc -> Arc
- isIn :: Arc -> Time -> Bool
Documentation
An arc of time, with a start time (or onset) and a stop time (or offset)
Instances
| Applicative ArcF Source # | |
| Functor ArcF Source # | |
| Show Arc Source # | |
| Generic (ArcF a) Source # | |
| Num a => Num (ArcF a) Source # | |
| Fractional a => Fractional (ArcF a) Source # | |
| Show a => Show (Event a) Source # | |
| Show a => Show (ArcF a) Source # | |
| NFData a => NFData (ArcF a) Source # | |
| Defined in Sound.Tidal.Time | |
| Eq a => Eq (ArcF a) Source # | |
| Ord a => Ord (ArcF a) Source # | |
| type Rep (ArcF a) Source # | |
| Defined in Sound.Tidal.Time type Rep (ArcF a) = D1 ('MetaData "ArcF" "Sound.Tidal.Time" "tidal-1.9.3-4wLLA8UaySH4WUbCORe3eb" 'False) (C1 ('MetaCons "Arc" 'PrefixI 'True) (S1 ('MetaSel ('Just "start") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 a) :*: S1 ('MetaSel ('Just "stop") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 a))) | |
The sam (start of cycle) for the given time value.
 Cycles have duration 1, so every integer Time value divides two cycles.
toTime :: Real a => a -> Rational Source #
Turns a number into a (rational) time value. An alias for toRational.
fromTime :: Fractional a => Time -> a Source #
Turns a (rational) time value into another number. An alias for fromRational.
nextSam :: Time -> Time Source #
The end point of the current cycle (and starting point of the next cycle)
subArc :: Arc -> Arc -> Maybe Arc Source #
subArc i j is the timespan that is the intersection of i and j.
 intersection
 The definition is a bit fiddly as results might be zero-width, but
 not at the end of an non-zero-width arc - e.g. (0,1) and (1,2) do
 not intersect, but (1,1) (1,1) does.
timeToCycleArc :: Time -> Arc Source #
The Arc returned is the cycle that the Time falls within.
Edge case: If the Time is an integer, the Arc claiming it is the one starting at that Time, not the previous one ending at that Time.
cycleArc :: Arc -> Arc Source #
Shifts an Arc to one of equal duration that starts within cycle zero. (Note that the output Arc probably does not start *at* Time 0 -- that only happens when the input Arc starts at an integral Time.)
cyclesInArc :: Integral a => Arc -> [a] Source #
Returns the numbers of the cycles that the input Arc overlaps
 (excluding the input Arc's endpoint, unless it has duration 0 --
 see "Edge cases" below).
 (The "cycle number" of an Arc is equal to its start value.
 Thus, for instance, cyclesInArc (Arc 0 1.5) == [0,1].)
Edge cases: > cyclesInArc $ Arc 0 1.0001 == [0,1] > cyclesInArc $ Arc 0 1 == [0] -- the endpoint is excluded > cyclesInArc $ Arc 1 1 == [1] -- unless the Arc has duration 0
PITFALL: Don't be fooled by the name. The output cycles
 are not necessarily completely contained in the input Arc,
 but they definitely overlap it,
 and they include every cycle that overlaps it.
cycleArcsInArc :: Arc -> [Arc] Source #
This provides exactly the same information as cyclesInArc,
 except that this represents its output as Arcs,
 whereas cyclesInArc represents the same information as integral indices.
 (The Arc from 0 to 1 corresponds to the index 0,
 the one from 1 to 2 has index 1, etc.)
arcCyclesZW :: Arc -> [Arc] Source #
Like arcCycles, but returns zero-width arcs