cbondbycrr

Ценовые конвертируемые облигации от биномиального дерева CRR

Описание

пример

Price = cbondbycrr(CRRTree,CouponRate,Settle,Maturity,ConvRatio) ценовые конвертируемые облигации от биномиального дерева CRR с помощью Тсиверайоти и метода Фернандеса.

пример

[Price,PriceTree] = cbondbycrr(CRRTree,CouponRate,Settle,Maturity,ConvRatio) ценовые конвертируемые облигации от биномиального дерева CRR с помощью Тсиверайоти и метода Фернандеса.

пример

[Price,PriceTree,EquityTree,DebtTree] = cbondbycrr(___,Name,Value) ценовые конвертируемые облигации от биномиального дерева CRR с помощью кредитного спреда или включая риск значения по умолчанию связи.

Чтобы включить риск в форме кредитного спреда (метод Тсиверайотис-Фернандеса), используйте дополнительный входной параметр пары "имя-значение" Spread. Чтобы включить кредитный риск в алгоритм, задайте дополнительные входные параметры пары "имя-значение" DefaultProbability и RecoveryRate.

Примеры

свернуть все

Оцените конвертируемую облигацию с помощью следующих данных в структуре термина процентной ставки:

StartDates =  'Jan-1-2014'; 
EndDates = 'Jan-1-2015'; 
Rates = 0.1; 
Basis = 1;

Создайте RateSpec и StockSpec.

Sigma = 0.3;
Price = 50;

RateSpec = intenvset('ValuationDate',StartDates,'StartDates',StartDates,'EndDates',EndDates,...
'Rates',Rates,'Compounding',-1,'Basis',Basis)
RateSpec = struct with fields:
           FinObj: 'RateSpec'
      Compounding: -1
             Disc: 0.9048
            Rates: 0.1000
         EndTimes: 1
       StartTimes: 0
         EndDates: 735965
       StartDates: 735600
    ValuationDate: 735600
            Basis: 1
     EndMonthRule: 1

StockSpec = stockspec(Sigma,Price)
StockSpec = struct with fields:
             FinObj: 'StockSpec'
              Sigma: 0.3000
         AssetPrice: 50
       DividendType: []
    DividendAmounts: 0
    ExDividendDates: []

Создайте дерево CRR для акции.

Settle = '1-Jan-2014';
Maturity = '1-Oct-2014';
NumSteps = 3; 
TimeSpec = crrtimespec(Settle,Maturity,NumSteps);
CRRT = crrtree(StockSpec,RateSpec,TimeSpec)
CRRT = struct with fields:
       FinObj: 'BinStockTree'
       Method: 'CRR'
    StockSpec: [1x1 struct]
     TimeSpec: [1x1 struct]
     RateSpec: [1x1 struct]
         tObs: [0 0.2491 0.4982 0.7473]
         dObs: [735600 735691 735782 735873]
        STree: {1x4 cell}
      UpProbs: [0.5465 0.5465 0.5465]

Задайте и оцените конвертируемую облигацию.

CouponRate = 0;
Period = 1;
ConvRatio = 2;
CallExDates = '1-Oct-2014';
CallStrike = 115;
AmericanCall = 1;
Spread = 0.05;

[Price,PriceTree,EqtTree,DbtTree] = cbondbycrr(CRRT,CouponRate,Settle,Maturity,ConvRatio,...
'Period',Period,'Spread',Spread,'CallExDates',CallExDates,'CallStrike',CallStrike,'AmericanCall',AmericanCall)
Price = 104.9490
PriceTree = struct with fields:
    FinObj: 'BinPriceTree'
     PTree: {1x4 cell}
      tObs: [0 0.2491 0.4982 0.7473]
      dObs: [735600 735691 735782 735873]

EqtTree = struct with fields:
    FinObj: 'BinPriceTree'
     PTree: {1x4 cell}
      tObs: [0 0.2491 0.4982 0.7473]
      dObs: [735600 735691 735782 735873]

DbtTree = struct with fields:
    FinObj: 'BinPriceTree'
     PTree: {[28.4278]  [0 65.0790]  [0 43.6821 96.3327]  [1x4 double]}
      tObs: [0 0.2491 0.4982 0.7473]
      dObs: [735600 735691 735782 735873]

Создайте структуру термина процентной ставки RateSpec.

StartDates = 'Jan-1-2014'; 
EndDates = 'Jan-1-2016'; 
Rates = 0.025; 
Basis = 1; 
RateSpec = intenvset('ValuationDate',StartDates,'StartDates',...
StartDates,'EndDates',EndDates,'Rates',Rates,'Compounding',-1,'Basis',Basis)
RateSpec = struct with fields:
           FinObj: 'RateSpec'
      Compounding: -1
             Disc: 0.9512
            Rates: 0.0250
         EndTimes: 2
       StartTimes: 0
         EndDates: 736330
       StartDates: 735600
    ValuationDate: 735600
            Basis: 1
     EndMonthRule: 1

