Matlab 画图

该文详细介绍了如何使用Matlab进行各种图形的绘制,包括散点图、折线图、柱状图、饼状图、火柴棍图等多种图表,提供了具体的代码示例,适合初学者参考学习。
摘要由CSDN通过智能技术生成

原文链接
https://blog.csdn.net/m0_62600503/article/details/125987698

画图基本指令

在这里插入图片描述

很详细

一、散点图

1.最基础的散点图

x = 0.01:0.01:0.08;
y = [3.0743,3.0707,3.0716,3.1133,3.1685,3.1778,3.2467,3.2634];  
scatter(x, y);

 
 
  • 1
  • 2
  • 3

在这里插入图片描述

2.函数专用散点图

x = linspace(-2, 2, 100);
y = x .^ 3;  
scatter(x, y);

 
 
  • 1
  • 2
  • 3

在这里插入图片描述

3.设置圆圈大小的散点图

x = linspace(-2, 2, 100);
y = x .^ 2;  
sz = linspace(1, 100, 100);
scatter(x, y, sz);

 
 
  • 1
  • 2
  • 3
  • 4

在这里插入图片描述

二、折线图

1.一条线

x = 3:2:11;
y=[4,5,9,6,4];  
plot(x, y);

 
 
  • 1
  • 2
  • 3

在这里插入图片描述

2.多条线

x = 3:2:11;
y=[4,5,9,6,4;5,8,2,4,3];  
plot(x, y);

 
 
  • 1
  • 2
  • 3

在这里插入图片描述

三、柱状图(三种)

1.最基础的柱形图

x = 3:2:11;
y=[4,5,9,6,4];  
bar(x, y);

 
 
  • 1
  • 2
  • 3

在这里插入图片描述

2.多变量柱形图

x=3:5;
y=[4,5,9,6,4;5,7,9,8,7;1,3,5,9,7];  
bar(x,y);

 
 
  • 1
  • 2
  • 3

在这里插入图片描述

3.三维的柱形图

只需要把bar换成bar3即可。

x=3:5;
y=[4,5,9,6,4;5,7,9,8,7;1,3,5,9,7];  
bar3(x,y);

 
 
  • 1
  • 2
  • 3

在这里插入图片描述

4.堆叠形柱形图

y=[4,5,9,6,4;5,7,9,8,7;1,3,5,9,7];
bar(y,'stacked');

 
 
  • 1
  • 2

在这里插入图片描述

5.水平柱形图

只需要把bar改成barh即可:

y=[4,5,9,6,4;5,7,9,8,7;1,3,5,9,7];
barh(y);

 
 
  • 1
  • 2

在这里插入图片描述

四、火柴棍图(挺好看的)

clc;clear;
x =linspace(0,2*pi,60);
y = sin(x);
stem(x,y);

 
 
  • 1
  • 2
  • 3
  • 4

在这里插入图片描述

clc;clear;
x =linspace(0,2*pi,60);
y1 = sin(x);
y2 = cos(x);
stem(x,y1);
hold on
stem(x,y2);

 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

在这里插入图片描述

五、饼状图

1.基本饼状图

y=[4,5,9,6,4];  
pie(y);

 
 
  • 1
  • 2

在这里插入图片描述

2.三维饼状图

把pie该为pie3即可

y=[4,5,9,6,4];  
pie3(y);

 
 
  • 1
  • 2

在这里插入图片描述

3.突出某一扇形的饼状图

X=[2,2,1,5,2];
explode = [0 1 0 0 0];
pie(X,explode);

 
 
  • 1
  • 2
  • 3

在这里插入图片描述

六、面积图

x=3:8;
y=[45,6,8;7,4,7;6,25,4;7,5,8;9,9,4;2,6,8]; 
area(x,y);

 
 
  • 1
  • 2
  • 3

在这里插入图片描述

七、雷达图

在另一篇博客上有详解,如下:
Matalb画雷达图(四行代码)
在这里插入图片描述
在这里插入图片描述

八、双坐标图

分别控制左右坐标就可以了,不要太简单。而且可以很多种图形任意搭配。

 x= 1:3;
 y= [9.0725,9.075,9.5175];
 w= [229,230,207];
 yyaxis left%控制左纵轴
 bar(x,y);
 yyaxis right%控制右纵轴
 plot(x,w);

 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

