matlab 矢量化,matlab矢量化编程简要

一、基本技术

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处理稀疏矩阵的方式。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Hadoop-HBASE案例分析-Hadoop学习笔记二

之前有幸在MOOC学院抽中小象学院hadoop体验课。 这是小象学院hadoop2.X概述第八章的笔记 主要介绍HBase&#xff0c;一个分布式数据库的应用案例。 案例概况&#xff1a; 1&#xff09;时间序列数据库(OpenTSDB) 用HBase储存时间序列数据&#xff0c;每时每刻都在解决&#xff…

python测试udp端口_怎样测试UDP端口

文章概述&#xff1a;怎样测试远程UDP端口&#xff0c;我们一般情况下&#xff0c;应用服务都使用的TCP端口&#xff0c;但是某些情况下&#xff0c;我们也需要开启UDP端口。本文简要描述怎样测试UDP端口是否正常&#xff1f;TCP端口大家都知道,比如80端口&#xff0c;可以使用…

Matlab经纬度坐标转换xy坐标,经纬度坐标系转换为UTM坐标系(matlab)

如题所说&#xff0c;直接上程序。验证自己做一下&#xff0c;结果应该是对的。诚不我欺。(注意&#xff1a;程序名与函数名保持一致&#xff01;&#xff01;&#xff01;)function[shuchu]lat_lon2utm(lat_shuru,lon_shuru)%地理经纬度坐标转换为UTM坐标size_shuzusize(lat_s…

ASP.NET MVC中的模型装配 封装方法 非常好用

下面说一下我们知道在asp.net mvc中 视图可以绑定一个实体模型 然后我们三层架构中也有一个model模型 但是这两个很多时候却是不一样的对象来的 就拿微软的官方mvc例子来说明 微软的视图实体中 有loginmodel 有registermodel 等等 这些视图模型 都只是占用户实体的某几个字段而…

python webviewer爬虫_爬虫再也不怕检测浏览器环境了

