Hello,
I'd like to fill the gap between two a curve and a line, but only when the curve is above the line.
This is my actual code:
curve = F(:,2)';
line = 13;
plot(curve,'k');
hold on;
area(x,curve,line,'FaceColor','c','LineWidth',1);
yline(line, '--r',LineWidth=2)
Thankyou for your help!

 Akzeptierte Antwort

Cris LaPierre
Cris LaPierre am 8 Jan. 2024

1 Stimme

I think you could accomplish this by modifying the data you pass into area so that y is lever less that line.
max(curve,line)
For example:
x = 0:0.1:10;
curve = 5*sin(x) + 10;
line = 13;
plot(x,curve,'k');
hold on;
area(x,max(curve,line),line,'FaceColor','c','LineWidth',1);
hold off
yline(line, '--r',LineWidth=2)

4 Kommentare

Cora Boriga
Cora Boriga am 8 Jan. 2024
Verschoben: Matt J am 8 Jan. 2024
Thanks for your quick answer! When i try this, as you can see, the curve is choppy at the red dotted line
Admittedly, this is a pretty crude approach. It will be influenced by the resolution of your data. Consider this modification to my original example
% increased the step size
x = 0:0.5:10;
curve = 5*sin(x) + 10;
line = 13;
plot(x,curve,'k');
hold on;
area(x,max(curve,line),line,'FaceColor','c','LineWidth',1);
hold off
yline(line, '--r',LineWidth=2)
Note that this approach does not do any interpolation to find the crossing point. You may want to try upsampling your data as a way to decrease the error. Otherwise, you will need a method to approxmiate the (x,y) values of each crossing.
Cora Boriga
Cora Boriga am 11 Jan. 2024
You were right! I tried to upsample my data and now it works much better. Thankyou very much.
Image Analyst
Image Analyst am 11 Jan. 2024
If this Answer solves your original question, then could you please click the "Accept this answer" link to award the answerer with "reputation points" for their efforts in helping you? They'd appreciate it. Thanks in advance. 🙂 Note: you can only accept one answer (so pick the best one) but you can click the "Vote" icon for as many Answers as you want. Voting for an answer will also award reputation points.

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Community Treasure Hunt

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

Start Hunting!

Translated by