MATLAB函数、数组
(完整版)MATLAB常用函数大全

一、MATLAB常用的基本数学函数abs(x):纯量的绝对值或向量的长度angle(z):复数z的相角(Phase angle)sqrt(x):开平方real(z):复数z的实部imag(z):复数z的虚部conj(z):复数z的共轭复数round(x):四舍五入至最近整数fix(x):无论正负,舍去小数至最近整数floor(x):地板函数,即舍去正小数至最近整数ceil(x):天花板函数,即加入正小数至最近整数rat(x):将实数x化为分数表示rats(x):将实数x化为多项分数展开sign(x):符号函数(Signum function)。
当x<0时,sign(x)=-1;当x=0时,sign(x)=0;当x>0时,sign(x)=1。
rem(x,y):求x除以y的馀数gcd(x,y):整数x和y的最大公因数lcm(x,y):整数x和y的最小公倍数exp(x):自然指数pow2(x):2的指数log(x):以e为底的对数,即自然对数或log2(x):以2为底的对数log10(x):以10为底的对数二、MATLAB常用的三角函数sin(x):正弦函数cos(x):余弦函数tan(x):正切函数asin(x):反正弦函数acos(x):反馀弦函数atan(x):反正切函数atan2(x,y):四象限的反正切函数sinh(x):超越正弦函数cosh(x):超越馀弦函数tanh(x):超越正切函数asinh(x):反超越正弦函数acosh(x):反超越馀弦函数atanh(x):反超越正切函数三、适用於向量的常用函数有:min(x): 向量x的元素的最小值max(x): 向量x的元素的最大值mean(x): 向量x的元素的平均值median(x): 向量x的元素的中位数std(x): 向量x的元素的标准差diff(x): 向量x的相邻元素的差sort(x): 对向量x的元素进行排序(Sorting)length(x): 向量x的元素个数norm(x): 向量x的欧氏(Euclidean)长度sum(x): 向量x的元素总和prod(x): 向量x的元素总乘积cumsum(x): 向量x的累计元素总和cumprod(x): 向量x的累计元素总乘积dot(x, y): 向量x和y的内积cross(x, y): 向量x和y的外积四、MATLAB的永久常数i或j:基本虚数单位(即)eps:系统的浮点(Floating-point)精确度inf:无限大,例如1/0nan或NaN:非数值(Not a number),例如0/0 pi:圆周率p(= 3.1415926...)realmax:系统所能表示的最大数值realmin:系统所能表示的最小数值nargin: 函数的输入引数个数nargout: 函数的输出引数个数五、MATLAB基本绘图函数plot: x轴和y轴均为线性刻度(Linear scale)loglog: x轴和y轴均为对数刻度(Logarithmic scale)semilogx: x轴为对数刻度,y轴为线性刻度semilogy: x轴为线性刻度,y轴为对数刻度六、plot绘图函数的叁数字元颜色字元图线型态y 黄色 . 点k 黑色o 圆w 白色x xb 蓝色+ +g 绿色* *r 红色- 实线c 亮青色: 点线m 锰紫色-. 点虚线-- 虚线七、注解xlabel('Input Value'); % x轴注解ylabel('Function Value'); % y轴注解title('Two Trigonometric Functions'); % 图形标题legend('y = sin(x)','y = cos(x)'); % 图形注解grid on; % 显示格线八、二维绘图函数bar 长条图errorbar 图形加上误差范围fplot 较精确的函数图形polar 极座标图hist 累计图rose 极座标累计图stairs 阶梯图stem 针状图fill 实心图feather 羽毛图compass 罗盘图quiver 向量场图1、特殊变量与常数ans 计算结果的变量名computer 确定运行的计算机eps 浮点相对精度Inf 无穷大I 虚数单位inputname 输入参数名NaN 非数nargin 输入参数个数nargout 输出参数的数目pi 圆周率nargoutchk 有效的输出参数数目realmax 最大正浮点数realmin 最小正浮点数varargin 实际输入的参量varargout 实际返回的参量操作符与特殊字符+ 加- 减* 矩阵乘法 .* 数组乘(对应元素相乘)^ 矩阵幂 .^ 数组幂(各个元素求幂)\ 左除或反斜杠/ 右除或斜面杠./ 数组除(对应元素除)kron Kronecker张量积: 冒号() 圆括[] 方括 . 小数点.. 父目录 ... 继续, 逗号(分割多条命令); 分号(禁止结果显示)% 注释! 感叹号' 转置或引用= 赋值== 相等<> 不等于& 逻辑与| 逻辑或~ 逻辑非xor 逻辑异或2、基本数学函数abs 绝对值和复数模长acos,acodh 反余弦,反双曲余弦acot,acoth 反余切,反双曲余切acsc,acsch 反余割,反双曲余割angle 相角asec,asech 反正割,反双曲正割asin,asinh 反正弦,反双曲正弦atan,atanh 反正切,双曲正切tangent 正切atan2 四象限反正切ceil 向着无穷大舍入complex 建立一个复数conj 复数配对cos,cosh 余弦,双曲余弦csc,csch 余切,双曲余切cot,coth 余切,双曲余切exp 指数fix 朝0方向取整floor 朝负无穷取整gcd 最大公因数imag 复数值的虚部lcm 最小公倍数log 自然对数log2 以2为底的对数log10 常用对数mod 有符号的求余nchoosek 二项式系数和全部组合数real 复数的实部rem 相除后求余round 取整为最近的整数sec,sech 正割,双曲正割sign 符号数sin,sinh 正弦,双曲正弦tan,tanh 正切,双曲正切3、基本矩阵和矩阵操作blkding 从输入参量建立块对角矩阵eye 单位矩阵linespace 产生线性间隔的向量logspace 产生对数间隔的向量numel 元素个数ones 产生全为1的数组rand 均匀颁随机数和数组randn 正态分布随机数和数组zeros 建立一个全0矩阵colon) 等间隔向量cat 连接数组diag 对角矩阵和矩阵对角线fliplr 从左自右翻转矩阵flipud 从上到下翻转矩阵repmat 复制一个数组reshape 改造矩阵roy90 矩阵翻转90度tril 矩阵的下三角triu 矩阵的上三角dot 向量点集cross 向量叉集ismember 检测一个集合的元素intersect 向量的交集setxor 向量异或集setdiff 向是的差集union 向量的并集数值分析和傅立叶变换cumprod 累积cumsum 累加cumtrapz 累计梯形法计算数值微分factor 质因子inpolygon 删除多边形区域内的点max 最大值mean 数组的均值mediam 中值min 最小值perms 所有可能的转换polyarea 多边形区域primes 生成质数列表prod 数组元素的乘积rectint 矩形交集区域sort 按升序排列矩阵元素sortrows 按升序排列行std 标准偏差sum 求和trapz 梯形数值积分var 方差del2 离散拉普拉斯diff 差值和微分估计gradient 数值梯度cov 协方差矩阵corrcoef 相关系数conv2 二维卷积conv 卷积和多项式乘法filter IIR或FIR滤波器deconv 反卷积和多项式除法filter2 二维数字滤波器cplxpair 将复数值分类为共轭对fft 一维的快速傅立叶变换fft2 二维快速傅立叶变换fftshift 将FFT的DC分量移到频谱中心ifft 一维快速反傅立叶变换ifft2 二维傅立叶反变换ifftn 多维快速傅立叶变换ifftshift 反FFT偏移nextpow2 最靠近的2的幂次unwrap 校正相位角多项式与插值conv 卷积和多项式乘法roots 多项式的根poly 具有设定根的多项式polyder 多项式微分polyeig 多项式的特征根polyfit 多项式拟合polyint 解析多项式积分polyval 多项式求值polyvalm 矩阵变量多项式求值residue 部分分式展开interp1 一维插值interp2 二维插值interp3 三维插值interpft 使用FFT的一维插值interpn 多维插值meshgrid 为3维点生成x和y的网格ndgrid 生成多维函数和插值的数组pchip 分段3次Hermite插值多项式ppval 分段多项式的值spline 3次样条数据插值绘图函数bar 竖直条图barh 水平条图hist 直方图histc 直方图计数hold 保持当前图形loglog x,y对数坐标图pie 饼状图plot 绘二维图polar 极坐标图semilogy y轴对数坐标图semilogx x轴对数坐标subplot 绘制子图bar3 数值3D竖条图bar3h 水平3D条形图comet3 3D慧星图cylinder 圆柱体fill3 填充的3D多边形plot3 3维空间绘图quiver3 3D震动(速度)图slice 体积薄片图sphere 球stem3 绘制离散表面数据waterfall 绘制瀑布trisurf 三角表面clabel 增加轮廓标签到等高线图中datetick 数据格式标记grid 加网格线gtext 用鼠标将文本放在2D图中legend 图注plotyy 左右边都绘Y轴title 标题xlabel X轴标签ylabel Y轴标签zlabel Z轴标签contour 等高线图contourc 等高线计算contourf 填充的等高线图hidden 网格线消影meshc 连接网格/等高线mesh 具有参考轴的3D网格peaks 具有两个变量的采样函数surf 3D阴影表面图surface 建立表面低层对象surfc 海浪和等高线的结合surfl 具有光照的3D阴影表面trimesh 三角网格图Matlab函数大全信源函数randerr 产生比特误差样本randint 产生均匀分布的随机整数矩阵randsrc 根据给定的数字表产生随机矩阵wgn 产生高斯白噪声信号分析函数biterr 计算比特误差数和比特误差率eyediagram 绘制眼图scatterplot 绘制分布图symerr 计算符号误差数和符号误差率信源编码compand mu律/A律压缩/扩张dpcmdeco DPCM(差分脉冲编码调制)解码dpcmenco DPCM编码dpcmopt 优化DPCM参数lloyds Lloyd法则优化量化器参数quantiz 给出量化后的级和输出值误差控制编码bchpoly 给出二进制BCH码的性能参数和产生多项式convenc 产生卷积码cyclgen 产生循环码的奇偶校验阵和生成矩阵cyclpoly 产生循环码的生成多项式decode 分组码解码器encode 分组码编码器gen2par 将奇偶校验阵和生成矩阵互相转换gfweight 计算线性分组码的最小距离hammgen 产生汉明码的奇偶校验阵和生成矩阵rsdecof 对Reed-Solomon编码的ASCII文件解码rsencof 用Reed-Solomon码对ASCII文件编码rspoly 给出Reed-Solomon码的生成多项式syndtable 产生伴随解码表vitdec 用Viterbi法则解卷积码(误差控制编码的低级函数)bchdeco BCH解码器bchenco BCH编码器rsdeco Reed-Solomon解码器rsdecode 用指数形式进行Reed-Solomon解码rsenco Reed-Solomon编码器rsencode 用指数形式进行Reed-Solomon编码调制与解调ademod 模拟通带解调器ademodce 模拟基带解调器amod 模拟通带调制器amodce 模拟基带调制器apkconst 绘制圆形的复合ASK-PSK星座图ddemod 数字通带解调器ddemodce 数字基带解调器demodmap 解调后的模拟信号星座图反映射到数字信号dmod 数字通带调制器dmodce 数字基带调制器modmap 把数字信号映射到模拟信号星座图(以供调制)qaskdeco 从方形的QASK星座图反映射到数字信号qaskenco 把数字信号映射到方形的QASK星座图专用滤波器hank2sys 把一个Hankel矩阵转换成一个线性系统模型hilbiir 设计一个希尔伯特变换IIR滤波器rcosflt 升余弦滤波器rcosine 设计一个升余弦滤波器(专用滤波器的低级函数)rcosfir 设计一个升余弦FIR滤波器rcosiir 设计一个升余弦IIR滤波器信道函数awgn 添加高斯白噪声伽罗域计算gfadd 伽罗域上的多项式加法gfconv 伽罗域上的多项式乘法gfcosets 生成伽罗域的分圆陪集gfdeconv 伽罗域上的多项式除法gfdiv 伽罗域上的元素除法gffilter 在质伽罗域上用多项式过滤数据gflineq 在至伽罗域上求Ax=b的一个特解gfminpol 求伽罗域上元素的最小多项式gfmul 伽罗域上的元素乘法gfplus GF(2^m)上的元素加法gfpretty 以通常方式显示多项式gfprimck 检测多项式是否是基本多项式gfprimdf 给出伽罗域的MATLAB默认的基本多项式gfprimfd 给出伽罗域的基本多项式gfrank 伽罗域上矩阵求秩gfrepcov GF(2)上多项式的表达方式转换gfroots 质伽罗域上的多项式求根gfsub 伽罗域上的多项式减法gftrunc 使多项式的表达最简化gftuple 简化或转换伽罗域上元素的形式工具函数bi2de 把二进制向量转换成十进制数de2bi 把十进制数转换成二进制向量erf 误差函数erfc 余误差函数istrellis 检测输入是否MATLAB的trellis结构(structure)marcumq 通用Marcum Q 函数oct2dec 八进制数转十进制数poly2trellis 把卷积码多项式转换成MATLAB的trellis描述vec2mat 把向量转换成矩阵——————————————————————————————————————————————————A aabs 绝对值、模、字符的ASCII码值acos 反余弦acosh 反双曲余弦acot 反余切acoth 反双曲余切acsc 反余割acsch 反双曲余割align 启动图形对象几何位置排列工具all 所有元素非零为真angle 相角ans 表达式计算结果的缺省变量名any 所有元素非全零为真area 面域图argnames 函数M文件宗量名asec 反正割asech 反双曲正割asin 反正弦asinh 反双曲正弦assignin 向变量赋值atan 反正切atan2四象限反正切atanh 反双曲正切autumn 红黄调秋色图阵axes 创建轴对象的低层指令axis 控制轴刻度和风格的高层指令B bbar 二维直方图bar3 三维直方图bar3h 三维水平直方图barh 二维水平直方图base2dec X进制转换为十进制bin2dec 二进制转换为十进制blanks 创建空格串bone 蓝色调黑白色图阵box 框状坐标轴break while 或for 环中断指令brighten 亮度控制C ccapture (3版以前)捕获当前图形cart2pol 直角坐标变为极或柱坐标cart2sph 直角坐标变为球坐标cat 串接成高维数组caxis 色标尺刻度cd 指定当前目录cdedit 启动用户菜单、控件回调函数设计工具cdf2rdf 复数特征值对角阵转为实数块对角阵ceil 向正无穷取整cell 创建元胞数组cell2struct 元胞数组转换为构架数组celldisp 显示元胞数组内容cellplot 元胞数组内部结构图示char 把数值、符号、内联类转换为字符对象chi2cdf 分布累计概率函数chi2inv 分布逆累计概率函数chi2pdf 分布概率密度函数chi2rnd 分布随机数发生器chol Cholesky分解clabel 等位线标识cla 清除当前轴class 获知对象类别或创建对象clc 清除指令窗clear 清除内存变量和函数clf 清除图对象clock 时钟colorcube 三浓淡多彩交叉色图矩阵colordef 设置色彩缺省值colormap 色图colspace 列空间的基close 关闭指定窗口colperm 列排序置换向量comet 彗星状轨迹图comet3 三维彗星轨迹图compass 射线图compose 求复合函数cond (逆)条件数condeig 计算特征值、特征向量同时给出条件数condest 范-1条件数估计conj 复数共轭contour 等位线contourf 填色等位线contour3 三维等位线contourslice 四维切片等位线图conv 多项式乘、卷积cool 青紫调冷色图copper 古铜调色图cos 余弦cosh 双曲余弦cot 余切coth 双曲余切cplxpair 复数共轭成对排列csc 余割csch 双曲余割cumsum 元素累计和cumtrapz 累计梯形积分cylinder 创建圆柱D ddblquad 二重数值积分deal 分配宗量deblank 删去串尾部的空格符dec2base 十进制转换为X进制dec2bin十进制转换为二进制dec2hex 十进制转换为十六进制deconv 多项式除、解卷delaunay Delaunay 三角剖分del2 离散Laplacian差分demo Matlab演示det 行列式diag 矩阵对角元素提取、创建对角阵diary Matlab指令窗文本内容记录diff 数值差分、符号微分digits 符号计算中设置符号数值的精度dir 目录列表disp 显示数组display 显示对象内容的重载函数dlinmod 离散系统的线性化模型dmperm 矩阵Dulmage-Mendelsohn 分解dos 执行DOS 指令并返回结果double 把其他类型对象转换为双精度数值drawnow 更新事件队列强迫Matlab刷新屏幕dsolve 符号计算解微分方程E eecho M文件被执行指令的显示edit 启动M文件编辑器eig 求特征值和特征向量eigs 求指定的几个特征值end 控制流FOR等结构体的结尾元素下标eps 浮点相对精度error 显示出错信息并中断执行errortrap 错误发生后程序是否继续执行的控制erf 误差函数erfc 误差补函数erfcx 刻度误差补函数erfinv 逆误差函数errorbar 带误差限的曲线图etreeplot 画消去树eval 串演算指令evalin 跨空间串演算指令exist 检查变量或函数是否已定义exit 退出Matlab环境exp 指数函数expand 符号计算中的展开操作expint 指数积分函数expm 常用矩阵指数函数expm1 Pade法求矩阵指数expm2 Taylor法求矩阵指数expm3 特征值分解法求矩阵指数eye 单位阵ezcontour 画等位线的简捷指令ezcontourf 画填色等位线的简捷指令ezgraph3 画表面图的通用简捷指令ezmesh 画网线图的简捷指令ezmeshc 画带等位线的网线图的简捷指令ezplot 画二维曲线的简捷指令ezplot3 画三维曲线的简捷指令ezpolar 画极坐标图的简捷指令ezsurf 画表面图的简捷指令ezsurfc 画带等位线的表面图的简捷指令F ffactor 符号计算的因式分解feather 羽毛图feedback 反馈连接feval 执行由串指定的函数fft 离散Fourier变换fft2 二维离散Fourier变换fftn 高维离散Fourier变换fftshift 直流分量对中的谱fieldnames 构架域名figure 创建图形窗fill3 三维多边形填色图find 寻找非零元素下标findobj 寻找具有指定属性的对象图柄findstr 寻找短串的起始字符下标findsym 机器确定内存中的符号变量finverse 符号计算中求反函数fix 向零取整flag 红白蓝黑交错色图阵fliplr 矩阵的左右翻转flipud 矩阵的上下翻转flipdim 矩阵沿指定维翻转floor 向负无穷取整flops 浮点运算次数flow Matlab提供的演示数据fmin 求单变量非线性函数极小值点(旧版)fminbnd 求单变量非线性函数极小值点fmins 单纯形法求多变量函数极小值点(旧版)fminunc 拟牛顿法求多变量函数极小值点fminsearch 单纯形法求多变量函数极小值点fnder 对样条函数求导fnint 利用样条函数求积分fnval 计算样条函数区间内任意一点的值fnplt 绘制样条函数图形fopen 打开外部文件for 构成for环用format 设置输出格式fourier Fourier 变换fplot 返函绘图指令fprintf 设置显示格式fread 从文件读二进制数据fsolve 求多元函数的零点full 把稀疏矩阵转换为非稀疏阵funm 计算一般矩阵函数funtool 函数计算器图形用户界面fzero 求单变量非线性函数的零点G ggamma 函数gammainc 不完全函数gammaln 函数的对数gca 获得当前轴句柄gcbo 获得正执行"回调"的对象句柄gcf 获得当前图对象句柄gco 获得当前对象句柄geomean 几何平均值get 获知对象属性getfield 获知构架数组的域getframe 获取影片的帧画面ginput 从图形窗获取数据global 定义全局变量gplot 依图论法则画图gradient 近似梯度gray 黑白灰度grid 画分格线griddata 规则化数据和曲面拟合gtext 由鼠标放置注释文字guide 启动图形用户界面交互设计工具H hharmmean 调和平均值help 在线帮助helpwin 交互式在线帮助helpdesk 打开超文本形式用户指南hex2dec 十六进制转换为十进制hex2num 十六进制转换为浮点数hidden 透视和消隐开关hilb Hilbert矩阵hist 频数计算或频数直方图histc 端点定位频数直方图histfit 带正态拟合的频数直方图hold 当前图上重画的切换开关horner 分解成嵌套形式hot 黑红黄白色图hsv 饱和色图I iif-else-elseif 条件分支结构ifft 离散Fourier反变换ifft2 二维离散Fourier反变换ifftn 高维离散Fourier反变换ifftshift 直流分量对中的谱的反操作ifourier Fourier反变换i, j 缺省的"虚单元"变量ilaplace Laplace反变换imag 复数虚部image 显示图象imagesc 显示亮度图象imfinfo 获取图形文件信息imread 从文件读取图象imwrite 把imwrite 把图象写成文件ind2sub单下标转变为多下标inf 无穷大info MathWorks公司网点地址inline 构造内联函数对象inmem 列出内存中的函数名input 提示用户输入inputname 输入宗量名int 符号积分int2str把整数数组转换为串数组interp1 一维插值interp2 二维插值interp3 三维插值interpn N维插值interpft 利用FFT插值intro Matlab自带的入门引导inv 求矩阵逆invhilb Hilbert矩阵的准确逆ipermute 广义反转置isa 检测是否给定类的对象ischar 若是字符串则为真isequal 若两数组相同则为真isempty 若是空阵则为真isfinite 若全部元素都有限则为真isfield 若是构架域则为真isglobal 若是全局变量则为真ishandle 若是图形句柄则为真ishold 若当前图形处于保留状态则为真isieee 若计算机执行IEEE规则则为真isinf 若是无穷数据则为真isletter 若是英文字母则为真islogical 若是逻辑数组则为真ismember 检查是否属于指定集isnan 若是非数则为真isnumeric 若是数值数组则为真isobject 若是对象则为真isprime 若是质数则为真isreal 若是实数则为真isspace 若是空格则为真issparse 若是稀疏矩阵则为真isstruct 若是构架则为真isstudent 若是Matlab学生版则为真iztrans 符号计算Z反变换J j , K kjacobian 符号计算中求Jacobian 矩阵jet 蓝头红尾饱和色jordan 符号计算中获得Jordan标准型keyboard 键盘获得控制权kron Kronecker乘法规则产生的数组L llaplace Laplace变换lasterr 显示最新出错信息lastwarn 显示最新警告信息leastsq 解非线性最小二乘问题(旧版)legend 图形图例lighting 照明模式line 创建线对象lines 采用plot 画线色linmod 获连续系统的线性化模型linmod2 获连续系统的线性化精良模型linspace 线性等分向量ln 矩阵自然对数load 从MAT文件读取变量log 自然对数log10常用对数log2 底为2的对数loglog 双对数刻度图形logm 矩阵对数logspace 对数分度向量lookfor 按关键字搜索M文件lower 转换为小写字母lsqnonlin 解非线性最小二乘问题lu LU分解M mmad 平均绝对值偏差magic 魔方阵maple &nb, sp; 运作Maple格式指令mat2str 把数值数组转换成输入形态串数组material 材料反射模式max 找向量中最大元素mbuild 产生EXE文件编译环境的预设置指令mcc 创建MEX或EXE文件的编译指令mean 求向量元素的平均值median 求中位数menuedit 启动设计用户菜单的交互式编辑工具mesh 网线图meshz 垂帘网线图meshgrid 产生"格点"矩阵methods 获知对指定类定义的所有方法函数mex 产生MEX文件编译环境的预设置指令mfunlis 能被mfun计算的MAPLE经典函数列表mhelp 引出Maple的在线帮助min 找向量中最小元素mkdir 创建目录mkpp 逐段多项式数据的明晰化mod 模运算more 指令窗中内容的分页显示movie 放映影片动画moviein 影片帧画面的内存预置mtaylor 符号计算多变量T aylor级数展开N nndims 求数组维数NaN 非数(预定义)变量nargchk 输入宗量数验证nargin 函数输入宗量数nargout 函数输出宗量数ndgrid 产生高维格点矩阵newplot 准备新的缺省图、轴nextpow2 取最接近的较大2次幂nnz 矩阵的非零元素总数nonzeros 矩阵的非零元素norm 矩阵或向量范数normcdf 正态分布累计概率密度函数normest 估计矩阵2范数norminv 正态分布逆累计概率密度函数normpdf 正态分布概率密度函数normrnd 正态随机数发生器notebook 启动Matlab和Word的集成环境null 零空间num2str把非整数数组转换为串numden 获取最小公分母和相应的分子表达式nzmax 指定存放非零元素所需内存O oode1 非Stiff 微分方程变步长解算器ode15s Stiff 微分方程变步长解算器ode23t 适度Stiff 微分方程解算器ode23tb Stiff 微分方程解算器ode45非Stiff 微分方程变步长解算器odefile ODE 文件模板odeget 获知ODE 选项设置参数odephas2 ODE 输出函数的二维相平面图odephas3 ODE 输出函数的三维相空间图odeplot ODE 输出函数的时间轨迹图odeprint 在Matlab指令窗显示结果odeset 创建或改写ODE选项构架参数值ones 全1数组optimset 创建或改写优化泛函指令的选项参数值orient 设定图形的排放方式orth 值空间正交化P ppack 收集Matlab内存碎块扩大内存pagedlg 调出图形排版对话框patch 创建块对象path 设置Matlab搜索路径的指令pathtool 搜索路径管理器pause 暂停pcode 创建预解译P码文件pcolor 伪彩图peaks Matlab提供的典型三维曲面permute 广义转置pi (预定义变量)圆周率pie 二维饼图pie3 三维饼图pink 粉红色图矩阵pinv 伪逆plot 平面线图plot3 三维线图plotmatrix 矩阵的散点图plotyy 双纵坐标图poissinv 泊松分布逆累计概率分布函数poissrnd 泊松分布随机数发生器pol2cart 极或柱坐标变为直角坐标polar 极坐标图poly 矩阵的特征多项式、根集对应的多项式poly2str 以习惯方式显示多项式poly2sym 双精度多项式系数转变为向量符号多项式polyder 多项式导数polyfit 数据的多项式拟合polyval 计算多项式的值polyvalm 计算矩阵多项式pow2 2的幂ppval 计算分段多项式pretty 以习惯方式显示符号表达式print 打印图形或SIMULINK模型printsys 以习惯方式显示有理分式prism 光谱色图矩阵procread 向MAPLE输送计算程序profile 函数文件性能评估器propedit 图形对象属性编辑器pwd 显示当前工作目录Q qquad 低阶法计算数值积分quad8 高阶法计算数值积分(QUADL)quit 推出Matlab 环境quiver 二维方向箭头图quiver3 三维方向箭头图R rrand 产生均匀分布随机数randn 产生正态分布随机数randperm 随机置换向量range 样本极差rank 矩阵的秩rats 有理输出rcond 矩阵倒条件数估计real 复数的实部reallog 在实数域内计算自然对数realpow 在实数域内计算乘方realsqrt 在实数域内计算平方根realmax 最大正浮点数realmin 最小正浮点数rectangle 画"长方框"rem 求余数repmat 铺放模块数组reshape 改变数组维数、大小residue 部分分式展开return 返回ribbon 把二维曲线画成三维彩带图rmfield 删去构架的域roots 求多项式的根rose 数扇形图rot90矩阵旋转90度rotate 指定的原点和方向旋转rotate3d 启动三维图形视角的交互设置功能round 向最近整数圆整rref 简化矩阵为梯形形式rsf2csf 实数块对角阵转为复数特征值对角阵rsums Riemann和S ssave 把内存变量保存为文件scatter 散点图scatter3 三维散点图sec 正割sech 双曲正割semilogx X轴对数刻度坐标图semilogy Y轴对数刻度坐标图series 串联连接set 设置图形对象属性setfield 设置构架数组的域setstr 将ASCII码转换为字符的旧版指令sign 根据符号取值函数signum 符号计算中的符号取值函数sim 运行SIMULINK模型simget 获取SIMULINK模型设置的仿真参数simple 寻找最短形式的符号解simplify 符号计算中进行简化操作simset 对SIMULINK模型的仿真参数进行设置simulink 启动SIMULINK模块库浏览器sin 正弦sinh 双曲正弦size 矩阵的大小提问者评价强人!。
matlab基本函数

