有没有一种方法可以使用 python 求解字段 F2 上的线性方程组(即加法和乘法模 2 - 二进制字段)?我一直在尝试寻找一个有用的包,但没有想出任何东西......
谢谢,
有没有一种方法可以使用 python 求解字段 F2 上的线性方程组(即加法和乘法模 2 - 二进制字段)?我一直在尝试寻找一个有用的包,但没有想出任何东西......
谢谢,
我创建了一个 Python 包galois,它在有限域上扩展了 NumPy 数组。它还支持np.linalg
.
这是一个求解 in 的线性系统的Ax = b
示例。x
GF(2)
In [1]: import numpy as np
In [2]: import galois
In [3]: GF = galois.GF(2)
In [4]: A = GF.Random((4,4)); A
Out[4]:
GF([[0, 1, 0, 0],
[0, 0, 1, 1],
[0, 0, 0, 1],
[1, 1, 0, 0]], order=2)
In [5]: x_truth = GF([1,0,1,1]); x_truth
Out[5]: GF([1, 0, 1, 1], order=2)
In [6]: b = A @ x_truth; b
Out[6]: GF([0, 0, 1, 1], order=2)
# Solve Ax = b for x
In [7]: x = np.linalg.solve(A, b); x
Out[7]: GF([1, 0, 1, 1], order=2)
# Verify that x is x_truth
In [8]: np.array_equal(x, x_truth)
Out[8]: True