经典与量子算法及多元二次多项式问题求解

立即解锁
发布时间: 2025-08-31 01:10:23 阅读量: 16 订阅数: 45 AIGC
PDF

后量子密码学前沿研究

# 经典与量子算法及多元二次多项式问题求解 ## 1. 通用综合征的经典与量子算法 ### 1.1 函数 \(f\) 的构造与计算 对于固定的 \(k\),若存在 \(y_1', \cdots, y_{2a - 1}'\),使得每个 \(y_i' \in L_i\) 且 \(\sum_{i} y_i' + y_{2a}^k = s\)(即属于 \(L_{top}\)),我们可以得到与 \(i \in [2a - 1]\) 相关的 \(b_i\),满足 \(H b_i = y_i'\),且 \(H b_{2a} = y_{2a}^k\)。此时令 \(e_k = \sum_{i} b_i\),若存在多个这样的向量,则按照字典序取第一个。若该等式成立,则 \(H e_k = s\)。我们定义函数 \(f\) 如下: \[ f(k) = \begin{cases} e_k \text{(上述定义)}, & \text{若这样的向量存在}\\ 0, & \text{否则} \end{cases} \] 构造 \(f\) 的步骤如下: 1. 为除最右侧列表外的每个楼层构造所有列表。 2. 根据相应 \(J_j\) 的索引,按字典序对这些列表进行排序。 3. 对于输入 \(k\),从 \(y_{2a}^k\) 开始,尝试将其与左侧相邻列表中的元素 \(y'\) 相加,使和出现在顶部列表中(若有多个,按字典序取第一个)。这可以通过二分搜索在列表大小的对数时间内高效完成。 4. 重复上述过程,直到失败(输出 0)或到达顶部列表,然后输出相应的 \(e_k\)。 构造和排序列表以计算 \(f\) 需要时间 \(qN(u' + o(1))\)(省略常数乘法项 \(2a\)),但后续计算 \(f\) 只需多项式时间。使得 \(f(k)\) 输出有效解的 \(k\) 的数量实际上就是 \(L_{top}\) 的大小,即 \(qN(3u' - x)\),由于 \(f : [Y] \to F_q^n\),这证明了相关命题。 ### 1.2 计算表面积 考虑一个大小为 \(n\) 的多重集,其元素取自 \(\{0, \cdots, q - 1\}\),每个元素重复 \(c_i\) 次,\(i \in \{0, 1, \cdots, q - 1\}\)。这样的多重集的排列数由多项式系数定义: \[ \begin{pmatrix} n \\ c_0, c_1, \cdots, c_{q - 1} \end{pmatrix} \stackrel{\text{def}}{=} \frac{n!}{c_0! c_1! \cdots c_{q - 1}!} \] 这个数对应于由 \(c_0\) 个零、\(c_1\) 个一、\(\cdots\)、\(c_q\) 个 \(q\) 组成的向量的数量。 进一步定义 \(C = \{c = (c_0, \cdots, c_{q - 1}) : i \in \{0, 1, \cdots, q - 1\}, c_i \in \mathbb{N}, \sum_{i = 0}^{q - 1} c_i = n, \sum_{i = 0}^{q - 1} c_i \text{wt}'(i) = w\}\)。根据球面表面积的定义,我们有: \[ S_n^w = \sum_{c \in C} \begin{pmatrix} n \\ c \end{pmatrix} \] 对于固定的 \(n\) 和 \(q\),集合 \(C\) 的大小(即求和项的数量)上界为 \(\begin{pmatrix} n + q - 1 \\ q - 1 \end{pmatrix}\)。因此,\(S_n^w\) 的上下界为: \[ \max_{c \in C} \begin{pmatrix} n \\ c \end{pmatrix} \leq S_n^w \leq \begin{pmatrix} n + q - 1 \\ q - 1 \end{pmatrix} \max_{c \in C} \begin{pmatrix} n \\ c \end{pmatrix} \] 按照特定推理方式,即对上述方程的每一部分取以 \(q\) 为底的对数,乘以 \(\frac{1}{n}\)(其中 \(n \to +\infty\)),并使用斯特林近似,最终可得到方程 (5)。 ### 1.3 凸优化问题 问题 3 属于凸优化问题的子类,即锥优化问题。因此可以使用 MOSEK 求解器来解决。不过,为了能通过 MOSEK 求解,问题 3 需要转换为锥优化问题的标准形式,即问题 4: 设 \(\lambda = (\lambda_0, \lambda_1, \cdots, \lambda_{q - 1}) \in \mathbb{R}_+^q\) 且 \(\tau = (\tau_0, \tau_1, \cdots, \tau_{q - 1}) \in \mathbb{R}_+^q\)。 - 最大化:\(\sum_{i = 0}^{q - 1} \tau_i\) - 约束条件: - \(\sum_{i = 0}^{q - 1} \lambda_i = 1\) - \(\sum_{i = 0}^{q - 1} \lambda_i \text{wt}'(i) = \omega\) - \((1, \lambda, \tau) \in K_{exp}\),其中约束 \((1, \lambda, \tau) \in K_{exp}\) 表示对于每个 \(i \in \{0, 1, \cdots, q - 1\}\),\(\tau_i \leq - \lambda_i \log_q \lambda_i\)。 可以很容易验证问题 3 和问题 4 是等价的,因此求解其中任何一个都能得到球面表面积的渐近值。 ## 2. 多元二次多项式问题求解 ### 2.1 多元二次多项式问题概述 多元二次多项式问题(MQ 问题)是后量子密码学中的一个基本计算问题。我们用 \(MQ(q, n, m)\) 表示在有限域 \(F_q\) 上 \(n\) 个变量的 \(m\) 个二次方程的 MQ 问题。若 \(n > m\),则系统为欠定的;若 \(n < m\),则为超定的。该问题是 NP 完全的,因此被认为有潜力抵抗量子计算机的攻击。 ### 2.2 混合方法 给定在 \(F_q\) 上 \(n\) 个变量的二次多项式系统 \(P = (p_1, \cdots, p_m)\),考虑系统 \(P(x) = 0\)。假设变量数量 \(n\) 小于或等于方程数量 \(m\)(若 \(n > m\),可以随机指定 \(n - m\) 个变量,大概率不影响解的存在性)。 二次系统可以使用 XL 算法或 Gröbner 基技术(如 F4 和 F5 算法)求解。此外,我们引入混合方法,它将穷举搜索与 MQ 求解器(如 XL、F4 或 F5)相结合。在这种方法中,对于 \(0 \leq k \leq n - 1\),在将 MQ 求解器应用于剩余 \(n - k\) 个变量的系统之前,随机猜测 \(k\) 个变量,重复此过程直到找到解。使用 Wiedemann XL 的复杂度,混合方法的复杂度估计为: \[ O \left( q^k \cdot 3 \cdot \binom{n -
corwn 最低0.47元/天 解锁专栏
买1年送3月
继续阅读 点击查看下一篇
profit 400次 会员资源下载次数
profit 300万+ 优质博客文章
profit 1000万+ 优质下载资源
profit 1000万+ 优质文库回答
复制全文

