Fill between two lines not working

13 visualizaciones (últimos 30 días)
Saugat Shrestha
Saugat Shrestha el 9 de Abr. de 2020
Comentada: Saugat Shrestha el 11 de Abr. de 2020
I am trying to fill the between the lines but its is only plotting the limiting lines. I cant seem to understand the problem.
Hope you can help. Thanks in advance.
figure(2)
semilogx((f_Along)*(0.1/WS),f_Along.*((PSD_AL_M))/WSP^2,'Color',...
'k','LineWidth',2)
hold on
semilogx((f_Along)*(0.1/WS),f_Along.*((SD_AL_P))/WSP^2,'Color',...
[0.7 0.7 0.7],'LineWidth',2,'DisplayName','STD+')
hold on
semilogx((f_Along)*(0.1/WS),f_Along.*((SD_AL_N))/WSP^2,'Color',...
[0.7 0.7 0.7],'LineWidth',2,'DisplayName','STD-')
hold on
x2 = [(f_Along')*(0.1/WS), fliplr((f_Along')*(0.1/WS))];
inBetween = [f_Along'.*((SD_AL_P'))/WSP^2, fliplr(f_Along'.*((SD_AL_N'))/WSP^2)]
fill(x2, inBetween, 'k');
hold on
  3 comentarios
Walter Roberson
Walter Roberson el 10 de Abr. de 2020
It would be easier if we had your data so we could test on our own system to avoid accidentally giving you a solution that does not work for your situation.
Saugat Shrestha
Saugat Shrestha el 10 de Abr. de 2020
I have attached the variables.
Thanks in advance.

Iniciar sesión para comentar.

Respuestas (1)

Star Strider
Star Strider el 9 de Abr. de 2020
Plot everything (including the patch calls) using linear axis rulers first, then convert the scale to logarithmic.
.
  8 comentarios
Star Strider
Star Strider el 10 de Abr. de 2020
@Saugat Shrestha — It would have helped to have had your data at the outset. As Walter points out, the problem is that ‘f_Along’ begins with 0. Since log(0) appraches -Inf, the transformation fails for patch.
Add before you create ‘figure(2)’:
f_Along = f_Along + eps;
and after the patch (or fill) call:
xlim([f_Along(2) f_Along(end)])
set(gca, 'XScale','log')
@Walter — Thank you.
.
Saugat Shrestha
Saugat Shrestha el 11 de Abr. de 2020
@Walter Roberson, I did as you instructed and it worked.
Thank You so much.

Iniciar sesión para comentar.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by