Создайте StockSpec.

AssetPrice = 110; 
Sigma = 0.22; 
Div = 0.02; 
StockSpec = stockspec(Sigma,AssetPrice,'continuous',Div)
StockSpec = struct with fields:
             FinObj: 'StockSpec'
              Sigma: 0.2200
         AssetPrice: 110
       DividendType: {'continuous'}
    DividendAmounts: 0.0200
    ExDividendDates: []

Создайте дерево CRR для акции.

Settle = '1-Jan-2014';
Maturity = '1-Oct-2014';
NumSteps = 3;
TimeSpec = crrtimespec(Settle,Maturity,NumSteps);
CRRT = crrtree(StockSpec,RateSpec,TimeSpec)
CRRT = struct with fields:
       FinObj: 'BinStockTree'
       Method: 'CRR'
    StockSpec: [1x1 struct]
     TimeSpec: [1x1 struct]
     RateSpec: [1x1 struct]
         tObs: [0 0.2491 0.4982 0.7473]
         dObs: [735600 735691 735782 735873]
        STree: {1x4 cell}
      UpProbs: [0.4782 0.4782 0.4782]

Задайте и оцените конвертируемую облигацию с помощью дополнительного DefaultProbability и RecoveryRate аргументы.

CouponRate = 0;
Period = 1;
ConvRatio = 2;
CallExDates = '1-Oct-2014';
CallStrike = 115;
AmericanCall = 1;
DefaultProbability = .30;
RecoveryRate = .82;

[Price,PriceTree,EqtTree,DbtTree] = cbondbycrr(CRRT,CouponRate,Settle,Maturity,ConvRatio,...
'Period',Period,'CallExDates',CallExDates,'CallStrike',CallStrike,'AmericanCall',AmericanCall,...
'DefaultProbability',DefaultProbability,'RecoveryRate',RecoveryRate)
Price = 220
PriceTree = struct with fields:
    FinObj: 'BinPriceTree'
     PTree: {1x4 cell}
      tObs: [0 0.2491 0.4982 0.7473]
      dObs: [735600 735691 735782 735873]

EqtTree = struct with fields:
    FinObj: 'BinPriceTree'
     PTree: {1x4 cell}
      tObs: [0 0.2491 0.4982 0.7473]
      dObs: [735600 735691 735782 735873]

DbtTree = struct with fields:
    FinObj: 'BinPriceTree'
     PTree: {[0]  [0 0]  [0 0 0]  [0 0 0 0]}
      tObs: [0 0.2491 0.4982 0.7473]
      dObs: [735600 735691 735782 735873]

Входные параметры

свернуть все

Древовидная структура запаса, заданная при помощи crrtree.

Типы данных: struct

Уровень облигационного купона, заданный как NINST- 1 десятичный годовой показатель или NINST- 1 массив ячеек, где каждым элементом является NumDates- 2 cellArray. Первый столбец NumDates- 2 массив ячеек является датами, и второй столбец является сопоставленными уровнями. Дата указывает в последний день, что купонная ставка допустима.

Типы данных: double | cell

Расчетный день, заданный как NINST- 1 скаляр с помощью последовательного номера даты или вектора символов даты.

Примечание

Settle дата каждой конвертируемой облигации назначена к ValuationDate из дерева запаса CRR. Аргумент связи, Settle, проигнорирован.

Типы данных: double | char

Дата погашения, заданная как NINST- 1 скаляр с помощью последовательного номера даты или вектора символов даты.

Типы данных: double | char

Количество долей, конвертируемых к одной связи, заданной как NINST- 1 с неотрицательным номером.

Типы данных: double

Аргументы в виде пар имя-значение

Задайте дополнительные разделенные запятой пары Name,Value аргументы. Name имя аргумента и Value соответствующее значение. Name должен появиться в кавычках. Вы можете задать несколько аргументов в виде пар имен и значений в любом порядке, например: Name1, Value1, ..., NameN, ValueN.

Пример: [Price,PriceTree,EquityTree,DebtTree] = cbondbycrr(CRRT,CouponRate,Settle, Maturity, ConvRatio,'Spread',Spread,'CallExDates',CallExDates,'CallStrike',CallStrike,'AmericanCall',1)

Количество пунктов по ссылочному уровню, заданному как разделенная запятой пара, состоящая из 'Spread' и NINST- 1 вектор.

