Matlab 中while循环语句的用法?

作者&投稿:牢乖 (若有异议请与网页底部的电邮联系)
matlab中的如何跳出while死循环~

1、首先打开电脑和matlab软件,新建一个m文件,并在m文件里面输入一个死循环的代码,如下所示,for循环里面的inf是表示一个无穷大数的意思。

2、然后点击matlab上面的绿色run按钮,可以看到Command Window里面一直处于运行busy状态,也就是死循环的状态。

3、此时退出该死循环的第一个方法:就是把光标定位到Command Window窗口,看到在fx右边一直闪烁的状态。

4、然后同时按下键盘上的ctrl+C组合键,就可以看到for循环停止运行,并跳出一个Warning的蓝色提示语句。

5、还可以在任务管理器的“进程”下面的应用找到“MATLAB(R2015a)”,在其上面点击右键,在弹出来的菜单中选择“结束任务(E)”。

6、还可以直接点击matlab主面板右上角的打叉符号,在弹出来的对话框中Stop Now and Exit这个按钮即可跳出死循环。

一、基本技术
-----------------------------------------------------
1)MATLAB索引或引用(MATLAB Indexing or Referencing)
在MATLAB中有三种基本方法可以选取一个矩阵的子阵。它们分别是
下标法,线性法和逻辑法(subscripted, linear, and logical)。
如果你已经熟悉这个内容,请跳过本节

1.1)下标法
非常简单,看几个例子就好。
A = 6:12;
A([3,5])
ans =
8 10
A([3:2:end])
ans =
8 10 12

A =

[11 14 17; ...
12 15 18; ...
13 16 19];
A(2:3,2)
ans =
15
16

1.2)线性法
二维矩阵以列优先顺序可以线性展开,可以通过现行展开后的元素序号
来访问元素。
A =

[11 14 17; ...
12 15 18; ...
13 16 19];
A(6)
ans =
16

A([3,1,8])
ans =
13 11 18
A([3;1;8])
ans =
13
11
18

1.3)逻辑法
用一个和原矩阵具有相同尺寸的0-1矩阵,可以索引元素。在某个
位置上为1表示选取元素,否则不选。得到的结果是一个向量。
A = 6:10;
A(logical([0 0 1 0 1]))
ans =
8 10
A =
[1 2
3 4];
B = [1 0 0 1];
A(logical(B))
ans =
1 4
-----------------------------------------------------
2)数组操作和矩阵操作(Array Operations vs. Matrix Operations)
对矩阵的元素一个一个孤立进行的操作称作数组操作;而把矩阵视为
一个整体进行的运算则成为矩阵操作。MATLAB运算符*,/,,^都是矩阵
运算,而相应的数组操作则是.*, ./, ., .^
A=[1 0 ;0 1];
B=[0 1 ;1 0];
A*B % 矩阵乘法
ans =
0 1
1 0
A.*B % A和B对应项相乘
ans =
0 0
0 0
------------------------------------------------------
3)布朗数组操作(Boolean Array Operations)
对矩阵的比较运算是数组操作,也就是说,是对每个元素孤立进行的。
因此其结果就不是一个“真”或者“假”,而是一堆“真假”。这个
结果就是布朗数组。
D = [-0.2 1.0 1.5 3.0 -1.0 4.2 3.14];
D >= 0
ans =
0 1 1 1 0 1 1
如果想选出D中的正元素:
D = D(D>0)
D =
1.0000 1.5000 3.0000 4.2000 3.1400
除此之外,MATLAB运算中会出现NaN,Inf,-Inf。对它们的比较参见下例
Inf==Inf返回真
Inf<1返回假
NaN==NaN返回假
同时,可以用isinf,isnan判断,用法可以顾名思义。
在比较两个矩阵大小时,矩阵必须具有相同的尺寸,否则会报错。这是
你用的上size和isequal,isequalwithequalnans(R13及以后)。
------------------------------------------------------
4)从向量构建矩阵(Constructing Matrices from Vectors)
在MATLAB中创建常数矩阵非常简单,大家经常使用的是:
A = ones(5,5)*10
但你是否知道,这个乘法是不必要的?
A = 10;
A = A(ones(5,5))
A =
10 10 10 10 10
10 10 10 10 10
10 10 10 10 10
10 10 10 10 10
10 10 10 10 10
类似的例子还有:
v = (1:5)';
n = 3;
M = v(:,ones(n,1))
M =

