How do I shade the area between two STAIR curve

10 次查看(过去 30 天)
I am trying to fill the area between two stair curves. I can do this successfully between lines but I need stairs.
This is the code that I wrote:
X=[x,fliplr(x)];X=[X;X];
Y=[y2,fliplr(y1)]; Y=[Y;Y];
clf;
fill(X([2:end end]),Y(1:end),rgb('orange'),'FaceAlpha',0.2);
Where x represents the common, evenly spaced axis and y1 and y2 represent the data for the lower and upper curve respectively. My problem is that when graphed the lower curve is offset by one "bin". I understand this is coming from the X([2:end end]) but this is the inly way I found to fill with the stairs.
I would appreciate any suggestions.
Deborah
  1 个评论
Florian
Florian 2016-1-25
编辑:Florian 2016-1-25
I did not find a solution either, so I figured out a way myself.
Here is a little example: - I "imitate" the stairs function (by keeping the previous y-value until the next) - I did not manage to fill the space between the stairs "in one step" (it always looked weird), so I did it piecewise. (for-loop)
Maybe my solution is not the best but it works.
% X-Data
X = 0:23;
% Y-Data
Y1 = sin(X .* (2*pi/max(X)) ); % Func 1
Y2 = Y1 + 0.1*sin(X .* (2*pi/max(X)) ); % Func 2
% Create "Stairs-Function"
Xi = [X(sort([1:length(X), 2:length(X)])), X(end)+(X(end)-X(end-1))];
Y1i = [Y1(sort([1:length(X), 1:length(X)]))];
Y2i = [Y2(sort([1:length(X), 1:length(X)]))];
% Plot Stairs
figure(2)
hold off;
plot(Xi, Y1i, 'r-');
hold all;
plot(Xi, Y2i, 'k-');
% Fill Stairs
for i = 1:2:length(Xi)
if ( Y1i(i) > Y2i(i) ) % Upper
xx = [Xi(i:i+1), fliplr(Xi(i:i+1))];
yy = [Y1i(i:i+1), fliplr(Y2i(i:i+1))];
fill(xx, yy, 'k', 'FaceAlpha',0.2);
elseif ( Y2i(i) > Y1i(i) ) % Lower
xx = [Xi(i:i+1), fliplr(Xi(i:i+1))];
yy = [Y1i(i:i+1), fliplr(Y2i(i:i+1))];
fill(xx, yy, 'r', 'FaceAlpha',0.2);
else % Identical
% do nothing
end
end
% Draw Lines Again
plot(Xi, Y1i, 'r-');
plot(Xi, Y2i, 'k-');
title('Coded Stairs Function');
Cheers Florian
PS.: I added it to the file exchange fillstairs

请先登录,再进行评论。

回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Interpolation 的更多信息

标签

Community Treasure Hunt

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

Start Hunting!

Translated by