# Valuing American Options Using Monte Carlo Simulation –Derivative Pricing in Python

In a previous post, we presented the binomial tree method for pricing American options. Recall that an American option is an option that can be exercised any time before maturity.

A drawback of the binomial tree method is that the implementation of a more complex option payoff is difficult, especially when the payoff is path-dependent. For example, for an American double-average option with periodic sampling time points, the strike price is not known at the start of the option.  It can only be determined in the future and is therefore path-dependent.  Another example is an American forward start option. These options cannot be valued using the binomial tree approach.

In this post, we are going to present a method for valuing American options using Monte Carlo simulation. This method will allow us to implement more complex option payoffs with greater flexibility, even if the payoffs are path-dependent. Specifically, we use the Least-Squares Method of Longstaff and Schwartz [1] in order to take into account the early exercise feature.  The stock price is assumed to follow the Geometrical Brownian Motion and the dividend is simulated continuously.

Using this approach, it would be optimal to exercise the option if the immediate payment is larger than the expected future cash flows, otherwise it should be kept.  Specifically, for each generated path, we regress the future payoffs on the basis functions of S and S2[2]. The regression equation provides us with estimation for the expected value of future payoffs as a function of S and S2. This expected value is the value of holding on to the option, i.e. the continuation value. Using the regression equation, we can decide if it is preferable to exercise the option immediately or to wait one more period. This procedure is repeated backward from the maturity date to the time zero. Finally, the price of the option is calculated as the average value of all the discounted payoffs.

We implemented the Least-Squares Method of Longstaff and Schwartz in Python and priced the option presented in the previous post.  The main input parameters are as follows,

The picture below shows the results obtained by using the Python program.

References

[1] F. Longstaff and E. Schwartz, Valuing American options by simulation: A simple least-squares approach, Review of Financial Studies, Spring 2001, pp. 113–147.

[2] S denotes the stock price. Other basis functions can also be used.

## Further questions

Have an answer to the questions below? Post it here or in the forum

Views
Question
237
views
924
views
405
views
LATEST NEWS
Russian court seizes assets worth €700mn from UniCredit, Deutsche Bank and Commerzbank

Move against western lenders follows dispute with a subsidiary of Gazprom

LATEST NEWS
Donald Trump's political maelstrom could be close to sucking Ivanka back in

Friends of Ivanka Trump told Business Insider that, despite her recent distance from her father's political brand, never say never to a return.

LATEST NEWS
The Magnificent 7 companies are worth a combined \$14 trillion &mdash; here's how much their CEOs make

Microsoft, Apple, Nvidia, Alphabet, Amazon, Meta and Tesla are worth \$14 trillion — and their CEOs are paid handsomely.