cbondbyitt
Price convertible bonds from ITT trinomial tree
Syntax
Description
prices convertible bonds from an ITT trinomial tree using the Tsiveriotis and Fernandes method.Price
= cbondbyitt(ITTTree
,CouponRate
,Settle
,Maturity
,ConvRatio
)
Note
Alternatively, you can use the ConvertibleBond
instrument object to price a convertible bond. For more information, see Get Started with Workflows Using Object-Based Framework for Pricing Financial Instruments.
[
prices convertible bonds from an ITT trinomial tree using a credit spread or incorporating the
risk of bond default.Price
,PriceTree
,EquityTree
,DebtTree
]
= cbondbyitt(___,Name,Value
)
To incorporate the risk in the form of credit spread (Tsiveriotis-Fernandes method), use
the optional name-value pair input argument Spread
. To incorporate default
risk into the algorithm, specify the optional name-value pair input arguments
DefaultProbability
and RecoveryRate
.
Examples
Price a convertible bond using the following data for an ITTTree
from deriv.mat
:
load deriv.mat
Use cbondbyitt
to price a convertible bond using an ITT trinomial tree.
CouponRate = 0.05; Settle = datetime(2006,1,1); Maturity = datetime(2008,1,1); Period = 1; CallStrike = 65; CallExDates = datetime(2007,1,1); ConvRatio = 1; Spread = 0.015; [Price,PriceTree,EqtTre,DbtTree] = cbondbyitt(ITTTree,CouponRate,Settle,Maturity,ConvRatio,... 'Period',Period,'Spread',Spread,'CallExDates',CallExDates,'CallStrike',CallStrike,'AmericanCall',1)
Price = 58.9170
PriceTree = struct with fields:
FinObj: 'TrinPriceTree'
PTree: {[58.9170] [66.3448 65 65] [105 105 105 105 105] [0 0 0 0 0 0 0] [0 0 0 0 0 0 0 0 0]}
tObs: [0 1 2 3 4]
dObs: [732678 733043 733408 733773 734139]
EqtTre = struct with fields:
FinObj: 'TrinPriceTree'
PTree: {[28.0629] [66.3448 0 0] [0 0 0 0 0] [0 0 0 0 0 0 0] [0 0 0 0 0 0 0 0 0]}
tObs: [0 1 2 3 4]
dObs: [732678 733043 733408 733773 734139]
DbtTree = struct with fields:
FinObj: 'TrinPriceTree'
PTree: {[30.8540] [0 65 65] [105 105 105 105 105] [0 0 0 0 0 0 0] [0 0 0 0 0 0 0 0 0]}
tObs: [0 1 2 3 4]
dObs: [732678 733043 733408 733773 734139]
Price a convertible bond using the following data for an ITTTree
from deriv.mat
.
load deriv.mat
Use cbondbyitt
to price a convertible bond using an ITT trinomial tree with the optional DefaultProbability
and RecoveryRate
arguments.
CouponRate = 0.05; Settle = datetime(2006,1,1); Maturity = datetime(2008,1,1); Period = 1; CallStrike = 65; CallExDates = datetime(2007,1,1); ConvRatio = 1; DefaultProbability = .30; RecoveryRate = .82; [Price,PriceTree,EqtTre,DbtTree] = cbondbyitt(ITTTree,CouponRate,Settle,Maturity,ConvRatio,... 'Period',Period,'CallExDates',CallExDates,'CallStrike',CallStrike,'AmericanCall',1,... 'DefaultProbability',DefaultProbability,'RecoveryRate',RecoveryRate)
Price = 50.6487
PriceTree = struct with fields:
FinObj: 'TrinPriceTree'
PTree: {[50.6487] [66.3448 65 65] [105 105 105 105 105] [0 0 0 0 0 0 0] [0 0 0 0 0 0 0 0 0]}
tObs: [0 1 2 3 4]
dObs: [732678 733043 733408 733773 734139]
EqtTre = struct with fields:
FinObj: 'TrinPriceTree'
PTree: {[20.7895] [66.3448 0 0] [0 0 0 0 0] [0 0 0 0 0 0 0] [0 0 0 0 0 0 0 0 0]}
tObs: [0 1 2 3 4]
dObs: [732678 733043 733408 733773 734139]
DbtTree = struct with fields:
FinObj: 'TrinPriceTree'
PTree: {[29.8591] [0 65 65] [105 105 105 105 105] [0 0 0 0 0 0 0] [0 0 0 0 0 0 0 0 0]}
tObs: [0 1 2 3 4]
dObs: [732678 733043 733408 733773 734139]
Input Arguments
Stock tree structure, specified by using itttree
.
Data Types: struct
Bond coupon rate, specified as an NINST
-by-1
decimal annual rate or NINST
-by-1
cell array, where each
element is a NumDates
-by-2
cell array. The first column
of the NumDates
-by-2
cell array is dates and the second
column is associated rates. The date indicates the last day that the coupon rate is
valid.
Data Types: double
| cell
Settlement date, specified as an NINST
-by-1
vector
using a datetime array, string array, or date character vectors.
Note
The Settle
date for every convertible bond is set to the
ValuationDate
of the standard trinomial (STT) stock tree. The bond
argument, Settle
, is ignored.
To support existing code, cbondbyitt
also
accepts serial date numbers as inputs, but they are not recommended.
Maturity date, specified as an NINST
-by-1
vector
using a datetime array, string array, or date character vectors.
To support existing code, cbondbyitt
also
accepts serial date numbers as inputs, but they are not recommended.
Number of shares convertible to one bond, specified as an
NINST
-by-1
with a nonnegative number.
Data Types: double
Name-Value Arguments
Specify optional pairs of arguments as
Name1=Value1,...,NameN=ValueN
, where Name
is
the argument name and Value
is the corresponding value.
Name-value arguments must appear after other arguments, but the order of the
pairs does not matter.
Before R2021a, use commas to separate each name and value, and enclose
Name
in quotes.
Example: [Price,PriceTree,EquityTree,DebtTree] =
cbondbyitt(ITTTree,CouponRate,Settle, Maturity,
ConvRatio,'Spread',Spread,'CallExDates',CallExDates,'CallStrike',CallStrike,'AmericanCall',1)
Number of basis points over the reference rate, specified as the comma-separated pair
consisting of 'Spread'
and a
NINST
-by-1
vector. For example, if the reference rate
is 2% and spread is 4%, then the Spread
value in basis points would be
0.04
.
Note
To incorporate the risk in the form of credit spread (Tsiveriotis-Fernandes method),
use the optional input argument Spread
. To incorporate default risk into
the algorithm, specify the optional input arguments DefaultProbability
and RecoveryRate
. Do not use Spread
with
DefaultProbability
and RecoveryRate
.
Data Types: double
Coupons per year, specified as the comma-separated pair consisting of
'Period'
and a NINST
-by-1
vector.
Data Types: double
Bond issue date, specified as the comma-separated pair consisting of
'IssueDate'
and a NINST
-by-1
vector
using a datetime array, string array, or date character vectors.
To support existing code, cbondbyitt
also
accepts serial date numbers as inputs, but they are not recommended.
Irregular first coupon date, specified as the comma-separated pair consisting of
'FirstCouponDate'
and a NINST
-by-1
vector using a datetime array, string array, or date character vectors.
To support existing code, cbondbyitt
also
accepts serial date numbers as inputs, but they are not recommended.
Irregular last coupon date, specified as the comma-separated pair consisting of
'LastCouponDate'
and a NINST
-by-1
vector using a datetime array, string array, or date character vectors.
To support existing code, cbondbyitt
also
accepts serial date numbers as inputs, but they are not recommended.
Face value, specified as the comma-separated pair consisting of
'Face'
and a NINST
-by-1
vector of
nonnegative face values or a NINST
-by-1
cell array,
where each element is a NumDates
-by-2
cell array. The
first column of the NumDates
-by-2
cell array is dates
and the second column is the associated face value. The date indicates the last day that the
face value is valid.
Data Types: cell
| double
Call strike price for European, Bermuda, or American option, specified as the
comma-separated pair consisting of 'CallStrike'
and one of the following
values:
For a European call option —
NINST
-by-1
vector of nonnegative integers.For a Bermuda call option —
NINST
-by-NSTRIKES
matrix of call strike price values, where each row is the schedule for one call option. If a call option has fewer thanNSTRIKES
exercise opportunities, the end of the row is padded withNaN
s.For an American call option —
NINST
-by-1
vector of strike price values for each option.
Data Types: double
Call exercise date for European, Bermuda, or American option, specified as the
comma-separated pair consisting of 'CallExDates'
and a datetime array,
string array, or date character vectors for one of the following values:
For a European option —
NINST
-by-1
vector of date character vectors.For a Bermuda option —
NINST
-by-NSTRIKES
matrix of exercise dates, where each row is the schedule for one option. For a European option, there is only oneCallExDate
on the option expiry date.For an American option —
NINST
-by-1
orNINST
-by-2
matrix of exercise date boundaries. For each instrument, the call option can be exercised on any tree date between or including the pair of dates on that row. IfCallExDates
isNINST
-by-1
, the option can be exercised between theValuationDate
of the ITT stock tree and the single listedCallExDate
.
To support existing code, cbondbyitt
also
accepts serial date numbers as inputs, but they are not recommended.
Call option type, specified as the comma-separated pair consisting of
'AmericanCall'
and a NINST
-by-1
vector of positive integer flags with values 0
or
1
.
For a European or Bermuda option —
AmericanCall
is0
for each European or Bermuda option.For an American option —
AmericanCall
is1
for each American option. TheAmericanCall
argument is required to invoke American exercise rules.
Data Types: double
Put strike values for European, Bermuda, or American option, specified as the
comma-separated pair consisting of 'PutStrike'
and one of the following
values:
For a European put option —
NINST
-by-1
vector of nonnegative integers.For a Bermuda put option —
NINST
-by-NSTRIKES
matrix of strike price values where each row is the schedule for one option. If a put option has fewer thanNSTRIKES
exercise opportunities, the end of the row is padded withNaN
s.For an American put option —
NINST
-by-1
vector of strike price values for each option.
Data Types: double
Put exercise date for European, Bermuda, or American option, specified as the
comma-separated pair consisting of 'PutExDates'
and a datetime array,
string array, or date character vectors for one of the following values:
For a European option —
NINST
-by-1
vector of date character vectors.For a Bermuda option —
NINST
-by-NSTRIKES
matrix of exercise dates where each row is the schedule for one option. For a European option, there is only onePutExDate
on the option expiry date.For an American option —
NINST
-by-1
orNINST
-by-2
matrix of exercise date boundaries. For each instrument, the put option can be exercised on any tree date between or including the pair of dates on that row. IfPutExDates
isNINST
-by-1
, the put option can be exercised between theValuationDate
of the ITT stock tree and the single listedPutExDate
.
To support existing code, cbondbyitt
also
accepts serial date numbers as inputs, but they are not recommended.
Put option type, specified as the comma-separated pair consisting of
'PutExDates'
and a NINST
-by-1
vector of positive integer flags with values 0
or
1
.
For a European or Bermuda option —
AmericanPut
is0
for each European or Bermuda option.For an American option —
AmericanPut
is1
for each American option. TheAmericanPut
argument is required to invoke American exercise rules.
Data Types: double
Convertible dates, specified as the comma-separated pair consisting of
'ConvDates'
and a NINST
-by-1
or
NINST
-by-2
vector using a datetime array, string
array, or date character vectors. If ConvDates
is not specified, the bond
is always convertible until maturity.
To support existing code, cbondbyitt
also
accepts serial date numbers as inputs, but they are not recommended.
For each instrument, the bond can be converted on any tree date between or including the pair of dates on that row.
If ConvDates
is NINST
-by-1
, the
bond can be converted between the ValuationDate
of the ITT stock tree and
the single listed ConvDates
.
Annual probability of default rate, specified as the comma-separated pair consisting of
'DefaultProbability'
and a
NINST
-by-1
nonnegative decimal value.
Note
To incorporate default risk into the algorithm, specify the optional input arguments
DefaultProbability
and RecoveryRate
. To
incorporate the risk in the form of credit spread (Tsiveriotis-Fernandes method), use the
optional input argument Spread
. Do not use
DefaultProbability
and RecoveryRate
with
Spread
.
Data Types: double
Recovery rate, specified as the comma-separated pair consisting of
'RecoveryRate'
and a NINST
-by-1
nonnegative decimal value.
Note
To incorporate default risk into the algorithm, specify the optional input arguments
DefaultProbability
and RecoveryRate
. To
incorporate the risk in the form of credit spread (Tsiveriotis-Fernandes method), use the
optional input argument Spread
. Do not use
DefaultProbability
and RecoveryRate
with
Spread
.
Data Types: double
Output Arguments
Expected price at time 0
, returned as an
NINST
-by-1
array.
Structure with a vector of convertible bond prices at each node, returned as a tree structure.
Structure with a vector of convertible bond equity components at each node, returned as a tree structure.
Structure with a vector of convertible bond debt components at each node, returned as a tree structure.
More About
A convertible bond is a type of hybrid security that combines features of both debt and equity; it is bond that can be converted into a predetermined number of shares of the issuing company's stock at the bondholder's discretion, usually at specific times during its life.
Upon call, the bondholder can either convert the bond or redeem at the call price. This option enables the issuer to control the price of the convertible bond and, if necessary, refinance the debt with a new cheaper one.
A convertible bond that is callable by the issuer. The issuer of the bond forces conversion, removing the advantage that conversion is at the discretion of the bondholder.
Upon call, the bondholder can either convert the bond or redeem at the call price. This option enables the issuer to control the price of the convertible bond and, if necessary, refinance the debt with a new cheaper bond.
A convertible bond with a put feature allows the bondholder to sell back the bond at a premium on a specific date.
This option protects the holder against rising interest rates by reducing the year to maturity.
Algorithms
cbondbycrr
, cbondbyeqp
, cbondbyitt
, and cbondbystt
return price information in the form of
a price vector and a price tree. These functions implement the risk in the form of either a
credit spread or incorporating the risk of bond default. To incorporate the risk in the form of
credit spread (Tsiveriotis-Fernandes method), use the optional name-value pair argument
Spread
. To incorporate default risk into the algorithm, specify the
optional name-value pair arguments DefaultProbability
and
RecoveryRate
.
References
[1] Tsiveriotis, K., and C. Fernandes. “Valuing Convertible Bonds with Credit Risk.” Journal of Fixed Income. Vol 8, 1998, pp. 95–102.
[2] Hull, J. Options, Futures and Other Derivatives. Fourth Edition. Prentice Hall, 2000, pp. 646–649.
Version History
Introduced in R2015bAlthough cbondbyitt
supports serial date numbers,
datetime
values are recommended instead. The
datetime
data type provides flexible date and time
formats, storage out to nanosecond precision, and properties to account for time
zones and daylight saving time.
To convert serial date numbers or text to datetime
values, use the datetime
function. For example:
t = datetime(738427.656845093,"ConvertFrom","datenum"); y = year(t)
y = 2021
There are no plans to remove support for serial date number inputs.
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Seleziona un sito web
Seleziona un sito web per visualizzare contenuto tradotto dove disponibile e vedere eventi e offerte locali. In base alla tua area geografica, ti consigliamo di selezionare: .
Puoi anche selezionare un sito web dal seguente elenco:
Come ottenere le migliori prestazioni del sito
Per ottenere le migliori prestazioni del sito, seleziona il sito cinese (in cinese o in inglese). I siti MathWorks per gli altri paesi non sono ottimizzati per essere visitati dalla tua area geografica.
Americhe
- América Latina (Español)
- Canada (English)
- United States (English)
Europa
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)