Функция Блэка-Шоулза с векторными входами в Matlab - PullRequest
0 голосов
/ 29 сентября 2019

Я пытаюсь написать функцию в Matlab, которая вычисляет цену Call по формуле Блэка Шоулза с векторными входами. У меня так далеко:

function [C] = BlackScholesCall(S,K,t,r,sigma)
%This function calculates the call price per Black-Scholes equation
%INPUT S ... stock price at time 0
%      K ... strike price
%      r ... interest rate
%      sigma ... volatility of the stock price measured as annual standard deviation
%      t ... duration in years
%OUTPUT C ... call price
%USAGE BlackScholesCall(S,K,t,r,sigma)
for l = 1:length(K)
   for z = 1:length(t)
      d1 = (log(S/K(l)) + (r + 0.5*sigma^2)*t(z))/(sigma*sqrt(t(z)));
      d2 = d1 - sigma*sqrt(t(z));
      N1 = 0.5*(1+erf(d1/sqrt(2)));
      N2 = 0.5*(1+erf(d2/sqrt(2)));
      C(l) = S*N1-K(l)*exp(-r*t(z))*N2;
   end
end
end 

Например, код для вызова моей функции будет

S = 20
K = 16:21
t = 1:1:5
r = 0.02
sigma = 0.25
C = BlackScholesCall(S, K, t, r, sigma)

Но когда я сравниваю это с результатами функции blsprice в Matlab, я получаю другоеРезультаты. Я подозреваю, что что-то не так с тем, как я сделал цикл?

Ответы [ 2 ]

0 голосов
/ 30 сентября 2019

Версия R может быть следующей.

BlackScholesCall <- function(S, K, tt, r, sigma){
  f <- function(.K, .tt){
    d1 <- (log(S/.K) + (r + 0.5*sigma^2)*.tt)/(sigma*sqrt(.tt))
    d2 <- d1 - sigma*sqrt(.tt)
    S*pnorm(d1) - .K*exp(-r*.tt)*pnorm(d2)
  }
  m <- length(K)
  n <- length(tt)
  o <- outer(K, tt, f)
  last <- if(m > n) o[n:m, n] else o[m, m:n]
  c(diag(o), last)
}

BlackScholesCall(S, K, tt, r, sigma)
#[1] 4.703480 4.783563 4.914990 5.059922 5.210161 5.210161 4.809748
0 голосов
/ 30 сентября 2019

Вы получаете те же результаты, что и,

>> blsprice(S,K,r,t(end),sigma)
ans =
    7.1509    6.6114    6.1092    5.6427    5.2102    4.8097

Это потому, что с помощью C(l) = ... вы перезаписываете каждый элемент C numel(t) раз и, следовательно, сохраняете / возвращаете только последнийрассчитанные значения для каждого значения z.

Как минимум, вам нужно использовать,

%C(l) = S*N1-K(l)*exp(-r*t(z))*N2;
C(z,l) = S*N1-K(l)*exp(-r*t(z))*N2;

Но вы также должны предварительно выделить свою выходную матрицу. То есть перед любым из циклов вы должны добавить

C = nan(numel(K),numel(t));

Наконец, вы должны заметить, что вам вообще не нужно использовать какие-либо циклы,

[Kmat,tmat] = meshgrid(K,t);
d1 = (log(S./Kmat) + (r + 0.5*sigma^2)*tmat)./(sigma*sqrt(tmat));
d2 = d1 - sigma*sqrt(tmat);
N1 = 0.5*(1+erf(d1/sqrt(2)));
N2 = 0.5*(1+erf(d2/sqrt(2)));
C = S*N1-Kmat.*exp(-r*tmat).*N2;
...