1 1 1
2 2 2
3 3 3
4 4 4
5 5 5
事实上,上述过程还有一种更加容易理解的实现方法:
A = repmat(10,[5 5]);
M = repmat([1:5]', [1,3]);
其中repmat的含义是把一个矩阵重复平铺,生成较大矩阵。
更多详细情况,参见函数repmat和meshgrid。
-----------------------------------------------------
5)相关函数列表(Utility Functions)
ones 全1矩阵
zeros 全0矩阵
reshape 修改矩阵形状
repmat 矩阵平铺
meshgrid 3维plot需要用到的X-Y网格矩阵
ndgrid n维plot需要用到的X-Y-Z...网格矩阵
filter 一维数字滤波器,当数组元素前后相关时特别有用。
cumsum 数组元素的逐步累计
cumprod 数组元素的逐步累计
eye 单位矩阵
diag 生成对角矩阵或者求矩阵对角线
spdiags 稀疏对角矩阵
gallery 不同类型矩阵库
pascal Pascal 矩阵
hankel Hankel 矩阵
toeplitz Toeplitz 矩阵

==========================================================
二、扩充的例子
------------------------------------------------------
6)作用于两个向量的矩阵函数
假设我们要计算两个变量的函数F
F(x,y) = x*exp(-x^2 - y^2)
我们有一系列x值,保存在x向量中,同时我们还有一系列y值。
我们要对向量x上的每个点和向量y上的每个点计算F值。换句话
说,我们要计算对于给定向量x和y的所确定的网格上的F值。

使用meshgrid,我们可以复制x和y来建立合适的输入向量。然后
可以使用第2节中的方法来计算这个函数。
x = (-2:.2:2);
y = (-1.5:.2:1.5)';
[X,Y] = meshgrid(x, y);
F = X .* exp(-X.^2 - Y.^2);
如果函数F具有某些性质,你甚至可以不用meshgrid,比如
F(x,y) = x*y ,则可以直接用向量外积
x = (-2:2);
y = (-1.5:.5:1.5);
x'*y
在用两个向量建立矩阵时,在有些情况下,稀疏矩阵可以更加有
效地利用存储空间,并实现有效的算法。我们将在第8节中以一个
实例来进行更详细地讨论.
--------------------------------------------------------
7)排序、设置和计数(Ordering, Setting, and Counting Operations)
在迄今为止讨论过的例子中,对向量中一个元素的计算都是独立
于同一向量的其他元素的。但是,在许多应用中,你要做的计算
则可能与其它元素密切相关。例如,假设你用一个向量x来表示一
个集合。不观察向量的其他元素,你并不知道某个元素是不是一
个冗余元素,并应该被去掉。如何在不使用循环语句的情况下删除
冗余元素,至少在现在,并不是一个明显可以解决的问题。

解决这类问题需要相当的智巧。以下介绍一些可用的基本工具

max 最大元素
min 最小元素
sort 递增排序
unique 寻找集合中互异元素(去掉相同元素)
diff 差分运算符[X(2) - X(1), X(3) - X(2), ... X(n) - X(n-1)]
find 查找非零、非NaN元素的索引值
union 集合并
intersect 集合交
setdiff 集合差
setxor 集合异或

继续我们的实例,消除向量中的多余元素。注意:一旦向量排序后,
任何多余的元素就是相邻的了。同时,在任何相等的相邻元素在向量
diff运算时变为零。这是我们能够应用以下策略达到目的。我们现在
在已排序向量中,选取那些差分非零的元素。

% 初次尝试。不太正确!
x = sort(x(:));
difference = diff(x);
y = x(difference~=0);

