Optimise a reference that cuts my curve into 2 equal sections

조회 수: 1 (최근 30일)
fadi awar
fadi awar 2022년 2월 12일
편집: Matt J 2022년 2월 12일
Hello,
I am collecting data from excel, then basic idea is that i want to determine a constant value line that cuts my curve into 2 eqaual sections (area above the line and the curve = area under).
The objective is to determine the value of the red line.

채택된 답변

Matt J
Matt J 2022년 2월 12일
편집: Matt J 2022년 2월 12일
%t= time, X=consumption, x=unknown midline
tc=t-t(1);
Xc=cumtrapz(t,X);
x=optimvar('x');
sol=solve( optimproblem('Objective',x,'Constraints',Xc-x*tc<=90,'ObjectiveSense','minimize') );
lb=sol.x; %lower bound
sol=solve( optimproblem('Objective',x,'Constraints',10<=Xc-x*tc,'ObjectiveSense','maximize') );
ub=sol.x; %upper bound
if lb>ub
disp 'Problem is infeasible'
else
xunc=trapz(t,X)/(t(end)-t(1)); %unconstrained solution
x=min(max(xunc,lb),ub); %constrained solution
end
  댓글 수: 3
Matt J
Matt J 2022년 2월 12일
편집: Matt J 2022년 2월 12일
You probably need to upgrade your Matlab version.
If you cannot upgrade, you can try my revised version.
fadi awar
fadi awar 2022년 2월 12일
Yeah, this one worked.
Thank you for your help!

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

추가 답변 (2개)

William Rose
William Rose 2022년 2월 12일
If you mean that the area between the red line and the blue curve abve the line equals the area between the red line and the blue curve below the line, then the height of the red line is simply the mean value of the blue line data.
  댓글 수: 5
dpb
dpb 2022년 2월 12일
Attach the data as a .mat file.
Just looking at the graph, I'd venture it isn't possible to meet the constraints that the integral of the area be <95 when the magnitudes of the integrand are in the thousands. Just by a very crude approximation of the leftmost area (brown?) as roughly a rectangle of height ~(2800-1800) and a duration of 12, the integral would be roughly 1000*12 --> 12,000. Unless there's a very small scaling factor to be applied, it "just ain't a-gonna' happen".
fadi awar
fadi awar 2022년 2월 12일
Kindly find attached the files.
I am to get the result according to my limits even if in this case of chosen data it wont matter a lot.
But Future wise I will be chaniging the data.
Thank you

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


Catalytic
Catalytic 2022년 2월 12일
편집: Catalytic 2022년 2월 12일
midline = trapz(x,y)/(max(x)-min(x))

카테고리

Help CenterFile Exchange에서 Subplots에 대해 자세히 알아보기

제품


릴리스

R2018b

Community Treasure Hunt

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

Start Hunting!

Translated by