Windowed Coskewness
PortfolioOptimisers.WindowedCoskewness Type
struct WindowedCoskewness{__T_ske, __T_w, __T_window} <: CoskewnessEstimatorCoskewness estimator that restricts computation to a rolling or indexed observation window.
WindowedCoskewness wraps another coskewness estimator and applies it to a subset of observations defined by a window and/or custom observation weights. This enables time-varying or recency-weighted coskewness estimation.
Fields
ske: Coskewness estimator.w: Optional observation weights vectorobservations × 1, or a concrete subtype ofDynamicAbstractWeights. Ifnothing, the computation is unweighted.window: Window specification: an integer (lastwindowobservations) or a vector of indices.
Constructors
WindowedCoskewness(;
ske::CoskewnessEstimator = Coskewness(),
w::Option{<:ObsWeights} = nothing,
window::Option{<:Int_VecInt} = nothing
) -> WindowedCoskewnessKeywords correspond to the struct's fields.
Validation
If
wis notnothing,!isempty(w).If
windowis provided, it must be nonempty, nonnegative, and finite.
Related
sourcePortfolioOptimisers.factory Method
factory(ske::WindowedCoskewness, w::ObsWeights) -> WindowedCoskewnessReturn a new WindowedCoskewness estimator with observation weights w applied to the underlying coskewness estimator and stored as the windowed weights.
Arguments
ske: Windowed coskewness estimator.w: Observation weights vectorobservations × 1.
Returns
ske::WindowedCoskewness: Updated estimator with weights applied.
Related
sourcePortfolioOptimisers.coskewness Method
coskewness(ske::WindowedCoskewness, X::MatNum; dims::Int = 1, iv::Option{<:MatNum} = nothing, kwargs...)Compute the coskewness tensor and processed matrix using a rolling or indexed observation window.
This method selects a window of observations from X (and applies observation weights if specified), then delegates to the underlying coskewness estimator.
Arguments
ske: Windowed coskewness estimator.X: Data matrix of asset returns (observations × assets).dims: Dimension along which to perform the computation.iv: Optional implied volatility matrix. Used if any internal covariance estimator is an instance ofImpliedVolatility.kwargs...: Additional keyword arguments passed to the underlying estimator.
Returns
cskew::Matrix{<:Number}: Coskewness tensor (assets × assets²).V::Matrix{<:Number}: Processed coskewness matrix (assets × assets).
Related
source