matlab plotyy 坐标轴设置,[转载]Matlab plotyy画双纵坐标图实例[通俗易懂]

matlab plotyy 坐标轴设置,[转载]Matlab plotyy画双纵坐标图实例[通俗易懂]Matlabplotyy画双纵坐标图实例x=0:0.01:20;y1=200*exp(-0.05*x).*sin(x);y2=0.8*exp(-0.5*x).*sin(10*x);[AX,H1,H2]=plotyy(x,y1,x,y2,’plot’);set(AX(1),’XColor’,’k’,’YColor’,’b’);set(AX(2),’XColor’,’k’,’YCol…

大家好,又见面了,我是你们的朋友全栈君。

Matlab plotyy画双纵坐标图实例

x = 0:0.01:20;

y1 = 200*exp(-0.05*x).*sin(x);

y2 = 0.8*exp(-0.5*x).*sin(10*x);

[AX,H1,H2] = plotyy(x,y1,x,y2,’plot’);

set(AX(1),’XColor’,’k’,’YColor’,’b’);

set(AX(2),’XColor’,’k’,’YColor’,’r’);

HH1=get(AX(1),’Ylabel’);

set(HH1,’String’,’Left Y-axis’);

set(HH1,’color’,’b’);

HH2=get(AX(2),’Ylabel’);

set(HH2,’String’,’Right Y-axis’);

set(HH2,’color’,’r’);

set(H1,’LineStyle’,’-‘);

set(H1,’color’,’b’);

set(H2,’LineStyle’,’:’);

set(H2,’color’,’r’);

legend([H1,H2],{‘y1 = 200*exp(-0.05*x).*sin(x)’;’y2 =

0.8*exp(-0.5*x).*sin(10*x)’});

xlabel(‘Zero to 20 musec.’);

title(‘Labeling plotyy’);

73976953_1

Q:右边用蓝色圈起来的tick能去掉吗?由于用plotyy画图,为了使图尽量地显示出来,用了set(AX(1),’YLimMode’,’auto’),但这样可能会导致左边AX(1)和右边AX(2)的tick的间距不一样,影响美观。或者说能不能使plotyy画出的图两边的tick间距是一样的,这样在图形右边的tick就会重合在一起.

A:如果只是想让plotyy的图美一些,可以使用其如下形式的调用方式:

[AX,H1,H2] = plotyy(…)

其中AX(2)就是右边Axes对象的句柄,拿到它以后就可以set或者get来处理了,也可以把其ytick关掉。

A:也可以用line语句来画,就没有左边和上边的线了。

Q:plotyy(X1,Y1,X2,Y2,FUN1,FUN2),FUN1和FUN2应该怎么写?

A:这两个FUN代表plotyy不一定要用两个plot,比如下面的例子,一条曲线用plot,一条用semilogy

x1=1:0.1:100;

x2=x1;

y1=x1;

y2=x2.^3;

plotyy(x1,y1,x2,y2,@plot,@semilogy)

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

MATLAB画双纵坐标

具有两个纵坐标标度的图形

在MATLAB中,如果需要绘制出具有不同纵坐标标度的两个图形,可以使用plotyy绘图函数。调用格式为:

plotyy(x1,y1,x2,y2)

其中x1,y1对应一条曲线,x2,y2对应另一条曲线。横坐标的标度相同,纵坐标有两个,左纵坐标用于x1,y1数据对,右纵坐标用于x2,y2数据对。

双y轴坐标可以用plotyy(x,y1,x,y2)来实现

双x坐标可以用

set(gca,’xaxislocation’,’bottom’,’xticklabel’,{‘0′,’1′,’2′,’3′,’4’})

(假设x轴的标注为1,2,3,4)

set(gca,’xaxislocation’,’top’,’xticklabel’,{‘0′,’1′,’2′,’3′,’4’})

进行相应的设置

【 * 例 10.7.3 -1 】制作一个双坐标系用来表现高压和低温两个不同量的过渡过程。

tp=(0:100)/100*5;yp=8+4*(1-exp(-0.8*tp).*cos(3*tp)); % 压力数据

tt=(0:500)/500*40;yt=120+40*(1-exp(-0.05*tt).*cos(tt)); %

温度数据

% 产生双坐标系图形

clf reset,h_ap=axes(‘Position’,[0.13,0.13,0.7,0.75]);

%<4>

set(h_ap,’Xcolor’,’b’,’Ycolor’,’b’,’Xlim’,[0,5],’Ylim’,[0,15]);

nx=10;ny=6; %<6>

pxtick=0:((5-0)/nx):5;pytick=0:((15-0)/ny):15;

%<7>

set(h_ap,’Xtick’,pxtick,’Ytick’,pytick,’Xgrid’,’on’,’Ygrid’,’on’)

h_linet=line(tp,yp,’Color’,’b’);

%<9>

set(get(h_ap,’Xlabel’),’String’,’ 时间 /rightarrow (分) ‘)

set(get(h_ap,’Ylabel’),’String’,’ 压力 /rightarrow(/times10 ^{5}

Pa )’)

h_at=axes(‘Position’,get(h_ap,’Position’));

%<12>

set(h_at,’Color’,’none’,’Xcolor’,’r’,’Ycolor’,’r’);

%<13>

set(h_at,’Xaxislocation’,’top’)

%<14>

set(h_at,’Yaxislocation’,’right’,’Ydir’,’rev’)

%<15>

set(get(h_at,’Xlabel’),’String’,’/fontsize{15}/fontname{ 隶书 } 时间

/rightarrow (分) ‘)

set(get(h_at,’Ylabel’),’String’,’ ( {/circ}C )/fontsize{15}

/leftarrow /fontname{ 隶书 } 零下温度 ‘)

set(h_at,’Ylim’,[0,210]) %<18>

line(tt,yt,’Color’,’r’,’Parent’,h_at)

%<19>

xpm=get(h_at,’Xlim’); %<20>

txtick=xpm(1):((xpm(2)-xpm(1))/nx):xpm(2);

%<21>

tytick=0:((210-0)/ny):210;

%<22>

set(h_at,’Xtick’,txtick,’Ytick’,tytick)

%<23>

73976953_2

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

实例(已验证):

clc;

clear all;

close all;

x=0:0.1:2*pi;

y1=sin(x);

y2=cos(x);

[AX]=plotyy(x,y1,x,y2);

set(get(gca,’xlabel’),’string’,’X-axis’);

set(get(AX(1),’Ylabel’),’string’,’left Y-axis’);

set(get(AX(2),’Ylabel’),’string’,’right Y-axis’);

set(gca,’xTick’,[0:0.5:7]);

set(AX(1),’yTick’,[-1:0.2:1]);

set(AX(2),’yTick’,[-1:0.5:1]);

73976953_3

尚存在问题:这种设置方法,对各个轴的最小刻度单位可以设置,但是刻度范围(x取(0~7),y1取(-1~1))不能设置。

2010-12-23修改

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

clc

clear all

close all

runoff=[10700 11400 15800 22900 43100 40700 50500 46000 41800

35000];

sed=[0.105 0.094 0.156 1.264 0.363 0.429 0.731 0.682 0.654 0.290];

m=1:10;

[ax,h1,h2]=plotyy(m,runoff,m,sed); %h– line handle

set(get(ax(1),’Ylabel’),’string’,’Runoff (m^3/s))’,’color’,’r’)

