[MATLAB]符号对象建立运算以及符号矩阵(syms,factor,assume,collect)

2023-10-12 23:20

本文主要是介绍[MATLAB]符号对象建立运算以及符号矩阵(syms,factor,assume,collect),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本实验源于中南大学《科学计算与MATLAB语言》,包括三个内容,内容如下:

  • 符号对象的建立
  • 符号对象的运算
  • 符号矩阵

符号对象的建立

  • sym函数
    sym函数用于建立单个符号对象,其常用调用格式为:
符号对象名=sym(A)

将由A来建立符号对象,其中,A可以是一个数值常量、数值矩阵或数值表达式(不加单引号),此时符号对象为一个符号常量;A也可以是一个变量名(加单引号),这时符号对象为一个符号变量.
下面给出两个例子
1、将符号常量2赋给t,参与四则运算
2、 将常量pi/3转化为符号对象求正弦值
3、将pi/3做数值计算,得到真实的sin正弦值
代码如下:

>> t=sym(2);
>> t+1/2ans =5/2>> sin(sym(pi/3))ans =1/2*3^(1/2)>> sin(pi/3)ans =0.8660>> 

总结:第一个求的是数值,第二个计算符号常量是一个表达时,第三个计算常量是一个数值
下面来两个符号变量的例子

>> a=5;
>> b=-8;
>> x=sym('a');
>> y=sym('b');
>> w=(a+b)*(a-b)w =-39>> s=(x+y)*(x-y)s =(a+b)*(a-b)>> 

大家有没有体会到,反正博主已经体会到了,这个变量能计算,符号常量貌似只能出个表达式,也就是符号计算的结果是一个精确的数学表达式,数值计算只能是数值。

>> eval(s)ans =-39>> 

没有我matlab函数干不了的,再来一个eval函数!

  • syms命令
    syms命令可以一次定义多个符号变量,其一般调用格式如下:
syms 符号变量1 符号变量2 ... 符号变量名n

其中,变量名不能加单引号,相互之间用空格隔开。

符号对象的运算

四则运算

符号表达式的四则运算与数值运算一样,用+、-、*、/、^运算符实现,其运算结果依然是一个符号表达式.

>> syms x;
>> f=2*x^2+3*x-5;
>> g=x^2-x+7;
>> f+gans =3*x^2+2*x+2>> 

这段代码就是利用符号对象创建表达式然后进行两个多项的加法,是不是非常神奇?

关系运算

  • 6种关系运算符:<、<=、>、>=、==、~=
  • 对应的6个函数:lt()、le()、gt()、ge()、eq()、ne()
    若参与运算的是符号表达式,其结果是一个符号表达式:若参与运算的是符号矩阵,其结果是由符号关系表达式组成的矩阵.
    在进行符号对象的运算前,可用assume函数符号对象设置值域,函数调用格式为:
assume(condition)
assume(expr,set)

第一种格式指定变量满足条件condition,第二种格式指定表达式expr属于集合set。

syms x;
assume(x<0);
abs(x)==xassume(x,'positive');
abs(x)==x

逻辑运算

  • 3种逻辑运算符:)(与)、|(或)和~(非)。
  • 4个逻辑运算函数:and()、or()、not()、xor().
syms x
and(x<0,x>10);

因式分解与展开运算

MATLAB提供了符号表达式进行因式分解、展开、合并的函数,函数的调用格式为:

factor(s):对符号表达式s分解因式
expand(s):对符号表达式s进行展开
collect(s):对符号表达式s合并同类项
collect(s,v):对符号表达式s按变量v合并同类项
>> syms a b;
>> s=a^3-b^3;
>> factor(s)ans =-(b-a)*(b^2+b*a+a^2)>> 
>> factor(12)ans =2     2     3>> 

我用c实现的,结果matlab都已经实现好了,太强了!

梅森素数的验证问题

在这里插入图片描述
数学的理论领域里要研究大素数,而大素数都是梅森素数,梅森素数的寻找也就变得为大素数提供了方向!

>> syms p;
>> m=2^p-1;
>> p=19;
>> m19=eval(m)m19 =524287>> factor(m19)ans =524287>> 
>> p=23;
>> m23=eval(m)m23 =8388607>> factor(m23)ans =47      178481>> p=29;
>> m29=eval(m)m29 =536870911>> factor(m29)ans =233        1103        2089>> p=31;
>> m31=eval(m)m31 =2.1475e+009>> factor(m31)ans =2.1475e+009>> 

总结:M19/M31不能被分解,所以是素数
M23/M29能被分解,所以不是素数

其他运算

提取有理分式的分子分母:[n,d]=nuden(s)
提取符号表达式的系数:c=coeffs(s,x)
符号表达式化简:simplify(s)
符号多项式与多项式系数向量之间的转换:
符号多项式转换为多项式系数向量:p=sym2poly(s)
多项式系数向量转换为符号多项式:s=poly2sym(p)