matlab基本函数MATLAB是一种功能强大的编程语言和开发环境,广泛应用于科学计算、数据分析和工程设计等领域。
本文将介绍一些MATLAB的基本函数,包括数据操作、图形绘制、数学计算等方面的函数。
一、数据操作函数1. size()函数:用于获取数组或矩阵的大小,返回一个包含行数和列数的向量。
2. length()函数:用于获取向量的长度。
3. ndims()函数:用于获取数组或矩阵的维度数。
4. reshape()函数:用于改变数组或矩阵的形状,可以将其转换为不同大小的矩阵。
5. find()函数:用于查找数组或矩阵中满足特定条件的元素的索引。
6. sort()函数:用于对数组或矩阵进行排序,可以按照升序或降序排列。
7. unique()函数:用于返回数组或矩阵中的唯一元素,并去除重复值。
二、图形绘制函数1. plot()函数:用于绘制二维曲线图,可以通过输入不同的坐标点来绘制不同形状的曲线。
2. scatter()函数:用于绘制散点图,可以根据不同的数据点设置不同的颜色和大小。
3. bar()函数:用于绘制柱状图,可以展示不同类别或组之间的比较。
4. pie()函数:用于绘制饼图,可以展示不同类别所占比例的大小关系。
5. histogram()函数:用于绘制直方图,可以展示数据的分布情况。
6. contour()函数:用于绘制等高线图,可以展示二维数据的等高线分布。
三、数学计算函数1. sin()函数:用于计算正弦值。
2. cos()函数:用于计算余弦值。
3. exp()函数:用于计算指数函数的值。
4. sqrt()函数:用于计算平方根。
5. sum()函数:用于计算数组或矩阵中元素的总和。
6. mean()函数:用于计算数组或矩阵中元素的平均值。
7. max()函数:用于找出数组或矩阵中的最大值。
8. min()函数:用于找出数组或矩阵中的最小值。
9. rand()函数:用于生成随机数。
四、其他常用函数1. disp()函数:用于在命令窗口中显示文本或变量的值。
MATLAB之(一)数组、矩阵和函数及运算