这离正确结果很近了,但是我们忘了diff函数返回向量的元素个数比
输入向量少1。在我们的初次尝试中,没有考虑到最后一个元素也可能
是相异的。为了解决这个问题,我们可以在进行差分之前给向量x加入
一个元素,并且使得它与以前的元素一定不同。一种实现的方法是增
加一个NaN。

% 最终的版本。
x = sort(x(:));
difference = diff([x;NaN]);
y = x(difference~=0);

我们使用(:)运算来保证x是一个向量。我们使用~=0运算,而不用find
函数,因为find函数不返回NaN元素的索引值,而我们操作中差分的最
后元素一定是NaN。这一实例还有另一种实现方式:

y=unique(x);

后者当然很简单,但是前者作为一个练习并非无用,它是为了练习使用
矢量化技术,并示范如何编写你自己的高效代码。此外,前者还有一个
作用:Unique函数提供了一些超出我们要求的额外功能,这可能降低代
码的执行速度。

假设我们不只是要返回集合x,而且要知道在原始的矩阵里每个相异元素
出现了多少个“复本”。一旦我们对x排序并进行了差分,我们可以用
find来确定差分变化的位置。再将这个变化位置进行差分,就可以得到
复本的数目。这就是"diff of find of diff"的技巧。基于以上的讨论,
我们有:

% Find the redundancy in a vector x

x = sort(x(:));
difference = diff([x;max(x)+1]);
count = diff(find([1;difference]));
y = x(find(difference));
plot(y,count)

这个图画出了x中每个相异元素出现的复本数。注意,在这里我们避开了
NaN,因为find不返回NaN元素的索引值。但是,作为特例,NaN和Inf
的复本数可以容易地计算出来:

count_nans = sum(isnan(x(:)));
count_infs = sum(isinf(x(:)));

另一个用于求和或者计数运算的矢量化技巧是用类似建立稀疏矩阵的方
法实现的。这还将在第9节中作更加详细的讨论.
-------------------------------------------------------
8)稀疏矩阵结构(Sparse Matrix Structures)

在某些情况下,你可以使用稀疏矩阵来增加计算的效率。如果你构造一
个大的中间矩阵,通常矢量化更加容易。在某些情况下,你可以充分利
用稀疏矩阵结构来矢量化代码,而对于这个中间矩阵不需要大的存储空
间。

假设在上一个例子中,你事先知道集合y的域是整数的子集,
{k+1,k+2,...k+n};即,
y = (1:n) + k

例如,这样的数据可能代表一个调色板的索引值。然后,你就可以对集
合中每个元素的出现进行计数(构建色彩直方图?译者)。这是对上一
节中"diff of find of diff"技巧的一种变形。


现在让我们来构造一个大的m x n矩阵A,这里m是原始x向量中的元素数,
n是集合y中的元素数。
A(i,j) = 1 if x(i) = y(j)
0 otherwise

回想一下第3节和第4节,你可能认为我们需要从x和y来构造矩阵A。如果
当然可以,但要消耗许多存储空间。我们可以做得更好,因为我们知道,
矩阵A中的多数元素为0,x中的每个元素对应的行上只有一个值为1。

以下就是构造矩阵的方法(注意到y(j) = k+j,根据以上的公式):
x = sort(x(:));
A = sparse(1:length(x), x+k, 1, length(x), n);

现在我们对A的列进行求和,得到出现次数。
count = sum(A);
在这种情况下,我们不必明确地形成排序向量y,因为我们事先知道
y = 1:n + k.

这里的关键是使用数据,(也就是说,用x控制矩阵A的结构)。由于x在
一个已知范围内取整数值,我们可以更加有效地构造矩阵。

假设你要给一个很大矩阵的每一列乘以相同的向量。使用稀疏矩阵,不仅
可以节省空间,并且要比在第5节介绍的方法更加快速. 下面是它的工作
方式:
F = rand(1024,1024);
x = rand(1024,1);
% 对F的所有行进行点型乘法.
Y = F * diag(sparse(x));
% 对F的所有列进行点型乘法.
Y = diag(sparse(x)) * F;

