how to write years in xtick.

2 visualizaciones (últimos 30 días)
ravi
ravi el 26 de Mayo de 2014
Comentada: ravi el 19 de Jun. de 2014
sir i want to write years in xtick like this figure and also write R2 value in figure how can do this? please help.thank you in advance.

Respuestas (2)

Chad Greene
Chad Greene el 18 de Jun. de 2014
If your x vector is in datenum format, you can use datetick('x','yyyy').

Azzi Abdelmalek
Azzi Abdelmalek el 26 de Mayo de 2014
  4 comentarios
Azzi Abdelmalek
Azzi Abdelmalek el 18 de Jun. de 2014
I adapted the code from the previous link to plot x,y
% Generate some test data. Assume that the X-axis represents months.
x = 1901:3:2003
y = 10*rand(1,length(x));
% Plot the data.
h = plot(x,y);
% Reduce the size of the axis so that all the labels fit in the figure.
pos = get(gca,'Position');
set(gca,'Position',[pos(1), .2, pos(3) .65])
% Add a title.
title('This is a title')
% Set the X-Tick locations so that every other month is labeled.
Xl = [1901 2003];
set(gca,'XTick',x,'XLim',Xl);
% Add the months as tick labels.
years=cellfun(@num2str,num2cell(x),'un',0)
ax = axis; % Current axis limits
axis(axis); % Set the axis limit modes (e.g. XLimMode) to manual
Yl = ax(3:4); % Y-axis limits
% Place the teaxt labels
t = text(x,Yl(1)*ones(1,length(x)),years);
set(t,'HorizontalAlignment','right','VerticalAlignment','top', ...
'Rotation',90);
% Remove the default labels
set(gca,'XTickLabel','')
% Get the Extent of each text object. This
% loop is unavoidable.
for i = 1:length(t)
ext(i,:) = get(t(i),'Extent');
end
% Determine the lowest point. The X-label will be
% placed so that the top is aligned with this point.
LowYPoint = min(ext(:,2));
% Place the axis label at this point
XMidPoint = Xl(1)+abs(diff(Xl))/2;
tl = text(XMidPoint,LowYPoint,'X-Axis Label', ...
'VerticalAlignment','top', ...
'HorizontalAlignment','center');
ravi
ravi el 19 de Jun. de 2014
sir when i am adding your code in my code then years are perfectly plot in the figure but timeseries is not ploting(showing blank) because yaxis limit set 0 to 1.how can remove this fault from code
subplot(2,2,2);
yrs = linspace(1,86,86);
rainfall = y2;
b = polyfit(yrs,rainfall, 1);
fr = polyval(b, yrs);
plot(yrs, rainfall, '-b')
hold on
plot(yrs, fr, '-r')
hold off
h1 = legend('Data', 'Linear', 'Location','NE');
set(h1, 'FontSize',8)
[xlim ylim]
textposx = diff(xlim)*0.50+min(xlim);
textposy = diff(ylim)*0.95+min(ylim);
text(textposx,textposy, sprintf('y = %.2f*x %c %0.2f', b(1),
char(45-(sign(b(1))+1)), abs(b(2))), 'FontSize',8)
title(' CCSM4(rcp2.6) : hr')
xl = get(gca,'xlim')';
xt=linspace(xl(1),xl(2),2100-2015+1);
set(gca,'xtick',xt)
set(gca,'xticklabel',cellfun(@num2str,num2cell(2015:2100),'un',0))
xlabel('\fontname{Arial}Year','fontSize',10,'fontWeight','bold','FontName','Arial');
ylabel('\fontname{Arial}Rainfall(mm)','fontSize',10,'fontWeight','bold','FontName','Arial');
%text(0.6,0.85,'R2=-0.2580')
% Set the X-Tick locations so that every other month is labeled.
x = 2015:5:2100
Xl = [2015 2100];
set(gca,'XTick',x,'XLim',Xl);
% Add the months as tick labels.
years=cellfun(@num2str,num2cell(x),'un',0)
ax = axis; % Current axis limits
axis(axis); % Set the axis limit modes (e.g. XLimMode) to manual
Yl = ax(3:4); % Y-axis limits
% Place the teaxt labels
t = text(x,Yl(1)*ones(1,length(x)),years);
set(t,'HorizontalAlignment','right','VerticalAlignment','top', ... 'Rotation',90);
% Remove the default labels
set(gca,'XTickLabel','')
% Get the Extent of each text object. This
% loop is unavoidable.
for i = 1:length(t)
ext(i,:) = get(t(i),'Extent');
end
% Determine the lowest point. The X-label will be
% placed so that the top is aligned with this point.
LowYPoint = min(ext(:,2));
% Place the axis label at this point
XMidPoint = Xl(1)+abs(diff(Xl))/2;
tl = text(XMidPoint,LowYPoint,'Year','fontSize',10,'fontWeight','bold','FontName','Arial','VerticalAlignment','top','HorizontalAlignment','center');

Iniciar sesión para comentar.

Categorías

Más información sobre Axis Labels en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by