说明 4位小数
3.14159265358979 15位小数
3.14
2位小数
355/113
最接近的有理数
format short e,t =pi 3.1416e+000
科学计数
format long e ,t =pi 四、函数
3.141592653589793e+000
MATLAB提供了大量的函数,按照起用法分为标量函数、 向量函数和矩阵函数。
14
b= 1 3 5 7
c=6:-3:-6(从6到-6公差为-3的等差数组)
c=
6 3 0 -3 -6 e=[0:2:8,ones(1,3)](等差数组和行向量的拼接)
e=
0 2468111
2数组的运算
数组除作为1×n矩阵(行向量)遵循矩阵运算外,
MATLAB还为数组提供了一些特殊运算。两个数组间的
的最重要特征是按元素进行运算。
2021/4/14
13
1 数组的输入 ⑴可以像1×n矩阵(即行向量)一样输入,如: a=[2,3,4,5] a=
2345
⑵数组常用“:”来方便地生成一些特殊的数组。如:
a=1:5(从1到5公差为1的等差数组)
a=
12345
b=1:2:7(从1到7公差为2的等差数组)
2021/4/14
(5) randn(生成正态分布随机矩阵); U=ones(3)
W=zeros(2,3) V=eye(2,4)
U=
W=
V=
111
000
2021/4/14
000
1000 0100
111
9
111
X=rand(2,3)
X=
matlab中cell函数的用法

