Matlab软件实训

暑期实训


训练目的

  1. 熟悉Matlab工具软件的开发环境
  2. 掌握Matlab的一些常用命令
  3. 掌握Matlab/Simulink建模仿真的方法

训练内容

  1. 利用命令进行各种相关数学计算
  2. 编写M文件实现各种相关数学计算
  3. 利用Simulink建模并仿真

训练任务

  1. 解方程

就是解个矩阵方程:Ax=B,求x;题目不写了,贴代码吧。

% 矩阵间计算
A = [-3 5 0 8; 1 -8 2 -1; 0 -5 9 3; -7 0 -4 5]
B = [1; 5; -3; 8];
% Ax=B,求x,相当于 x=inv(A)*B 则x=A\B
X = A\B;
disp(X);

唯一值得注意的是matlab的矩阵间的操作真的花样繁多,有普通的乘*和除/还有点乘.*点除./,对数值运算来说这些符号没有区别,但在矩阵中*是普通的矩阵的乘法,而.*是两个矩阵里每一个对应元素相乘,它就要求前后矩阵的行和列数相同;除此之外还分了左除\右除/,对除法而言这条杠压在谁身上谁就是“分母”。

  1. 数值运算

第二题是个数值运算,给入一堆小孩的不同科目的成绩,找出每一科和总分哪个小孩考的最好,最高分是多少。贴代码吧。

% s= [高数 外语 电路]
math = [       78        89         64      73        78       85]
eng  = [       83        77         83      78        70       79]
elec = [       85        91         78      82        68       81];
Max = [-1 -1 -1 -1]
flag = [0 0 0 0]
summ = []; % 空矩阵
for i = 1:6
    summ(i) = math(i)+eng(i)+elec(i);
    if math(i)>Max(1)
        Max(1) = math(i);
        flag(1) = i;
    end;
    if eng(i)>Max(2)
        Max(2) = eng(i);
        flag(2) = i;
    end;
    if elec(i)>Max(3)
        Max(3) = elec(i);
        flag(3) = i;
    end;
    if summ(i)>Max(4)
        Max(4) = summ(i);
        flag(4) = i;
    end;
end;
% 将结果转换为字符串输出
disp(['高数:max number =', num2str(flag(1)), ',max score = ', num2str(Max(1))]);
disp(['英语:max number =', num2str(flag(2)), ',max score = ', num2str(Max(2))]);
disp(['电路:max number =', num2str(flag(3)), ',max score = ', num2str(Max(3))]);
disp(['总分:max number =', num2str(flag(4)), ',max score = ', num2str(Max(4))]);

这题唯一的难度是如何定义数组以及如何访问矩阵/数组的元素。我这里定义总分矩阵是定义了个空矩阵,运算时再对它赋值summ = []
访问数组元素可以以A[x]的形式或A[i,j]的形式等。

a(i,j) % 第i行第j列队元素
a(n1:n2) % 表示数组中的第n1到n2个元素
a(:,j) % 第j列的所有元素
a(2:end,j) % 第j列中第2行到最后一行的元素
a(:,3:5) % 第3〜5列的所有元素
a(x) % 第x个元素(x为从最左边第1列开始编号)

由于我将每一科分数拆成了单行矩阵,就直接用A[x]访问,x表示学生的代号。

  1. 定积分的计算

直接贴代码。

% 计算定积分
syms x f;% 定义变量
f = sin(x);
y = int(f,x,0,pi/2);
disp(y)

积分的计算有公式的:

R = int(S,v,a,b) % S是表达式,v是组成S的自变量,a,b表示被积区间

注意v作为变量要提前定义,否则编译时会报错。

  1. 画图

贴代码吧。

% 画二维曲线图
x = linspace(-4*pi, 4*pi, 404)
y = sin(x).*cos(5*x); % 不用点乘会报错
plot(x,y,'b')
ylabel('函数值')
xlabel('x')

注意画图时的x是要给定范围的,并且调用linspace(a,b,n)函数在a~b之间描n个点。
另外在对y赋值时不用点乘会报错:

错误使用  * 
内部矩阵维度必须一致。
  1. Simulink建模仿真

先画成这样,不知道对不对。


二阶系统.JPG

总结

心情好的时候写。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,843评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,538评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,187评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,264评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,289评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,231评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,116评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,945评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,367评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,581评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,754评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,458评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,068评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,692评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,842评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,797评论 2 369
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,654评论 2 354

推荐阅读更多精彩内容