Azzera filtri
Azzera filtri

Where's the bug with my auxiliary function?

3 visualizzazioni (ultimi 30 giorni)
My code is as follows, it includes a main function (FindVolatility) and a local function (selectOutput). The idea here is I'd like to select which price to compute: either call option or put option using blsprice function, and this is executed in the auxiliary function "selectOutput". Next, I'd like to calculate volatility using my auxiliary function and also using fzero function. But I got errors, who knows why? Thanks in advance!
function impVol=FindVolatility(S,K,r,T,q,number,c0)
impVol=fzero(@(x)selectOutput(S,K,r,T,x,q,number)-c0,0);
end
function c=selectOutput(S,K,r,T,sigma,q,number)
[callPrice,putPrice]=blsprice(S,K,r,T,sigma,q);
if number==1
c=callPrice;
else
c=putPrice;
end
end
  2 Commenti
Stephen23
Stephen23 il 10 Ott 2015
Modificato: Stephen23 il 10 Ott 2015
What errors are you getting? Please give us the complete error messages (all of the red text), and show us how you are calling the function. Sorry, but our mind-reading abilities are a bit weak today, so you actually need to give us this information in writing.

Accedi per commentare.

Risposta accettata

Walter Roberson
Walter Roberson il 10 Ott 2015
Just like before, you are failing to constrain your input Volatility to be positive. When you use the one-value form of x0 in fzero then fzero is free to try negative numbers (and definitely will try negative numbers when you use 0 as the initial value.) You need to pass x0 as a vector of two elements, like I showed in your previous Question.

Più risposte (0)

Categorie

Scopri di più su Financial Toolbox in Help Center e File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by