MATLAB中cell函数的用法1. 介绍•cell函数是MATLAB中的一种数据类型,用于存储不同类型的元素,如数字、字符串、矩阵等。
•它类似于一维数组,但每个元素可以是不同类型的数据。
•本文将详细介绍cell函数的用法,包括创建cell数组、访问和操作cell 数组中的元素等。
2. 创建cell数组2.1 使用大括号创建单个cell数组•可以使用大括号{}来创建一个单个的cell数组。
•每个元素用逗号分隔,可以是任何类型的数据。
•以下是一个示例代码:cellArr = {'apple', 10, [1 2 3]};2.2 使用cell函数创建多个cell数组•使用cell函数可以创建一个指定大小的空cell数组。
•可以在cell函数中指定行数和列数。
•以下是一个示例代码:emptyCellArr = cell(3, 2);2.3 使用cellstr函数创建字符型cell数组•cellstr函数可以将字符串数组转换为字符型cell数组。
•字符串数组中的每个元素将作为cell数组中的一个元素。
•以下是一个示例代码:strArr = ["apple", "banana", "orange"];cellArr = cellstr(strArr);3. 访问和操作cell数组中的元素3.1 访问cell数组中的元素•可以使用大括号{}和圆括号()来访问cell数组中的元素。
•大括号{}返回一个指定位置的元素。
•圆括号()返回一个包含指定位置的元素的子cell数组。
•以下是一个示例代码:cellArr = {'apple', 10, [1 2 3]};strElem = cellArr{1}; % 访问第一个元素,并赋值给strElemnumElem = cellArr{2}; % 访问第二个元素,并赋值给numElemsubCellArr = cellArr(2:3); % 返回第2到第3个元素的子cell数组3.2 修改cell数组中的元素•可以直接对cell数组中的元素进行修改。
matlab 数组重复元素

