Move the pricing engine sources out of src/ into cpp/, add the closed-form engine and pybind wiring, and align tests/build targets with the new project layout. Made-with: Cursor
26 lines
782 B
C++
26 lines
782 B
C++
/**
|
|
* @file MonteCarloEngine.cpp
|
|
* @brief Monte Carlo mean estimator with discounting.
|
|
*/
|
|
|
|
#include "MonteCarloEngine.hpp"
|
|
#include <iostream>
|
|
#include "Instrument.hpp"
|
|
#include "Statistics.hpp"
|
|
|
|
double MonteCarloEngine::calculate(const Instrument &instrument) const {
|
|
// parameters
|
|
double T = instrument.maturity();
|
|
double spot = process_->data().spot();
|
|
Statistics stats;
|
|
|
|
auto rNumbers = rng_->nextGaussianVector(numPaths_);
|
|
std::vector<double> payoffs(numPaths_);
|
|
for (std::size_t i = 0; i < numPaths_; ++i) {
|
|
double terminalPrice = process_->step(0.0,spot,T,rNumbers[i]);
|
|
double payoff = instrument.payoff()(terminalPrice);
|
|
stats.dump(payoff);
|
|
}
|
|
return stats.mean() * process_->data().yield_curve().discount(T);
|
|
}
|