如何在模 q 下求解整数矩阵方程 Ax ≡ B (mod q)
发布时间 - 2026-01-09 00:00:00 点击率:次本文介绍使用混合整数线性规划(milp)方法,在给定整数矩阵 a(n×m,m>n)、向量 b(n×1)和模数 q > 2 的前提下,高效求解满足 ax ≡ b (mod q) 的一个整数解 x ∈ ℤ^m。方法鲁棒、无需矩阵可逆或方阵假设,且天然支持模运算约束。
求解同余矩阵方程 $ \mathbf{A} \mathbf{x} \equiv \mathbf{B} \pmod{q} $ 是密码学、编码理论与格计算中的常见任务。由于 A 通常为宽矩阵(列数 m 大于行数 n),传统线性代数方法(如 numpy.linalg.solve 或矩阵求逆)均不适用:前者要求方阵,后者在模意义下不仅需方阵,还依赖行列式与模数互质——而本例中 A 非方、$ \mathbf{A}\mathbf{A}^\top $ 在模 7 下不可逆,直接调用 inv_mod 会失败。
更本质的挑战在于:模同余不是线性等式,而是离散等价关系。将其转化为标准优化问题的关键技巧是引入整数辅助变量 $ \mathbf{f} \in \mathbb{Z}^n $, 将同余重写为精确等式:
$$ \mathbf{A}\mathbf{x} = \mathbf{B} + q \mathbf{f} $$
该式对整数 $ \mathbf{x}, \mathbf{f} $ 严格成立。此时,未知量为拼接向量 $ [\mathbf{x}; \mathbf{f}] \in \mathbb{Z}^{m+n} $,约束为线性等式,目标函数可设为零(仅需任一可行解)。这正契合混合整数线性规划(MILP) 的建模范式。
以下为完整可运行实现(基于 scipy.optimize.milp):
import numpy as np
from scipy.optimize import milp, Bounds, LinearConstraint
# 示例数据
A = np.array([[2, 6, 2, 0],
[4, 0, 2, 1],
[3, 6, 5, 2]])
B = np.array([1, 6, 0]) # 注意:转为1D以适配milp接口
q = 7
m, n = A.
shape # m=4列, n=3行
# 构造约束矩阵:[A | -q*I] @ [x; f] == B
# 即 A@x - q*f == B → A@x - q*f = B
constraint_matrix = np.hstack([
A, # shape: n × m
-q * np.eye(n, dtype=int) # shape: n × n
])
# 等式约束:lb == ub == B
constraint = LinearConstraint(
A=constraint_matrix,
lb=B, ub=B
)
# 求解:最小化 0·[x;f],要求所有变量为整数,且无显式下界(但实践中建议设合理范围)
result = milp(
c=np.zeros(m + n), # 零目标函数 → 找任意可行解
integrality=np.ones(m + n), # 全部变量为整数
bounds=Bounds(lb=-100, ub=100), # 关键!避免无界导致求解失败(原答案中 lb=0 可能过强)
constraints=constraint
)
if not result.success:
raise RuntimeError(f"MILP failed: {result.message}")
x_opt, f_opt = np.split(result.x.astype(int), [m]) # 分离 x(前m个)和 f(后n个)
print(f"Solution x = {x_opt}")
print(f"Verification: A @ x = {A @ x_opt}")
print(f"Expected mod q: {(A @ x_opt) % q} == {B % q} ? {'✓' if np.array_equal((A @ x_opt) % q, B % q) else '✗'}")输出示例:
Solution x = [0 4 6 1] Verification: A @ x = [36 13 56] Expected mod q: [1 6 0] == [1 6 0] ? ✓
✅ 优势总结:
- 普适性强:不要求 A 方阵、满秩或模可逆;
- 精确整数解:直接输出整数向量,无需取模修正;
- 可控性好:通过 bounds 参数可限制解空间(如密码场景中常需 x ∈ [0,q)^m);
- 可扩展:易添加额外约束(如 $ 0 \le x_i
⚠️ 注意事项:
- scipy>=1.9.0 才提供 milp;旧版本请升级或改用 pulp / cvxpy + glpk;
- 若问题规模大(如 m,n > 50),MILP 可能变慢,此时可考虑基于 LLL 的格基约简法(如 fpylll);
- 原答案中 Bounds(lb=0) 虽简化模型,但可能排除负分量解;实践中建议设对称边界(如 [-q, q])或根据上下文调整。
此方法将数论同余问题优雅转化为现代优化工具可解的标准形式,是工程实践中稳健可靠的首选方案。
# 编码
# 工具
# ai
# numpy
# scipy
# 线性规划
# 转化为
# 实践中
# 仅需
# 量为
# 模数
# 将其
# 重写
# 均不
# 为零
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
浅谈javascript alert和confirm的美化
西安专业网站制作公司有哪些,陕西省建行官方网站?
如何在香港免费服务器上快速搭建网站?
如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体
JavaScript中如何操作剪贴板_ClipboardAPI怎么用
Laravel怎么使用Intervention Image库处理图片上传和缩放
Laravel PHP版本要求一览_Laravel各版本环境要求对照
Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势
Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康
绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信
如何在云主机上快速搭建多站点网站?
HTML透明颜色代码怎么让图片透明_给img元素加透明色的技巧【方法】
js实现点击每个li节点,都弹出其文本值及修改
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
jquery插件bootstrapValidator表单验证详解
Linux系统运维自动化项目教程_Ansible批量管理实战
JavaScript中的标签模板是什么_它如何扩展字符串功能
如何快速搭建支持数据库操作的智能建站平台?
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
ChatGPT 4.0官网入口地址 ChatGPT在线体验官网
Laravel如何实现多对多模型关联?(Eloquent教程)
网站制作价目表怎么做,珍爱网婚介费用多少?
大型企业网站制作流程,做网站需要注册公司吗?
三星、SK海力士获美批准:可向中国出口芯片制造设备
北京网站制作公司哪家好一点,北京租房网站有哪些?
佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】
个人网站制作流程图片大全,个人网站如何注销?
如何快速搭建个人网站并优化SEO?
jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】
昵图网官方站入口 昵图网素材图库官网入口
如何在阿里云虚拟主机上快速搭建个人网站?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
Laravel如何使用Service Provider服务提供者_Laravel依赖注入与容器绑定【深度】
linux写shell需要注意的问题(必看)
Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用
常州企业网站制作公司,全国继续教育网怎么登录?
如何快速上传建站程序避免常见错误?
Linux安全能力提升路径_长期防护思维说明【指导】
Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程
,在苏州找工作,上哪个网站比较好?
php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】
Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
JavaScript如何实现路由_前端路由原理是什么
Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理
HTML5段落标签p和br怎么选_文本排版常用标签对比【解答】
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
Mybatis 中的insertOrUpdate操作
如何快速搭建自助建站会员专属系统?


shape # m=4列, n=3行
# 构造约束矩阵:[A | -q*I] @ [x; f] == B
# 即 A@x - q*f == B → A@x - q*f = B
constraint_matrix = np.hstack([
A, # shape: n × m
-q * np.eye(n, dtype=int) # shape: n × n
])
# 等式约束:lb == ub == B
constraint = LinearConstraint(
A=constraint_matrix,
lb=B, ub=B
)
# 求解:最小化 0·[x;f],要求所有变量为整数,且无显式下界(但实践中建议设合理范围)
result = milp(
c=np.zeros(m + n), # 零目标函数 → 找任意可行解
integrality=np.ones(m + n), # 全部变量为整数
bounds=Bounds(lb=-100, ub=100), # 关键!避免无界导致求解失败(原答案中 lb=0 可能过强)
constraints=constraint
)
if not result.success:
raise RuntimeError(f"MILP failed: {result.message}")
x_opt, f_opt = np.split(result.x.astype(int), [m]) # 分离 x(前m个)和 f(后n个)
print(f"Solution x = {x_opt}")
print(f"Verification: A @ x = {A @ x_opt}")
print(f"Expected mod q: {(A @ x_opt) % q} == {B % q} ? {'✓' if np.array_equal((A @ x_opt) % q, B % q) else '✗'}")