Qia*_* Li 2 wolfram-mathematica
我获得了folloiwng方程(作为例子):
{2 w11 + 3 w21 == 2 w12, w11 == 4 w12 + 3 w22, w11 + 2 w21 + w22 == 0,
2 w12 + w21 + 2 w22 == 0}
Run Code Online (Sandbox Code Playgroud)
我想确定w11,w12,w21,w22.但是,只需执行以下操作:
Solve[{3 w11 + 2 w21 == 5 w11 + 3 w12, w11 + w21 == 5 w21 + 3 w22,
3 w12 + 2 w22 == -2 w11 - w12, w12 + w22 == -2 w21 - w22}, {w11,
w12, w21, w22}]
Run Code Online (Sandbox Code Playgroud)
因为方程系统是不确定的.我有一个想法,即使用矩阵代数.但我需要自动将w11,w12,w21,w22前面的那些系数分组到矩阵(列表列表)中,然后从那里开始.但我不确定如何轻易地操纵这些方程来生成这样的矩阵.请帮助,或者如果您有更好的想法,请分享.
非常感谢.
有一个内置函数CoefficientArrays可以将线性(或多项式)方程组转换成矩阵形式.
你想要的矩阵是结果的第二部分:
In[7]:= vars = {w11, w12, w21, w22};
In[8]:= CoefficientArrays[{2 w11 + 3 w21 == 2 w12,
w11 == 4 w12 + 3 w22, w11 + 2 w21 + w22 == 0,
2 w12 + w21 + 2 w22 == 0}, vars] // Normal
Out[8]= {{0, 0, 0,
0}, {{2, -2, 3, 0}, {1, -4, 0, -3}, {1, 0, 2, 1}, {0, 2, 1, 2}}}
Run Code Online (Sandbox Code Playgroud)
不均匀的部分是结果的第一部分,一个向量:
In[9]:= CoefficientArrays[{3 w11 + 2 w12 == 5 w11 + 3 w21 + a,
w11 + w12 == 5 w12 + 3 w22 - c,
3 w21 + 2 w22 + b == a - 2 w11 - w21,
w21 + w22 == f - 2 w12 - w22}, vars] // Normal
Out[9]= {{-a,
c, -a + b, -f}, {{-2, 2, -3, 0}, {1, -4, 0, -3}, {2, 0, 4, 2}, {0,
2, 1, 2}}}
Run Code Online (Sandbox Code Playgroud)
这是你的方程式和变量:
vars = {w11, w12, w21, w22};
eqs = {2 w11 + 3 w21 == 2 w12, w11 == 4 w12 + 3 w22,
w11 + 2 w21 + w22 == 0, 2 w12 + w21 + 2 w22 == 0};
Run Code Online (Sandbox Code Playgroud)
这是矩阵:
In[48]:= matrix = Transpose[ eqs /. Equal :> Subtract /.
Map[Thread[vars -> #] &, IdentityMatrix[Length[vars]]]]
Out[48]= {{2, -2, 3, 0}, {1, -4, 0, -3}, {1, 0, 2, 1}, {0, 2, 1, 2}}
Run Code Online (Sandbox Code Playgroud)
编辑:
同样适用于您的第二组方程:
In[49]:= eqs = {3 w11 + 2 w21 == 5 w11 + 3 w12, w11 + w21 == 5 w21 + 3 w22,
3 w12 + 2 w22 == -2 w11 - w12, w12 + w22 == -2 w21 - w22};
In[50]:= matrix = Transpose[ eqs /. Equal :> Subtract /.
Map[Thread[vars -> #] &, IdentityMatrix[Length[vars]]]]
Out[50]= {{-2, -3, 2, 0}, {1, 0, -4, -3}, {2, 4, 0, 2}, {0, 1, 2, 2}}
Run Code Online (Sandbox Code Playgroud)
编辑:
根据要求扩展解决方案.首先,它是如何工作的:想法是首先将所有变量放到左边,这是通过用减法替换equals运算符来实现的:
In[69]:= eqs = {3 w11 + 2 w21 == 5 w11 + 3 w12, w11 + w21 == 5 w21 + 3 w22,
3 w12 + 2 w22 == -2 w11 - w12, w12 + w22 == -2 w21 - w22};
Run Code Online (Sandbox Code Playgroud)
在[70]:= eqs /.相等:>减去
Out [70] = {-2 w11 - 3 w12 + 2 w21,w11 - 4 w21 - 3 w22,2 w11 + 4 w12 + 2 w22,w12 + 2 w21 + 2 w22}
构造规则使得对于任何规则组,只有一个变量设置为1,其余变量设置为0:
In[71]:= Map[Thread[vars -> #] &, IdentityMatrix[Length[vars]]]
Out[71]= {{w11 -> 1, w12 -> 0, w21 -> 0, w22 -> 0}, {w11 -> 0, w12 -> 1, w21 -> 0, w22 -> 0},
{w11 -> 0, w12 -> 0, w21 -> 1, w22 -> 0}, {w11 -> 0, w12 -> 0, w21 -> 0, w22 -> 1}}
Run Code Online (Sandbox Code Playgroud)
这允许计算系数:
In[72]:= eqs /. Equal :> Subtract /. Map[Thread[vars -> #] &, IdentityMatrix[Length[vars]]]
Out[72]= {{-2, 1, 2, 0}, {-3, 0, 4, 1}, {2, -4, 0, 2}, {0, -3, 2, 2}}
Run Code Online (Sandbox Code Playgroud)
在检查规则如何工作时,很容易看出我们需要应用于Transpose结果.
现在,您的第二个请求需要更多工作:
In[53]:= eqs = {3 w11 + 2 w12 == 5 w11 + 3 w21 + a, w11 + w12 == 5 w12 + 3 w22 - c,
3 w21 + 2 w22 + b == a - 2 w11 - w21, w21 + w22 == f - 2 w12 - w22};
In[55]:= modifiedEqs = With[{alts = Alternatives @@ vars},
eqs //. {lhs_ == HoldPattern[Plus[left___, x_, right___]] /; !FreeQ[x, alts] :>
lhs - x == left + right,
HoldPattern[Plus[left___, x_, right___] == rhs_] /; FreeQ[x, alts] :>
(left + right == rhs - x)}]
Out[55]= {-2 w11 + 2 w12 - 3 w21 == a, w11 - 4 w12 - 3 w22 == -c,
2 w11 + 4 w21 + 2 w22 == a - b, 2 w12 + w21 + 2 w22 == f}
In[68]:= matrix = {Transpose[# /. (lhs_ == rhs_) :> lhs /.
Map[Thread[vars -> #] &, IdentityMatrix[Length[vars]]]], #[[All,2]]} &[modifiedEqs]
Out[68]= {{{-2, 2, -3, 0}, {1, -4, 0, -3}, {2, 0, 4, 2}, {0, 2, 1, 2}}, {a, -c, a - b, f}}
Run Code Online (Sandbox Code Playgroud)
主要区别在于我们需要一个额外的步骤来分隔常量并将它们带到rhs您可能会发现更有用的是弄清楚它是如何工作的细节.
编辑:
是的,我忘了提及:要理解解决方案,您应该知道在嵌套列表中应用规则时会发生什么 - 在这种情况下,较大列表中的每个规则列表都会生成表达式的转换副本,例如:
In[73]:= {a, b, c} /. {{a -> 1}, {b -> 1}, {c -> 1}}
Out[73]= {{1, b, c}, {a, 1, c}, {a, b, 1}}
Run Code Online (Sandbox Code Playgroud)
HTH
| 归档时间: |
|
| 查看次数: |
1536 次 |
| 最近记录: |