An Introduction To Financial Mathematics With Matlab: Research Reports Mdh/Ima Issn 1404-4978
An Introduction To Financial Mathematics With Matlab: Research Reports Mdh/Ima Issn 1404-4978
____________________________________________ Research Report 2001-4 Department of Mathematics and Physics Mlardalen University SE-721 23 Vsters, Sweden ____________________________________________
Abstract We describe a complex of programs called IFM, which will be used in the course Introduction to nancial mathematics for students of the rst year of a new Master educational program Analytical nance at the M alardalen University.
Contents
1 2 Introduction Elementary probability theory 2.1 Getting started . . . . . . . . 2.2 A model of price evolution . 2.3 Central Limit Theorem . . . 2.4 Geometric Brownian Motion 2 3 3 4 8 11 13 13 16 16 23 23 27 27 32 32 37 39 40 40 42 43 44 47
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
Elementary nancial calculations 3.1 Interest rates . . . . . . . . . . . 3.1.1 Problems . . . . . . . . 3.2 Present value analysis . . . . . . 3.2.1 Problems . . . . . . . . 3.3 Rate of return . . . . . . . . . . 3.3.1 Problems . . . . . . . . 3.4 Pricing via arbitrage . . . . . . . 3.4.1 Problems . . . . . . . . 3.5 The multi-period binomial model 3.5.1 Problems . . . . . . . . 3.6 The BlackScholes formula . . . 3.6.1 Problems . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
. . . . . . . . . . . .
A Overcoming limitations A.1 The program present value A.2 The program ror . . . . . . . A.3 The program mbm . . . . . . . A.3.1 Problems . . . . . . .
. . . .
. . . . 1
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
1 Introduction
The new Master education program Analytical Finance was introduced at the M alardalen University in August, 2001. It gives students a general base in Mathematics, Business Administration, Economics and Computer Science. Advanced nancial software is planned to be used in the teaching. The course Introduction to Financial Mathematics is included in the program. It contains the elementary introduction to the theory of options pricing. All the necessary preliminary material including elementary probability, normal random variables and the geometric Brownian motion model is presented. The BlackScholes theory of options as well as such general topics in nance as the time value of money and rate of return of an investment cash-ow sequence are part of the course. This material is covered in the rst seven chapters of [4]. In order to support the course, the authors wrote a complex of MATLAB programs called IFM, which stands for Introduction to Financial Mathematics. Why we choose MATLAB as a tool for the development of the complex IFM?  MATLAB integrates mathematical computing, visualisation, and a powerful, but simple language.  Open architecture. The user can easy manage MATLAB system: to add and remove MATLAB routines, both written by MATLAB team or by the user him (or her-)self.  Graphical User Interface. This is a user interface built with graphical objects, such as buttons, text elds, sliders, and menus. In general, these objects already have meanings to most computer users. Applications that provide a Graphical User Interface are generally easier to learn and use since the person using the application does not need to know what commands are available or how they work.  Mobility of the source code (Windows, Unix, Linux). The source code of MATLAB programs designed using IBM-compatible PC under MS Windows, will work in the same way on the Sun workstation under Unix or Linux.  Special nancial toolboxes. The toolbox is a set of MATLAB routines competed together. The Financial, Financial Derivatives, and Financial Time Series toolboxes contain a wide variety of computational and graphical tools for nancial engineering.  Simple interface to MAPLE  . MAPLE V, a symbolic computational language, can manipulate, solve, and evaluate mathematical expressions, both symbolically and numerically. MATLAB allows easy access to a kernel of MAPLE for symbolic computation (see, for example, [3]). We plan to use such an interface in other courses of the program Analytical Finance. In this report we describe the complex. In Section 2, we rst describe, how to start and quit MATLAB, and how to execute any program of the complex. Then we describe the programs for calculations in elementary probability theory. These calculations include a log-normal model of price evolution, an illustration of the central limit theorem and the simulation of the geometric Brownian motion. 2
In Section 3, the programs for elementary nancial calculations are described. These include interest rates, present value analysis, rate of return, pricing the simplest options via arbitrage, multi-period binomial model, and the BlackScholes formula. Some programs of the complex contain limitations. For example, it is impossible to calculate the multi-period binomial model with more than 5 periods. One can overcome these limitations using the MATLAB Command Window directly. In Appendix A, we give the examples along with some description of the simplest MATLAB commands. Some parts of the text need careful reading. Such places are emphasised by the special sign on the margins. You can see this sign here. This complex is free software. To obtain IFM, contact Professor Dmitrii Silvestrov, Department of Mathematics and Physics, M alardalen University, SE-72 123 V asters, Sweden. E-mail: dmitrii.silvestrov@mdh.se. MATLAB is a registered trademark of The MathWorks, Inc. Other product or brand names are trademarks or registered trademarks of their respective holders. The authors would like to thank Henrik J onsson for careful reading of the manuscript and useful discussions.
Figure 1: The MATLAB desktop You can start any of the programs of the complex IFM, using one of the next two methods. 1. Type ifm at the MATLAB prompt in the Command Window and press Enter. The dialog of the program ifm will appear (Fig. 2). Choose a program from the list of available programs and press Start button. The dialog window of the corresponding program will appear. 2. Type the name of the program at the MATLAB prompt in the Command Window and press Enter. The names of all programs are listed in Table 1. The programs present value, ror, mbm and black scholes require MATLAB Financial toolbox. All the other programs require only standard MATLAB installation. Remark 1. A string The list of all available programs on Fig. 2 is called a tooltip string. Such a string appears when you put the mouse cursor over a user interface control. It gives the user a tip describing the corresponding control.
Name ifm price evolution clt gbm interest rate present value ror options pricing mbm black scholes
Description Control centre A model of price evolution An illustration of the Central limit theorem Geometric Brownian motion Interest rates Present value analysis Rate of return Pricing via arbitrage Multiperiod binomial model BlackScholes formula Table 1: Programs in the complex
Example 2.3d] assumes that the price ratios S (n)/S (n 1) are independent and identically distributed lognormal random variables. Recall that the random variable Y is called a lognormal random variable with parameters and [4, p. 26] if log(Y ) is a normal random variable with mean and variance 2 . The pricing process under consideration can be simulated with the help of the program price evolution (Fig. 3). The program price evolution requires only standard MATLAB installation (no additional toolboxes are used).
Figure 3: A window of the program price evolution The dialog window of the program price evolution contains the user interface controls. The user interacts with the program, using these controls. In the upper left corner of the dialog you can see a frame that encloses a group of edit boxes. Consider the functions of these boxes. Starting price. Here you can enter the value of parameter S (0), i.e. the initial price of the security. Mean value. Here you can enter the value of parameter , i.e. the mean of the logarithm of the random variable Y . Standard deviation. Here you can enter the value of parameter , i.e. the standard deviation of the logarithm of the random variable Y . 6
Number of weeks. Here you can enter the length of the time interval of simulation of the evolution of the price, measured in weeks. Remark 2. Some edit boxes in the programs of the complex have default values. In simple cases, you can start calculations without changing these values. We will refer to this feature as solution of the standard problem. Fig. 3 shows that the standard problem has the following values: starting price is equal to 100 (say, Swedish krones), mean value is equal to 0.0165, standard deviation is equal to 0.073, and we want to simulate price evolution during 10 weeks. Remark 3. Some edit boxes have prevention to non-correct input. For example, somebody tried to enter a negative value of the starting price into the corresponding edit box. The result is shown on Fig. 4. A warning message was produced, and the program returned the previous value into the edit box instead of the wrong value. In such cases, you must press the OK button in order to continue your work.
Figure 4: An example of incorrect input Under the frame you can see two push buttons. The functions of these buttons are: Graph. A graph of the pricing process will be produced after pressing this button (Fig. 5). Exit. Exits the program. 7
Figure 5: An output of the program price evolution As you can see from Fig. 5, the graph of the pricing process is drawn in a separate window. You can press the push button Graph several times and obtain several dierent graphs. Every graph is a stand-alone application, which occupies a separate place on the Windows taskbar and lives its own life. You can play with the menu system of any graph.
Sn =
k=1
Xn
(1)
Consider the following example. Let X1 be a Bernoulli random variable, i.e., X1 = 1 with probability p and X1 = 0 with probability 1 p. In this case we have ([4, Examples 1.3c and 1.3f]): E X1 = p , Var X1 = p(1 p). According to the central limit theorem, a random variable Yn = S n np np(1 p) (2)
is approximately a standard normal random variable. Here S n is dened by (1). This example is illustrated by the program clt (Fig. 6).
Figure 6: A window of the program clt The program clt requires only standard MATLAB installation (no additional toolboxes are used). Two edit boxes are situated in the left upper corner of the dialog. Their functions are: n. Here you can enter the number of independent Bernoulli random variables in the sum S n . The standard problem has the value n = 100. p. Here you can enter the parameter of each of the independent Bernoulli random variables. The standard problem has the value p = 0.5. 9
Onto the right of the edit boxes you can see two push buttons. They have the following functions: Generate. A gure containing two graphs and their legend (Fig. 7) is produced. The solid line is the graph of the probability density of a normal distribution with parameters = np and 2 = np(1 p). The dashed line is the graph of the distribution of the random variable S n . It is drawn in the following way. We generate many (say, N ) realisations of the random variable S n . Let k0 be the number of realisations taking the value 0, let k1 be the number of realisations taking the value 1, and so on up to kn . We draw a dashed line through the points with coordinates 0, Exit. Stops the program. k0 , N 1, k1 ,..., N n, kn . N
Figure 7: An output of the program clt You can press the push button Generate several times using the same values of the variables n and p. The solid line on the graph will not change. The dashed line will be subject to small changes, because it is random. 10
is independent of all random variables S (z), 0 z < y, and the logarithm of the random variable (3) is a normal random variable with mean t and variance t2 [4, p. 32]. Geometric Brownian motion is a popular model of price evolution in continuous time (in contrast to a discrete time model from Section 2.2). Suppose we want to build a computer model of the geometric Brownian motion. A computer can simulate values of any function only at some discrete set of points, say, n, where 0 n N , N is some number and denotes a small increment of time. In order to simulate values S (n), 0 n N , we can use a simpler model proposed in [4, p. 3335]. The value S (0) is some non-random number which is known, because it denotes the initial price of a security. Now let Yn , 1 n N be the sequence of independent Bernoulli random variables with parameter p= 1 . 1+ 2
Our model can be calculated as , if the price goes up (Yn = 1), S ( n 1) e S (n) = S (n 1)e , if the price goes down (Yn = 0).
(4)
As tends to 0, the model (4) tends to geometric Brownian motion. A rigourous proof of this fact is very complicated. A simplied proof can be found in [4, p. 3335]. Remark 4. On page 32 and subsequent pages of [4] the author denotes the initial price by two dierent symbols, namely, by S (0) and s0 . We prefer to use only the rst one. The model (4) is realised in the program gbm (Fig. 8). The program gbm requires only standard MATLAB installation (no additional toolboxes are used). Consider the functions of the edit boxes of the program gbm. Initial price. Here you can enter the value of the parameter S (0), i.e., the initial price of a security. The standard problem has the value S = 100. Drift. Here you can enter the value of the parameter , i.e., the drift parameter of the geometric Brownian motion under simulation. The standard problem has the value = 0.01. Volatility. Here you can enter the value of the parameter , i.e., the volatility parameter of the geometric Brownian motion under consideration. The standard problem has the value = 0.2. 11
Figure 8: A window of the program gbm Delta. Here you can enter the value of the time increment . The standard problem has the value = 0.05. You can also change the value of the time increment using the slider on the left hand side of the Delta edit box. You can move the sliders bar by pressing the mouse button and dragging the slide, by clicking on the trough, or by clicking an arrow. The minimum slider (and edit box) value is equal to 0.01, the maximum slider and edit box value is equal to 0.1.
The functions of two push buttons in the lower left part of the dialog are:
Generate. Generates a graph of the model (4). See Fig. 9. Exit. Stops the program.
You can press the push button Generate several times without changing model parameters. Every time you will obtain a graph of a new realisation of the random sequence (4). 12
larger and larger. In this case the amount owed at the end of the year is P lim (1 + r/n)n = Per .
n
Similarly, if the principal P is borrowed for t years at a nominal interest rate of r per year compounded continuously, then the amount owed at time t is P lim (1 + rt/n)n = Pert .
n
The program interest rate (Fig. 10) calculates dierent compound interests and shows the corresponding graphs.
Figure 10: A window of the program interest rate The program interest rate requires only standard MATLAB installation (no additional toolboxes are used). Consider the functions of the two edit boxes in the upper left corner of the dialog. Principal. The amount of money which is borrowed. The standard problem has the value P = 10000. Nominal interest rate. The simple interest per year. The standard problem has the value r = 0.05, which corresponds to 5%, Here, as well as in all other programs of 14
the complex, you must enter percent values. The corresponding numerical value of r is calculated by the program itself. You can also change the value of the interest using the slider on the right hand side of the Nominal interest rate edit box. The minimum slider (and edit box) value is equal to 0%, the maximum slider and edit box value is equal to 10%. Seven checkboxes are situated below the edit boxes. The checked state of any box means that the corresponding compound interest will be calculated. Consider these checkboxes in more details. Annual. Corresponds to the value n = 1, i.e. the simple interest. The interest is compound annually. The standard problem calculates this kind of interest. Semi-annual. Corresponds to the value n = 2. The interest is compound every 6 months. The standard problem does not calculate this kind of interest. Tri-annual. Corresponds to the value n = 3. The interest is compound every 4 months. The standard problem does not calculate this kind of interest. Quarterly. Corresponds to the value n = 4. The interest is compound every 3 months. The standard problem does not calculate this kind of interest. Bi-monthly. Corresponds to the value n = 6. The interest is compound every 2 months. The standard problem does not calculate this kind of interest. Monthly. Corresponds to the value n = 12. The interest is compound every month. The standard problem does not calculate this kind of interest. Continuously. Corresponds to the limit, when n growths larger and larger. The interest is compound continuously. The standard problem does not calculate this kind of interest. A list box under the checkboxes contains ve elements. It determines the borrowing time (in years) and can take values 1, 2, 3, 4 or 5 years. You can choose any of these terms from the list. The standard problem has value t = 5 years. The functions of the two push buttons in the lower left part of the dialog are: Generate. Generates a graph of the repay. See Fig. 11. If no checkboxes are checked, an error message is generated instead. Exit. Stops the program. The graph (Fig. 11) shows the time dependence of dierent compound schemes chosen by the user. A legend explains which line corresponds to which scheme, and shows the corresponding eective interest rate. 15
Figure 11: An output of the program interest rate 3.1.1 Problems Problem 1. What is the eective annual rate if a rate of 8 percent per year is compounded a) semi-annually? b) tri-annually? c) quarterly? d) bi-monthly? e) monthly? f) continuously?
The monthly interest rate is equal to 0.06/12 = 0.005. You can pay 201 = 200 1 + 0.005 dollars today. On December 1 you will have 200 (1 + 0.005) = 201 dollars on your account exactly as you need. We say that $200 is the present value of your payment of $201 one month later from today. In this case it means, that you can pay $200 today or $201 one month later the results will be the same. In other words, the cash ows from Table 2 are equal. Cash ow 1 Cash ow 2 Date Payment Date Payment November 1 -200 December 1 -201 Table 2: Two equal simple cash ows Consider more complicated example. You obtain $200 monthly into a saving account earning 6%. The payments are made at the end of the month for ve years. What is the present worth of these payments? The monthly interest rate is equal to 0.06/12 = 0.005. Assume for simplicity that you will obtain $200 only once one month later. It means, that today you can obtain an amount of 200 199.00 1 + 0.005 dollars and one month later you will have an amount of $200. Therefore the present value of this payment is equal to $199.00 Assume now that you will obtain $200 one month later and $200 two months later. The present value of the rst payment is still equal to $199.00 and the present value of the second payment is equal to 200 198.01 (1 + 0.005)2 dollars. Indeed, today you can obtain an amount of $198.01 and two months later you will have an amount of 198.01 (1 + 0.005)2 = 200. The present value of both payments is equal to 199.0 + 198.01 397.01 dollars. As a result we obtain that the present value of our payment is equal to 200 (1 + 0.005)1 + 200 (1 + 0.005)2 + + 200 (1 + 0.005)60 10345.11. In other words, the two cash ows from Table 3 are equal. 17
Cash ow 1 Cash ow 2 Date Payment Date Payment Today 10345.11 Today + 1 month 200 Today + 2 months 200 ... ... Today + 60 months 200 Table 3: Two equal more complicated cash ows Present value enables us to compare dierent cash ows to see which is preferable. In our case the cash ow consists of equal payments which are payed periodically. We will call such a ow a xed cash ow. In our rst example the cash ow contains only negative values, i.e., you should pay money. In the second example the cash ow contains only positive values, i.e., you receive money. More complicated cash ows can contain both positive and negative values, i.e., you both pay and receive money. Consider another example. A cash ow (Table 4) represents the yearly income from an iniYear 1 $2000 tial investment of $10,000. The annual interest rate is 8%. How to Year 2 $1500 Year 3 $3000 calculate the present value of this varying cash ow? Let x j , 0  j  5 be the sequence of payments ( x0 = 10, 000 is Year 4 $3800 Year 5 $5000 the initial investment). The present value is: Table 4: Varying periodic cash ow
5
(1 + r) j x j  1715.39,
j=0
where r denotes the annual interest rate. The present value can be calculated with the help of the program present value (Fig. 12). The program present value requires Financial toolbox. An edit box Annual interest rate in the upper part of the dialog contains the value of the simple interest per year. The standard problem has the value r = 0.05, which corresponds to 5%, You can also change the value of the interest using a slider on the left hand side of the Annual interest rate edit box. The minimum slider (and edit box) value is equal to 0%, the maximum slider and edit box value is equal to 10%. Just below these elements you can see two frames that enclose two groups of related controls. Consider the rst group on the left side of the dialog. The controls of this group are related to the xed cash ow. First consider the functions of the three edit boxes in the upper part of the frame. Number of months. For simplicity, in the case of a xed cash ow our program calculates only cash ows having a period equal to one month. In this edit box, you can enter the number of one-month periods. The standard problem has this value equal to 60. Month payment. Here you can enter the amount of money which you plan to pay or obtain monthly. The standard problem has this value equal to 200. 18
Figure 12: A window of the program present value Extra payment. Some nancial institutions propose an extra payment received in the last period. You can enter the value of such a payment in this edit box. The standard problem has this value equal to 0. Just below the above described edit boxes, you can see a group of two related radio buttons. In contrast to checkboxes, only one radio button can be in a selected state at any given time. To activate a radio button, click a mouse button on the object. Sometimes payment can be payed in the beginning of a period instead of at the end. In this case you can activate the Beginning of month radio button. In the standard problem, the radio button End of month is active. The push button Calculate below is intended for calculation of the present value in the case of xed periodic payments, or xed cash ow. Press it after entering all data of your problem. The result will appear in the edit box Present value (Fig. 13). In contrast to the above described edit boxes, this edit box is disabled. The digits inside it are in gray colour. You can not change the value inside, only the program can do this. Consider, how the program present value solves the example from Table 4 (see Fig. 14). In this case you should use controls inside the right frame. The edit box Initial investment contains the value of an initial investment. In the standard problem, this value 19
Figure 13: An output of the program present value, case of xed periodic payments is equal to 10000. The group of two related radio buttons below determines one of two dierent types of a varying cash ow. In our case the cash ow is varying, but periodic. For simplicity, the program calculates only one-year periodic cash ows. Therefore the radio button Periodic is active. In our next example we will calculate the present value of a non-periodic cash ow. The radio button Non-periodic will be active. The group of six edit boxes under the endorsement Cash ow should contain the values of the initial investment and payments. The value of the initial investment is multiplied by 1 and automatically copied from the Initial investment edit box to the rst edit box of the group. This edit box is disabled. The other ve edit boxes are enabled. By default they contain zero values. You should ll one or more of these edit boxes by values of payments, otherwise an error message is generated. The push button Calculate is intended for calculation of the present value of the varying cash ow. After entering data of our example you can press this button. The answer will appear in the disabled edit box Present value inside the right frame (Fig. 14). Consider an example of a varying non-periodic cash ow. An investment of $10,000 returns an irregular cash ow (Table 5). The annual interest rate is 9%. Calculate the present value of this cash ow. In addition to previous notation, let t j denotes the time of payments in years. Then the 20
Figure 14: An output of the program present value, case of varying periodic payments
Dates January 12, 1987 February 14, 1988 March 3, 1988 June 14, 1988 December 1, 1988
21
present value is
5
(1 + r)(t j t0 ) x j  142.16.
j=0
In this case, you should work more harder to calculate this expression by hand. Consider, how the program present value solves this example ( see Fig. 15).
Figure 15: An output of the program present value, case of varying non-periodic payments As in the previous example, the edit box Initial investment contains the value of an initial investment. But now the radio button Periodic is not active. The radio button Non-periodic is active instead. The group of six edit boxes Cash ow still contains values of the cash ow under consideration. Another group of six edit boxes, Dates, becomes enabled. You must enter dates of the initial investment and the values of all payments in these edit boxes. Remark 5. Unfortunately, MATLAB follows the American convention for the format of dates. The string 12/01/1988 means December 1, not January 12! Remark 6. Be careful when enter dates. The corresponding edit boxes do not control its input. Finally, the push button Exit stops the program. 22
Remark 7. The program present value has a limitation. You can not calculate the present value of a cash ow with 6 or more payments. For calculation with such ows you can use MATLAB Command Window directly. See Section A.1. 3.2.1 Problems Problem 2. $150 is paid monthly into a saving account earning 4%. The payments are made at the end of the month for ten years. What is the present value of these payments? Problem 3. $250 is paid monthly into a saving account earning 5%. The payments are made at the beginning of the month for seven years. What is the present worth of these payments? Problem 4. A cash ow (Table 6) represents the yearly income from an initial investment of $4,400. The annual interest rate is 6%. Calculate the present value of this cash ow. Problem 5. An investment of $10,000 returns an irregular cash ow (Table 7). The annual interest rate is 9%. Calculate the present value of this cash ow. Dates Initial Year 1 Year 2 Year 3 Year 4 Year 5 Cash ow -$4,400 $800 $800 $1800 $800 $1400 Cash ow -$10,000 $800 $800 $1800 $800 $1400 Dates January 1, 2002 March 10, 2003 April 14, 2004 June 26, 2005 August 31, 2006 November 15, 2007
Table 8: The yearly income from an initial investment of $100,000 Consider the next example. Some nancial organisation proposed you to make an initial investment of $100,000. They promised that you will obtain the sequence of yearly incomes shown in Table 8. Another nancial organisation proposed you to put the same amount to the bank and to obtain the yearly interest rate r. What proposition is better? 23
To solve this problem, we must calculate the present value of the cash ow dened by an initial investment of $100,000, the incomes in Table 8 and the yearly interest rate r. Three possibilities can happen: 1. The present value is less than zero. 2. The present value is equal to zero. 3. The present value is greater than zero. In the rst case the initial investment exceeds the total of the amounts received. Therefore we loose money under the conditions of the rst proposition, and the second proposition is better. In the third case the total of the amounts received exceeds the initial investment. Therefore we obtain a gain under the conditions of the rst proposition, and the rst proposition is better. In the second case, however, the propositions are equivalent. The rate of return of the investment can be dened as the interest rate r that makes the present value of the cash ow dened by an initial investment and the payments equal to zero. Remark 8. It is easy to see that this denition is the same as a denition in [4, p. 51]. We prefer this kind of denition, because in MATLAB the value of an initial investment, multiplied by 1, should be the rst element of the vector representing the cash ow. Let b0 , b1 , . . . , bn denote the periodic cash ow sequence, in which b0 < 0 denotes the initial investment. If the interest rate per one period is equal to r, then the present value of this cash ow is equal to
n
P(r) =
j=0
b j (1 + r) j .
By denition, the rate of return per period of the investment is that value r > 1, for which (5) P(r ) = 0. In our case n = 5, and the rate of return should be determined numerically. Consider, how the program ror (Fig. 16) solves this problem. The program ror requires Financial toolbox. The two radio buttons in the upper part of the dialogue determine the type of cash ow under consideration. If the radio button Yearly cash ow is active, then we consider (for simplicity) a cash ow having the period equal to one year. If the radio button Nonperiodic cash ow is active, then the cash ow is irregular. The group of six edit boxes under the radio button Yearly cash ow should contain the values of the initial investment and payments. The rst edit box should contain the value of the initial investment, multiplied by 1. By default, the other ve edit boxes contain zero values. You should ll one or more of these edit boxes by values of payments, otherwise an error message is generated. The push button Calculate in the lower left corner calculates the rate of return. Press it after you have entered the values of the initial investment and payments. The result will 24
Figure 16: A window of the program ror appear in the disabled edit box Rate of return. In our case we entered the value of an initial investment, the values of payments from Table 8 and obtained the result (Fig. 17). r 0, 1201 (12.01%). You can quit the program ror by pressing the push button Exit in the lower right corner of the dialog. Consider a more complicated example. An investment of $10,000 returns non-periodic cash ow shown in Table 9. Calculate the rate of return for this non-periodic cash ow. Cash ow -$10000 $2500 $2000 $3000 $4000 Dates January 12, 2000 February 14, 2001 March 3, 2001 June 14, 2001 December 1, 2001
b0 b1 b2 b3 b4
Figure 17: An output of the program ror, case of periodic payments Let t0 denotes the date of the initial investment (measured in years A.D.). For example, 12 in our case t0 = 1999 + 366  1999.0328. Denote by t j , 1  j  4 the dates of payments. Let b0 denotes the initial investment, multiplied by 1, and b j , 1  j  4 denote payments. Then the rate of return r should be equal to the root of the equation
4
b j (1 + r)(t j t0 ) = 0.
j=0
This equation is much more complicated than the equation (5). Consider its solving with the help of the program ror (Fig. 18). First, we activate the radio button Non-periodic cash ow. Second, we enter the value of an initial investment, multiplied by 1, into the rst edit box of the left column. Third, we entered values of payments into next edit boxes of the left column. Now, the edit boxes of the right column are enabled (in the previous example they were disabled). We entered dates of the initial investment and payments into the edit boxes of the right column. After pressing the push button Calculate, we obtained the result r 0.1009 (10.09%). Remark 9. The program ror has a limitation. You can not calculate the present value of a cash ow with 6 or more payments. For calculation with such ows you can use MATLAB Command Window directly. See Section A.2. 26
Figure 18: An output of the program ror, case of non-periodic payments 3.3.1 Problems Problem 6. The initial investment of $4,400 returns the yearly cash ow shown in Table 6. You can both borrow and save money at the yearly interest rate of 6%. Is this a worthwhile investment for you? Problem 7. The initial investment of $10,000 returns the irregular cash ow shown in Table 7. You can both borrow and save money at the yearly interest rate of 7%. Is this a worthwhile investment for you?
price of the security to be as above. At the present time, it is not known which state will be realised after one time period. It is known only that one (and only one) of these states will occur. There is no assumption made about the probability of each states occurrence, except that each state has a positive probability of occurrence. In this model, the states capture the uncertainty about the price of the security after one time period.
:u 200         u   X XXX XXX XX XXX XX XXX zu
100
50
t=0
t=1
Figure 19: Possible security prices at time 1 For any y, at a cost of cy you can purchase at time 0 the y call options to buy y shares of the stock at time 1 for the price of $150 per share. In addition, you can purchase x shares of the security at time 0. For what values of c exists an arbitrage possibility? Recall that an arbitrage is a sure-win betting scheme [4, p. 63]. The vector ( x, y) is called a portfolio. In our case the portfolio consists of the security and the options. Step 1. We choose y so that the value of our portfolio at time 1 does not depend on the state of nature. In the rst state of nature, when the price of security at time 1 is $200 per share, the x shares of the security are worth 200 x and the y units of options to buy the security at a share price of $150 are worth (200 150)y = 50y. Therefore the value of our portfolio at time 1 is equal to 200 x + 50y. On the other hand, in the second state of nature, when the price of security at time 1 is $50 per share, then the x shares are worth 50 x and the y units of options are worthless. Therefore the value of our portfolio at time 1 is equal to 50 x. That is, we choose y so that 200 x + 50y = 50 x, or y = 3 x,
and the value of our portfolio at time 1 is equal to 50 x no matter what is the state of nature. Step 2. At time 0 we purchase x units of security and 3 x units of options. The cost of this transaction is 100 x + cy = (100 3c) x. If the cost of the transaction is positive, i.e., (100 3c) x > 0, then it should be borrowed from a bank, to be repaid with interest r at time 1. Therefore our gain is equal to gain = 50 x (100 3c) x(1 + r) = (1 + r) x[3c 100 + 50(1 + r)1 ]. 28 (6)
On the other hand, if the cost of transaction is negative, then the amount received, (100 3c) x, should be put in the bank to be withdrawn at time 1. Therefore our gain is determined by (6) no matter of the sign of transaction. Thus, if 3c = 100 50(1 + r)1 , then the gain is zero. Otherwise we can guarantee a free lunch (no matter what the price of the security at time 1). Indeed, suppose that r = 0, 05 or 5%. Consider two cases. Case 1. 3c < 100 50(1 + r)1 , for example, c = 15. The option is too cheap. At time 0 we sell in short one share of the security ( x = 1) and obtain $100. Selling in short means that we sell a security that we do not own. We buy 3 options (y = 3) at a cost of $45 and put the amount $55 in the bank. At time 1 we withdraw the amount 55(1 + r) = $57.75 from the bank. In the rst state of nature the stocks price is $200. We exercise our options, buy 3 shares of the security at a cost of $450, return one share which we borrowed at time 0 and sell 2 shares at a cost of $400. Our gain is 57.75 50 = $7.75 and we go to have our free lunch. In the second state of nature the stocks price is $50. We do not exercise our options. Instead we buy 1 share of the security and return it to the owner. Our gain is 57.75 50 = $7.75 and we go to have our free lunch. Case 2. 3c > 100 50(1 + r)1 , for example, c = 20. The option is too expensive. At time 0 we borrow from a bank $40. We sell in short 3 options at a cost of $60 (y = 3) and buy 1 share of the security ( x = 1). In the rst state of nature the stocks price is $200. The options owner realises the options. We are obliged to buy 3 shares at a cost of $600 and sell them to the options owner at a cost of 450. Then we sell our share at a cost of $200. The amount earned is $50, but we have to return the loan 40 (1 + 0.05) = $42 to the bank. Our gain is 50 42=$8 and we go to have our free lunch. In the second state of nature the stocks price is $50. The options owner does not realise the options. We sell our share for $50, return the loan of $42 and go to have our free lunch. The model under consideration contains one time period and only two possible outcomes. Therefore sometimes it is called a one-period binomial model. The program options pricing performs these calculations (Fig. 20). The program options pricing requires only standard MATLAB installation (no additional toolboxes are used). The window of the program options pricing can be considered as consisting of the left and right hand sides. The left hand side called Problem contains user interface controls for formulation of the problem. The solution of the problem appears in the user interface controls on the right hand side of the window called Solution. Consider the user interface controls on the left hand side rst. The slider and edit box Period interest rate in the upper left corner contain value of the interest rate per period under consideration. Standard problem has a value r = 0.05, which corresponds to 5%. The minimum slider (and edit box) value is equal to 0%, the maximum slider and edit box value is equal to 10%. The frame under the above described group contains three edit boxes. Now. This edit box contains the initial price of one share of the security. The standard problem has this value equal to 100. 29
Figure 20: The window of the program options pricing After one period. Two edit boxes under this caption contain possible values of the price of one share of the security one time period later. The standard problem has values 200 and 50. The next frame contains two edit boxes. Strike price. This edit box contains value of the strike price of the option. The standard problem has this value equal to 150. Option cost. This edit box contains the price of the option. The standard problem has this value equal to 20. The push button Calculate calculates the arbitrage possibility. Consider the results of solution of the standard problem in the right hand side of the program window (Fig. 21). Four disabled edit boxes are in the right hand side of the program window. Stock . . . units. The edit box enclosed by these captions contains the number of stocks in our portfolio. In the case of too expensive option it always contains the value 1. Of course, the player can always multiply all values in the edit boxes on the right hand side of the window by any positive number. 30
Figure 21: An output of the program options pricing, case of too expensive option Option . . . units. The edit box enclosed by these captions contains the number of options in our portfolio. In our example, this value is negative. It means, that we should sell options in short. Free lunch. This edit box contains the value of our gain. No-arbitrage price. This edit box contains the value of the only option cost that does not result in an arbitrage. This price is called no-arbitrage or risk-neutral price. Pricing of an option means the calculation of its no-arbitrage or risk-neutral price. Finally, the push button Exit stops the program. Consider the case of a too cheap option (Fig. 22). We changed the value in the edit box Option cost only. In this case the rst edit box always contains the value 1, It means that the player should sell one share of the security in short. The second edit box contains the value 3, i.e., we buy three options. The value of our gain and the non-arbitrage price of the option are contained in the third and fourth edit box respectively. We can check how the program works in the following way. Substitute the value of the no-arbitrage price into the edit box Option cost (Fig. 23). The st two edit boxes do not contain any values. It means that no portfolio can bring a positive gain. The edit box 31
Figure 22: An output of the program options pricing, case of too cheap option Free lunch contains the word No. As in all the previous cases, the edit box No-arbitrage price contains the corresponding value. 3.4.1 Problems Problem 8. The nominal interest rate per time period is r. The present price of the security is P0 dollars per share. After one time period it will be either P1 or P2 dollars per share. At a cost of c dollars you can purchase at time 0 the call option to buy one share of the stock at time 1 for the price of S dollars per share. Describe the sure-win betting scheme for the cases from Table 10. Find the noarbitrage price of the call option for every case.
Figure 23: An output of the program options pricing, case of no-arbitrage price
r 5 3 1 4 9 2 6 8
P1 50 90 92 108 20 60 75 60
c 9 9 4 7 8 5 21 26
33
option into n = 5 equal periods of length t/n. Suppose that the price of a security can change only at the times tk = kt/n, k = 1, 2, . . . , n and that the option can be exercised only at one of the times tk . Moreover, suppose that the security price S (k + 1) at k + 1 time periods later is either uS (k) or dS (k). How to nd the risk-neutral price of this option? Recall that American option can be exercised at any time up to expiration time, whereas European option can be exercised only at the expiration time. In contrast to the one-period binomial model described in Section 3.4, the model under consideration is called a multi-period binomial model. We want the above described process to approximate the geometrical Brownian motion when n grows. According to (4) that happens if u = e According to [4, p. 92] 1 + rt/n  d , ud u  1  rt/n P{S (k + 1) = dS (k)} = 1  p = . ud
P{S (k + 1) = uS (k)} = p =
 t/n