在这里插入图片描述

九、图像分割函数subplot

subplot函数:
使用方法:subplot(m,n,p)或者subplot(m n p)。
subplot是将多个图画到一个平面上的工具。其中,m表示是图排成m行,n表示图排成n列。顺序是先从左到右,再从上到下。p即表示第几个图。

subplot(1,2,1);
y = [3.4308,3.2773,3.1345,3.0526,3.7684,8.1929,15.7455,18.9201]; 
pie(y);
subplot(1,2,2);
y1=[3.0743,3.0707,3.0716,3.1133,3.1685,3.1778,3.2467,3.2634];
pie(y1);

 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

在这里插入图片描述
再画一个,便于理解:

subplot(2,2,1);
y = [5,9,3,4,7,8,11,6]; 
plot(y);
subplot(2,2,2);
x=3:8;
y=[45,6,8;7,4,7;6,25,4;7,5,8;9,9,4;2,6,8]; 
area(x,y);
subplot(2,2,3);
x =linspace(0,2*pi,60);
y1 = sin(x);
y2 = cos(x);
stem(x,y1);
hold on
stem(x,y2);
subplot(2,2,4);
y=[4,5,9,6,4;5,7,9,8,7;1,3,5,9,7];
barh(y);

 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

在这里插入图片描述

十、罗盘图

clc;clear;
x=-pi:pi/10:pi;
y=sin(x)+cos(x);
compass(x,y,'G')

 
 
  • 1
  • 2
  • 3
  • 4

在这里插入图片描述

十一、瀑布图

MyWaterFall([6 -3 4 -5 8],["A" "B" "C" "D" "E"]);

 
 
  • 1

以下是函数:别忘记换文件名了。

function hfig = MyWaterFall(data, Xlabel)
len = length(data);
hfig = figure;
axes1 = axes('Parent',hfig);
hold on;
width = 40;
xbegin = 10;
ybegin = 0;
set(axes1, 'XTick', xbegin+width/2:width*1.5:xbegin+width/2+(len+1)*1.5*width,...
    'XTickLabel', [Xlabel "总计"]);
for i = 1:len
    if data(i) >= 0 
        text(xbegin+width/2+(i-1)*1.5*width, sum(data(1:i)), num2str(data(i), '%g'),...
            'HorizontalAlignment','center','VerticalAlignment','bottom');
    else
        text(xbegin+width/2+(i-1)*1.5*width, sum(data(1:i)), num2str(data(i), '%g'),...
            'HorizontalAlignment','center','VerticalAlignment','top');
    end
end
if sum(data) >= 0
    text(xbegin+width/2+(len)*1.5*width, sum(data), num2str(sum(data), '%g'),...
        'HorizontalAlignment','center','VerticalAlignment','bottom');
else
    text(xbegin+width/2+(len)*1.5*width, sum(data), num2str(sum(data), '%g'),...
        'HorizontalAlignment','center','VerticalAlignment','top');
end
for i = 1:len
    if data(i) >= 0
        rectangle('Position',[xbegin, ybegin, width, data(i)],'facecolor',[0.8500 0.3250 0.0980],...
            'LineWidth',0.5);
    else
        rectangle('Position',[xbegin, ybegin+data(i), width, -data(i)],'facecolor',[0 0.4470 0.7410],...
            'LineWidth',0.5);
    end
    plot([xbegin+width xbegin+1.5*width],[ybegin+data(i) ybegin+data(i)],'k-');
    xbegin = xbegin + width * 1.5;
    ybegin = ybegin +data(i);
end
if sum(data) >= 0
    rectangle('Position',[xbegin, 0, width, ybegin],'facecolor',[0.8500 0.3250 0.0980],...
        'LineWidth',0.5);
else
    rectangle('Position',[xbegin, ybegin, width, -ybegin],'facecolor',[0.8500 0.3250 0.0980],...
        'LineWidth',0.5);
end
end

 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46

在这里插入图片描述

十二、总结

目前就写这么多吧,还有哪些好图,评论留言告诉博主呀,以后会不断的更新,尽量总结出所有的图。创作不易,记得点赞关注哦。

</article>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值