Finance
ImpliedVolatilitySurface
create new implied volatility term structure
Calling Sequence
Parameters
Options
Description
Examples
References
Compatibility
ImpliedVolatilitySurface(volatility, T, S, opts)
ImpliedVolatilitySurface(riskfreerate, dividendyield, spot, times, strikes, prices, opts)
ImpliedVolatilitySurface(riskfreerate, dividendyield, spot, dates, strikes, prices, opts)
ImpliedVolatilitySurface(riskfreerate, dividendyield, price, T, K, opts)
ImpliedVolatilitySurface(times, volatilities, opts)
ImpliedVolatilitySurface(dates, volatilities, opts)
ImpliedVolatilitySurface(times, values, volatilities, opts)
ImpliedVolatilitySurface(dates, values, volatilities, opts)
volatility
-
algebraic expression, operator or procedure; implied volatility
T
name; variable representing time to maturity
S
name; variable representing the value of the underlying
riskfreerate
non-negative constant, algebraic expression or a yield term structure; risk-free rate
dividendyield
non-negative constant, algebraic expression or a yield term structure; dividend yield
spot
algebraic expression; initial value of the underlying asset
times
list or Vector; times (in years)
strikes
list, Vector, listlist or Matrix; strike prices of European call options
prices
list, Vector, listlist or Matrix; prices of European call options
dates
list; dates
price
algebraic expression or procedure; price of a European call option
K
name; variable representing the strike price
volatilities
list, Vector, listlist or Matrix; volatilities
values
list or Vector; values of the underlying
opts
equations of the form option = value where option is one of daycounter, interpolation, or referencedate; specify options for the ImpliedVolatilitySurface command
daycounter = Actual360, Actual365Fixed, AFB, Bond, Euro, Historical, ISDA, ISMA, OneDay, Simple, Thirty360BondBasis, Thirty360EuroBondBasis, Thirty360European, Thirty360Italian, Thirty360USA, or a day counter data structure -- This option specifies the convention used to convert the amount of time between two dates to year fractions.
interpolation = Bilinear or Bicubic -- This option specifies the type of interpolation used to build a volatility surface from a discrete set of rates. The Bilinear interpolation is used by default.
referencedate = date in any of the formats recognized by the Finance[ParseDate] command -- This option specifies the reference date (date when the discount factor is equal to 1).
The ImpliedVolatilitySurface command creates new implied volatility term structure with the given parameters. This term structure is represented as a module. This module can be passed to other commands of the Finance package that expect an implied volatility term structure as one of the parameters; it can also be used as if it were a procedure. Assume, for example, that the module returned by ImpliedVolatilitySurface was assigned to the name V. Then for any positive constants T and S, V⁡T,S will return the corresponding value of the implied volatility. If one of the parameters T or S is non-numeric, V⁡T,S will return unevaluated.
The ImpliedVolatilitySurface(times, volatilities, opts) and ImpliedVolatilitySurface(dates, volatilities, opts) calling sequences create an implied-volatility term structure based on a piecewise interpolation of the specified implied volatilities at the given times or dates. The implied volatilities are assumed to be strike-independent. The times parameter is a list or Vector of times for which implied volatilities are available. In this case the value of the implied volatility at any time is assumed to be independent of the value of the underlying. The dates parameter must be a list of dates given in any of the formats recognized by the Finance[ParseDate] command. The volatilities parameter is a list or Vector of known volatilities.
The ImpliedVolatilitySurface(times, values, volatilities, opts) and ImpliedVolatilitySurface(dates, values, volatilities, opts) calling sequences create an implied-volatility term structure based on a piecewise interpolation of the specified implied volatilities at the given times or dates. The values parameter is a list or a Vector of values of the underlying process for which implied volatilities are available. In this case the volatilities parameter must be a Matrix. The number of rows of the volatilities matrix must be equal to the number of elements in the values vector. Columns of the volatilities matrix correspond to elements of times or dates. So, volatilityi,j is the implied volatility at timesj (or datesj) if the value of the underlying is valuesi.
The ImpliedVolatilitySurface(volatility, T, S, opts) calling sequence constructs an implied-volatility term structure based on the given volatility function. The parameter volatility is the implied volatility given as a function of time from reference and value of the underlying. It can be given either as a Maple procedure or as an algebraic expression. If volatility is given as a procedure it must accept two parameters (time and value of the underlying) and return the corresponding implied volatility as a floating-point number. Finally, if volatility is an algebraic expression, it must depend on two variables. In this case the parameters T and S will be used to determine which variable represents time and which variable represents the value of the underlying.
The ImpliedVolatilitySurface(riskfreerate, dividendyield, callprice, T, K, opts) calling sequence constructs an implied-volatility term structure implied by the available prices of European call options. The parameter riskfreerate is the instantaneous interest rate, which may be time-dependent. The parameter spot is the initial value of the underlying asset. The parameter callprice is the price of the European call option given as a function of time to maturity and strike price. This parameter can be given either as a procedure or as an algebraic expression. In the first case, callprice must accept two parameters: time to maturity and strike price and return the corresponding option price. In the second case, callprice must be an algebraic expression depending on at most two variables. The parameters T and K will specify which variable represents time to maturity and which variable represents the strike price.
The ImpliedVolatilitySurface(riskfreerate, dividendyield, spot, times, strikes, prices, opts) and ImpliedVolatilitySurface(riskfreerate, dividendyield, dates, strikes, prices, opts) calling sequences are similar to the above except that the price function will be determined based on an interpolation of known prices.
with⁡Finance:
r≔0.05
d≔0.01
σ≔0.3
First construct an implied volatility term structure based on:
C≔BlackScholesPrice⁡100,K,T,r,σ,d,call
C≔100.⁢ⅇ−0.01000000000⁢T⁢0.5000000000+0.5000000000⁢erf⁡14.14213562⁢ln⁡100.K+0.2912500000⁢TT−1.⁢ⅇ−0.3000000000⁢T⁢K⁢0.5000000000+0.5000000000⁢erf⁡14.14213562⁢ln⁡100.K+0.2912500000⁢TT−0.03535533905⁢T
LV≔ImpliedVolatilitySurface⁡r,d,C,T,K
LV ≔ moduleend module
LV⁡1.0,50
1.861242223×1041
LV⁡1.0,150
0.1088801580
The following example is based on a piecewise approximation of known implied volatilities.
V≔0.30,0.29,0.3|0.31,0.30,0.31|0.32,0.31,0.33|0.33,0.32,0.35
V≔0.300.310.320.330.290.300.310.320.30.310.330.35
T≔0.5,1.0,1.5,2.0
T≔0.51.01.52.0
S≔95,100,105
S≔95100105
LV2≔ImpliedVolatilitySurface⁡T,S,V,Bicubic,referencedate=Jun-7-2006
LV2 ≔ moduleend module
LV2⁡0.5,105
0.3000000000
LV2⁡0.5,100
0.2900000000
LV2⁡Jun-7-2007,105
0.3100000000
LV2⁡Jun-7-2007,110
0.3196873473
t≔YearFraction⁡Jun-7-2006,Jun-7-2017
t≔11.
LV2⁡t,110
0.3776241518
In this example you use bi-linear and bi-cubic interpolation of known prices.
T≔seq⁡0.1⁢i,i=1..20
K≔seq⁡90+i,i=1..20
A≔Matrix⁡seq⁡seq⁡BlackScholesPrice⁡100,Ki,Tj,r,σ,d,j=1..20,i=1..20,datatype=float8
LV2≔ImpliedVolatilitySurface⁡r,d,100,T,K,A,Bilinear
LV3≔ImpliedVolatilitySurface⁡r,d,100,T,K,A,Bicubic
LV3 ≔ moduleend module
LV2⁡1,100
0.6011620097
LV2⁡1,105
0.5527749264
LV2⁡1.5,100
0.7016426945
LV2⁡1.5,105
0.6658347722
LV3⁡1,100
LV3⁡1,105
LV3⁡1.5,100
LV3⁡1.5,105
In this example you plot implied volatility surface obtained using a piecewise interpolation of known prices.
P≔Matrix⁡7.20,7.60,8.60,10.0,2.85,3.52,5.00,6.30,0.50,1.10,2.25,3.50,0.05,0.25,0.85,1.85,0.05,0.10,0.35,0.85
P≔7.207.608.6010.02.853.525.006.300.501.102.253.500.050.250.851.850.050.100.350.85
T≔0.05,0.10,0.35,0.65
T≔0.050.100.350.65
K≔80.0,85.0,90.0,95.0,100.0
K≔80.085.090.095.0100.0
V≔Finance:-ImpliedVolatilitySurface⁡0.05,0.,87,T,K,P,Bicubic
V ≔ moduleend module
plot3d⁡V,0.05..0.65,80..100,orientation=−145,75,axes=BOXED
Brigo, D., Mercurio, F., Interest Rate Models: Theory and Practice, Springer Verlag, 2001.
Gatheral, J., The Volatility Surface: A Practitioner's Guide, (with foreword by Nassim Taleb), Wiley, 2006.
Hull, J., Options, Futures, and Other Derivatives, 5th. edition, Prentice Hall, 2003.
The Finance[ImpliedVolatilitySurface] command was introduced in Maple 15.
For more information on Maple 15 changes, see Updates in Maple 15.
See Also
Finance[BlackScholesProcess]
Finance[DiscountCurve]
Finance[ForwardCurve]
Finance[ForwardRate]
Finance[MertonJumpDiffusion]
Finance[ParRate]
Finance[ZeroCurve]
Download Help Document