02-结构化程式与自定义函数

视频教程:b站视频【MATLAB教程_台大郭彦甫(14课)原视频补档】https://www.bilibili.com/video/BV1GJ41137UH/?share_source=copy_web&vd_sourc*e=d6b9f96888e9c85118cb40c164875dfc
官网教程:

  • MATLAB 快速入门 - MathWorks 中国

参考博客

  • MATLAB(二)结构化程式与自定义函数
  • 【台大郭彦甫】Matlab入门教程超详细学习笔记三:结构化程式与自定义函数(附PPT链接)

声明:自己跟着敲了一遍,仅供个人参考学习。
软件版本:MATLAB R2016b


脚本编辑器

新建脚本-运行

新建一个脚本文件(我的命名M02_01.m),文件保存命名不能以数字开头,用字母开头,字母大小写有区别

我习惯路径都为英文,关键字命名后面可以加条下划线,如for_.m

1712026136463.png

for i=1:10
    x=linspace(0,10,101);
    plot(x,sin(x+i));
    print(gcf,'-deps',strcat('plot',num2str(i),'.ps'));
end

遇坑:按运行出现弹框

1712026274242.png
我搜了一下,大概原因是:
:::tips
如果我们新建一个.m文件,习惯性保存在默认文件夹,但是没有先重新从进入默认文件夹,再打开我们新建的文件,那么MATLAB就还没有反应过来我们已经将新建的文件保存到了默认文件夹,从而误认为文件不在默认文件夹下,进而在我们运行文件时还是会报错,因为MATLAB没反应过来。
参考博客MATLAB“在当前文件夹或MATLAB路径中未找到文件“的小“坑”
:::

做法:先打开浏览文件夹,再从左侧的结构树上找到该.m文件(该文件夹下的),并打开它,再运行就不报错。
1712027609969.png
1712026533972.png

常用功能

  • 注释 ctrl+R
  • 取消注释 ctrl+T
  • 注释换行 ctrl+J
  • 智能缩进 ctrl+I


语法

关系逻辑(操作)符

条件语句

if-elseif-else 语句

if-else
% Generate a random number
a = randi(100, 1);

% If it is even, divide by 2
if rem(a, 2) == 0
    disp('a is enen')
    b = a/2;
    disp(b)
else
    disp('a is old')
    b = a/2;
    disp(b) 
end

1712031968115.png

if-elseif-else

多个条件

% Generate a random number
a = randi(100, 1);
disp(a) 

if a < 30
    disp('small')
elseif a < 80  % 30 <= a <80
    disp('medium')
else 
    disp('large')
end

1712032407945.png

switch语句


1712029167657.png

% input_num=1;%可以修改
input_num=0;
% input_num=-1;

switch input_num
    case -1
        disp('negative 1');
    case 0
        disp('zero');
    case 1
        disp('positive 1');
    otherwise
        disp('other value');
end

1712029147299.png

循环语句

for循环语句

1712028121820.png

for n=1:10
    a(n)=2^n;
end
disp(a)

1712035166195.png

while循环语句

1712028097016(1).png
1e100=1x10^100
prod(1:n)=n!

n = 1;
while prod(1:n) <1e100 % prod(1:n)=n!
    n = n+1;
end
disp(n) % 得到的结果n-1是小于1e100的最大的阶乘数

1712035454139.png

练习

  1. 使用while循环来计算序列的总和1+2+3+…+999
% 初始化
n = 1;
sum = 0;

% while循环
while n < 1000
%     disp(n) %打印循环次数
    sum = n+sum;
    n = n+1;
%     disp(sum)%打印每次循环得到的结果
end
disp(sum) %打印结果

1712450346760.png

  1. 用for循环做一遍上题。
% 初始化
n = 1;
sum = 0;

% for循环
for n = 1:999
    sum = n + sum;
    n = n+1;
end
disp(sum) %打印结果

结果同上。

预分配

参考官网https://ww2.mathworks.cn/help/matlab/matlab_prog/preallocating-arrays.html

  • 如果未预分配空间,matlab每次经过 for 和 while 循环时,会在每次迭代时调整其大小,会比较费时间
  • 若一个变量所需要的内存空间是一个可预测的定值,我们应尽量提前为其分配内存空间。

对要初始化的数组类型使用适当的预分配函数:

  • 对于数值数组,使用 zeros
  • 对于字符串数组,使用 strings
  • 对于元胞数组,使用 cell
  • 对于表数组,使用 table

示例

  • tic-toc可以用于计时。

1712451112009.png
1712451185713.png
运行效果:

tic
x = 0;
for k = 2:100000
    x(k) = x(k-1) +5;