我们充分利用矩阵乘法算符来执行大规模运算,并使用稀疏矩阵以防止临
时变量变得太大。
--------------------------------------------------------
9)附加的例子(Additional Examples)
下面的例子使用一些在本技术手册中讨论过的方法,以及其它一些相关方
法。请尝试使用tic 和toc(或t=cputime和cputime-t),看一下速度加快
的效果。
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
用于计算数组的双重for循环。
使用的工具:数组乘法
优化前:
A = magic(100);
B = pascal(100);
for j = 1:100
for k = 1:100;
X(j,k) = sqrt(A(j,k)) * (B(j,k) - 1);
end
end
优化后:
A = magic(100);
B = pascal(100);
X = sqrt(A).*(B-1);
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
用一个循环建立一个向量,其元素依赖于前一个元素
使用的工具:FILTER, CUMSUM, CUMPROD
优化前:
A = 1;
L = 1000;
for i = 1:L
A(i+1) = 2*A(i)+1;
end
优化后:
L = 1000;
A = filter([1],[1 -2],ones(1,L+1));
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
如果你的向量构造只使用加法或乘法,你可使用cumsum或cumprod函数。
优化前:
n=10000;
V_B=100*ones(1,n);
V_B2=100*ones(1,n);
ScaleFactor=rand(1,n-1);
for i = 2:n
V_B(i) = V_B(i-1)*(1+ScaleFactor(i-1));
end
for i=2:n
V_B2(i) = V_B2(i-1)+3;
end
优化后:
n=10000;
V_A=100*ones(1,n);
V_A2 = 100*ones(1,n);
ScaleFactor=rand(1,n-1);
V_A=cumprod([100 1+ScaleFactor]);
V_A2=cumsum([100 3*ones(1,n-1)]);
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
向量累加,每5个元素进行一次:
工具:CUMSUM , 向量索引
优化前:
% Use an arbitrary vector, x
x = 1:10000;
y = [];
for n = 5:5:length(x)
y = [y sum(x(1:n))];
end
优化后(使用预分配):
x = 1:10000;
ylength = (length(x) - mod(length(x),5))/5;
% Avoid using ZEROS command during preallocation
y(1:ylength) = 0;
for n = 5:5:length(x)
y(n/5) = sum(x(1:n));
end
优化后(使用矢量化,不再需要预分配):
x = 1:10000;
cums = cumsum(x);
y = cums(5:5:length(x));
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

操作一个向量,当某个元素的后继元素为0时,重复这个元素:
工具:FIND, CUMSUM, DIFF
任务:我们要操作一个由非零数值和零组成的向量,要求把零替换成为
它前面的非零数值。例如,我们要转换下面的向量:
a=2; b=3; c=5; d=15; e=11;
x = [a 0 0 0 b 0 0 c 0 0 0 0 d 0 e 0 0 0 0 0];
为:
x = [a a a a b b b c c c c c d d e e e e e e];
解(diff和cumsum是反函数):
valind = find(x);
x(valind(2:end)) = diff(x(valind));
x = cumsum(x);
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
将向量的元素累加到特定位置上
工具:SPARSE
优化前:
% The values we are summing at designated indices
values = [20 15 45 50 75 10 15 15 35 40 10];
% The indices associated with the values are summed cumulatively
indices = [2 4 4 1 3 4 2 1 3 3 1];
totals = zeros(max(indices),1);
for n = 1:length(indices)
totals(indices(n)) = totals(indices(n)) + values(n);
end
优化后:
indices = [2 4 4 1 3 4 2 1 3 3 1];
totals = full(sparse(indices,1,values));

注意:这一方法开辟了稀疏矩阵的新用途。在使用sparse命令创建稀疏矩阵
时,它是对分配到同一个索引的所有值求和,而不是替代已有的数值。这称
为"向量累加",是MATLAB处理稀疏矩阵的方式。

while语句用法如下:

格式:

while(条件)

循环体

end

【注】:条件成立时,执行循环体

扩展资料:

Matlab注意事项:

一、安装出错时,可换注册码继续安装,到同一目录;

二、【谨记】安装路径不要有中文名称;

