#[non_exhaustive]pub struct Position {
pub side: PositionSide,
pub entry_timestamp: i64,
pub entry_price: f64,
pub quantity: f64,
pub entry_commission: f64,
pub entry_signal: Signal,
}Expand description
An open position
Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional
Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.side: PositionSidePosition direction
entry_timestamp: i64Entry timestamp
entry_price: f64Entry price (after slippage)
quantity: f64Number of shares/units
entry_commission: f64Entry commission paid
entry_signal: SignalSignal that triggered entry
Implementations§
Source§impl Position
impl Position
Sourcepub fn new(
side: PositionSide,
entry_timestamp: i64,
entry_price: f64,
quantity: f64,
entry_commission: f64,
entry_signal: Signal,
) -> Self
pub fn new( side: PositionSide, entry_timestamp: i64, entry_price: f64, quantity: f64, entry_commission: f64, entry_signal: Signal, ) -> Self
Create a new position
Sourcepub fn current_value(&self, current_price: f64) -> f64
pub fn current_value(&self, current_price: f64) -> f64
Calculate current value at given price
Sourcepub fn unrealized_pnl(&self, current_price: f64) -> f64
pub fn unrealized_pnl(&self, current_price: f64) -> f64
Calculate unrealized P&L at given price (before exit commission)
Sourcepub fn unrealized_return_pct(&self, current_price: f64) -> f64
pub fn unrealized_return_pct(&self, current_price: f64) -> f64
Calculate unrealized return percentage
Sourcepub fn is_profitable(&self, current_price: f64) -> bool
pub fn is_profitable(&self, current_price: f64) -> bool
Check if position is profitable at given price
Trait Implementations§
Source§impl<'de> Deserialize<'de> for Position
impl<'de> Deserialize<'de> for Position
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Auto Trait Implementations§
impl Freeze for Position
impl RefUnwindSafe for Position
impl Send for Position
impl Sync for Position
impl Unpin for Position
impl UnsafeUnpin for Position
impl UnwindSafe for Position
Blanket Implementations§
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> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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