python - 如何在 Python 2.7 中使用矩阵平衡化学方程式

标签 python matrix equation balance chemistry

我有一项大学作业,我必须平衡以下等式:

NaOH + H2S04 --> Na2S04 + H2O

我目前对 Python 和编码的了解非常有限。 到目前为止,我已经尝试使用矩阵来求解方程。 看起来我得到了解决方案 a=b=x=y=0 我想我需要将其中一个变量设置为 1 并求解其他三个变量。 我不知道该怎么做, 我搜索了一下,好像 其他人使用了更复杂的代码,但我真的无法理解!

这是我目前所拥有的

    #aNaOH + bH2S04 --> xNa2SO4 +y H20

    #Na: a=2x
    #O: a+4b=4x+y
    #H: a+2h = 2y
    #S: b = x

    #a+0b -2x+0y = 0
    #a+4b-4x-y=0
    #a+2b+0x-2y=0
    #0a +b-x+0y=0

    A=array([[1,0,-2,0],

             [1,4,-4,-1],

             [1,2,0,-2],

             [0,1,-1,0]])

    b=array([0,0,0,0])




    c =linalg.solve(A,b)

    print c

0.0.0.0

最佳答案

问题是您构建了一个线性系统,其中 b 是零向量。现在对于这样的系统,总是有一个直接的答案,即所有变量也都是零。因为将数字与零相乘并添加零,结果始终为零。

一个解决方案可能是将 1 赋给一个变量。以 a 为例。如果我们分配 a = 1,那么我们将在 的函数中得到 bxy a 为 1。

所以现在或线性系统是:

 B  X  Y |    #
    2    |1   #  A    = 2X
-4  4  1 |1   #  A+4B = 4X+4Y
-2     2 |1   #  A+2B =    2Y
-1  1  0 |0   #     B =     X

或者将其写入代码:

>>> A = array([[0,2,0],[-4,4,1],[-2,0,2],[-1,1,0]])
>>> B = array([1,1,1,0])
>>> linalg.lstsq(A,B)
(array([ 0.5,  0.5,  1. ]), 6.9333477997940491e-33, 3, array([ 6.32979642,  2.5028631 ,  0.81814033]))

这意味着:

 A = 1, B = 0.5, X = 0.5, Y = 1.

如果我们将其乘以 2,我们得到:

2 NaOH + H2S04 -> Na2S04 + 2 H20

哪个是正确的。

关于python - 如何在 Python 2.7 中使用矩阵平衡化学方程式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45220032/

相关文章:

python - 具有多个迭代值的 For 循环

c++ - 迷宫生成算法设计(递归除法)

r - 如何将数据帧(或向量)转换为矩阵以将 R 基线包用于除提供的示例数据之外的数据?

r - 将稀疏矩阵的元素归零,基于另一个矩阵(矩阵包)

algorithm - 斐波那契算法的递归方程

Python。从 data.frame 获取结构

python - 将模型导出到 PMML

python - 放大后无法获取任何元素的屏幕截图

python - 函数不返回特定值

Python 方程求解器(最大值和最小值)