All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.finmath.montecarlo.conditionalexpectation.RegressionBasisFunctionsFromProducts Maven / Gradle / Ivy

/*
 * (c) Copyright Christian P. Fries, Germany. Contact: [email protected].
 *
 * Created on 26.08.2018
 */
package net.finmath.montecarlo.conditionalexpectation;

import java.util.List;
import java.util.function.Function;

import net.finmath.exception.CalculationException;
import net.finmath.montecarlo.AbstractMonteCarloProduct;
import net.finmath.montecarlo.MonteCarloSimulationModel;
import net.finmath.stochastic.RandomVariable;

/**
 * An implementation of an RegressionBasisFunctionsProvider using a list of AbstractMonteCarloProduct-s.

 * The getBasisFunctions method will perform a check if the products getValue method returns an
 * \( \mathcal{F}_{t} \)-measurable random variable if called with evaluationTime being \( t \).
 * If this test fails an IllegalArgumentException exception is thrown.
 *
 * @author Christian Fries
 * @version 1.0
 */
public class RegressionBasisFunctionsFromProducts implements RegressionBasisFunctionsProvider {

	private final List products;

	public RegressionBasisFunctionsFromProducts(List products) {
		super();
		this.products = products;
	}

	@Override
	public RandomVariable[] getBasisFunctions(double evaluationTime, MonteCarloSimulationModel model) {

		Function valuation = p -> {
			RandomVariable value = null;
			try {
				value = p.getValue(evaluationTime, model);
			} catch (CalculationException e) {
				throw new IllegalArgumentException("Product " + p + " cannot be valued by model " + model + " at time " + evaluationTime, e);
			}

			if(value.getFiltrationTime() > evaluationTime) {
				throw new IllegalArgumentException(
						"Product " + p + " valued by model " + model + " cannot be used as basis function at time " + evaluationTime + ". "
								+ "Filtration time is " + value.getFiltrationTime());
			}

			return value;
		};

		return products.stream().map(valuation).toArray(RandomVariable[]::new);
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy