matlab plot颜色_Matlab在一个图里同时绘制多条曲线的两种方式

5cebcbca61f4841243ce745d945f36ae.png

接上文:

Matlab精彩画图示例:多子图

Matlab精彩画图示例:图上图

对比查看不同曲线,除了采用图上图多子图的方式,还可以采用将多条曲线画到一张图里查看,这样更方便、直观,尤其对于曲线族的绘制。

这里有两种方式:

  • 利用plot指令同时绘制多条曲线;
  • 利用hold on命令叠加绘制多条曲线。

1、plot 命令同时绘制多条曲线

Matlab代码:

48b3ac02b32c1551cd3d30684a9cfa23.png

如上图所示,plot指令可同时绘制多条曲线。

运行结果:

9d27418123997918906c2f698a76d43c.png

2、hold on 命令叠加绘制多条曲线

matlab代码:

22fc4a9c42550e6c8c03d31bc80948a9.png

如上图所示,可将数据存到一个矩阵里,利用hold on命令可在当前坐标轴上叠加绘制曲线。

hold on retains plots in the current axes so that new plots added to the axes do not delete existing plots.

程序运行结果:

2207d711fb089305fb940c13dfdb55e7.png

需要说明的一点是,即使不设置每条曲线的颜色,matlab也会自动采用不同的颜色来区分不同的曲线。

相关阅读

Matlab学习总结:基础命令、可视化、算法示例等

### 回答1: 在matlab中拟合多条曲线一个图里可以通过以下步骤实现: 第一步:准备数据。将要拟合的数据存储在一个数组中,每一列代表一条曲线。 第二步:设置图像属性。使用“subplot”函数创建一个包含多个子图的图像,并设置横轴和纵轴的标签以及标题。 第三步:拟合曲线。对每一条曲线使用“polyfit”函数进行拟合,并使用“polyval”函数计算拟合数据。 第四步:绘制图像。使用“plot”函数绘制原始数据和拟合数据,并添加图例以区分不同曲线。 第五步:保存图像。使用“saveas”函数将图像保存为图片文件。 总之,matlab拟合多条曲线一个图里可以通过以上几个步骤轻松实现。需要注意的是,拟合方法和曲线类型应根据实际情况进行选择,并通过调整拟合参数和绘图属性来达到最佳效果。 ### 回答2: 在Matlab中,可以利用plot函数拟合多条曲线一个图里。下面介绍具体步骤: 1. 准备数据 拟合多条曲线需要准备多组数据。例如,我们要拟合y1 = f1(x)和y2 = f2(x)两条曲线,首先需要准备x向量和y向量,每组向量对应一条曲线。 2. 绘制图形 利用plot函数绘制两条曲线。在命令窗口中输入以下代码: ``` x = 0:pi/10:pi; y1 = sin(x); y2 = cos(x); plot(x, y1, x, y2); ``` 以上代码会在一个图里绘制两条曲线,一条为sin(x),另一条为cos(x)。 3. 设定曲线样式 利用plot函数的属性设置可以设定曲线样式,包括颜色、线型和标识符等。例如,以下代码将两条曲线分别设置为蓝色实线和红色虚线,并在图例中标识出y1和y2: ``` plot(x, y1, 'b-', x, y2, 'r--'); legend('y1', 'y2'); ``` 以上代码会在一个图里绘制两条曲线,蓝色实线对应y1,红色虚线对应y2,并在图例中标识出y1和y2。 4. 调整图形 可以利用axis函数调整图形的坐标轴范围和刻度。例如,以下代码将x轴范围设为0到2*pi,y轴范围设为-1到1,调整坐标轴刻度: ``` axis([0 2*pi -1 1]); xticks(0:pi/2:2*pi); yticks(-1:0.5:1); ``` 以上代码会在一个图里绘制两条曲线,x轴范围为0到2*pi,y轴范围为-1到1,并调整坐标轴刻度。 总体来说,在Matlab中拟合多条曲线一个图里非常简单,只需要准备好数据,并利用plot函数绘制曲线即可。在绘制过程中,可以根据需要调整曲线样式和图形布局。 ### 回答3: 要在一个图里拟合多条曲线,可以使用Matlabplot函数和polyfit函数。首先,要准备好要拟合的数据,并将它们存储在一个矩阵中,每一列代表一条曲线。 例如,我们想要拟合三条曲线,第一条曲线数据存储在矩阵X中的第一列,第二条曲线数据存储在X的第二列,依此类推。X的行数应该是数据点的数量。 然后,可以使用polyfit函数分别对每一列数据进行拟合,得到每一条曲线的系数。例如: coeff1 = polyfit(X(:,1), Y(:,1), n); % n 为拟合多项式的次数 coeff2 = polyfit(X(:,2), Y(:,2), n); coeff3 = polyfit(X(:,3), Y(:,3), n); 接下来,可以使用plot函数将每一条曲线绘制出来,在一个图里显示。例如: x1 = linspace(min(X(:,1)), max(X(:,1)), 100); % 将x轴范围分成100个点 y1 = polyval(coeff1, x1); % 使用polyval函数计算拟合函数的值 x2 = linspace(min(X(:,2)), max(X(:,2)), 100); y2 = polyval(coeff2, x2); x3 = linspace(min(X(:,3)), max(X(:,3)), 100); y3 = polyval(coeff3, x3); figure; % 新建一个图形窗口 hold on; % 将多条曲线绘制在同一个图里 plot(x1, y1, 'r-'); plot(x2, y2, 'g-'); plot(x3, y3, 'b-'); legend('Line 1', 'Line 2', 'Line 3'); % 设置图例 以上代码会绘制出三条拟合曲线,分别用红色、绿色和蓝色的实线表示。legend函数会添加一个图例,方便辨认每一条曲线。 此外,还可以通过设置plot函数的线型、颜色、宽度等参数,来美化图形,使它更加清晰、易读。 以上就是在Matlab中拟合多条曲线,并在一个图里显示的方法。通过这种方法,可以方便地比较不同曲线的拟合效果,进一步分析数据
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值