pub struct SortinoRatio { /* private fields */ }Expand description
Calculates the Sortino ratio for portfolio returns.
The Sortino ratio is a variation of the Sharpe ratio that only penalizes downside volatility, making it more appropriate for strategies with asymmetric return distributions.
Formula: Mean Return / Downside Deviation * sqrt(period)
Where downside deviation is calculated as:
sqrt(sum(negative_returns^2) / total_observations)
Note: Uses total observations count (not just negative returns) as per Sortino’s methodology.
§References
- Sortino, F. A., & van der Meer, R. (1991). “Downside Risk”. Journal of Portfolio Management, 17(4), 27-31.
- Sortino, F. A., & Price, L. N. (1994). “Performance Measurement in a Downside Risk Framework”. Journal of Investing, 3(3), 59-64.
Implementations§
Source§impl SortinoRatio
impl SortinoRatio
Sourcepub fn new(period: Option<usize>) -> Self
pub fn new(period: Option<usize>) -> Self
Creates a new SortinoRatio instance.
Trait Implementations§
Source§impl Clone for SortinoRatio
impl Clone for SortinoRatio
Source§fn clone(&self) -> SortinoRatio
fn clone(&self) -> SortinoRatio
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for SortinoRatio
impl Debug for SortinoRatio
Source§impl Display for SortinoRatio
impl Display for SortinoRatio
Source§impl<'a, 'py> FromPyObject<'a, 'py> for SortinoRatiowhere
Self: Clone,
impl<'a, 'py> FromPyObject<'a, 'py> for SortinoRatiowhere
Self: Clone,
Source§impl<'py> IntoPyObject<'py> for SortinoRatio
impl<'py> IntoPyObject<'py> for SortinoRatio
Source§type Target = SortinoRatio
type Target = SortinoRatio
Source§type Output = Bound<'py, <SortinoRatio as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <SortinoRatio as IntoPyObject<'py>>::Target>
Source§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
fn into_pyobject( self, py: Python<'py>, ) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
Source§impl PortfolioStatistic for SortinoRatio
impl PortfolioStatistic for SortinoRatio
type Item = f64
Source§fn name(&self) -> String
fn name(&self) -> String
Source§fn calculate_from_returns(&self, raw_returns: &Returns) -> Option<Self::Item>
fn calculate_from_returns(&self, raw_returns: &Returns) -> Option<Self::Item>
Source§fn calculate_from_realized_pnls(
&self,
_realized_pnls: &[f64],
) -> Option<Self::Item>
fn calculate_from_realized_pnls( &self, _realized_pnls: &[f64], ) -> Option<Self::Item>
Source§fn calculate_from_positions(
&self,
_positions: &[Position],
) -> Option<Self::Item>
fn calculate_from_positions( &self, _positions: &[Position], ) -> Option<Self::Item>
Source§fn calculate_from_orders(
&self,
orders: Vec<Box<dyn Order>>,
) -> Option<Self::Item>
fn calculate_from_orders( &self, orders: Vec<Box<dyn Order>>, ) -> Option<Self::Item>
Source§fn check_valid_returns(&self, returns: &Returns) -> bool
fn check_valid_returns(&self, returns: &Returns) -> bool
Source§fn downsample_to_daily_bins(&self, returns: &Returns) -> Returns
fn downsample_to_daily_bins(&self, returns: &Returns) -> Returns
Source§fn calculate_std(&self, returns: &Returns) -> f64
fn calculate_std(&self, returns: &Returns) -> f64
Source§impl PyClass for SortinoRatio
impl PyClass for SortinoRatio
Source§impl PyClassImpl for SortinoRatio
impl PyClassImpl for SortinoRatio
Source§const IS_BASETYPE: bool = false
const IS_BASETYPE: bool = false
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
Source§const IS_IMMUTABLE_TYPE: bool = false
const IS_IMMUTABLE_TYPE: bool = false
Source§const RAW_DOC: &'static CStr = /// Calculates the Sortino ratio for portfolio returns.
///
/// The Sortino ratio is a variation of the Sharpe ratio that only penalizes downside
/// volatility, making it more appropriate for strategies with asymmetric return distributions.
///
/// Formula: `Mean Return / Downside Deviation * sqrt(period)`
///
/// Where downside deviation is calculated as:
/// `sqrt(sum(negative_returns^2) / total_observations)`
///
/// Note: Uses total observations count (not just negative returns) as per Sortino's methodology.
///
/// # References
///
/// - Sortino, F. A., & van der Meer, R. (1991). "Downside Risk". *Journal of Portfolio Management*, 17(4), 27-31.
/// - Sortino, F. A., & Price, L. N. (1994). "Performance Measurement in a Downside Risk Framework".
/// *Journal of Investing*, 3(3), 59-64.
const RAW_DOC: &'static CStr = /// Calculates the Sortino ratio for portfolio returns. /// /// The Sortino ratio is a variation of the Sharpe ratio that only penalizes downside /// volatility, making it more appropriate for strategies with asymmetric return distributions. /// /// Formula: `Mean Return / Downside Deviation * sqrt(period)` /// /// Where downside deviation is calculated as: /// `sqrt(sum(negative_returns^2) / total_observations)` /// /// Note: Uses total observations count (not just negative returns) as per Sortino's methodology. /// /// # References /// /// - Sortino, F. A., & van der Meer, R. (1991). "Downside Risk". *Journal of Portfolio Management*, 17(4), 27-31. /// - Sortino, F. A., & Price, L. N. (1994). "Performance Measurement in a Downside Risk Framework". /// *Journal of Investing*, 3(3), 59-64.
Source§const DOC: &'static CStr
const DOC: &'static CStr
text_signature if a constructor is defined. Read moreSource§type Layout = <<SortinoRatio as PyClassImpl>::BaseNativeType as PyClassBaseType>::Layout<SortinoRatio>
type Layout = <<SortinoRatio as PyClassImpl>::BaseNativeType as PyClassBaseType>::Layout<SortinoRatio>
Source§type ThreadChecker = NoopThreadChecker
type ThreadChecker = NoopThreadChecker
type Inventory = Pyo3MethodsInventoryForSortinoRatio
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
PyAny by default, and when you declare
#[pyclass(extends=PyDict)], it’s PyDict.fn items_iter() -> PyClassItemsIter
fn lazy_type_object() -> &'static LazyTypeObject<Self>
§fn dict_offset() -> Option<PyObjectOffset>
fn dict_offset() -> Option<PyObjectOffset>
§fn weaklist_offset() -> Option<PyObjectOffset>
fn weaklist_offset() -> Option<PyObjectOffset>
Source§impl PyClassNewTextSignature for SortinoRatio
impl PyClassNewTextSignature for SortinoRatio
const TEXT_SIGNATURE: &'static str = "(period=None)"
Source§impl PyStubType for SortinoRatio
impl PyStubType for SortinoRatio
Source§fn type_output() -> TypeInfo
fn type_output() -> TypeInfo
§fn type_input() -> TypeInfo
fn type_input() -> TypeInfo
Source§impl PyTypeInfo for SortinoRatio
impl PyTypeInfo for SortinoRatio
Source§const NAME: &str = <Self as ::pyo3::PyClass>::NAME
const NAME: &str = <Self as ::pyo3::PyClass>::NAME
prefer using ::type_object(py).name() to get the correct runtime value
Source§const MODULE: Option<&str> = <Self as ::pyo3::impl_::pyclass::PyClassImpl>::MODULE
const MODULE: Option<&str> = <Self as ::pyo3::impl_::pyclass::PyClassImpl>::MODULE
prefer using ::type_object(py).module() to get the correct runtime value
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
§fn is_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type or a subclass of this type.§fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type.impl DerefToPyAny for SortinoRatio
Auto Trait Implementations§
impl Freeze for SortinoRatio
impl RefUnwindSafe for SortinoRatio
impl Send for SortinoRatio
impl Sync for SortinoRatio
impl Unpin for SortinoRatio
impl UnsafeUnpin for SortinoRatio
impl UnwindSafe for SortinoRatio
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
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>
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>
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§impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
§fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
self into an owned Python object, dropping type information.§fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
self into an owned Python object, dropping type information and unbinding it
from the 'py lifetime.§fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
self into a Python object. Read more§impl<'py, T> IntoPyObjectNautilusExt<'py> for Twhere
T: IntoPyObjectExt<'py>,
impl<'py, T> IntoPyObjectNautilusExt<'py> for Twhere
T: IntoPyObjectExt<'py>,
§fn into_py_any_unwrap(self, py: Python<'py>) -> Py<PyAny>
fn into_py_any_unwrap(self, py: Python<'py>) -> Py<PyAny>
§impl<T> PyErrArguments for T
impl<T> PyErrArguments for T
§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
§const NAME: &'static str = T::NAME
const NAME: &'static str = T::NAME
Use ::classinfo_object() instead and format the type name at runtime. Note that using built-in cast features is often better than manual PyTypeCheck usage.
§fn type_check(object: &Bound<'_, PyAny>) -> bool
fn type_check(object: &Bound<'_, PyAny>) -> bool
§fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
isinstance and issubclass function. Read more