Non-uniform axis spacing in a plot
65 visualizzazioni (ultimi 30 giorni)
Mostra commenti meno recenti
Hi all,
I have two vectors: A = [0.5,0.65,0.7,0.66,0.81] and B = [5,10,20,100,1000]
I would like to plot A on the y-axis and B on the x-axis, so that the x-axis has a UNIFORM spacing of the 5 elements in B. Instead, if I simply use plot(B,A) I obtain the usual Matlab plot, in which the point 5,10,20,100 are very close one to the other on the x-axis, while 1000 is very distant.
How can I make this plot, having uniform spacing between the distante values in B?
Thanks
2 Commenti
Risposte (4)
Steven Lord
il 1 Feb 2019
Modificato: Steven Lord
il 1 Feb 2019
About the only way you'll be able to get what you want is to lie a little bit.
A = [0.5,0.65,0.7,0.66,0.81];
B = [5,10,20,100,1000];
Plot the A data with X coordinates 1, 2, ... instead of the data in B. Don't worry, we'll use B soon.
plot(A);
Show only the ticks corresponding to those integer coordinates.
xticks(1:length(A));
Set the labels for those ticks to be the elements in B.
xticklabels(string(B))
0 Commenti
Star Strider
il 1 Feb 2019
Try this:
x = 10.^(rand( 1, 20)*3); % Create Data
y = rand(1, 20); % Create Data
A = [0.5,0.65,0.7,0.66,0.81];
B = [5,10,20,100,1000];
figure
plot(x, y, 'p')
set(gca, 'XScale','log', 'XTick',B, 'XTickLabel',B, 'YTick',sort(A))
The x-axis spacing is not absolutely uniform, however this is as likely as close as it is possible to get to what you want.
0 Commenti
KSSV
il 1 Feb 2019
Modificato: KSSV
il 1 Feb 2019
Do interpolation....read about interp1
A = [0.5,0.65,0.7,0.66,0.81] ;
B = [5,10,20,100,1000] ;
plot(B,A,'*r')
hold on
Bi = linspace(min(B),max(B),100) ; % or you may use Bi = min(B):10:max(Bi)
Ai = interp1(B,A,Bi) ;
plot(Bi,Ai,'.-b')
Jianye Xu
il 13 Ago 2022
Firstly, turn x-data to categorical data. Then, use plot():
A = [0.5,0.65,0.7,0.66,0.81];
B = [5,10,20,100,1000];
B_cat = categorical(B);
figure
plot(B_cat,A)
Hope that helps.
0 Commenti
Vedere anche
Categorie
Scopri di più su Line Plots in Help Center e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!