data:image/s3,"s3://crabby-images/1639f/1639f245117b7fecd01f797e7591ac28b7b5e1c8" alt="1Shade the region between a curve and the vertical axis - 2020 01 06.png"
Shade the region between a curve and the vertical axis
22 ビュー (過去 30 日間)
古いコメントを表示
I have several velocity profiles in a figure, and I've been trying to play around with the area function to try and shade the region between the curve a vertical line. I'm looking to create a plot like this.
data:image/s3,"s3://crabby-images/9801d/9801de1f3edcad71d1c46299c5796ff1084b3ca8" alt="Screen%20Shot%202014-03-16%20at%208.45.32%20PM.png"
Here is the relavent parts of my code.
% V is the dependent variable, plotted on the x-axis
% Y is the independent variable, plotted on the y-axis
% My actual data is not attached but you can use tan(x) -1<x<1 or tan^-1(x) mirrored about y = x
Y = linspace(-1,1,50);
V = atan(Y);
% R is an array for the radial positions along the wing, the zero location has to move with each radial position
R = 1:4; % for this case
% plot data
plot(V+(R(1)),Y); % only using the first R value for this example
% draw vertical line for reference
plot(R(1)*ones(1,50),Y,'k')
data:image/s3,"s3://crabby-images/ce930/ce930f464a4d7306b3911425480d15da964ff53b" alt="Capture.PNG"
Now if I try to shade in the region, let's say from a base of 0 this is the result.
area(V+R(1),Y,1,'facealpha',0.5)
data:image/s3,"s3://crabby-images/a4712/a4712649f54ae1276e442d76f25fc9ab87b6972e" alt="Capture2.PNG"
As expected the area function fills in the region from Y = 1 to V. I tried switching X and Y as some have suggested, but I don't get the results I would like. The area function does what's it's supposed to and shades in the region up to V = atan(X)+1 from Y = 1.
data:image/s3,"s3://crabby-images/fe055/fe055ac3fb6ce2403ad6f52e5235a71ca578cf95" alt="Capture3.PNG"
I would like to shade along the X axis (instead of Y) up to the curve.
data:image/s3,"s3://crabby-images/94f84/94f84aa0b242f9acc678bed9c7dcbff55f44d8c2" alt="Capture4.PNG"
This last figure shows what I am actually trying to accomplish but with my actual data instead of with V = atan(Y) as I did above.
data:image/s3,"s3://crabby-images/e6731/e6731fdcb03039bac655cffe51a95345bd11721a" alt="Normalized Flow Profile Utnd_C0_Q1_02_AR5_Reg110_shaded.png"
0 件のコメント
採用された回答
Star Strider
2020 年 1 月 6 日
編集済み: Star Strider
2020 年 1 月 6 日
I am not certain what you want.
Try this:
Y = linspace(-1,1,50);
V = atan(Y);
% R is an array for the radial positions along the wing, the zero location has to move with each radial position
R = 1:4; % for this case
% plot data
plot(V+(R(1)),Y); % only using the first R value for this example
% draw vertical line for reference
hold on
plot(R(1)*ones(1,50),Y,'k')
Vidx = (V+R(1)) > 1;
Vones = ones(size(V));
patch([V(Vidx)+R(1) fliplr(V(Vidx)+R(1))], [Y(Vidx) Vones(Vidx)], [0.1 0.3 0.5], 'FaceAlpha',0.3) % ‘patch’ Call
hold off
It uses the patch function to define the area I believe you want to shade. Increase the number of elements in ‘Y’ to increase the resolution of the patch object.
EDIT —
Added plot image —
data:image/s3,"s3://crabby-images/1639f/1639f245117b7fecd01f797e7591ac28b7b5e1c8" alt="1Shade the region between a curve and the vertical axis - 2020 01 06.png"
8 件のコメント
Star Strider
2020 年 1 月 8 日
As always, my pleasure.
While I would like to see the actual problem, itwould be best to post a detailed description of the problem — and your solution (and all other necessary code) — as a new Question if you want specific help with it.
It would be best to add a Comment with a link to the new Question here, for continuity.
その他の回答 (0 件)
参考
カテゴリ
Help Center および File Exchange で Annotations についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!