%y1

set(get(ax(2),’Ylabel’),’string’,’Sediment concentration

(kg/m^3)’,’color’,’k’) %y2

xlabel(‘Month’)

set(h1,’linestyle’,’-‘,’color’,’r’); set(h2,’linestyle’,’- -‘,’color’,’k’);

legend([h1 h2],’runoff’,’sediment concentration’) %标注两条线

legend(‘boxoff’)

% box off

set(ax(:),’Ycolor’,’k’) %设定两个Y轴的颜色为黑色

set(ax(1),’ytick’,[0:10000:100000]); %设置y轴间隔

set(ax(2),’ytick’,[0:0.1:1.5])

set(ax,’xlim’,[1 12]) % 设置x轴范围

hold on

scatter(ax(1),4,22900,’r*’)

axes(ax(2));

hold on

scatter(4,1.264,’ro’)

73976953_4

2011年4月22日新增

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/150679.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SecureCRT中文乱码解决方法(6)

    SecureCRT中文乱码解决方法(6)1、重新查看会话,是否中文显示正常2、依然无法正常显示中文,可能是由于Linux系统中默认的字符编码非UTF8所致用root用户登录。输入cat/etc/sysconfig/i18n如果安装系统为中文系统,则修改【LANG=“zh_CN.UTF-8”】如果安装系统为英文系统,则修改【LANG=“en_US.UTF-8”】保存文件。断开SSH,重新登录。就正常了下面是修改…

    2022年7月17日
    17
  • C语言判断回文字符串(指针)

    C语言判断回文字符串(指针)东北大学在线编程社区problem1678题目描述:编写函数:intfun(char*p),功能是判断一个字符串是否是回文字符串(提示:回文字符串是指正读和反读都一样的字符串),要求从主函数中由键盘输入字符串,调用函数fun后,根据函数fun的返回值,主函数输出是否为回文字符串的判断。输入样例:haah输出样例:是回文串//该代码使用MicrosoftVisualStudio2019编写#define_CRT_SECURE_NO_WARNINGS#include<stdio.

    2022年5月4日
    48
  • 自动构建(CICD)

    自动构建(CICD)Docker、Kubernetes的CICD实现思路Jenkins是一个比较流行的持续集成工具GitLab是存储镜像的镜像仓库由客户端将代码push推送到git仓库,gitlab上配置了一个webHook的东西可以触发Jenkins的构建。进入到Jenkins虚线范围内,它所做的事情非常多,从mvn构建代码,对代码进行静态分析,做单元测试,测试通过之后就可以build镜像,镜像构建成功后…

    2022年5月3日
    64
  • 关于学习的名言_classnotdeffounderror

    关于学习的名言_classnotdeffounderror 现在java编程中经常碰到ClassCastException错误,ClassCastException是JVM在检测到两个类型间的转换不兼容时引发的运行时异常。此类错误通常会终止用户请求。本模式试图为您提供了解和排除ClassCastException错误最常见成因的一些基本要素。为什么发生此问题?在执行几乎任何子系统(Web容器、EJB、JCA、群集等)的应用程序代码或…

    2022年9月10日
    0
  • ETL开发面试题集

    ETL开发面试题集ETL讲解(很详细!!!)ETL是将业务系统的数据经过抽取、清洗转换之后加载到数据仓库的过程,目的是将企业中的分散、零乱、标准不统一的数据整合到一起,为企业的决策提供分析依据。ETL是BI项目重要的一个环节。通常情况下,在BI项目中ETL会花掉整个项目至少1/3的时间,ETL设计…

    2022年6月13日
    73
  • 【数据增强】Cutout「建议收藏」

    【数据增强】Cutout「建议收藏」论文:ImprovedRegularizationofConvolutionalNeuralNetworkswithCutout.Github:https://github.com/uoguelph-mlrg/Cutout.Cutout的出发点和随机擦除一样,也是模拟遮挡,目的是提高泛化能力,实现上比RandomErasing简单,随机选择一个固定大小的正方形区域,然后采用全0填充就OK了,当然为了避免填充0值对训练的影响,应该要对数据进行中心归一化操作,norm到0。(如果你还不了

    2022年9月25日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号