Gradient optimization problem with fmincon

Hi I'm currently working on an optimzation problem where I need to optimization a design dimension to minimize the ROI with Sequential Quadratic Programing with fmincon. However, I don't really know how the fmincon work and how my constrain will need to implement into the code. I'm new to matlab
Thank you for your time,
Here is my equation and constrain that I want to put in Matlab
with r is the radius and l is the length of the tank

댓글 수: 11

ROI is the function that I want to minimize using fmincon
Torsten
Torsten 2021년 5월 19일
What are you trying to minimize ?
Your ROI is constant and equals -0.95.
I tried to minimize the ROI
ROI depends on radius and length
I found the constraint between them and other requirements constraints. I just don't know how to do fmincon and how to put those constraint. Please help
Here are your variables are r and l. What constraints (in a range of numbers) do you have for r (radius) and l (length)?
Torsten
Torsten 2021년 5월 19일
Your ROI doesn't depend on l and r.
It's constant and equals -0.95.
Can you explain me why it doesn't depend on it cuz the volume change in the response of r and l. If r and l change the ROI needs to be changed also. how do you get -0.95 from it
these are the constrainst
This is the volume function
my initial design is 5000 for length and 500 for radius
yeah you are right it doesn't depends. I think in this case imma minimize the volume

댓글을 달려면 로그인하십시오.

답변 (1개)

Sulaymon Eshkabilov
Sulaymon Eshkabilov 2021년 5월 19일

0 개 추천

Here is a simple solution to your exercise. Adjust your constrains for r (radius) and l (length).
% NOTE: RL(1) is R and RL(2) is L.
ROI =@(RL) (.05*(509.7*pi(RL(1)^3+RL(1)^2*RL(2))+5.505e3*RL(1)^2)-509.7*pi*(RL(1)^3+RL(1)^2*RL(2))+5.505e3*RL(1)^2)/(509.7*pi*(RL(1)^3+RL(1)^2*RL(2))+5.505e3*RL(1)^3);
Rb = [0,0];
% NOTE: 0<=R<=5; 0<=L<=15; Thus, Rb= [0, 0]; and Lb = [5, 15];
Lb = [5, 15];
% No Other constraints are considered here
A = [];
b = [];
Aeq = [];
beq = [];
x0 = (Lb + Rb)/2;
RL = fmincon(ROI,x0,A,b,Aeq,beq,Lb,Rb);
R = RL(1);
L = RL(2);
fprintf('Found values: R = %f [ft] L = %f [ft] \n', [R, L])
Good luck.

댓글 수: 9

can you explain for me what is Lb and Rb
Thank you so much
what is @RL is it the first derivative in term of r and l
RL is the variable: RL = [r, l];
Sulaymon Eshkabilov
Sulaymon Eshkabilov 2021년 5월 19일
편집: Sulaymon Eshkabilov 2021년 5월 19일
Now you have edited your problem statement significantly from the initially posted one. That means your function for minimization would be V(r, l) in the proposed code of mine.
And the constrains for r and l need to be inserted properly.
ok do I need to delete the x0 ( it's the midpoint, isn't it)
That is an initial guess value. The search starts w.r.t x0 values. Good luck with your sims.
Yeah I tried to put the constraints but my constraints is non linear
c(1)= L + R - 131.23; % height of tank
c(2) = 1224.303*RL(1)^2; % height of distance, fuel needed
c(3) = (RL(1)*RL(2))/(2*(RL(2)+RL(1)))- 0.25; % thickness of tank
Torsten
Torsten 2021년 5월 20일
편집: Torsten 2021년 5월 20일
The first constraint is linear, the second is superfluous and the third can be put in function "nonlcon".
Read the documentation of fmincon for more details.

댓글을 달려면 로그인하십시오.

카테고리

도움말 센터File Exchange에서 Surrogate Optimization에 대해 자세히 알아보기

제품

질문:

2021년 5월 19일

편집:

2021년 5월 20일

Community Treasure Hunt

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

Start Hunting!

Translated by