/** * Copyright (C) 2011 - present by OpenGamma Inc. and the OpenGamma group of companies * * Please see distribution for license. */ package com.opengamma.analytics.financial.var; import org.apache.commons.lang.Validate; import com.opengamma.analytics.math.statistics.distribution.ProbabilityDistribution; import com.opengamma.analytics.math.statistics.distribution.StudentTDistribution; import com.opengamma.util.ArgumentChecker; /** * */ public class StudentTVaRParameters { private final double _horizon; private final double _periods; private final double _quantile; private final double _dof; private final double _mult; private final double _scale; private final ProbabilityDistribution<Double> _studentT; public StudentTVaRParameters(final double horizon, final double periods, final double quantile, final double dof) { Validate.isTrue(horizon > 0, "horizon"); Validate.isTrue(periods > 0, "periods"); if (!ArgumentChecker.isInRangeInclusive(0, 1, quantile)) { throw new IllegalArgumentException("Quantile must be between 0 and 1"); } Validate.isTrue(dof > 0, "degrees of freedom"); _horizon = horizon; _periods = periods; _quantile = quantile; _dof = dof; _studentT = new StudentTDistribution(dof); _mult = Math.sqrt((_dof - 2) * horizon / dof / periods) * _studentT.getInverseCDF(quantile); _scale = horizon / periods; } public double getMult() { return _mult; } public double getScale() { return _scale; } public double getHorizon() { return _horizon; } public double getPeriods() { return _periods; } public double getQuantile() { return _quantile; } public double getDegreesOfFreedom() { return _dof; } @Override public int hashCode() { final int prime = 31; int result = 1; long temp; temp = Double.doubleToLongBits(_dof); result = prime * result + (int) (temp ^ (temp >>> 32)); temp = Double.doubleToLongBits(_horizon); result = prime * result + (int) (temp ^ (temp >>> 32)); temp = Double.doubleToLongBits(_periods); result = prime * result + (int) (temp ^ (temp >>> 32)); temp = Double.doubleToLongBits(_quantile); return result; } @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (getClass() != obj.getClass()) { return false; } StudentTVaRParameters other = (StudentTVaRParameters) obj; if (Double.doubleToLongBits(_dof) != Double.doubleToLongBits(other._dof)) { return false; } if (Double.doubleToLongBits(_horizon) != Double.doubleToLongBits(other._horizon)) { return false; } if (Double.doubleToLongBits(_periods) != Double.doubleToLongBits(other._periods)) { return false; } if (Double.doubleToLongBits(_quantile) != Double.doubleToLongBits(other._quantile)) { return false; } return true; } }