Where's the bug with my auxiliary function?

2 visualizaciones (últimos 30 días)
Shawn Miller
Shawn Miller el 10 de Oct. de 2015
Comentada: Stephen23 el 10 de Oct. de 2015
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 comentarios
Stephen23
Stephen23 el 10 de Oct. de 2015
Editada: Stephen23 el 10 de Oct. de 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.

Iniciar sesión para comentar.

Respuesta aceptada

Walter Roberson
Walter Roberson el 10 de Oct. de 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.

Más respuestas (0)

Categorías

Más información sobre Platform and License en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by