数据类型
MATLAB中的数据类型主要包括数值类型、逻辑类型、字符串、函数句柄、结构体和 单元数组类型。这6种基本的数据类型都是按照数组形式存储和操作的。另外,MATLAB 中还有两种用于高级交叉编程的数据类型,分别是用户自定义的面向对象的用户类类型和 Java类类型。
数值类型
基本的数值类型主要有整数、单精度浮点数和双精度浮点数。
数据格式 | 示例 | 说明 |
---|---|---|
int8,unit8 int16,unit16 int32,unit32 int64,unit64 | int32(820) | 有符号和无符号的数据类型 相同数值的整数类型占用比浮点类型更少的内存 除int64和unit64类型外的所有整数类型,都可以进行数学运算 |
single | single(128.1) | 单精度浮点类型 相同数值的单精度浮点类型比双精度浮点类型占用更少的内存 |
double | 333.77 1.000-1.000i | 双精度浮点类型,MATLAB中默认的数值类型 |
- MATLAB中数值类型的数据包括有符号和无符号整数、单精度浮点数和双精度浮点数。在未加说明与特殊定义时,MATLAB对所有数值按照双精度浮点数进行存储和操作。
MATLAB会自动进行记忆体的使用和回收,而不像C语言,必须由使用者一一指定。这些功能使得MATLAB易学易用,使用者可专心致力于撰写程序。
整数类型
由于MATLAB中数值的默认存储类型是双精度浮点类型,因此将变量设置为整数类型时,需要使用相应的转换函数,将双精度浮点数转换为指定的整数类型。
- 在转换过程中,MATLAB默认将待转换数值转换为与之最为接近的整数值,若小数部分为0.5,则转换后的结果为与该浮点数最接近的两个整数中绝对值较大的一个。
- 这些转换函数也可以将其他数据类型转换为指定的数据类型。在不超出数值范围的情况下,任意两个整数类型之间也可以通过转换函数进行相互转换。同时,由于不同的整数类型能够表示的数值范围不同,因此当运算结果超出相应的整数类型能够表示的范围时,就会出现一处错误,运算结果被置为该整数类型能够表示的最大值或最小值。
- MATLAB中还包含了几类不同运算法则的取整函数,也可以把浮点数转换成整数。
浮点数类型
由于MATLAB中的默认数值类型为双精度浮点类型,因此与创建整数类型数值一样,也可以通过转换函数来实现创建单精度浮点类型。
双精度浮点数参与运算时,返回值的类型依赖于参与运算的其他数据类型。
- 参与运算的其他数据为逻辑型、字符型时,返回结果为双精度浮点型;
- 参与运算的其他数据为整数型时,返回结果为相应的整数类型;
- 参与运算的其他数据为单精度浮点型时,返回结果为相应的单精度浮点型。
在MATLAB中,单精度浮点类型不能与整数类型进行算术运算。
- 由于浮点数只占用一定的存储位宽,其中只有有限位分别用来存储指数部分和小数部分。因此,浮点类型能够表示的实际数值是有限且离散的,任何两个最近相邻的浮点数之间都有微小间隙,而处在间隙中的数值都只能用这两个相邻的浮点数之中的一个来表示。
- MATLAB中提供了 eps函数,可以获取一个数值和最接近该数值的浮点数之间的间隙。
复数
复数包括实部和虚部两部分。MATLAB中默认使用字符i或j作为虚部标志。创建复数时,可以直接按照复数形式进行输入或利用complex函数。
复数: a + b i a+bi a+bi(其中,a为实部,b为虚部)
共轭复数: a − b i a-bi a−bi
模: ∣ z ∣ = ( a 2 + b 2 ) |z|=\sqrt{(a^2+b^2)} ∣z∣=(a2+b2)
辅角: θ = a r c t a n b a θ=arctan\frac{b}a θ=arctanab
无穷量(Inf)和非数值量(NaN)
●Inf
使用Inf和-Inf分别代表正无穷量和负无穷量。
正负无穷量的产生一般是由于运算溢出,产生了超出双精度浮点数数值范围的结果。
●NaN
NaN表示非数值量。
非数值量则是由于0/0或In/Inf类型的非正常运算而产生的,这两个NaN彼此是不相等的。
除了异常运算结果外,MATLAB还提供了特定函数Inf和NaN来创建指定数值类型的无穷量和非数值量,生成结果默认为双精度浮点类型中还有一种特殊的指数类型的数据叫作非数,通常表示运算得到的数值结果超出了运算范围。非数的实部用NaN表示,虚部用InF表示。
逻辑类型
- 逻辑类型的数据是指布尔类型的数据及数据之间的逻辑关系。除了传统的数学运算之外,MATLAB还支持关系和逻辑运算。这些运算的目的是提供求解真/假命题的答案。
- 作为所有关系和逻辑表达式的输入,MATLAB把任何非零数值当作真,把零当作假。所有关系和逻辑表达式的输出:对于真,输出为1;对于假,输出为0。
MATLAB关系操作符能用来比较两个同样大小的数组,或用来比较一个数组和一个标量。在后一种情况中,标量和数组中的每一个元素相比较,结果与数组大小一样。
“=”和“==”在MATLAB中的意义是不同的。
“==”是对等号两边的两个变量进行比较,当它们相等时返回1,不相等时返回0;
“=”则是被用来将运算的结果赋给一个变量。
xor(x,y)指令的功能为异或运算,x和y同为零(假)或非零(真)时返回0,否则返回1。
any(x)指令的功能为判断是否为零向量或零矩阵(即向量或矩阵中的元素全部为零),如果是零向量或零矩阵,则返回1,否则返回0。