Примечание

Чтобы включить риск в форме кредитного спреда (метод Тсиверайотис-Фернандеса), используйте дополнительный входной параметр Spread. Чтобы включить кредитный риск в алгоритм, задайте дополнительные входные параметры DefaultProbability и RecoveryRate. Не используйте Spread с DefaultProbability и RecoveryRate.

Типы данных: double

Купоны в год, заданный как разделенная запятой пара, состоящая из 'Period' и NINST- 1 вектор.

Типы данных: double

Дата выпуска облигаций, заданная как разделенная запятой пара, состоящая из 'IssueDate' и NINST- 1 вектор с помощью последовательного номера даты или вектора символов даты.

Типы данных: double | char

Неправильная первая дата купона, заданная как разделенная запятой пара, состоящая из 'FirstCouponDate' и NINST- 1 вектор с помощью последовательного номера даты или вектора символов даты.

Типы данных: double | char

Неправильная последняя дата купона, заданная как разделенная запятой пара, состоящая из 'LastCouponDate' и NINST- 1 вектор с помощью последовательного номера даты или вектора символов даты.

Типы данных: char | double

Номинальная стоимость, заданная как разделенная запятой пара, состоящая из 'Face' и NINST- 1 вектор неотрицательных номинальных стоимостей или NINST- 1 массив ячеек, где каждым элементом является NumDates- 2 cellArray. Первый столбец NumDates- 2 массив ячеек является датами, и второй столбец является связанной номинальной стоимостью. Дата указывает в последний день, что номинальная стоимость допустима.

Типы данных: cell | double

Вызовите цену исполнения опциона для европейца, Бермуд или американской опции, заданной как разделенная запятой пара, состоящая из 'CallStrike' и одно из следующих значений:

  • Для европейского колл-опциона — NINST- 1 вектор неотрицательных целых чисел

  • Для колл-опциона Бермуд — NINST- NSTRIKES матрица значений цены исполнения опциона вызова, где каждая строка является расписанием для одного колл-опциона. Если колл-опцион имеет меньше, чем NSTRIKES осуществите возможности, конец строки дополнен NaNs.

  • Для американского колл-опциона — NINST- 1 вектор значений цены исполнения опциона для каждой опции.

Типы данных: single | double

Вызовите дату осуществления европейца, Бермуд или американской опции, заданной как разделенная запятой пара, состоящая из 'CallExDates' и одно из следующих значений:

  • Для европейской опции — NINST- 1 вектор последовательных чисел даты или векторов символов даты.

  • Для опции Бермуд — NINST- NSTRIKES матрица дат осуществления, где каждая строка является расписанием для одной опции. Для европейской опции существует только один CallExDate на дате окончания срока действия опции.

  • Для американской опции — NINST- 1 или NINST- 2 матрица контуров даты осуществления. Для каждого инструмента колл-опцион может быть осуществлен в любую древовидную дату между или включая пару дат на той строке. Если CallExDates NINST- 1, опция может быть осуществлена между ValuationDate из дерева запаса CRR и одного перечисленного CallExDate.

Типы данных: char | cell | double

Тип колл-опциона, заданный как разделенная запятой пара, состоящая из 'AmericanCall' и NINST- 1 вектор положительного целого числа отмечает с помощью значений 0 или 1.

  • Для европейца или опции Бермуд — AmericanCall 0 для каждого европейца или опции Бермуд.

  • Для американской опции — AmericanCall 1 для каждой американской опции. AmericanCall аргумент требуется, чтобы вызывать правила осуществления American.

Типы данных: single | double

Поместите значения забастовки для европейца, Бермуд или американской опции, заданной как разделенная запятой пара, состоящая из 'PutStrike' и одно из следующих значений:

  • Для европейского пут-опциона — NINST- 1 вектор неотрицательных целых чисел

  • Для пут-опциона Бермуд — NINST- NSTRIKES матрица значений цены исполнения опциона, где каждая строка является расписанием для одной опции. Если пут-опцион имеет меньше, чем NSTRIKES осуществите возможности, конец строки дополнен NaNs.

  • Для американского пут-опциона — NINST- 1 вектор значений цены исполнения опциона для каждой опции.

Типы данных: single | double

Поместите дату осуществления европейца, Бермуд или американской опции, заданной как разделенная запятой пара, состоящая из 'PutExDates' и одно из следующих значений:

  • Для европейской опции — NINST- 1 вектор последовательных чисел даты или векторов символов даты.

  • Для опции Бермуд — NINST- NSTRIKES матрица дат осуществления, где каждая строка является расписанием для одной опции. Для европейской опции существует только один PutExDate на дате окончания срока действия опции.

  • Для американской опции — NINST- 1 или NINST- 2 матрица контуров даты осуществления. Для каждого инструмента пут-опцион может быть осуществлен в любую древовидную дату между или включая пару дат на той строке. Если PutExDates NINST- 1, пут-опцион может быть осуществлен между ValuationDate из дерева запаса CRR и одного перечисленного PutExDate.

