maximise a function and find paramete

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

masoumeh solgi
masoumeh solgi el 16 de Mayo de 2020
Editada: masoumeh solgi el 16 de Mayo de 2020
thank you for your reply.
lamda should be a single value that determines the maturity at which the function achieves its max
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 Centro de ayuda y File Exchange.

Etiquetas

Preguntada:

el 16 de Mayo de 2020

Comentada:

el 16 de Mayo de 2020

Community Treasure Hunt

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

Start Hunting!

Translated by