Options
This Finance`Options` subpackage contains tools to compute options using the Black-Scholes model.
This loads the Options subpackage.
In[1]:=<< Finance`Options`
Here are the basic option functions.
In[2]:=?Finance`Options`*
Delta Norm
Elasticity Option
HistoricalVolatility Rho
ImpliedVolatility Theta
Lambda
data:image/s3,"s3://crabby-images/9d844/9d844d15858ea18ea140e7223ed4e8383ac56663" alt=""
data:image/s3,"s3://crabby-images/0c5d5/0c5d5abed0cf30fee3698f6f9498c3931c9a4c93" alt=""
An option object.
This is a put option for an asset named XYZ that expires on December 20, 1992 with an exercise (or striking) price of 40.
In[3]:=xyzft = Option[{"Put", XYZ, 40, {12, 20, 1992}}]
Out[3]=data:image/s3,"s3://crabby-images/3de5d/3de5d68601ef37c98bd8f73b75f01a69a145f525" alt=""
However, we have to remember that an option is a derivative security and we need to specify the price and volatility of the underlying asset.
In[4]:=(Price[XYZ] ^= 40; Volatility[XYZ] ^= 3/10;)
We also have to define the riskless interest rate.
In[5]:=r = 12/100
Out[5]=data:image/s3,"s3://crabby-images/72cce/72cce45993bac14f76f340b74205282beb436fb2" alt=""
We define the settlement date to be August 20, 1992.
In[6]:=settlement = {8, 20, 1992}
Out[6]=data:image/s3,"s3://crabby-images/a2621/a26215b42960c16ca49895ba4ebd7bb7570f4afa" alt=""
This is a call option for an asset named ABC. The striking price is 40 and the expiration date is December 19, 1992.
In[7]:=abcft = Option[{"Call", ABC, 40, {12, 19, 1992}}]
Out[7]=data:image/s3,"s3://crabby-images/2c7c0/2c7c0ca5100e5e1807341b31b4156845355922df" alt=""
This time we specify the volatility but not the price of the underlying asset.
In[8]:=Volatility[ABC] = 3/10
Out[8]=data:image/s3,"s3://crabby-images/ee76f/ee76fbfed955c251c2a6c5f3a68107db9f41378a" alt=""
data:image/s3,"s3://crabby-images/76125/761256ee088974c9a9c5fad2eee81c420d0a3fa6" alt=""
data:image/s3,"s3://crabby-images/da899/da899b17ca34d60c29c317f861acb66a6044078e" alt=""
A basic function.
We compute the value of xyzft given the riskless interest rate r = 12%. Mathematica gives us an exact result.
In[9]:=val1 = Value[xyzft, settlement, r]
Out[9]=data:image/s3,"s3://crabby-images/444f2/444f25fc9d07ccac49b6ad3e0720480be7cdf63b" alt=""
Here is a numerical approximation.
In[10]:=N[%]
Out[10]=data:image/s3,"s3://crabby-images/06632/066324df0050cb3bc9470e56dedb151659646a0b" alt=""
Another way to get an approximation is to write one of the arguments with a decimal point.
In[11]:=Value[xyzft, settlement, .12]
Out[11]=data:image/s3,"s3://crabby-images/8bd52/8bd52554cce7398ce1c83db0cb7b19d5d051fbc2" alt=""
We define an option's value as a function of two variables, the price of the underlying asset x and the time to maturity t.
In[12]:=optionvalue[x_, t_] = Value[abcft, ToCalendar[ToJulian[settlement] + Floor[t]], r] /. Price[ABC] -> x;
This illustrates how the graph of the option value changes as the time to maturity varies.
In[13]:=Plot[Evaluate[Table[optionvalue[x, t], {t, 0, 120, 10}]], {x, 25, 45}, PlotLabel -> " Call Option Value\nfor Different Maturities", FrameLabel -> {"Stock Price", ""}];
data:image/s3,"s3://crabby-images/a5478/a54789fd414fc8d44df87fcda88b59f21160c42f" alt=""
Here is the equivalent three-dimensional graph.
In[14]:=Plot3D[optionvalue[x, t], {x, 25, 55}, {t, 0, 120}, AxesLabel->{"Stock Price", "Time", "Option \nValue "}];
data:image/s3,"s3://crabby-images/8f470/8f470a7be96f037c7991eb0330dd68791d6ba127" alt=""
data:image/s3,"s3://crabby-images/8662b/8662b8ada8392e516917bbe6134cdf42524b66c3" alt=""
data:image/s3,"s3://crabby-images/ef12c/ef12c7e14f37aed1b0b6fadc82e9d71f772ddc1d" alt=""
data:image/s3,"s3://crabby-images/6cb1b/6cb1b39b7cdcff5f67cc129dc0e3df72d30c89ce" alt=""
data:image/s3,"s3://crabby-images/98472/984727e8cdc3a50c9d46b2e3e8652697df299c40" alt=""
data:image/s3,"s3://crabby-images/0e65b/0e65b0b8e76995d2b6c9a77efeb1122df2089db1" alt=""
data:image/s3,"s3://crabby-images/716a4/716a4143bd626d07f7bb7461463f12eada91bbc7" alt=""
data:image/s3,"s3://crabby-images/82b4d/82b4d7cd0665822d6746c98220ce3d6a26513106" alt=""
data:image/s3,"s3://crabby-images/b3794/b379468b1b47206c38d9666bfecf1de0a3a38d86" alt=""
data:image/s3,"s3://crabby-images/f5200/f52008088b8077e4614985b3083306ee74c64937" alt=""
data:image/s3,"s3://crabby-images/75a2c/75a2cf8bb6d258178c60d78f5de1412f1ae13788" alt=""
data:image/s3,"s3://crabby-images/221de/221de1955c800077012a0831bc00ef56a9975eb9" alt=""
data:image/s3,"s3://crabby-images/cee89/cee8974c1f6c167c0bc20f3c4be1d6713394c536" alt=""
Sensitivity measures functions.
Here is the analytical expression for the delta of the put option xyzft.
In[15]:=Delta[xyzft, settlement, r]
Out[15]=data:image/s3,"s3://crabby-images/12e07/12e075826137110841c45b96b7e841c0d5d372ad" alt=""
This is a numerical approximation.
In[16]:=N[%]
Out[16]=data:image/s3,"s3://crabby-images/c9d40/c9d40b8fa5cb8fcfd78f027d3cd414fbaa7b09b3" alt=""
We define the delta of the option abxft as a function of two variables, x and t, the price of the underlying asset and the time to maturity, respectively.
In[17]:=optiondelta[x_, t_] = Delta[abcft, ToCalendar[ToJulian[settlement] + Floor[t]], r] /. Price[ABC] -> x;
This illustrates how the graph of the option delta changes as the time to maturity varies.
In[18]:=Plot[Evaluate[Table[optiondelta[x, j], {j, 0, 120, 10}]], {x, 25, 45}, PlotLabel -> " Call Option Delta\nfor Different Maturities", FrameLabel -> {"Stock Price", ""}];
data:image/s3,"s3://crabby-images/1c84f/1c84f34fa8eab9c0b329975c92b6ccec5aa60c74" alt=""
Here is the equivalent three-dimensional graph.
In[19]:=Plot3D[optiondelta[x, t], {x, 25, 55}, {t, 0, 120}, AxesLabel->{"Stock Price", "Time", "Option \nDelta"}];
data:image/s3,"s3://crabby-images/3a8b1/3a8b15c749e07f976fef84b7a7195cfe82e1d3f4" alt=""
Here is the analytical expression for the theta of the put option xyzft.
In[20]:=Theta[xyzft, settlement, r]
Out[20]=data:image/s3,"s3://crabby-images/3fc3c/3fc3c64ced1c766b52544264c753aa7e1b1a0e74" alt=""
This is a numerical approximation.
In[21]:=N[%]
Out[21]=data:image/s3,"s3://crabby-images/6b826/6b826cc4c26c3c4d3d6274aeb4efcfea2f8cd045" alt=""
We define the theta of the option abcft as a function of two variables, x and t, the price of the underlying asset and the time to maturity, respectively.
In[22]:=optiontheta[x_, t_] = Theta[abcft, ToCalendar[ToJulian[settlement] + Floor[t]], r] /. Price[ABC] -> x;
This illustrates how the graph of the option theta changes as the time to maturity varies.
In[23]:=Plot[Evaluate[Table[optiontheta[x, j], {j, 0, 110, 10}]], {x, 25, 45}, PlotLabel -> " Call Option Theta\nfor Different Maturities", FrameLabel -> {"Stock Price", ""}];
data:image/s3,"s3://crabby-images/777ca/777ca9e8827f07eef8dd30247bd21fdc61ed3cf9" alt=""
Here is the equivalent three-dimensional graph.
In[24]:=Plot3D[optiontheta[x, t], {x, 25, 55}, {t, 0, 110}, AxesLabel->{"Stock Price", "Time", "Option \nTheta"}];
data:image/s3,"s3://crabby-images/c9b8b/c9b8b0a6383bb3afb4caa16caea29f3dee646d0f" alt=""
Here is the analytical expression for the gamma of the put option xyzft.
In[25]:=Gamma[xyzft, settlement, r]
Out[25]=data:image/s3,"s3://crabby-images/75615/75615cfdec1eaa236e1a5c1e5397171c2dad8797" alt=""
This is a numerical approximation.
In[26]:=N[%]
Out[26]=data:image/s3,"s3://crabby-images/2f0fc/2f0fc953d75b506829b30e2b7db2c5b13d5af35c" alt=""
We define the gamma of the option abcft as a function of two variables, x and t, the price of the underlying asset and the time to maturity, respectively.
In[27]:=optiongamma[x_, t_] = Gamma[abcft, ToCalendar[ToJulian[settlement] + Floor[t]], r] /. Price[ABC] -> x;
This illustrates how the graph of the option gamma changes as the time to maturity varies.
In[28]:=Plot[Evaluate[Table[optiongamma[x, j], {j, 0, 110, 10}]], {x, 25, 45}, PlotLabel -> " Call Option Gamma\nfor Different Maturities", FrameLabel -> {"Stock Price", ""}];
data:image/s3,"s3://crabby-images/cbf28/cbf2805a6cdda0a3bdac48b9d98eb1eef0c8edbe" alt=""
Here is the equivalent three-dimensional graph.
In[29]:=Plot3D[optiongamma[x, t], {x, 25, 55}, {t, 0, 110}, AxesLabel->{"Stock Price", "Time", "Option Gamma"}];
data:image/s3,"s3://crabby-images/cb9e6/cb9e6f386326287f60e2419e4656d2b3e78095e3" alt=""
Here is the analytical expression for the rho of the put option xyzft.
In[30]:=Rho[xyzft, settlement, r]
Out[30]=data:image/s3,"s3://crabby-images/fa000/fa000a55d002daf0ca40723666077f005c63004f" alt=""
This is a numerical approximation.
In[31]:=N[%]
Out[31]=data:image/s3,"s3://crabby-images/723cb/723cb6476a4de6d09fa66af63abc7be20a982d4d" alt=""
We define the rho of the option abcft as a function of two variables, x and t, the price of the underlying asset and the time to maturity, respectively.
In[32]:=optionrho[x_, t_] = Rho[abcft, ToCalendar[ToJulian[settlement] + Floor[t]], r] /. Price[ABC] -> x;
This illustrates how the graph of the option rho changes as the time to maturity varies.
In[33]:=Plot[Evaluate[Table[optionrho[x, j], {j, 0, 120, 10}]], {x, 25, 45}, PlotLabel -> " Call Option Rho\nfor Different Maturities", FrameLabel -> {"Stock Price", ""}];
data:image/s3,"s3://crabby-images/18946/18946087bc2a8720e53d09fb842297206d17afc4" alt=""
Here is the equivalent three-dimensional graph.
In[34]:=Plot3D[optionrho[x, t], {x, 25, 55}, {t, 0, 110}, AxesLabel->{"Stock Price", "Time", "Option \nRho"}];
data:image/s3,"s3://crabby-images/35dc1/35dc17b31d0859e10f1022527acae5a087c317b3" alt=""
Here is the analytical expression for the lambda of the put option xyzft. Kappa, vega, and epsilon are sometimes used instead of lambda.
In[35]:=Lambda[xyzft, settlement, r]
Out[35]=data:image/s3,"s3://crabby-images/20083/20083287dcc8d98ca86163744068422a4be5fa65" alt=""
This is a numerical approximation.
In[36]:=N[%]
Out[36]=data:image/s3,"s3://crabby-images/50dd7/50dd7ad8f94377492d8790081407c0bf57893e86" alt=""
We define the lambda of the option abcft as a function of two variables, x and t, the price of the underlying asset and the time to maturity, respectively.
In[37]:=optionlambda[x_, t_] = Lambda[abcft, ToCalendar[ToJulian[settlement] + Floor[t]], r] /. Price[ABC] -> x;
This illustrates how the graph of the option lambda changes as the time to maturity varies.
In[38]:=Plot[Evaluate[Table[optionlambda[x, t], {t, 0, 110, 10}]], {x, 25, 45}, PlotLabel -> " Call Option Lambda\nfor Different maturities", FrameLabel -> {"Stock Price", ""}];
data:image/s3,"s3://crabby-images/7f1fa/7f1fa7170e10259fecf1c3f4ecbdc94695be494e" alt=""
Here is the equivalent three-dimensional graph.
In[39]:=Plot3D[optionlambda[x, t], {x, 25, 55}, {t, 0, 110}, AxesLabel->{"Stock Price", "Time", "Option \nLambda"}];
data:image/s3,"s3://crabby-images/81cc5/81cc5b5e76cf34e1ef01ba589addacf5deafa29c" alt=""
Here is the analytical expression for the elasticity of the put option xyzft.
In[40]:=Elasticity[xyzft, settlement, r]
Out[40]=data:image/s3,"s3://crabby-images/9b592/9b59280b1d596213592d9863d10d4b105b776eac" alt=""
This is a numerical approximation.
In[41]:=N[%]
Out[41]=data:image/s3,"s3://crabby-images/0bd9f/0bd9fb0f2472a49fa5bb69547c79516a747c58d2" alt=""
We define the elasticity of the option abcft as a function of two variables, x and t, the price of the underlying asset and the time to maturity, respectively.
In[42]:=optionelasticity[x_, t_] = Elasticity[abcft, ToCalendar[ToJulian[settlement] + Floor[t]], r] /. Price[ABC] -> x;
This illustrates how the graph of the option elasticity changes as the time to maturity varies.
In[43]:=Plot[Evaluate[Table[optionelasticity[x, t], {t, 0, 100, 10}]], {x, 25, 45}, PlotLabel -> "Call Option Elasticity\n"<> "for Different Maturities", FrameLabel -> {"Stock Price", ""}];
data:image/s3,"s3://crabby-images/d121a/d121ae76db8815bed673fc0981d47159557b1f02" alt=""
Here is the equivalent three-dimensional graph.
In[44]:=Plot3D[optionelasticity[x, t], {x, 25, 55}, {t, 0, 100}, AxesLabel->{"Stock Price", "Time", "Option \nElasticity"}];
data:image/s3,"s3://crabby-images/223e8/223e800f943099d2f3badf578d5025b9cff3a4ff" alt=""
data:image/s3,"s3://crabby-images/5c19f/5c19ff61c4445c47402b89a15a58f841f056db7a" alt=""
data:image/s3,"s3://crabby-images/68636/6863664bbca76c39c3215d7ce916cb49018789db" alt=""
Implied volatility function.
This calculates the implied volatility.
In[45]:=ImpliedVolatility[xyzft, settlement, r, val1]
Out[45]=data:image/s3,"s3://crabby-images/99e35/99e35878744d5cf989cee0e4e5979292f8f09b04" alt=""
data:image/s3,"s3://crabby-images/6750e/6750e1009d659fd14aa6a51ba022fe72aa65805d" alt=""
data:image/s3,"s3://crabby-images/7c8a9/7c8a9b58afe6cbaddff959a6a90f0e4b2732bb51" alt=""
data:image/s3,"s3://crabby-images/26bc3/26bc307abfc37088ab298d5ab2aeaed6ccaa326c" alt=""
Auxiliary functions.
To use the Black-Scholes model we need to know the underlying asset's volatility. The function HistoricalVolatility computes the maximum likelihood estimate of the asset's volatility given a list of past prices.
We read in the prices for one year of IBM stock from the file IBM-90.prc as pairs {date, price}.
In[46]:=prices[IBM] ^= Last[Transpose[ReadList[ ToFileName[{"Finance", "Data"}, "IBM-90.prc"], {Number, Number}]]];
Here is the graph of IBM's prices.
In[47]:=ListPlot[prices[IBM], PlotJoined -> True];
data:image/s3,"s3://crabby-images/9e94f/9e94fef09841be7d81544b1facb7abc7bde525d0" alt=""
Now we compute the maximum likelihood estimate for IBM's stock volatility. This is the daily volatility since we used daily stock prices.
In[48]:=HistoricalVolatility[prices[IBM]]
Out[48]=data:image/s3,"s3://crabby-images/65009/65009546e3eb9c226f6834647f38588d651183f7" alt=""
To get an estimate of the yearly volatility we multiply by the square root of the number of days in a year. Usually we only take the number of trading days, which is about 250.
In[49]:=% Sqrt[250.]
Out[49]=data:image/s3,"s3://crabby-images/352ba/352ba1575a6c91cea5063003a6ce7f8e958c9944" alt=""
The cumulative normal distribution is often used in modern finance and especially in the context of option pricing. Here is the graph of the cumulative standard normal distribution function.
In[50]:=Plot[Norm[x], {x, -5, 5}];
data:image/s3,"s3://crabby-images/d71f1/d71f15eb4e71a017bc6f634f27592c4f2250d433" alt=""
Its derivative with respect to x is indeed the standard normal distribution.
In[51]:=D[Norm[x], x]
Out[51]=data:image/s3,"s3://crabby-images/a9275/a927500d9c1f00e1dd0ccf57991b57968246b5ca" alt=""
Here is the graph of the standard normal distribution.
In[52]:=Plot[Evaluate[D[Norm[x], x]], {x, -5, 5}];
data:image/s3,"s3://crabby-images/c26d7/c26d7e03b564f88ab393baf9104e9ee90c04dc42" alt=""
|