Типы данных: double | char | cell

Тип пут-опциона, заданный как разделенная запятой пара, состоящая из 'AmericanPut' и NINST- 1 вектор положительного целого числа отмечает с помощью значений 0 или 1.

  • Для европейца или опции Бермуд — AmericanPut 0 для каждого европейца или опции Бермуд.

  • Для американской опции — AmericanPut 1 для каждой американской опции. AmericanPut аргумент требуется, чтобы вызывать правила осуществления American.

Типы данных: single | double

Конвертируемые даты, заданные как разделенная запятой пара, состоящая из 'ConvDates' и NINST- 1 или NINST- 2 матрица последовательных чисел даты или векторов символов даты. Если ConvDates не задан, связь всегда конвертируема до зрелости.

Для каждого инструмента связь может быть преобразована в любую древовидную дату между или включая пару дат на той строке.

Если ConvDates NINST- 1, связь может быть преобразована между ValuationDate из дерева запаса CRR и одного перечисленного ConvDates.

Типы данных: char | single | double

Ежегодная вероятность уровня по умолчанию, заданного как разделенная запятой пара, состоящая из 'DefaultProbability' и NINST- 1 неотрицательное десятичное значение.

Примечание

Чтобы включить кредитный риск в алгоритм, задайте дополнительные входные параметры DefaultProbability и RecoveryRate. Чтобы включить риск в форме кредитного спреда (метод Тсиверайотис-Фернандеса), используйте дополнительный входной параметр Spread. Не используйте DefaultProbability и RecoveryRate с Spread.

Типы данных: single | double

Скорость восстановления, заданная как разделенная запятой пара, состоящая из 'RecoveryRate' и NINST- 1 неотрицательное десятичное число.

Примечание

Чтобы включить кредитный риск в алгоритм, задайте дополнительные входные параметры DefaultProbability и RecoveryRate. Чтобы включить риск в форме кредитного спреда (метод Тсиверайотис-Фернандеса), используйте дополнительный входной параметр Spread. Не используйте DefaultProbability и RecoveryRate с Spread.

Типы данных: single | double

Выходные аргументы

свернуть все

Ожидаемая цена во время 0, возвращенный как NINST- 1 массив.

Структура с вектором цен конвертируемой облигации в каждом узле, возвращенном как древовидная структура.

Структура с вектором компонента акции конвертируемой облигации в каждом узле, возвращенном как древовидная структура.

Структура с вектором компонента долга конвертируемой облигации в каждом узле, возвращенном как древовидная структура.

Больше о

свернуть все

Вызываемый кабриолет

Конвертируемая облигация, которая является вызываемой выпускающим. Выпускающий связи обеспечивает преобразование, удаляя преимущество, что преобразование на усмотрение держателя облигаций.

На вызов держатель облигаций может или преобразовать связь или искупить по досрочной цене. Эта опция позволяет выпускающему регулировать цену конвертируемой облигации и, при необходимости, рефинансировать долг с новым более дешевым.

Кабриолет с правом досрочного погашения

Конвертируемая облигация с помещенной функцией позволяет держателю облигаций продавать назад связь в большом почете в определенную дату.

Эта опция защищает держателя от растущих процентных ставок путем сокращения года до зрелости.

Алгоритмы

cbondbycrr, cbondbyeqp, cbondbyitt, и cbondbysttвозвратите информацию о ценах в форме ценового вектора и ценового дерева. Эти функции реализуют риск или в форме кредитного спреда или в форме слияния риска значения по умолчанию связи. Чтобы включить риск в форме кредитного спреда (метод Тсиверайотис-Фернандеса), используйте дополнительный аргумент пары "имя-значение" Spread. Чтобы включить кредитный риск в алгоритм, задайте дополнительные аргументы пары "имя-значение" DefaultProbability и RecoveryRate.

Ссылки

[1] Tsiveriotis, K. и К. Фернандес. “Оценивая Конвертируемые облигации с Кредитным риском”. Журнал Фиксированного дохода. Издание 8, 1998, стр 95–102.

[2] Оболочка, J. Опции, фьючерсы и Другие Производные. Четвертый Выпуск. Prentice Hall, 2000, стр 646–649.

Представленный в R2015a

Для просмотра документации необходимо авторизоваться на сайте