optstockbyfd

Вычислите цены опции ванили с помощью метода конечной разности

Синтаксис

[Price,PriceGrid,AssetPrices,Times] = optstockbyfd(RateSpec,StockSpec,OptSpec,Strike,Settle,ExerciseDates)
[Price,PriceGrid,AssetPrices,Times] = optstockbyfd(___,Name,Value)

Описание

пример

[Price,PriceGrid,AssetPrices,Times] = optstockbyfd(RateSpec,StockSpec,OptSpec,Strike,Settle,ExerciseDates) вычисляет цены опции ванили с помощью метода конечной разности.

пример

[Price,PriceGrid,AssetPrices,Times] = optstockbyfd(___,Name,Value) добавляют дополнительные аргументы пары "имя-значение".

Примеры

свернуть все

Создайте RateSpec.

AssetPrice = 50;
Strike = 45;
Rate = 0.035;
Volatility = 0.30;
Settle = '01-Jan-2015';
Maturity = '01-Jan-2016';
Basis = 1;
 
RateSpec = intenvset('ValuationDate',Settle,'StartDates',Settle,'EndDates',...
Maturity,'Rates',Rate,'Compounding',-1,'Basis',Basis)
RateSpec = struct with fields:
           FinObj: 'RateSpec'
      Compounding: -1
             Disc: 0.9656
            Rates: 0.0350
         EndTimes: 1
       StartTimes: 0
         EndDates: 736330
       StartDates: 735965
    ValuationDate: 735965
            Basis: 1
     EndMonthRule: 1

Создайте StockSpec.

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

Вычислите цену европейского колл-опциона ванили с помощью метода конечной разности.

ExerciseDates = 'may-1-2015';
OptSpec = 'Call';
Price = optstockbyfd(RateSpec,StockSpec,OptSpec,Strike,Settle,ExerciseDates)
Price = 6.7352

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

свернуть все

Структура термина процентной ставки (пересчитанный на год и постоянно составляемый), заданный RateSpec получена из intenvset. Для получения информации о спецификации процентной ставки смотрите intenvset.

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

Спецификация запаса для базового актива. Для получения информации о спецификации запаса смотрите stockspec.

stockspec обрабатывает несколько типов базовых активов. Например, для физических предметов потребления ценой является StockSpec.Asset, энергозависимостью является StockSpec.Sigma, и урожаем удобства является StockSpec.DividendAmounts.

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

Определение опции как 'call' или 'put', заданный как вектор символов или массив строк со значениями 'call' или 'put'.

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

Значение цены исполнения опциона опции, заданное как неотрицательный скаляр или вектор.

  • Для европейской опции используйте скаляр цены исполнения опциона.

  • Для опции Бермуд используйте 1-by-NSTRIKES вектор цен исполнения опциона.

  • Для американской опции используйте скаляр цены исполнения опциона.

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

Урегулирование или торговая дата барьерного опциона, заданного как последовательный номер даты, вектор символов даты или объект datetime.

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

Даты осуществления опции, заданные как последовательный номер даты, вектор символов даты или объект datetime:

  • Для европейской опции используйте 1-by-1 вектор дат, заданных как неотрицательное скалярное целое число, вектор символов даты или объект datetime. Для опции Бермуд используйте 1-by-NSTRIKES вектор дат, заданных как неотрицательное скалярное целое число, вектор символов даты или объект datetime.

  • Для американской опции используйте 1-by-2 массив ячеек векторов символов даты. Опция может быть осуществлена в любую дату между или включая пару дат на той строке. Если только одна non-NaN дата перечислена, или если ExerciseDates является 1-by-1 вектор последовательных чисел даты или массив ячеек векторов символов даты, опция может быть осуществлена между Settle и одной перечисленной датой в ExerciseDates.

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

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

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

Пример: Price = optstockbyfd(RateSpec,StockSpec,OptSpec,Strike,Settle,ExerciseDates,'AssetGridSize',1000)

Размер сетки актива используется для сетки конечной разности, заданной как пара, разделенная запятой, состоящая из 'AssetGridSize' и положительной скалярной величины.

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

Максимальная цена за ценовой контур сетки, заданный как пара, разделенная запятой, состоящая из 'AssetPriceMax' как положительная скалярная величина.

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

Размер сетки времени используется для сетки конечной разности, заданной как пара, разделенная запятой, состоящая из 'TimeGridSize' и положительной скалярной величины.

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

Тип опции, заданный как пара, разделенная запятой, состоящая из 'AmericanOpt' и NINST-by-1 положительный целочисленный скаляр, отмечает с помощью значений:

  • 0 — Европеец/Бермуды

  • 1 — Американец

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

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

свернуть все

Ожидаемые цены за опции ванили, возвращенные как 1-by-1 матрица.

Сетка, содержащая цены, вычисленные методом конечной разности, возвращенным как сетка, которая двумерна с размером PriceGridSize*length(Times). Количество столбцов не должно быть равно TimeGridSize, потому что без дивиденда даты в StockSpec добавляются к сетке времени. Цена за t = 0 содержится в PriceGrid(:, end).

Цены актива, заданного StockSpec, соответствующим первой размерности PriceGrid, возвращенного как вектор.

Времена соответствуя второму измерению PriceGrid, возвращенного как вектор.

Ссылки

[1] Хог, Например, Дж. Хог и А. Льюис. "Назад к основам: новый подход к дискретной проблеме дивиденда". Издание 9, журнал Wilmott, 2003, стр 37–47.

[2] Ву, L. и И. К. Квок. "Фиксирующий переднюю сторону метод конечной разности для оценки американских опций". Журнал Финансовой Разработки. Издание 6.4, 1997, стр 83–97.

Введенный в R2017b