matlab 数组重复元素
在MATLAB中,要找出数组中的重复元素,可以使用一些内置的函数和技巧来实现。
首先,可以使用unique函数来找到数组中的唯一元素,并用它来确定重复元素。
接着,可以使用hist函数来计算每个元素在数组中的出现次数,然后找出出现次数大于1的元素即为重复元素。
另外,也可以使用循环和逻辑索引来实现查找重复元素的功能。
下面我将从不同角度来详细介绍这些方法。
首先,使用unique函数可以很容易地找到数组中的唯一元素。
例如,对于一个数组A,可以使用B = unique(A)来得到数组A中的唯一元素,并将其存储在数组B中。
然后,可以使用hist函数来计算每个元素在数组A中的出现次数,即hist(A,B),其中B是unique函数得到的唯一元素数组。
通过查看hist函数的输出,可以很容易地找到出现次数大于1的元素,即为重复元素。
另一种方法是使用循环和逻辑索引来查找重复元素。
可以使用双重循环来比较数组中的每对元素,然后使用逻辑索引来标记重复元素。
这种方法比较直接,但对于大型数组来说可能效率不高。
除了上述方法,MATLAB还提供了一些其他函数和工具,如
intersect、ismember等,可以用来查找数组中的重复元素。
intersect函数可以用来找到两个数组的交集,即重复元素;ismember函数可以用来查找一个数组中的元素是否在另一个数组中出现,从而找到重复元素。
综上所述,MATLAB中查找数组重复元素的方法有很多种,可以根据具体情况选择合适的方法来实现。
希望以上信息能够帮助你更好地理解如何在MATLAB中找到数组中的重复元素。
matlab中cell函数的用法