相关推荐

史东来

安全技术专家
复旦大学计算机硕士,资深安全技术专家,曾在知名的大型科技公司担任安全技术工程师,负责公司整体安全架构设计和实施。
最低0.47元/天 解锁专栏
买1年送3月
百万级 高质量VIP文章无限畅学
千万级 优质资源任意下载
千万级 优质文库回答免费看
立即解锁

专栏目录

最新推荐

媒体管理与收听指南

# 媒体管理与收听指南 ## 一、音乐库管理 ### (一)处理大容量音乐库 拥有大量音乐时,会面临两个问题:一是在音乐应用中管理所有音乐,二是将音乐同步到无法容纳所有内容的移动设备。为了更好地管理音乐文件,有以下建议: 1. **精确标签**:仔细为音乐添加标签,以便能轻松找到所需音乐。使用更多的音乐流派可以更方便地对音乐收藏进行分类和筛选。在音乐应用的“信息”对话框中输入流派名称,即可为音乐添加流派标签。 2. **清理音乐**:检查不常听的音乐,创建一个智能播放列表,规则设置为“[最后播放时间] [不在最后] 6 [个月]”,查看符合条件的音乐,将这些不常听的音乐移至第二个音乐库。这样

构建跨平台任务列表应用:iOS与macOS的数据存储与界面适配

# 构建跨平台任务列表应用:iOS 与 macOS 的数据存储与界面适配 ## 1. 实现 iOS 任务数据的持久化存储 在开发 iOS 任务列表应用 TahDoodle 时,我们发现当程序退出后,所有数据都会丢失,下次启动应用时又会回到示例数据。为了解决这个问题,我们需要实现任务数据的持久化存储。 ### 1.1 确定存储位置 首先,我们需要获取一个可以存储任务数据的本地 URL。这可以通过 `FileManager` 来实现: ```swift class TaskStore: ObservableObject { private let fileURL: URL = {

Mac系统安全与实用工具全解析

# Mac系统安全与实用工具全解析 ## 一、Mac系统更新与数据安全保护 ### 1.1 系统更新提示 若在程序坞的App Store图标上看到小数字,这意味着有相应数量的更新在等待。此时,需启动Mac App Store,然后点击“更新”标签来进行更新操作。 ### 1.2 数据防窥探安全措施 为保护文件不被局域网内其他用户或能物理访问Mac的用户干扰,可采取以下安全措施: - **阻止或限制连接**: - 打开“系统偏好设置”应用程序(可从“应用程序”文件夹、菜单或程序坞中启动)。 - 点击“共享”图标,打开“共享”系统偏好设置面板。 - 若禁用“共享”面板中

云计算与混合云:技术解析与应用指南