在这里插入图片描述
步骤:

  1. 建立方程
  2. 取出系数
  3. 反转系数
  4. 求根roots,打完收工!
>> syms a b c x;
>> f=a*x^2+b*x+c>> g=coeffs(f,x)>> g=g(end:-1:1)>> roots(g)

符号运算种变量的确定

  1. 如果没有明确指定自变量,MATLAB将按以下原则确定主变量并对其相应运算:
    ①寻找除i,j之外,在字母顺序上最接近x的小写字母
    ②若表达式中有两个符号变量与x的距离相等,则ASCII码大者优先。

  2. symvar()函数可以用于查找一个符号表达式中符号变量,函数的调用格式为:

symvart(s,n)

函数返回符号表达式s中n个符号变量。因此,可以用symvar(s1j)查找表达式s的主变量

符号矩阵

符号矩阵也是一种符号表达式,所以符号表达式运算都可以在矩阵意义下进行。
注意:这些函数作用于符号矩阵时,是分别作用于矩阵的每一个元素。
在这里插入图片描述

>> syms a b x y alp;
>> m=[a^3-b^3,sin(alp)^2+cos(alp)^2;(15*x*y-3*x^2)/(x-5*y),78]m =[                a^3-b^3,  sin(alp)^2+cos(alp)^2]
[ (15*x*y-3*x^2)/(x-5*y),                     78]>> simplify(m)ans =[ a^3-b^3,       1]
[    -3*x,      78]>> 

在这里插入图片描述
对于齐次线性方程组Ax=0,当rank(A)<n或|A|=0时,齐次线性方程组有非零解。

>> syms lamda;
>> A=[1-lamda,-2,4;2,3-lamda,1;1,1,1-lamda];
>> D=det(A);
>> factor(D)ans =-lamda*(lamda-2)*(-3+lamda)>> 

根据线性代数的知识,可以看出,当其为0,2,3即有非零解。
在这里插入图片描述

这篇关于[MATLAB]符号对象建立运算以及符号矩阵(syms,factor,assume,collect)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/199143

相关文章

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

uva 575 Skew Binary(位运算)

求第一个以(2^(k+1)-1)为进制的数。 数据不大,可以直接搞。 代码: #include <stdio.h>#include <string.h>const int maxn = 100 + 5;int main(){char num[maxn];while (scanf("%s", num) == 1){if (num[0] == '0')break;int len =

hdu 4565 推倒公式+矩阵快速幂

题意 求下式的值: Sn=⌈ (a+b√)n⌉%m S_n = \lceil\ (a + \sqrt{b}) ^ n \rceil\% m 其中: 0<a,m<215 0< a, m < 2^{15} 0<b,n<231 0 < b, n < 2^{31} (a−1)2<b<a2 (a-1)^2< b < a^2 解析 令: An=(a+b√)n A_n = (a +

建立升序链表

题目1181:遍历链表 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:2744 解决:1186 题目描述: 建立一个升序链表并遍历输出。 输入: 输入的每个案例中第一行包括1个整数:n(1<=n<=1000),接下来的一行包括n个整数。 输出: 可能有多组测试数据,对于每组数据, 将n个整数建立升序链表,之后遍历链表并输出。 样例输

hdu 6198 dfs枚举找规律+矩阵乘法

number number number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Problem Description We define a sequence  F : ⋅   F0=0,F1=1 ; ⋅   Fn=Fn

Java第二阶段---09类和对象---第三节 构造方法

第三节 构造方法 1.概念 构造方法是一种特殊的方法,主要用于创建对象以及完成对象的属性初始化操作。构造方法不能被对象调用。 2.语法 //[]中内容可有可无 访问修饰符 类名([参数列表]){ } 3.示例 public class Car {     //车特征(属性)     public String name;//车名   可以直接拿来用 说明它有初始值     pu

matlab读取NC文件(含group)

matlab读取NC文件(含group): NC文件数据结构: 代码: % 打开 NetCDF 文件filename = 'your_file.nc'; % 替换为你的文件名% 使用 netcdf.open 函数打开文件ncid = netcdf.open(filename, 'NC_NOWRITE');% 查看文件中的组% 假设我们想读取名为 "group1" 的组groupName

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87

C# double[] 和Matlab数组MWArray[]转换

C# double[] 转换成MWArray[], 直接赋值就行             MWNumericArray[] ma = new MWNumericArray[4];             double[] dT = new double[] { 0 };             double[] dT1 = new double[] { 0,2 };

HTML5自定义属性对象Dataset

原文转自HTML5自定义属性对象Dataset简介 一、html5 自定义属性介绍 之前翻译的“你必须知道的28个HTML5特征、窍门和技术”一文中对于HTML5中自定义合法属性data-已经做过些介绍,就是在HTML5中我们可以使用data-前缀设置我们需要的自定义属性,来进行一些数据的存放,例如我们要在一个文字按钮上存放相对应的id: <a href="javascript:" d