背景之前爬虫 驱动个 selenium 基本上就可以了.但是现在各种检测浏览器环境...特别是不熟悉 js 的同学就更烦了本文是直接把 selenium pyppeteer 以及正常打开浏览器 的环境差异直接列出来这样你就可以更愉快的爬虫了(可以直接把环境全部模拟上,或者大概看看有啥,下次看人家混淆…

jQuery: 整理2---操作元素的样式

1.获取元素的class属性值 attr("class") <div id"conBlue" class"blue larger">天蓝色</div>const cla $("#conBlue").attr("class") console.log(cla) // blue larger 2.设置元素的样式 attr("class…

matlab空间曲面拟合,matlab如何进行曲面拟合

matlab如何进行曲面拟合以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;在一丘陵地带测量高程&#xff0c;x和 y方向每隔100米测一个点&#xff0c;得高程如下表&#xff0c;试插值一曲面&am…

python做的游戏可以导出吗_Python for RenderDoc批量导出模型和贴图

故事背景&#xff1a;美术那里有需求&#xff0c;需要别人游戏的模型&#xff0c;来借鉴一下&#xff0c;问我是否有工具可以一键导出模型。我就搜索了一下RenderDoc批量导出图片&#xff0c;结果搜到了用C改RenderDoc源码的文章。让RenderDoc批量导出纹理_专栏-CSDN博客​blog…

treegrid.bootstrap使用说明

treegrid.bootstrap使用说明 这个插件是用来做有层次的表格的&#xff0c;大概如图&#xff1a; 官网 http://maxazan.github.io/jquery-treegrid/ 使用这个控件之前需要引入以下css及js&#xff08;因为用到了 bootstrap.js 所以加上了 bootstrap的样式和脚本&#xff09; bo…

matlab 条形图横坐标,Matlab条形图bar横坐标间距设置

1. 默认横坐标数据 X[x1, x2, x3, x4, x5, x6] %一行六列bar(X); %绘制基础条形图2. 修改横坐标标签#考虑横坐标标签文本较长且字体较大的情况bar(X);set(gca, xticklabels,{Apple, Orange, Banana, Pear, Pitaya, Lemon}, Fontname, Times New Roman, Fontsize, 16); %修…

成都python数据分析师职业技能_合格大数据分析师应该具备的技能

课程七、建模分析师之软技能 - 数据库技术本部分课程主要介绍MySQL数据库的安装使用及常用数据操作1、关系型数据库介绍2、MySQL的基本操作:1)数据库的操作2)数据表的操作3)备份与恢复3、常用的SQL语句:1)查询语句(SELECT)2)插入语句(INSERT)3)更新语句(UPDATE)4)删除语句(DELE…

项目属性--生成事件--后期生成事件命令行

以开源记牌器https://github.com/Epix37/Hearthstone-Deck-Tracker 为例&#xff0c;Hearthstone Deck Tracker项目中的后期生成事件命令行&#xff1a; if "$(ConfigurationName)" "Release" ( rmdir /S /Q "..\Hearthstone Deck Tracker" mkd…

大连理工优化方法matlab,大连理工大学2016年秋季优化方法大作业.pdf

优化方法期末上机大作业姓 名&#xff1a;李岚松学 部&#xff1a;电信学部电气工程学 号2016 年 11 月 9 日1最速下降法//最速下降法主函数//function llsdi1titidu(x)di1titidu(x)x0x; eps1e-4; k0; g0g(x0); s04; k0; g0g(x0); s0-g0;while (k>0)if norm(g0)break;elsela…

查看租户情况

source /root/openrc 查看keystone租户 keystone tenant-list 已知租户ID&#xff0c;获取租户名称 keystone tenant-get 5d95a18b92834ef2ada3abcf8eff1c83 查看某租户的配额及使用情况 # nova absolute-limits –-tenant ac9e6a9f-58c(租户ID)&#xff08;输出的内容不准确&a…

stm32 485和232可以用同一个串口吗_STM32的复用时钟何时开启?

STM32的AFIO时钟真的是在开启引脚复用功能的时候开启吗&#xff1f;其实并不是~什么是复用&#xff1f;我们知道&#xff0c;STM32有很多外设&#xff0c;这些外设的外部引脚都是与GPIO共用的。我们可以通过软件来配置引脚作为GPIO引脚还是作为外设引脚。当引脚配置为外设引脚时…

matlab 0-100随机数,添加到100的随机数:matlab

我经常看到这样的错误&#xff1a;要用给定的和来生成随机数&#xff0c;我们只需要使用一个一致的随机集&#xff0c;并且只需对它们进行缩放。但是&#xff0c;如果你这样做的话&#xff0c;结果真的都是随机的吗&#xff1f;在两个维度上尝试这个简单的测试。生成一个巨大的…

url中#号的作用

url中#号的作用就是本页面位置跳转 比如这个url地址&#xff1a;http://www.aaaaa.com/index.html?ad34&mc#red red就是index.html页面的依哥位置 浏览器读取这个URL后&#xff0c;会自动将red位置滚动至可视区域 位置定义方式 <a name"red">cdsc</a&…

python访问mysql_python连接mysql

首先需要导入驱动模块打开cmd导入模块 pip install mysqldb(pymysql)python2.x版本--------->mysqldbpython3.x版本---------->pymysqlpython调用MySQL数据库总共五步1、导入模块(驱动) pymysql mysqldb2、获取连接 connect3、获取游标cursor4、执行sql execute 并且返回…

php左侧菜单栏递归代码,js实现左侧菜单栏递归循环遍历

首先html布局菜单jsonconst menuList [{title: 首页,key: /home},{title: UI,key: /ui,children: [{title: 按钮,key: /ui/buttons,},{title: 弹框,key: /ui/modals,},{title: Loading,key: /ui/loadings,},{title: 通知提醒,key: /ui/notification,},{title: 全局Message,key…

重定向IO

引用自&#xff1a;http://www.cnblogs.com/liunanjava/p/4307793.html 1.三个静态变量 java.lang.System提供了三个静态变量 System.in&#xff08;默认键盘&#xff09;System.out(默认显示器)System.errSystem提供了三个重定向方法2.重写向方法 System提供了三个重定向方法 …