### 云计算与混合云:技术解析与应用指南 #### 1. 迈向云端的建议 在领略到云计算的魅力后,若想将网络迁移至云端,可参考以下建议: - **避免依赖劣质网络连接**:采用云计算前,勿依赖消费级网络连接。消费级网络虽有时速度快,但故障修复时间不定。建议投资高速企业级网络连接,其可随业务需求增长而扩展。 - **评估已使用的云应用**:若使用 Gmail 而非 Exchange 处理邮件,表明已在使用云服务。其他常见云服务包括远程 Web 或 FTP 主机、Dropbox 等文件共享服务、Carbonite 等在线备份服务以及薪资服务等。 - **逐步迁移至云端**:先确定一个适合迁移至

提升Windows使用便捷性的实用指南

### 提升Windows使用便捷性的实用指南 在日常使用电脑的过程中,我们常常会遇到各种操作上的不便,尤其是对于那些有行动或灵活性问题的用户。不过,Windows系统提供了一系列实用的功能和设置,能够显著提升使用的便捷性。下面将为大家详细介绍如何让键盘更易使用以及通过语音控制Windows的方法。 #### 让键盘更易使用 如果你在操作键盘时存在一定困难,可通过激活以下几个功能来增强键盘的可访问性: - **粘滞键(Sticky keys)**:该功能允许你一次按下一个键来实现多键组合快捷键,比如 `Ctrl + C` 和 `Alt + Tab` 等。 - **筛选键(Filter ke

探索云计算网络与Windows365的未来

# 探索云计算网络与 Windows 365 的未来 ## 1. 网络基础:互联网与云 互联网,也被称为“云”,是一个由众多网络相互连接而成的庞大网络体系。由于其连接方式极为复杂,难以用图表清晰展示,所以我们用“云”来简化表述。 ### 1.1 微软网络架构 想象一下,你购买了一批计算机,将它们放置在车库的架子上,并接入本地网络,这样就创建了一个数据中心。像微软这样的大公司也会构建数据中心,而且规模巨大。你可以通过网页浏览器和搜索引擎查看微软数据中心的图片,其规模令人惊叹。你的云 PC 就存放在这样的数据中心里(同时在其他地方有备份以确保冗余),并通过互联网与之连接。 微软等公司不仅拥有

PHP变量与函数全面解析

### PHP变量与函数全面解析 #### 1. PHP变量概述 PHP中的变量与shell变量类似,但PHP变量可以存储不同类型的值。引用变量时,无论读取还是设置值,都要在变量名前使用美元符号($)。PHP变量的类型主要有以下几种: - 字符串(Strings) - 整数(Integers) - 浮点数(Floats) - 数组(Arrays) - 对象(Objects) - 空值(Nulls) 下面我们详细探讨这些变量类型。 #### 2. 字符串变量 字符串是由引号括起来的一系列字符。可以使用单引号(')或双引号(")来定义字符串,但必须使用相同类型的引号开始和结束字符串,并且如果

提升MacBook使用效率与故障排除指南

### 提升MacBook使用效率与故障排除指南 #### 1. Keynote幻灯片与备注打印 如果你需要展示包含大量信息的长幻灯片,那么打印包含幻灯片缩略图和备注的讲义是个不错的选择。而且,除了纸质讲义,你还可以使用Keynote创建电子PDF文件,让观众从你的网站下载。如果你是教育工作者,还能结合交互式白板使用Keynote。 打印幻灯片和备注的步骤如下: 1. 在Keynote中,选择“文件”➪“打印”,或者按下⌘ + P。Keynote会显示打印面板,若有需要,可点击面板底部的“显示详细信息”按钮展开面板以显示所有设置。 2. 选择以下格式之一(每种格式会显示不同的布局选项):

SwiftUI状态管理与UIKit视图集成全解析

### SwiftUI 状态管理与 UIKit 视图集成全解析 #### 1. SwiftUI 状态管理 在 SwiftUI 中,状态管理是构建动态用户界面的关键。以下将介绍几种常用的状态管理方式。 ##### 1.1 使用 @ObservedObject 在 `ContentView.swift` 文件中,我们可以展示当前选择的搜索引擎。以下是具体代码: ```swift import SwiftUI struct ContentView: View { @ObservedObject var searchEngine = SearchEngineChoice() v

Unity游戏部署指南:从桌面到网页

# Unity游戏部署指南:从桌面到网页 ## 1. 桌面平台部署 ### 1.1 开始构建桌面应用 初次学习使用Unity构建游戏时,最简单的起点是将游戏部署到桌面计算机,支持的桌面系统包括Windows、Mac和Linux。由于Unity本身可在桌面计算机上运行,因此你可以为正在使用的计算机构建应用。 以下是构建桌面应用的具体步骤: 1. 打开任意Unity项目。任何项目都适用,建议在不同的构建过程中使用不同的项目,以验证Unity可以将任何项目构建到任何平台。 2. 选择“File > Build Settings”打开构建设置窗口。默认情况下,当前平台会设置为PC、Mac和Linu