Getting error in fmincon with below code how to correct it
Mostrar comentarios más antiguos
% Constants
m = 1; % mass of the rocket (kg)
x_target = 10; % target displacement (m)
t_final = 10; % final time (s)
% Objective function: integral of thrust squared
objective = @(F) integral(@(t) F(t).^2, 0, t_final);
% Initial guess for thrust profile (constant thrust)
%F0 = @(t) 0.0; % Initial guess for thrust profile is a zero vector
F0 = 0.0;
% Constraints
nonlcon = @(F) rocket_constraints(F, t_final, m, x_target);
% Solve optimization problem
options = optimoptions('fmincon', 'Display', 'iter');
F_opt = fmincon(objective, F0, [], [], [], [], [], [], nonlcon, options);
Respuestas (2)
You seem to be trying to minimize over a space of functionals, F. You cannot do that with fmincon. The objective must be a function of an unknown parameter vector in
and the initial point x0 must be a vector in 
4 comentarios
Charuka
el 19 de Feb. de 2024
Matt J
el 19 de Feb. de 2024
As well it should. Again, you cannot minimize over function spaces.
Walter Roberson
el 19 de Feb. de 2024
fmincon() passes a vector the length of F0 to the objective function.
Your objective function takes that vector and tries to run an integration, with the integration trying to index the vector.
Charuka
el 20 de Feb. de 2024
If you define F0 = 0, "fmincon" will use one scalar value as input F to "objective" and "nonlcon". Thus the use of F as a function handle or function doesn't make sense.
3 comentarios
Charuka
el 19 de Feb. de 2024
The inputs to "objective" and "nonlcon" must be vectors of parameters to be optimized, not functions or function handles.
So you will have to parametrize your function to be integrated and optimize these parameters.
If you don't know how to do that, I suggest you license TOMS software which focusses on solving optimal control problems with MATLAB:
Charuka
el 20 de Feb. de 2024
Categorías
Más información sobre Linear Least Squares en Centro de ayuda y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!