读取Simulink中Dataset类型的数据

时间:2024-03-07 10:09:22

https://files.cnblogs.com/files/pursuiting/%E5%80%92%E7%AB%8B%E6%91%86%E6%8E%A7%E5%88%B6%E7%B3%BB%E7%BB%9F%E7%9A%84Simulink%E4%BB%BF%E7%9C%9F.pdf

在这篇文章中,针对倒立摆系统进行的Simulink建模,模型截图如下:

 

在MATLAB(R2016b)中运行该模型后,MATLAB工作空间中会有类型为Dataset的logsout变量,下面是读取并显示其中数据的MATLAB代码:

1 % 读取Simulink.SimulationData.Dataset中的数据
2 data = logsout.get(1).Values.Data;
3 t = data(:, 1);                                     %时间
4 theta = data(:, 2);                                 %角度
5 dtheta = data(:, 3);                                %角速度
6 speed = data(:, 5);                                 %速度
7 createfigure(t, theta * 200, dtheta * 400, speed);

 

createfigure.m中的代码如下:

 1 function createfigure(XData1, YData1, YData2, YData3)
 2 %CREATEFIGURE(XDATA1, YDATA1, YDATA2, YDATA3, PARENT1)
 3 %  XDATA1:  line xdata
 4 %  YDATA1:  line ydata
 5 %  YDATA2:  line ydata
 6 %  YDATA3:  line ydata
 7 %  PARENT1:  text parent
 8 
 9 %  由 MATLAB 于 30-Nov-2016 09:53:51 自动生成
10 
11 % 创建 figure
12 figure(\'Tag\',\'ScopePrintToFigure\',\'Color\',[1 1 1],...
13     \'OuterPosition\',[221 63 927 650]);
14 
15 % uicontainer 当前不支持代码生成,请输入正确输入语法对应的 \'doc uicontainer\'
16 % 可以使用 GUIDE 来为 uicontainer 生成代码。有关详细信息,请输入 \'doc guide\'
17 % uicontainer(...);
18 
19 % uicontainer 当前不支持代码生成,请输入正确输入语法对应的 \'doc uicontainer\'
20 % 可以使用 GUIDE 来为 uicontainer 生成代码。有关详细信息,请输入 \'doc guide\'
21 % uicontainer(...);
22 
23 % uipanel 当前不支持代码生成,请输入正确输入语法对应的 \'doc uipanel\'
24 % 可以使用 GUIDE 来为 uipanel 生成代码。有关详细信息,请输入 \'doc guide\'
25 % uipanel(...);
26 
27 % 创建 axes
28 axes1 = axes(\'ColorOrder\',...
29     [1 1 0.0666666666666667;0.0745098039215686 0.623529411764706 1;1 0.411764705882353 0.16078431372549;0.392156862745098 0.831372549019608 0.0745098039215686;0.717647058823529 0.274509803921569 1;0.0588235294117647 1 1;1 0.0745098039215686 0.650980392156863],...
30     \'Tag\',\'DisplayAxes1_RealMag\');
31 hold(axes1,\'on\');
32 
33 % 创建 hgtransform
34 hgtransform(\'HitTest\',\'off\',\'Matrix\',[1 0 0 0;0 1 0 0;0 0 1 0;0 0 0 1]);
35 
36 % 创建 hgtransform
37 hgtransform(\'HitTest\',\'off\',\'Matrix\',[1 0 0 0;0 1 0 0;0 0 1 0;0 0 0 1]);
38 
39 % 创建 hgtransform
40 hgtransform(\'HitTest\',\'off\',\'Matrix\',[1 0 0 0;0 1 0 0;0 0 1 0;0 0 0 1]);
41 
42 % 创建 line
43 line(XData1,YData1,\'DisplayName\',\'Gain2\',\'Tag\',\'DisplayLine1\',...
44     \'Marker\',\'square\',...
45     \'Color\',[1 1 0.0666666666666667]);
46 
47 % 创建 line
48 line(XData1,YData2,\'DisplayName\',\'Gain3\',\'Tag\',\'DisplayLine2\',\'LineWidth\',2,...
49     \'Color\',[0.0745098039215686 0.623529411764706 1]);
50 
51 % 创建 line
52 line(XData1,YData3,\'DisplayName\',\'Demux/5\',\'Tag\',\'DisplayLine3\',...
53     \'Marker\',\'*\',...
54     \'Color\',[1 0.411764705882353 0.16078431372549]);
55 
56 % 创建 xlabel
57 xlabel(\' \');
58 
59 % 取消以下行的注释以保留坐标轴的 X 范围
60 % xlim(axes1,[0 400]);
61 % 取消以下行的注释以保留坐标轴的 Y 范围
62 % ylim(axes1,[-176.00008 280.22712]);
63 % 取消以下行的注释以保留坐标轴的 Z 范围
64 % zlim(axes1,[-1 1]);
65 box(axes1,\'on\');
66 % 设置其余坐标轴属性
67 set(axes1,\'ClippingStyle\',\'rectangle\',\'FontSize\',8,\'GridAlpha\',0.4,...
68     \'GridColor\',[0.686274509803922 0.686274509803922 0.686274509803922],...
69     \'TickLabelInterpreter\',\'none\',\'XColor\',[0 0 0],\'XGrid\',\'on\',\'YColor\',...
70     [0 0 0],\'YGrid\',\'on\',\'ZColor\',[0 0 0]);
View Code

所得图像如下:

相关文章