matlab中cell函数的用法一、概述cell是matlab中的一种数据类型,用于存储不同类型的数据,如数值、字符、逻辑值等。
cell函数可以创建一个指定大小的空cell数组。
二、创建空cell数组使用cell函数可以创建一个指定大小的空cell数组,语法如下:C = cell(m,n)其中m和n分别表示行数和列数,C为所创建的空cell数组。
例如:C = cell(2,3)这将创建一个2行3列的空cell数组。
三、向cell数组中添加元素1. 单个元素添加要向已有的cell数组中添加单个元素,可以使用花括号{}将元素括起来,并将其赋值给相应的位置。
例如:C{1,1} = 'apple'这将在第1行第1列添加一个字符型元素'apple'。
2. 多个元素添加要向已有的cell数组中添加多个元素,可以使用花括号{}将多个元素组成一个矩阵,并将其赋值给相应的位置。
例如:C{1,2} = [1 2; 3 4]这将在第1行第2列添加一个2行2列的矩阵[1 2; 3 4]。
四、访问和修改cell数组中的元素访问和修改已有的cell数组中的元素与普通矩阵类似,使用圆括号()和花括号{}即可。
例如:C{1,1} % 访问第1行第1列的元素C{1,2}(2,1) % 访问第1行第2列中的矩阵的第2行第1列的元素C{2,3} = 'banana' % 修改第2行第3列的元素为字符型'banana'五、cell数组的常见操作1. cell数组转换为矩阵如果cell数组中所有元素都是相同类型的数值型数据,可以使用cell2mat函数将其转换为矩阵。
例如:C = {[1 2 3]; [4 5 6]}M = cell2mat(C)这将把C转换成一个2行3列的数值型矩阵M。
2. 矩阵转换为cell数组与上述相反,如果要将一个矩阵转换为cell数组,可以使用mat2cell 函数。
第5章 matlab数组和数组运算(2)