end
toc

%%
tic
x = zeros(1,1000000);
for k = 2:100000
    x(k) = x(k-1) +5;
end
toc

1712451383135.png

练习


分析:

  1. 首先找到矩阵A中的所有负数;
  2. 把它们存在矩阵B中;
  3. 把这些负数变为0.

结果图:
1712454252975.png

方法1

注:体会一下第9、10行不加分号与加分号打印的结果。
其实发现不加分号打印的是循环的结果,加了分号用disp()打印的是最终结果。

%方法1
%% 1、不加分号
A = [0 -1 4; 9 -14 25; -34 49 64]

B=zeros(size(A)); % size(A)同时求矩阵的行和列数
for i = 1:size(A,1) % size(A,1)求矩阵的行数
    for j = 1:size(A,2) % size(A,2)求矩阵的列数
        if(A(i,j))<0 
            B(i,j)=1 % 把负数放到矩阵B,负数变为1
            A(i,j)=0 % 把矩阵A中的1全部置零
        end
    end
end


%% 2、加分号
A = [0 -1 4; 9 -14 25; -34 49 64]

B=zeros(size(A)); % size(A)同时求矩阵的行和列数
for i = 1:size(A,1) % size(A,1)求矩阵的行数
    for j = 1:size(A,2) % size(A,2)求矩阵的列数
        if(A(i,j))<0 
            B(i,j)=1; % 把负数放到矩阵B,负数变为1
            A(i,j)=0; % 把矩阵A中的1全部置零
        end
    end
end
disp(B) % 打印矩阵B
disp(A) % 打印最后的矩阵A

打印结果:

  • 不加分号
>> exe1

A =

     0    -1     4
     9   -14    25
   -34    49    64


B =

     0     1     0
     0     0     0
     0     0     0


A =

     0     0     4
     9   -14    25
   -34    49    64


B =

     0     1     0
     0     1     0
     0     0     0


A =

     0     0     4
     9     0    25
   -34    49    64


B =

     0     1     0
     0     1     0
     1     0     0


A =

     0     0     4
     9     0    25
     0    49    64
  • 加分号
>> exe1

A =

     0    -1     4
     9   -14    25
   -34    49    64

     0     1     0
     0     1     0
     1     0     0

     0     0     4
     9     0    25
     0    49    64
方法2
%方法2
A = [0 -1 4; 9 -14 25; -34 49 64]
B = A < 0 % 返回一个零一矩阵,数组A中小于0的位置为1
A(B) = 0 % A(B) = X(未知)      X : 与 B 大小一样(行数和列数相等)

打印结果:

>> exe2

A =

     0    -1     4
     9   -14    25
   -34    49    64


B =

  3×3 logical 数组

   0   1   0
   0   1   0
   1   0   0


A =

     0     0     4
     9     0    25
     0    49    64

break

break作用:终止执行 for 或 while 循环。

参考官网https://ww2.mathworks.cn/help/matlab/ref/break.html?searchHighlight=break&s_tid=srchtitle_support_results_1_break

limit = 0.8;
s = 0;

while 1
    tmp = rand; %随机数
    if tmp > limit
        break 
    end
    s = s + tmp; 
end
disp(s)

技巧

  1. clear all 清除工作区内存中的变量
  2. close all关闭之前程序绘制的图像
  3. clc 清空之前程序在终端的输出
  4. 在命令末尾使用分号;来抑制输出(就是终端不能直接打印结果)
  5. 省略号可以将多行语句拼接为一行,灵活使用该语句可以提高代码可读性
%%
A = [1 2 3 4 5 6; ...
        6 5 4 3 2 1]

%%等价于
A = [1 2 3 4 5 6; 6 5 4 3 2 1]

1712471583949.png

  1. Ctrl+C提前结束运行

自定义函数

查看内置函数

在命令行窗口输入edit(which('mean.m'))可以调出内置函数mean.m,如下图所示:
1712472357953.png

参考官网https://ww2.mathworks.cn/help/matlab/ref/function.html
1712472715644.png
说明:

  • 关键字: function … end 结尾
  • 函数保存的.m文件,函数名必须和文件名一致;
  • 也可将临时使用的函数定义在脚本文件内,但需要定义在文件最后;
  • 输入 input();输出可以用 disp() 或者 fprintf()
  • 注意 matlab 中对于字符串均使用 ‘’ 而不是 “” ,fprintf() 中的内容使用 ''括起来。

function的编写

例1:自由落体

写一个函数,计算给定初始位移xo,初始速度vo,下落时间t的自由落体位移:
1712472953895.png
1712473067873.png
1712473552154.png