d = e
t/n
(7)
(8)
According to [4, formulae (7.11) and (7.12)], the possible values of the price of the put option at time tn is equal to Vn ( j) = max{K u j d n j S (0), 0}, (9)
if j of the rst n price movements were increases and n j were decreases. The possible values of the price of the put option at time tk , k = n 1, n 2, . . . , 0 are calculated as Vk ( j) = max{K u j d k j S (0), pVk+1 ( j + 1) + (1 p)Vk+1 ( j)}, (10)
if there were j = 0, . . . , k increases and k j decreases. The rst term in gure brackets of (10) denotes the return if we exercise the option in moment tk at node j. The second term denotes the return if we do not exercise the option in moment tk at node j. denotes the discount factor per period. According to [4, p. 94] it is equal to = ert/n . Using these formulae, we obtain V0 (0) 4.488. Calculations by hand using these formulae can be computationally messy. Consider how the MATLAB program mbm (Fig. 24) solves this problem. The program mbm requires Financial toolbox. The frame in the upper part of the window of the program mbm contains two sliders, ve edit boxes and a pair of mutually exclusive radio buttons. Consider the functions of these controls. Price. This edit box contains the value of the initial price of the stock, S (0). The standard problem has the value S (0) = 50. 34 (11)
Figure 24: A window of the program mbm Strike. This edit box contains the value of the strike price of the security, K . The standard problem has the value K = 50. Interest. This edit box and the slider over it are responsible for the value of the annual risk-free interest rate, r. The standard problem has the value r = 0.05, which corresponds to 5%. The minimum slider (and edit box) value is equal to 0%, the maximum slider and edit box value is equal to 10%. Volatility This edit box and the slider over it are responsible for the value of the annualised volatility, . The standard problem has the value = 0.5, which corresponds to 50%. The minimum slider (and edit box) value is equal to 0%, the maximum slider and edit box value is equal to 100%. Time. This edit box contains the value of the length of life of the option, t, measured in years. The standard problem has the value t = 0.25 or 3 months. The mutually exclusive radio buttons Call and Put dene the type of the option. The standard problem considers a call option. The list box Periods just under the frame contains ve elements. This control determines the value of n. In our model, the possible values are 1 n 5. The standard problem has the value n = 5. 35
The push buttons perform the next functions. Calculate. Calculates the price of the option, using formulae (7)(10). Exit. Stops the program. The result of calculations is shown on Fig. 25. The group of 42 disabled edit boxes lls the triangle shape and represents the binomial tree. This tree has 21 nodes. Every node consists of two edit boxes.
Figure 25: An output of the program mbm, case of put option The upper edit boxes of the kth column (k = 0, 1, . . . , n) shows all the possible values of the price of the security at time tk . The price of the security at the jth node ( j = 0, 1, . . . , k) is calculates as S (0)u j d k j . The nodes are counted from the bottom to the top. The lower edit boxes show the time-tk expected return of the put, given that the put has not been exercised before time tk , that the price is determined by the value in the corresponding upper edit box, and that an optimal policy will be followed from time tk onward. In particular, the lower edit box in the 0th column shows the approximate value of the risk-neutral price of the put option. The lower edit box is highlighted, if the return from exercising the option at tk is greater than expected return if we keep the option at least until tk+1 . The holder of the 36
option should immediately exercise the option if it is in the highlighted edit box, and vice versa. The four disabled edit boxes in the bottom of the window show the values of dierent parameters. Discount per step. Shows the value of , calculated by (11). Up step size. Shows the value of u, calculated with the help of the rst equation in (7). Down step size. Shows the value of d , calculated with the help of the second equation in (7). Probability of up move. Shows the value of p, calculated by (8). Consider the example of an American call option. Let all the values be the same as in the previous example of the put option. How to calculate the risk-neutral price? The parameters u, d , , p and S (tk ) are calculated by the same formulas (11)(9). However, Vk ( j), the possible time-tk expected values of the call, are calculated as Vn ( j) = max{u j d n j S (0) K, 0}, and for k = n 1, . . . , 0 they are calculated as Vk ( j) = max{u j d k j S (0) K, pVk+1 ( j + 1) + (1 p)Vk+1 ( j)}, j = 0, . . . , k. Using these formulas, we obtain V0 (0) 6.359. Fig. 26 shows the results of calculations. Note that the radio button Call is active now. Also note that all the highlighted edit boxes are in the last column. Indeed, according to [4, Proposition 5.2.1], one should never exercise the American call option before its expiration time. Remark 10. A program mbm has a limitation. You can not calculate the multi-period binomial model with 6 or more periods. For calculation of such models you can use MATLAB Command Window directly. See Section A.3. 3.5.1 Problems Problem 9. Consider a ve-month (t = 0.4167) American option when the initial price of the stock is S (0), the strike price is K , the risk-free interest is r% per annum, and the volatility is per annum. Divide the life of the option into 5 equal periods. Suppose that the price of a security can change only at the times tk = kt/5, k = 1, 2, . . . , 5 and that the option can be exercised only at one of the times tk . Calculate the risk-neutral price of both call and put options for the cases from Table 11. For put options describe all the moments, when the holder of the option should immediately exercise the option. Also calculate the up step size, down step size and probability of up move for every case.
37
S (0) 40 50 100 50 80 40 50 25
K 39 50 100 49 80 40 51 27
r 8 10 8 10 5 8 5 10
38
and () is the standard normal distribution function. According to putcall option parity
Figure 27: A window of the program black scholes The program black scholes requires the Financial toolbox. 39
The frame in the left hand side of the window contains the edit box Interest and the corresponding slider. They are responsible for the value of the annual risk-free interest rate, r. The standard problem has the value r = 0.05, which corresponds to 5%. The minimum slider (and edit box) value is equal to 0%, the maximum slider and edit box value is equal to 10%. The frame in the left hand side of the window contains the edit box Volatility and the corresponding slider. They are responsible for the value of the annualised volatility. . Standard problem has a value = 0.5, which corresponds to 50%. The minimum slider (and edit box) value is equal to 0%, the maximum slider and edit box value is equal to 100%. The frame in the upper part of the window contains three edit boxes. Price. Contains the value of the initial price of the security, S (0). The standard problem has the value S (0) = 100. Strike. Contains the value of the strike price, K . The standard problem has the value K = 95. Time. Contains the time to maturity of the option in years, t. The standard problem has value t = 0.25. The push buttons perform the following functions. Calculate. Calculates values of call and put options, using the Black-Scholes formula and put-call option parity. Exit. Stops the program. The results of calculations of our example are shown on Fig. 28. The disabled edit box Call option value contains the value of the call option, C . The disabled edit box Put option value contains the value of a put option, P. 3.6.1 Problems Problem 10. Calculate the value of call and put options for the cases from Table 11. The time to maturity of the option is t = 0.4167 years. Compare your results with results of the solution of Problem 9.
A Overcoming limitations
Some programs in the complex contain limitations. You can overcome these limitations, using MATLAB Command Window directly. Consider some examples. 40
41
A.1
Using the program present value, you can not calculate the present value of a cash ow containing more than 5 payments. The Command Window can be used instead. Consider the next example. The cash ow (Table 12) represents the yearly income from an initial investment of $15,000. The annual interest rate is 8%. How to calculate the present value of this varying cash ow? We can not use the program present value directly, because our cash ow contains more than 5 payments. Instead we can make direct use of the MATLAB Command Window. The rst time MATLAB starts, the desktop appears as shown in Fig. 29. The window in the left top corner is called Launch Pad. It contains a list of tools, demos and documentation of your MATLAB conguration and provides easy access to them. The window in the right side is called Command Window. You can use it to enter variables and run functions and M-les. M-les are text les containing MATLAB code. In particular, any program of the complex (Table 1) is contained in a M-le. You can run this le by typing its name in MATLAB Command Window.
Figure 29: Finding present value of a long cash ow Input the next command into the MATLAB Command Window (Fig. 29). 42
PresentVal=pvvar([-15000 2000 1500 3000 3800 5000 6000],0.08) After pressing Enter you will obtain the result: PresentVal = 496.4040 Specically, we introduce a new MATLAB variable named PresentVal. You can think of a variable as a named place in the computers memory. Every variable should have some value. In our case we called MATLAB function pvvar. Functions are Mles that can accept input arguments and return output arguments. The function pvvar is contained in the Financial toolbox. We passed two input arguments to this function. The value of the rst argument is equal to [-15000 2000 1500 3000 3800 5000 6000]. This is the vector of cash ows. The initial investment is included as the initial cash ow value (a negative number). The value of the second argument is equal to 0.08. It is the yearly interest rate. The function pvvar returned an output argument (the present value of a cash ow representing by its rst input argument with the yearly interest rate representing by its second argument). The value of the output argument was written into the variable PresentVal. It was also written in the Command Window (Fig. 29). Other examples of calculations of present values can be found in [1, pp. 4-2244-226]. In order to download this document, point your browser to the address shown at page 3.
A.2
Using the program ror, you can not calculate the rate of return of a cash ow containing more than 5 payments. The Command Window can be used instead. Consider the next example. Let us calculate the rate of return from an initial investment of $15,000 and payments shown in Table 12. There are 6 payments, and we can not use the program ror. Let us use the MATLAB Command Window instead. Input the next command into the MATLAB Command Window (Fig. 30). Return=irr([-15000 2000 1500 3000 3800 5000 6000]) After pressing Enter you will obtain the result: Return = 0.0888 or approximately 8.88%. We called the MATLAB function irr. This function is contained in the Financial toolbox. A vector representing the cash ow was passed to the function irr as its unique input argument. After calculations, the function irr returned the value of the rate of return as its output argument and wrote it into the variable Return in the computers memory. MATLAB wrote the value of the variable Return for you in the Command Window. This variable was also written into the workspace. The MATLAB workspace consists of 43
Figure 30: Finding rate of return of a long cash ow the set of variables built up during a MATLAB session and stored in the memory. You can use the variables of the workspace in subsequent commands. Other examples of calculations of rates of return can be found in [1, pp. 4-166, 4-260 4.261].
A.3
Using the program mbm, you can not make calculations with return of a cash ow containing more than 5 payments. The Command Window can be used instead. Consider the example of an American put option from Section 3.5. Assume we want to calculate the risk-neutral price of this option using 100 periods. Input the next command into the MATLAB Command Window (Fig. 31) [AssetPrice,OptionValue]=binprice(50,50,0.1,0.4167,... 0.4167/100,0.4,0); We called the MATLAB function binprice. This function is contained in the Financial toolbox. We passed seven parameters to the function binprice. These parameters are shown in Table 13. In the MATLAB Command Window, we used three dots . . . to indicate that the statement continues at the next line. The fth parameter is adjusted so that the length of each 44
Number 1 2 3 4 5 6 7
Meaning The initial price of the security The exercise price of the option The risk-free interest rate The options exercise time in years The length of one period The annualised volatility Species whether the option is a call (1) or a put (0) Table 13: The parameters of the MATLAB function binprice
45
interval is consistent with the exercise time of the option. The options exercise time divided by the length of one period equals an integer number of periods. The function binprice returns two output arguments. The rst output argument is the matrix of the securitys prices. The second output argument is the matrix of the options prices. We used the semicolon ; to suppress the MATLABs output. Without semicolon two huge matrices 100 100 would appear in the Command Window. The approximate value of the risk-neutral price of the option contains in the variable OptionValue(1,1). Enter this variable into the Command Window and press Enter. We obtain the result (Fig. 32). ans = 4.2782
Figure 32: The result of calculation of the 100-period binomial model The dierence between two values (V0 (0) 4.488 for n = 5 and V0 (0) 4.2782) is essential. Note that another software, DerivaGem [2, p. 393], gives the same answer as MATLAB. You can calculate the American call option with 100 periods yourselves. The only dierence is: the value of the seventh parameter should be equal to 1. Other examples of binomial put and call pricing can be found in [1, p. 4-374-38] and in [2, Chapter 16]. 46
A.3.1 Problems Problem 11. Calculate the value of call and put options for the cases from Table 11. The time to maturity of the option is t = 0.4167 years. Divide it onto 100 equal parts. Compare your results with results of the solution of Problems 9 and 10.
References
[1] Financial Toolbox for Use with MATLAB, Users Guide, Version 2.1.2, The MathWorks, Inc., September 2000. [2] Hull, J. C. Options, Futures & Other Derivatives, Fourth Edition, Prentice Hall, Upper Saddle River, 2000. [3] Prisman, E. Z. Pricing Derivative Securities: an Interactive Dynamic Environment with Maple V and Matlab, Academic Press, 2000. [4] Ross, S. M. An introduction to Mathematical Finance: Options and Other Topics, Cambridge University Press, 1999.
List of Figures
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 The MATLAB desktop . . . . . . . . . . . . . . . . . . . . . . . . . . . The Control Centre . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A window of the program price evolution . . . . . . . . . . . . . . . An example of incorrect input . . . . . . . . . . . . . . . . . . . . . . . An output of the program price evolution . . . . . . . . . . . . . . . A window of the program clt . . . . . . . . . . . . . . . . . . . . . . . An output of the program clt . . . . . . . . . . . . . . . . . . . . . . . A window of the program gbm . . . . . . . . . . . . . . . . . . . . . . . An output of the program gbm . . . . . . . . . . . . . . . . . . . . . . . A window of the program interest rate . . . . . . . . . . . . . . . . An output of the program interest rate . . . . . . . . . . . . . . . . . A window of the program present value . . . . . . . . . . . . . . . . An output of the program present value, case of xed periodic payments An output of the program present value, case of varying periodic payments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . An output of the program present value, case of varying non-periodic payments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A window of the program ror . . . . . . . . . . . . . . . . . . . . . . . An output of the program ror, case of periodic payments . . . . . . . . . An output of the program ror, case of non-periodic payments . . . . . . Possible security prices at time 1 . . . . . . . . . . . . . . . . . . . . . . The window of the program options pricing . . . . . . . . . . . . . . An output of the program options pricing, case of too expensive option An output of the program options pricing, case of too cheap option . . 47 4 5 6 7 8 9 10 12 13 14 16 19 20 21 22 25 26 27 28 30 31 32
23 24 25 26 27 28 29 30 31 32
An output of the program options pricing, case of no-arbitrage price A window of the program mbm . . . . . . . . . . . . . . . . . . . . . . An output of the program mbm, case of put option . . . . . . . . . . . . An output of the program mbm, case of call option . . . . . . . . . . . . A window of the program black scholes . . . . . . . . . . . . . . . An output of the program black scholes . . . . . . . . . . . . . . . . Finding present value of a long cash ow . . . . . . . . . . . . . . . . Finding rate of return of a long cash ow . . . . . . . . . . . . . . . . . A command for calculation of the 100-period binomial model . . . . . The result of calculation of the 100-period binomial model . . . . . . .
. . . . . . . . . .
33 35 36 38 39 41 42 44 45 46
List of Tables
1 2 3 4 5 6 7 8 9 10 11 12 13 Programs in the complex . . . . . . . . . . . . . . . . . . . . . Two equal simple cash ows . . . . . . . . . . . . . . . . . . . Two equal more complicated cash ows . . . . . . . . . . . . . Varying periodic cash ow . . . . . . . . . . . . . . . . . . . . Varying non-periodic cash ow . . . . . . . . . . . . . . . . . . Cash ow, problem 4 . . . . . . . . . . . . . . . . . . . . . . . Cash ow, problem 5 . . . . . . . . . . . . . . . . . . . . . . . The yearly income from an initial investment of $100,000 . . . . The non-periodic cash ow from an initial investment of $10,000 One-period binomial models . . . . . . . . . . . . . . . . . . . Data for pricing of American options . . . . . . . . . . . . . . . A long varying periodic cash ow . . . . . . . . . . . . . . . . The parameters of the MATLAB function binprice . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 17 18 18 21 23 23 23 25 33 38 41 45
48