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

net.finmath.plots.demo.Plot2DDemoBlackScholesPaths Maven / Gradle / Ivy

Go to download

finmath lib plot extensions provide convenient plotting methods by providing consistent wrappers to plot libraries (like JFreeChart or JavaFX).

The newest version!
/*
https://java.com/de/download/mac_download.jsp * (c) Copyright Christian P. Fries, Germany. All rights reserved. Contact: [email protected].
 *
 * Created on 21 May 2018
 */

package net.finmath.plots.demo;

import java.util.function.DoubleFunction;

import net.finmath.exception.CalculationException;
import net.finmath.montecarlo.assetderivativevaluation.AssetModelMonteCarloSimulationModel;
import net.finmath.montecarlo.assetderivativevaluation.MonteCarloBlackScholesModel;
import net.finmath.plots.Named;
import net.finmath.plots.Plot;
import net.finmath.plots.PlotProcess2D;
import net.finmath.stochastic.RandomVariable;
import net.finmath.time.TimeDiscretization;
import net.finmath.time.TimeDiscretizationFromArray;

/**
 * Plots the value of an option under the Black-Scholes model as a function of strike and time-to-maturity.
 *
 * @author Christian Fries
 */
public class Plot2DDemoBlackScholesPaths {

	/**
	 * Run the demo.
	 * Plots the value of an option under the Black-Scholes model as a function of strike and time-to-maturity.
	 *
	 * @param args Not used.
	 * @throws Exception Exception from the graphics backend.
	 */
	public static void main(final String[] args) throws Exception {

		final double initialValue = 100;
		final double riskFreeRate = 0.04;
		final double volatility = 0.40;
		final int numberOfTimeSteps = 100;
		final double deltaT = 0.1;
		final int numberOfPaths = 1000;

		final TimeDiscretization timeDiscretization = new TimeDiscretizationFromArray(0.0, numberOfTimeSteps, deltaT);
		final AssetModelMonteCarloSimulationModel blackScholesMonteCarlo = new MonteCarloBlackScholesModel(timeDiscretization, numberOfPaths, initialValue, riskFreeRate, volatility);

		final DoubleFunction function = (time) -> {
			try {
				return blackScholesMonteCarlo.getAssetValue(time, 0 /* assetIndex */);
			} catch (ArrayIndexOutOfBoundsException | CalculationException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
			return null;
		};

		final Plot plot = new PlotProcess2D(timeDiscretization, new Named<>("Black-Scholes",function), 100 /* maxNumberOfPaths */);
		plot.setTitle("Black-Scholes Model Path").setXAxisLabel("time").setYAxisLabel("value");
		plot.show();

		// To save as PDF uncomment the following line
		// plot.saveAsPDF(new File("Black-Scholes Model Path.pdf"), 800, 400);
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy