European and American Equity Option Functions  Previous topicNext topicFirst topicLast topic


European and American Equity Option Functions

The following functions are specialized to equity underlyings with discrete dividend payouts. Two option models have been implemented: the payout-adjusted European Black-Scholes (BS), and the control-variate American trinomial model (Trin).

Following Hull (see Technical Articles), we consider the stock price as the sum of two components: a stream of known, riskless dividends during the life of the option, and a risky ex-dividend component. For European options, the software subtracts the present value of dividends paid over the life of the option from the current stock price before applying the standard Black-Scholes model. Dividends are discounted using appropriate zero coupon rates, linearly interpolated from an array passed by the user. For American options, the present value of dividends is computed at each node in the lattice, taking into account of forward rates implicit in the zero curve.

There are four calling or "wrapper" functions comprising the set of equity option functions:

EuroCallDivBS(argument list…) European call using the BS model
EuroPutDivBS(argument list…) European put using the BS model
AmerCallDivTrin(argument list…) American call using the Trin model
AmerPutDivTrin(argument list…) American put using the Trin model

Each of the four wrapper functions allow the user to choose from seven different calculations, indexed by an alphabetic Output_Type code:

P option price
D delta (derivative with respect to price
G gamma (second derivative with respect to price)
V vega (derivative with respect to volatility, 1% change)
T theta (time decay over next day)
R rho (sensitivity to the riskless rate, per 1% change)
I implied volatility

An Output_Type may be entered in either upper or lower case, and the user many substitute the entire word for the first letter if so desired (only the first letter is scanned).

The functions use the following arguments:

Argument Description Restrictions
Output_Type desired option calculation P, D, G, V, T, R, or I (see above)
Valuation_Date option valuation date valid Excel date number
Expiry_Date expiry date of option valid Excel date number
>= Valuation_Date
Stock_Price market stock price > 0
Strike strike price of the option > 0
Ex_Div_Dates array of stock ex-dividend dates strictly ascending order
Dates less than or equal to Valuation_Date and greater than Expiry_Date
are ignored
Div_Amounts array of stock dividend amounts corresponding to Ex_Div_Dates array >= 0
Zero_Dates array of zero coupon curve dates strictly ascending order
The first date of this array must be Valuation_Date
Zero_Rates array of continuously compounded riskless rates in decimal form (e.g. six percent entered as 0.06) corresponding to Zero_Dates > 0
Tax_Factor factor to accommodate ex-dividend price drops different than the amounts in the Div_Amounts array, due to differential tax rates between dividends and capital gains typically be set to 1.0, or slightly less
Vol, or
Opt_Price
underlying asset price volatility (risky portion of stock) in decimal form (e.g. twenty percent entered as 0.20), or market price of the option (when Output_Type = I) > 0
Tree_Steps extra argument used in trinomial model to specify number of tree steps in the lattice > 0
<= 300


© 1995-98 Leap of Faith Research Inc.