maximise a function and find paramete

2 visualizaciones (últimos 30 días)
masoumeh solgi
masoumeh solgi el 16 de Mayo de 2020
Comentada: masoumeh solgi el 16 de Mayo de 2020
Hi everybody,
i want to find lambda (single value) that determines the maturity at which the function achieves its max
((1-exp(-lambda*gmaturities))./(lambda*gmaturities)-exp(-lambda*gmaturities))
my code is
F=@(lambda)[((1-exp(-lambda*gmaturities))./(lambda*gmaturities)-exp(-lambda*gmaturities))];
lambda0=0.0609;
lambda=fsolve(F,lambda0)
and i got lambda = 1.005283084116551e+03,i know this is not correct
could you please help me?
gmaturities=[6;12;24;36;48;60;72;84;96;108;120;180;240]

Respuesta aceptada

Walter Roberson
Walter Roberson el 16 de Mayo de 2020
gmaturities = [6;12;24;36;48;60;72;84;96;108;120;180;240]
F = @(lambda) -(((1-exp(-lambda*gmaturities))./(lambda*gmaturities)-exp(-lambda*gmaturities)));
lambda0 = 0.0609;
lambda = gamultiobj(F, lambda0)
The result will be a vector of values, because you are trying to maximize 13 equations at the same time -- each of the values of gmaturies effectively defines another equation, so you are asking to maximize the equations simultaneously.
I suspect you want something more like
gmaturities = [6;12;24;36;48;60;72;84;96;108;120;180;240];
lambda0 = 0.0609;
lambda = arrayfun(@(GM) fminsearch(@(lambda) -(((1-exp(-lambda*GM))./(lambda*GM)-exp(-lambda*GM))), lambda0), gmaturities);
  3 comentarios
Walter Roberson
Walter Roberson el 16 de Mayo de 2020
Your function has 13 values because your maturities is a vector. No one lambda can maximize it all simultaneously.
The code I posted second optimizes for each individual maturity value.
masoumeh solgi
masoumeh solgi el 16 de Mayo de 2020
Thank you

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Creating and Concatenating Matrices 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