例2:具有多个输入和输出的函数

function [a F] = acc(v2,v1,t2,t1,m)
a = (v2-v1)./(t2-t1);
F = m.*a;

1712473878439.png

例3:从华氏温度转换到摄氏温度

1712474141950.png

华氏温度用F,摄氏温度用C。转换公式为:

在这里插入图片描述

%从华氏温度(F)转换到摄氏温度(C)
function F2C()
while 1
    F = input('请输入华氏温度:','s');
    F = str2num(F);
    if isempty(F)
        return
    end
    C = (F-32)*5/9;
    disp(['摄氏温度为:',num2str(C)])
end

1712474796581.png

内置的函数参数

1712474063526.png

使用函数句柄形式定义函数

参考官网https://ww2.mathworks.cn/help/matlab/ref/function_handle.html
使用 @ 运算符创建一个函数句柄。
1712475250063.png
要求该匿名函数从 0 到 1 的积分,请将其句柄传递给 integral。

f = @(x) x.^3 + x.^2 + x + 1;
q = integral(f,0,1) %该匿名函数从 0 到 1 的积分

1712475379009.png
-END-

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/533520.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

React 使用 three.js 加载 gltf 3D模型 | three.js 入门

系列文章 示例项目(gitcode)&#xff1a;https://gitcode.com/qq_41456316/simple-react-three-demo 文章目录 系列文章前言一、three.js是什么&#xff1f;二、使用 React 和 three.js 加载 glTF 3D 模型的步骤步骤 1&#xff1a;创建 React 应用步骤 2&#xff1a;安装 thre…

使用QT 开发不规则窗体

使用QT 开发不规则窗体 不规则窗体贴图法的不规则窗体创建UI模板创建一个父类创建业务窗体main函数直接调用user_dialog创建QSS文件 完整的QT工程 不规则窗体 QT中开发不规则窗体有两种方法&#xff1a;&#xff08;1&#xff09;第一种方法&#xff0c;使用QWidget::setMask函…

川土微高性能模拟芯片系列产品介绍和应用

一、公司简介 上海川土微电子有限公司是一家成立于2016年的专注于高端模拟芯片研发设计与销售的高科技公司&#xff0c;产品涵盖隔离与接口、驱动与电源、高性能模拟三大产品线以及μMiC战略产品&#xff08; micro-Module in Chip&#xff09;。目前产品已广泛应用于工业控制…

怎么在SU草图大师里做地形模型?

​​​​​​  1.导入地形数据&#xff1a;首先&#xff0c;找到你想要模拟的地形数据。常见的文件格式是DEM(数字高程模型)文件&#xff0c;它包含地表高程数据。在SketchUp中&#xff0c;通过菜单栏选择“文件” -> “导入” -> “DEM”&#xff0c;然后选择你的DEM文…

基于springboot实现桂林旅游景点导游平台管理系统【项目源码+论文说明】

基于springboot实现桂林旅游景点导游平台管理系统演示 摘要 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;管理信息系统的实施在技术上已逐步成熟。本文介绍了桂林旅游景点导游平台的开发全过程。通过分析桂林旅游景点导游平台管理的不足&#xff0c;创建了一个计算…

【数据结构(四)】链表经典练习题

❣博主主页: 33的博客❣ ▶️文章专栏分类:数据结构◀️ &#x1f69a;我的代码仓库: 33的代码仓库&#x1f69a; &#x1faf5;&#x1faf5;&#x1faf5;关注我带你学更多数据结构知识 目录 1.前言2.删除值为key的所有结点3.反转链表4.返回中间结点5.输出倒数第k个结点6.链表…

2024-04-10 Linux gzip 和 gunzip 命令,gzip 压缩的文件通常比原始文件小得多。

一、gzip 是 Linux 系统中用于压缩文件的命令&#xff0c;它通常用于将单个文件压缩成 .gz 格式的文件。gzip 压缩的文件通常比原始文件小得多&#xff0c;因此它在节省磁盘空间和减少文件传输时间方面非常有用。 gzip 命令的基本语法如下&#xff1a; gzip [选项] [文件]复制…

VMware vSphere Hypervisor,ESXi的介绍,下载与安装

1.介绍 看这篇文章就好了 Vmware ESXi 是免费吗&#xff1f;一文弄懂vSphere功能特性及ESXi与vSphere到底有什么区别和联系。 - 知乎 (zhihu.com) 2.下载 这里面有7.0各个版本的下载镜像文件和校验信息 VMware-Esxi7.0各个版本镜像文件iso下载链接_esxi7.0镜像-CSDN博客 3.…

团结引擎+OpenHarmony 2 xlua编译篇

