repicea.stats.RandomVariable Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of repicea-mathstats Show documentation
Show all versions of repicea-mathstats Show documentation
Mathematical and statistical methods
/*
* This file is part of the repicea library.
*
* Copyright (C) 2009-2012 Mathieu Fortin for Rouge-Epicea
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 3 of the License, or (at your option) any later version.
*
* This library is distributed with the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A
* PARTICULAR PURPOSE. See the GNU Lesser General Public
* License for more details.
*
* Please see the license at http://www.gnu.org/copyleft/lesser.html.
*/
package repicea.stats;
import java.io.Serializable;
import repicea.math.AbstractMatrix;
/**
* The RandomVariable class ensures the instance can provide its two first central moments (i.e. mean and variance) as
* well as a distribution. The parameter D sets the distribution of the random variables (see the repicea.stats.distributions
* package)
* @author Mathieu Fortin - May 2012
* @param a Distribution derived instance
*/
public abstract class RandomVariable> implements CentralMomentsGettable, Serializable {
private static final long serialVersionUID = 1L;
private final D distribution;
protected RandomVariable(D distribution) {
this.distribution = distribution;
}
/**
* This method returns the assumed distribution for the random variable.
* @return a Distribution-derived instance
*/
public D getDistribution() {
return distribution;
}
@Override
public M getMean() {
return getMeanFromDistribution();
}
protected M getMeanFromDistribution() {
return getDistribution().getMean();
}
@Override
public V getVariance() {
return getVarianceFromDistribution();
}
protected V getVarianceFromDistribution() {
return getDistribution().getVariance();
}
}