1. 标准数组:全1数组,全0数组,单位矩阵,随机矩阵,对角矩阵以及元素为指定常数的数组。
2.全1数组用ones函数,全0数组用zeros函数。
对于ones和zeros函数,当只有一个输入参数时,即ones(n)或zeros(n),Matlab就分别生成一个n×n的全1或者全0数组。
当有两个输入参数时,即ones(r,c)或者zeros(r,c),Matlab就分别生成r 行c列的全1或者全0数组。
要想生成一个与其他数组相同维数的全1或者全0数组,用户只要在ones或者zeros的参数中调用size函数就可以了。
测试数组:ones(4),m = ones(4,8)zeros(4),zeros(3,5),size(m),zeros(size(m))。
3.单位矩阵用eye函数。
该函数用与ones和zeros函数相同的语法格式来生成单位矩阵。
单位矩阵或数组是具有如下取值的矩阵或数组:除A(i,i)之外,所有其他元素都为0,其中i=min(r,c),min(r,c)是矩阵A中的行数和列数的最小数。
4.随机矩阵用rand函数。
函数rand生成均匀分布的随机数组,其元素取值介于0-1之间。
直接调用rand产生一个随机数,随机数组用rand(n)。
另外randn函数将生成均值为0,方差为1的正态分布矩阵。
rand和randn用法和ones相同。
5.对角矩阵用diag函数。
在该数组中,一个向量可以被放在与数组的主对角线平行的任何位置。
验证:a = 1:5 diag(a) diag(a,1)diag(a,-2)6.几种生成所有元素都相同的数组的方法,先令d=pi(1)d*one(3,4) slowest method(2)d+zeros(3,4) slower method(3)d(ones(3,4)) fast method(4)repmat(d,3,4) fastest method数组的数据量较小时,4种方法都可以。
matlab 常量数组

