pub struct CalendarSpread { /* private fields */ }Expand description
Calendar Spread — the relative spread between a dated (e.g. quarterly) futures price and the perpetual mark price.
spread = (futuresPrice − markPrice) / markPriceA calendar (or inter-delivery) spread trades the near leg against the
far leg — here the perpetual against a dated future. The relative spread is
the roll yield available between the two contracts: positive when the future
trades over the perpetual (contango roll), negative when under
(backwardation). Where TermStructureBasis measures the future against
spot, this measures it against the perpetual — the leg a perp-vs-future
basis trade actually holds. The output is a fraction; multiply by 10_000
for basis points.
Input = DerivativesTick, Output = f64. Stateless; ready after the first
tick.
§Example
use wickra_core::{CalendarSpread, DerivativesTick, Indicator};
fn tick(futures: f64, mark: f64) -> DerivativesTick {
DerivativesTick::new(0.0, mark, mark, futures, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0)
.unwrap()
}
let mut cs = CalendarSpread::new();
// futures 101 vs perpetual mark 100 -> 0.01.
assert!((cs.update(tick(101.0, 100.0)).unwrap() - 0.01).abs() < 1e-12);Implementations§
Trait Implementations§
Source§impl Clone for CalendarSpread
impl Clone for CalendarSpread
Source§fn clone(&self) -> CalendarSpread
fn clone(&self) -> CalendarSpread
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for CalendarSpread
impl Debug for CalendarSpread
Source§impl Default for CalendarSpread
impl Default for CalendarSpread
Source§fn default() -> CalendarSpread
fn default() -> CalendarSpread
Returns the “default value” for a type. Read more
Source§impl Indicator for CalendarSpread
impl Indicator for CalendarSpread
Source§type Input = DerivativesTick
type Input = DerivativesTick
Type of one input data point (typically
f64 for a price, or Candle / Tick).Source§fn update(&mut self, tick: DerivativesTick) -> Option<f64>
fn update(&mut self, tick: DerivativesTick) -> Option<f64>
Feed one new data point into the indicator and return the freshly computed
output, or
None if the indicator is still warming up.Source§fn reset(&mut self)
fn reset(&mut self)
Reset all internal state, leaving the indicator equivalent to a freshly
constructed instance with the same parameters.
Source§fn warmup_period(&self) -> usize
fn warmup_period(&self) -> usize
Number of inputs required before the first non-
None output can be produced.Auto Trait Implementations§
impl Freeze for CalendarSpread
impl RefUnwindSafe for CalendarSpread
impl Send for CalendarSpread
impl Sync for CalendarSpread
impl Unpin for CalendarSpread
impl UnsafeUnpin for CalendarSpread
impl UnwindSafe for CalendarSpread
Blanket Implementations§
Source§impl<T> BatchExt for Twhere
T: Indicator,
impl<T> BatchExt for Twhere
T: Indicator,
Source§fn batch(&mut self, inputs: &[Self::Input]) -> Vec<Option<Self::Output>>
fn batch(&mut self, inputs: &[Self::Input]) -> Vec<Option<Self::Output>>
Run the indicator over a slice of inputs in order, returning one output (or
None during warmup) per input.Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more