三、成功安装完毕之后,如果遇到matlab启动后,窗口在打开一到两秒后就自动关闭了, 可按以下方法试试:【假设你安装的目录为c:\MATLAB\】(不过不建议安装到C盘,那样会影响系统速度!)

1、确认安装好后,在此路径下c:\MATLAB\bin\win32有一个名为 atlas_Athlon.dll的文件;

2、我的电脑上右击点"属性",再在"高级"中点"环境变量",在"系统变量"中点击 "新建" 输入以下信息:变量名:BLAS_VERSION 变量址:

c:\MATLAB\bin\win32\atlas_Athlon.dll

3、这样之后,启动MATLAB,不过又出现一个问题:窗口显示

To get started, select MATLAB Help or Demos from the Help menu. The element type "name" must be terminated by the matching end-tag "</name>".

Could not parse the file:c:\matlaboolbox\ccslink\ccslink\info.xml

【解决方案】找到c:\matlaboolbox\ccslink\ccslink\info.xml这个文件,用记事本打开【注意,这是重点,或者写字板】找到有一行这样的<name>Link for Code Composer Studio?/name>,大概是在第七行吧,把这句的/name>改成</name>【加左尖括号】,保存文件,退出,即可。

4、安装MATLAB成功!

无法运行可以考虑使用兼容模式运行,比如windows 2000模式

参考资料来源:百度百科:MATLAB



while语法:

while expression

statements

end

说明:while expression, statements, end 计算一个表达式,并在该表达式为 true 时在一个循环中重复执行一组语句。表达式的结果非空并且仅包含非零元素(逻辑值或实数值)时,该表达式为 true。否则,表达式为 false。

示例代码如下:

function [sum] = summation(ratio, head, top)

sum = 0;

while (head <= top)

sum = sum + ratio ^ head;

head = head + 1;

end

end

假设ratio = 2,head = 0,top = 63

扩展资料

Matlab控制流语句包括条件语句、循环和分支。

if, elseif, else 条件为 true 时执行语句。

for 用来重复指定次数的 for 循环。

parfor 并行循环。

switch, case, otherwise 执行多组语句中的一组。

try, catch 执行语句并捕获产生的错误。

while 条件为 true 时重复执行的 while 循环。

break 终止执行 for 或 while 循环。

continue 将控制权传递给 for 或 while 循环的下一迭代。

end 终止代码块或指示最大数组索引。

pause 暂时停止执行 MATLAB。

return 将控制权返回给调用函数。

参考资料:

MathWorks文档——while循环



用法如下:

MATLAB中while循环的语法是 

while <expression>

<statements>

end

只要表达式(expression)为true,while循环将重复执行程序语句(statements)。

当结果为非空并且包含所有非零元素(逻辑或实数)时,表达式(expression)为true。 否则,表达式(expression)为false。

扩展资料:

循环语句种类如下

一、计次循环

循环体内的命令重复执行指定的次数。提供的整数参数值决定将重复执行的次数。

计次循环首 (循环次数, 已循环次数变量)

计次循环尾 ()

二、判断循环

根据提供的逻辑参数的值,来决定是否进入循环。如果提供的逻辑参数值为真,程序顺序执行下一条命令进入循环,否则跳转到本命令所对应的“判断循环尾”命令的下一条命令处以跳出循环。

判断循环首(条件)

判断循环尾 ()

三、循环判断

循环判断尾为循环的条件所在,根据提供的逻辑参数的值,来决定是否返回到循环首部继续进行循环。如果提供的逻辑参数值为真,程序返回到对应的“循环判断首”命令处继续进行循环,否则顺序执行下一条命令退出本程序循环。

循环判断首 ()

循环判断尾 (条件)

参考资料:百度百科 循环语句



matlab while循环的用法。while循环的使用与for循环是类似的。但是其中还是有不少的区别,例如对于循环次数而言,while循环的次数是不定的,而for循环如果你不加上判断语句他会一直循环下去的。

matlab while 循环介绍



while语法:

while expression

statements

end

