Expand description
Core data structures to be used internally in Curve implementations, encapsulating storage and access patterns for reuse.
The Core
types here expose their fields publicly so that it is easier to manipulate and
extend them, but in doing so, you must maintain the invariants of those fields yourself. The
provided methods all maintain the invariants, so this is only a concern if you manually mutate
the fields.
Structs§
- The data core of a curve using uneven samples (i.e. keyframes), where each sample time yields some fixed number of values — the sampling width. This may serve as storage for curves that yield vectors or iterators, and in some cases, it may be useful for cache locality if the sample type can effectively be encoded as a fixed-length slice of values.
- The data core of a curve derived from evenly-spaced samples. The intention is to use this in addition to explicit or inferred interpolation information in user-space in order to implement curves using
domain
andsample_with
. - The data core of a curve defined by unevenly-spaced samples or keyframes. The intention is to use this in concert with implicitly or explicitly-defined interpolation in user-space in order to implement the curve interface using
domain
andsample_with
.
Enums§
- An error that indicates that a
ChunkedUnevenCore
could not be formed. - An error indicating that an
EvenCore
could not be constructed. - This type expresses the relationship of a value to a fixed collection of values. It is a kind of summary used intermediately by sampling operations.
- An error indicating that an
UnevenCore
could not be constructed.
Functions§
- Given a domain and a number of samples taken over that interval, return an
InterpolationDatum
that governs how samples are extracted relative to the stored data. - Given a list of
times
and a target value, get the interpolation relationship for the target value in terms of the indices of the starting list. In a sense, this encapsulates the heart of uneven/keyframe sampling.