文章目录 前言一、下载 xlua 源码二、OpenHarmony SDK三、开干 前言 提示&#xff1a;我们的 app 鸿蒙化过程 需要用到 xlua ,目前没有适配 OpenHarmony 平台&#xff0c;所以需要重新编译一下。编译有多种方式&#xff0c;但是我只会这一种 就是使用 cmake。 一、下载 xlua 源…

花一分钟简单认识 CSS 中的规则 —— 级联层 @layer

layer 简介&#xff1a; 声明级联层时&#xff0c;越靠后优先级越高。不属于任何级联层的样式&#xff0c;将自成一层匿名级联层&#xff0c;并置于所有层之后 —— 级别最高。 用法一&#xff1a;在同一文件中 layer base, special; layer special {/* 优先 */li { color: …

2、Qt UI控件 -- qucsdk项目使用

前言&#xff1a;上一篇文章讲了qucsdk的环境部署&#xff0c;可以在QDesigner和Qt Creator中看到qucsdk控件&#xff0c;这一篇来讲下在项目中使用qucsdk库中的控件。 一、准备材料 要想使用第三方库&#xff0c;需要三个先决条件&#xff0c; 1、控件的头文件 2、动/静态链…

软考数据库---1.事务管理

目录 1.1 事物的基本概念1.2 数据库的并发控制1.2.1 事务调度概念1.2.2 并发操作带来的问题1.2.3 并发控制技术1.2.4 隔离级别&#xff1a; 1.3 数据库的备份和恢复1.3.1 故障种类1.3.2 备份方法1.3.3 日志文件1.3.4 恢复 1.1 事物的基本概念 ●概念&#xff1a;一个操作序列&…

AiChat是什么?

AIChat是一款功能强大的聚合AI大模型智能聊天助手&#xff0c;为用户提供自动化的客服和聊天机器人服务。无论是需要为企业提供更好的客户体验&#xff0c;还是为个人用户提供高效便捷的服务&#xff0c;AIChat都是最佳选择。本文将详细介绍AIChat的特点和优势。 Aichat简介&am…

学习R语言第二天

R语言可以做什么 1.数据分析 R语言如何使用 1. 请看我的操作方式 2. 如何获取当前路径 -- 获取当前路径 > getwd() [1] "E:/R/RWorkSpace/day01" -- 修改当前路径 > setwd(dir "E:/R") > getwd() [1] "E:/R" 3.查看当下数据值的信…

HCIP课后习题之一

1、路由协议用工作机制上分为那几种&#xff1f;分别是&#xff1f; A&#xff1a;两种。分别是静态路由和动态路由&#xff08;可分为IGP和EGP&#xff09; 2、IGP和EGP协议有哪些&#xff1f; A&#xff1a;IGP: RIP、OSPF、ISIS、EIGRP EGP: BGP 3、路由优先级的用途&…

机器人坐标系转换之从世界坐标系到局部坐标系

三角函数实现 下面是代码c和python实现&#xff1a; #include <iostream> #include <cmath>struct Point {double x;double y; };class RobotCoordinateTransform { private:Point origin; // 局部坐标系的原点在世界坐标系中的坐标public:RobotCoordinateTransfo…

zabbix企业级监控平台

zabbix部署 安装源 重新创建纯净环境&#xff0c;利用base克隆一台虚拟机server1 给server1做快照&#xff0c;方便下次实验恢复使用 进入zabbix官网https://www.zabbix.com rpm -Uvh https://repo.zabbix.com/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm …

C++:构造函数、析构函数、拷贝构造函数

hello&#xff0c;各位小伙伴&#xff0c;本篇文章跟大家一起学习《C&#xff1a;构造函数、析构函数、拷贝构造函数》&#xff0c;感谢大家对我上一篇的支持&#xff0c;如有什么问题&#xff0c;还请多多指教 &#xff01; 如果本篇文章对你有帮助&#xff0c;还请各位点点赞…

c++的学习之路:16、list(3)

上章有一些东西当时没学到&#xff0c;这里学到了将在补充&#xff0c;文章末附上代码&#xff0c;思维导图。 目录 一、赋值重载 二、带模板的创建 三、析构函数 四、代码 五、思维导图 一、赋值重载 这里的赋值重载就是直接利用交换函数进行把传参生成的临时数据和需要…

Vue 读取后台二进制文件流转为图片显示

Vue 读取后台二进制文件流转为图片显示 后台返回格式 <img :src"payImg" id"image" style"width: 150px;height: 150px;" alt"">axios写法 重点 responseType: ‘blob’ &#xff0c; 使用的是res中的data blob this.$axios.…