matlab 常量数组
在Matlab中,常量数组是指在程序执行过程中其值不会发生变
化的数组。
在Matlab中,我们可以使用以下方法来创建常量数组:
1. 使用zeros函数,可以使用zeros函数创建一个全为0的常
量数组。
例如,创建一个3行2列的全为0的常量数组可以使用以
下代码,A = zeros(3, 2);
2. 使用ones函数,同样地,可以使用ones函数创建一个全为
1的常量数组。
例如,创建一个2行4列的全为1的常量数组可以
使用以下代码,B = ones(2, 4);
3. 使用repmat函数,repmat函数可以用来创建一个重复的常
量数组。
例如,创建一个2行3列的常量数组,每个元素的值都为5,可以使用以下代码,C = repmat(5, 2, 3);
4. 使用eye函数,可以使用eye函数创建一个单位矩阵,单位
矩阵是指主对角线上的元素都为1,其余元素都为0的矩阵。
例如,创建一个3阶的单位矩阵可以使用以下代码,D = eye(3);
5. 使用常量赋值,也可以直接通过赋值的方式创建常量数组。
例如,创建一个包含指定值的常量数组可以使用以下代码,E = [2 4 6; 8 10 12];
这些方法可以帮助我们在Matlab中创建常量数组,从而方便我们在程序中使用不会发生变化的固定数值。
常量数组在Matlab中有着广泛的应用,例如在数学运算、图像处理和信号处理等领域。
希望这些信息能够帮助到你。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
MATLAB函数、数组、矩阵1. 基本运算与函数在MATLAB下进行基本数学运算,只需将运算式直接打入提示号(>>)之後,并按入Enter键即可。
例如:>> (5*2+1.3-0.8)*10/25ans =4.2000MATLAB会将运算结果直接存入一变数ans,代表MATLAB运算後的答案(Answer)并显示其数值於萤幕上。
我们也可将上述运算式的结果设定给另一个变数x:x = (5*2+1.3-0.8)*10^2/25x = 42此时MATLAB会直接显示x的值。
由上例可知,MATLAB认识所有一般常用到的加(+)、减(-)、乘(*)、除(/)的数学运算符号,以及幂次运算(^)。
若不想让MATLAB每次都显示运算结果,只需在运算式最後加上分号(;)即可,如下例:y = sin(10)*exp(-0.3*4^2);若要显示变数y的值,直接键入y即可:>>yy =-0.0045在上例中,sin是正弦函数,exp是指数函数,这些都是MATLAB常用到的数学函数。
小整理:MATLAB常用的基本数学函数abs(x):纯量的绝对值或向量的长度angle(z):复数z的相角(Phase angle)sqrt(x):开平方real(z):复数z的实部imag(z):复数z的虚部conj(z):复数z的共轭复数round(x):四舍五入至最近整数fix(x):无论正负,舍去小数至最近整数floor(x):地板函数,即舍去正小数至最近整数ceil(x):天花板函数,即加入正小数至最近整数rat(x):将实数x化为分数表示rats(x):将实数x化为多项分数展开sign(x):符号函数 (Signum function)。
当x<0时,sign(x)=-1;当x=0时,sign(x)=0;当x>0时,sign(x)=1。
小整理:MATLAB常用的三角函数sin(x):正弦函数cos(x):余弦函数tan(x):正切函数asin(x):反正弦函数acos(x):反余弦函数atan(x):反正切函数atan2(x,y):四象限的反正切函数sinh(x):超越正弦函数cosh(x):超越余弦函数tanh(x):超越正切函数asinh(x):反超越正弦函数acosh(x):反超越余弦函数atanh(x):反超越正切函数MATLAB 的内部函数是有限的,有时需要为MATLAB 定义新函数,为此必须编写函数M 文件。
例:()f x =在M 文件编辑窗口录入:function y=f1(x)y=sqrt((x-20).^2+100^2)+ sqrt((x-120).^2+120^2) ;以f1.m 将文件存盘并退出M 文件编辑状态,然后重新回到MATLAB 命令窗口。
然后可用f1(3),f1(17)等计算。
注意:函数文件的文件名必须与函数名同名。
练习:编写22212211(,)100()(1)f x x x x x =-+-的函数M 文件。
并计算f(1,2). 在M 文件编辑窗口录入:function f=f2(x)f=100*(x(2)-x(1)^2)^2+(1-x(1))^2 ;以f2.m将文件存盘并退出M文件编辑状态,然后重新回到MATLAB命令窗口。
然后可用f2(1,2)等计算。
2. 数组与矩阵2.1 数组2.1.1一维数组的构造方法1)逐个元素输入法如x=[2 pi/2 sqrt(3) 3+5i]。
2)冒号生成法以“first:increment:last”格式创建数组。
表示从first开始,以增量increment为步长,直到大于last前结束。
冒号表示increment 是数据元素增量。
例如:x=0:0.5:2 x=0:0.5:2.4 x=0:0.5:2.6 注1:也可以用()或[]括住表示,如x=(0:0.5:2), x=[0:0.5:2]。
注2:若增量为1,则可写成“fisrt:last”3)线性均匀采样函数法格式:linspace(first_value,last_value,number)linspace(first_value,last_value)----产生first_value到last_value之间100个行矢量数值。
linspace(first_value,last_value,number)----产生两值域之间number个数值。
4)常用对数采样法格式:logspace(a,b)----在ba10~10之间,产生50个对数空间点的行矢量。
logspace(a,b,n)----在ba1010之间产生n个对数空间点。
~logspace(a,pi)----在~10a之间产生50个对数空间点。
可以用于在该区间的频率在单位圆内时的数字信号处理情形。
注1:以上创建的是行矢量。
对列矢量的创建,可以用分号直接给出。
如x=[1;2;3;4;5;6]。
(当然也可用x=[1 2 3 4 5 6]'创建,' 表示转置)2.1.2一维数组的访问与编辑对数组的访问取决于下标的范围,下标取值在1-end之间,end 是数组的最大下标值,也即数组的长度。
x=rand(1,5) %产生一个均匀分布的随机数数组x(3) %访问第三个元素;x([1 2 5]) %第1、2、5个元素构成新的子数组x(1:3) %第1到3个元素构成的子数组x(3:end) %将3个元素以后的所有元素构成的子数组x(3:-1: 1) %形成由前3个元素构成的子数组注1:x(3:-1:1)是对数组x的访问,所以,其中的3表示的是起始下标值,-1表示的增量,1表示的是终止下标值。
但(3:-1:1)则是生成数组的冒号法,其中,3表示数组元素的起始值,-1是数组元素的变化步长,1是终止元素的最小值。
x(find (x>0.5)) %将大于0.5的元素构成新的子数组x([1 2 3 4 4 3 2 1]) %允许重复访问形成新的长度大于原数组的新数组。
对数组的赋值方法与访问方法相似。
如:x(3)=0x([1 4])=[1 1]注2:要保证赋值数组的长度不超过被赋值子数组的长度。
否则,系统报错。
例如:x([1 3])=[100 200] %合法赋值x([1 3])=[100] 或x([1 3])=100 %合法赋值x([1 3])=[100 200 300] %非法赋值删除数组中的数x(3)=[] %删除数组x第3个位置的数x([1 2])=[] %删除数组x第1, 2个位置的数2.1.3 数组的运算(1)标量-数组设a=[a1,a2,...,an],c=标量,则a+c=[a1+c,a2+c,...,an+c]a*c=[a1*c,a2*c,...,an*c]a./c=[a1/c,a2/c,...,an/c]=1/c*aa.\c=[c /a1, c /a2,..., c /an]a.^c=[a1^c,a2^c,...,an^c]c.^a=[c^a1, c ^a2,..., c ^an](2)数组-数组设a=[a1,a2,...,an],b=[b1,b2,...,bn],则a+b=[a1+b1,a2+b2,...,an+bn]a.*b=[a1*b1,a2*b2,...,an*bn]a./b=[a1/b1,a2/b2,...,an/bn]a.\b=[b1/a1,b2/a2,...,bn/an]a.^b=[a1^b1,a2^b2,...,an^bn]小整理:适用於向量的常用函数有:min(x): 向量x的元素的最小值max(x): 向量x的元素的最大值mean(x): 向量x的元素的平均值median(x): 向量x的元素的中位数std(x): 向量x的元素的标准差diff(x): 向量x的相邻元素的差sort(x): 对向量x的元素进行排序(Sorting)length(x): 向量x的元素个数norm(x): 向量x的欧氏(Euclidean)长度sum(x): 向量x的元素总和prod(x): 向量x的元素总乘积cumsum(x): 向量x的累计元素总和cumprod(x): 向量x的累计元素总乘积dot(x, y): 向量x和y的内积cross(x, y): 向量x和y的外积(大部份的向量函数也可适用於矩阵,详见下述。
)2.2 矩阵2.2.1矩阵的构造方法二维数组和矩阵的区别:二维数组具有线性变换含义时,称为矩阵。
否则,称为数组。
从数据结构的形式上,两者没有区别。
二维数组的创建:逐个元素的直接输入法(与一维相似)三个要素:一是必须以“[ ]”括住;数组的行与行之间必须以分号分隔,即“;”,或回车分隔;数组元素之间必须以逗号分隔,即“,”,或空格分隔。
1)利用已知数值变量值创建二维数组例如:a=2.75;b=33/99; %给变量a和b赋值c=[1,2*a+i*b,b*sqrt(a);sin(pi/4),a+5*b,3.5+i] %创建二维数组注1:分号在数组中时,表示每一行的分隔符;用做命令的结束符号时表示该命令执行的结果不显示在屏幕上。
2)利用一维数组变量创建二维数组例如:a=[1 2 3 4 5]; %创建一维数组ab=[6 7 8 9 10]; %创建一维数组bc=[a;b] %用数组a和b创建二维数组c3)对复数数组的另一种创建方法(分别创建实部和虚部,然后组成复数数组)例如:m_r=[1 2 3;4 5 6], m_i=[11 12 13;14 15 16] %分别创建实部和虚部cn=m_r+i*m_i %合成复数注2:逗号在方括号中时表示元素与元素之间的分隔符;在命令后时表示赋值结果将被显示在屏幕上。
4)利用M文件创建和保存数组对今经常要用到的大的、复杂的数组,一般可以建立一M文件保存之。
其步骤如下:(1)打开文件编辑调试器,输入如下内容:% mymatrix AMAM=[1,2,3,4,5,6; …3,4,5,6,7,8; …6,7,8,9,10];(2)取一M文件名来保存此文件,如mymatrix_AM.m。
(3)以后,只要在命令窗口中运行该M文件即可将其调如内存中来。
5)标准函数生成法常用来生成标准数组的函数:diag()----产生对角形数组(只实用于2维)。
格式有:diag(v,k)----v是一个长为n的矢量,k是对角以上(k>0)或以下(k<0)的最大次对角序号,则产生一个对应角上元素为对称的矩阵。
k=0时为主对角矩阵。
diag(v)----产生一个与v的元素个数为准的主对角矩阵。
diag(X,k)----返回矩阵X的k对角线上元素,并以列向量形式返回。
diag(X)----返回主对角线上的元素,并以列向量形式返回。