how to run optimisation problem

1 vue (au cours des 30 derniers jours)
DAN TURMACU
DAN TURMACU le 20 Mar 2019
Commenté : DAN TURMACU le 21 Mar 2019
Hello!
How can I run such kind of optimization :
max Q subject to x = x1,..., xn, where = Rp / σp
and constraints :
Rp = R' * x
σp^2 =x' * Σ * x
sum(x) = 1
Can someone help me about how to write down my objective function ...and the rest of the constraints. What type of sover I need to use ?
Best regards,
  2 commentaires
Walter Roberson
Walter Roberson le 21 Mar 2019
I think part of the equations got lost?
What is Q?
You say "where = " but what needs to equal that?
Why do you say "subject to" and list variable names?
In Rp / op is that matrix division (least squared fitting) or is it element-by-element division ?
DAN TURMACU
DAN TURMACU le 21 Mar 2019
Modifié(e) : DAN TURMACU le 21 Mar 2019
yes.
Q = Rp / σp
Rp - Return of portfolio it is a number
σp - Risk of portfolio it is a number
but R' , Σ are matrix
The constraint is sum(x) = 1.

Connectez-vous pour commenter.

Réponse acceptée

DAN TURMACU
DAN TURMACU le 21 Mar 2019
Dear Torsten,
I have another unexpected problem.
When I run x = fmincon(fun,x0,A,b,Aeq,beq) in Command Window, I receive the error message:
Undefined function or variable 'returns'.
Error in @(x)-(x'*returns)/sqrt(x'*sigma*x)
Error in fmincon (line 564)
initVals.f = feval(funfcn{3},X,varargin{:});
Caused by:
Failure in initial user-supplied objective function evaluation. FMINCON
cannot continue.
I do not understand. I provided with returns and sigma matrixes in Workspace Window.
Thank you.
  2 commentaires
Torsten
Torsten le 21 Mar 2019
Modifié(e) : Torsten le 21 Mar 2019
Write a .m file and load it into matlab.
BTW: "returns" must be a vector of the same length as x, not a matrix.
DAN TURMACU
DAN TURMACU le 21 Mar 2019
Now it is ok. I have to run fun script first.
Many thanks,
Dan

Connectez-vous pour commenter.

Plus de réponses (1)

Torsten
Torsten le 21 Mar 2019
Modifié(e) : Torsten le 21 Mar 2019
Use fmincon with objective function
f = @(x)(R'*x)/sqrt(x'*sigma*x)
and linear constraint
Aeq = ones(size(x))
beq = 1
Best wishes
Torsten.
  6 commentaires
Torsten
Torsten le 21 Mar 2019
f = @(x)-(R'*x)/sqrt(x'*sigma*x)
DAN TURMACU
DAN TURMACU le 21 Mar 2019
Thanks.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Get Started with Optimization Toolbox dans Help Center et File Exchange

Produits


Version

R2008a

Community Treasure Hunt

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

Start Hunting!

Translated by