说明:while expression, statements, end 计算一个表达式,并在该表达式为 true 时在一个循环中重复执行一组语句。表达式的结果非空并且仅包含非零元素(逻辑值或实数值)时,该表达式为 true。否则,表达式为 false。

示例代码如下:

function [sum] = summation(ratio, head, top)

sum = 0;

while (head <= top)

sum = sum + ratio ^ head;

head = head + 1;

end

end

假设ratio = 2,head = 0,top = 63

扩展资料:

Matlab控制流语句包括条件语句、循环和分支。

if, elseif, else 条件为 true 时执行语句。

for 用来重复指定次数的 for 循环。

parfor 并行循环。

switch, case, otherwise 执行多组语句中的一组。

try, catch 执行语句并捕获产生的错误。

while 条件为 true 时重复执行的 while 循环。

break 终止执行 for 或 while 循环。

continue 将控制权传递给 for 或 while 循环的下一迭代。

end 终止代码块或指示最大数组索引。

pause 暂时停止执行 MATLAB。

return 将控制权返回给调用函数。

参考资料:

MathWorks文档——while循环


连山区19477896094: matlab while死循环 -
毓泊敏定: clear n=input('输入成绩n='); m=60; while 1if n>m && n<=100fprintf('及格\n');elseif n<m && n>0fprintf('不及格\n');elsebreak;endn=input('输入成绩n='); end我猜楼主是想实现这样的功能吧,while死循环是ctrl+c就可以退出来

连山区19477896094: matlab while 1循环语句的意思 -
毓泊敏定: 就这种结构而言,是使用形式上的死循环,然后用if进行判断,在满足某个条件时用break跳出循环.第一段代码也可以改写成: fid = fopen('fgetl.m');tline = fgetl(fid); while ischar(tline)disp(tline)tline = fgetl(fid); endfclose(fid);二者作用是完全相同的.两段代码都是逐行读文本文件,差别只是第一个读出来之后就显示,而第二个读出来之后转换为数据存储到数组中而已.

连山区19477896094: matlab的while循环语句老是弄不懂 -
毓泊敏定: 你的程序中,while循环里除了count,其他的变量都没有改变过,Wucha2一直是个定值始终不变,而Wucha2 - 1.370054400372624e-04 = 3.000000000001157e-08 > 0,仍然满足循环条件,因此是个死循环. 你打几个断点,让循环内的变量发生变化,再调试调试.另外,while语句是当不满足条件的时候会跳出循环,可以简单运行一下: count = 0; while count<100count = count+1;disp(['count = ',num2str(count)]) end

连山区19477896094: matlab while循环 -
毓泊敏定: 看上去你这两个条件应该是或的关系,应该用 while lm>=0.8 || lm<=0.2 如果是与的关系,就是 while lm>0.8 && lm<=0.2 但是这两个条件不能同时成立,与的话没有意义

连山区19477896094: MATLAB中的while循环请问MATLAB中while循环是
毓泊敏定: 是先判断后执行,跟c一样,配合end标记循环体

连山区19477896094: 我想问问matlab 中的while语句 循环里面有没有什么顺序要求之类的? -
毓泊敏定: 你这里只有while s

连山区19477896094: MATLAB如何写一个带有或运算的while循环? -
毓泊敏定: while (w2

连山区19477896094: 在matlab中如何实现用while循环读取任意数量的数据? -
毓泊敏定: 比如编写一个while循环,结束条件为该向量个数: clc; clear all; n = randint(1, 1, [1 100]); x = rand(n, 1); k = 1; while k < n disp(x(k)); k = k + 1; end

连山区19477896094: matlab中 while循环语句里可不可以有if语句 -
毓泊敏定: 可以有if语句,比如:% By lyqmath clc; clear all; close all; flag = 1; while 1if flagfprintf('\nHello!\n');break;end end

连山区19477896094: 在matlab中如何实现用while循环读取任意数量的数据?
毓泊敏定: 呵呵 根据编程知识 你弄一个识别数据的判断就可以了 比如 数据不可仍出现值 -1 (你按照你的对象自己弄是0 -1 或其他标志) 那么 只要输入不为-1就继续啊 while 变量 不等于 -1 .......

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网