explore-diophantine-equations
关于
This skill solves Diophantine equations to find integer-only solutions for problems like linear equations (ax + by = c), Pell's equation, and Pythagorean triples. It implements key number theory algorithms including the extended Euclidean algorithm and uses methods like modular constraints to prove solution existence. Use it when you need to generate all integer solutions or find fundamental solutions from which others are derived.
快速安装
Claude Code
推荐npx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/explore-diophantine-equations在 Claude Code 中复制并粘贴此命令以安装该技能
技能文档
探 Diophantine 程
解 Diophantine 程——只求整解之多項式。按類分、試可解、求特與通解、生解族。含線程、Pell 程、Pythagorean 三、與通二次。
用
- 尋 ax + by = c 之諸整解
- 解 Pell x^2 - Dy^2 = 1(或 = -1)
- 生 Pythagorean 三或他參整族
- 經模約證程無整解
- 試通二次 Diophantine 之可解
- 尋諸解所自生之本解
入
- 必:欲解之程(明式,如 3x + 5y = 17 或 x^2 - 7y^2 = 1)
- 可:尋諸解、一特解、或證無解
- 可:變域約(如僅正整)
- 可:是否以參式示通解
- 可:偏證技(構、降、模阻)
行
一:分程類
定 Diophantine 之構以擇解法。
-
線:ax + by = c,a, b, c 為予整,x, y 為未知
- 解法:擴 Euclid 算
-
Pell:x^2 - Dy^2 = 1(或 = -1、= N),D 為正非方整
- 解法:sqrt(D) 之續分展
-
Pythagorean:x^2 + y^2 = z^2
- 解法:參族 x = m^2 - n^2、y = 2mn、z = m^2 + n^2
-
通二次:ax^2 + bxy + cy^2 + dx + ey + f = 0
- 解法:完全方、減為 Pell 或簡式、或施模約
-
高階或特:Fermat 型(x^n + y^n = z^n, n > 2)、方和、或他
- 解法:模阻、降、或已知不可能
錄分類與所擇法。
得:精分類並識解策。
敗:程不合標類→試代或轉以減為已知式。如 x^2 + y^2 + z^2 = n 可經 Legendre 三方論。無減可見→施模約(四步)試阻。
二:解線 Diophantine(若類=線)
解 ax + by = c 之整 x, y。
-
算 g = gcd(a, b) 以 Euclid 算
-
試可解:解存當且僅當 g | c
- 若 g 不除 c→證無解:「gcd(a, b) = g 且 g 不除 c→ax + by = c 無整解」
- 若無解→止
-
簡:除 g 得 (a/g)x + (b/g)y = c/g,其 gcd(a/g, b/g) = 1
-
尋特解用擴 Euclid:
- 經反代得 1 = (a/g)*s + (b/g)*t
- 乘 c/g:(c/g) = (a/g)(sc/g) + (b/g)(tc/g)
- 特解:x0 = s * (c/g)、y0 = t * (c/g)
-
書通解:
- x = x0 + (b/g)*k
- y = y0 - (a/g)*k
- 諸整 k
-
施約(若須正解):
- 解 x0 + (b/g)*k > 0 與 y0 - (a/g)*k > 0 求 k
- 報有效 k 域或述無正解
例(15x + 21y = 39):
gcd(15, 21) = 3. Does 3 | 39? Yes.
Simplify: 5x + 7y = 13.
Extended Euclidean: 1 = 3*5 - 2*7.
Multiply by 13: 13 = 39*5 - 26*7.
Particular: x0 = 39, y0 = -26.
General: x = 39 + 7k, y = -26 - 5k, k in Z.
Check (k=0): 5*39 + 7*(-26) = 195 - 182 = 13. Correct.
得:以整 k 參之通解族,並驗特解。
敗:特解誤→步步察擴 Euclid 反代。最常誤為號。驗:a * x0 + b * y0 宜正等 c(非僅模某)。
三:解 Pell(若類=Pell)
解 x^2 - Dy^2 = 1,D 為正非方整。
-
驗 D 非全方:若 D = k^2→x^2 - k^2*y^2 = (x - ky)(x + ky) = 1 強 x - ky = x + ky = +/-1,致 y = 0、x = +/-1(瑣)。程唯非方 D 有趣
-
算 sqrt(D) 之續分展:
- 初:a0 = floor(sqrt(D))、m0 = 0、d0 = 1
- 迭:m_{i+1} = d_i * a_i - m_i、d_{i+1} = (D - m_{i+1}^2) / d_i、a_{i+1} = floor((a0 + m_{i+1}) / d_{i+1})
- 續至 a_i 序重(展於 a0 後週期)
- 錄週長 r
-
自收斂取本解:
- 算續分之收斂 p_i / q_i
- 收斂 p_{r-1} / q_{r-1}(首週末)予本解:
- r 偶:(x1, y1) = (p_{r-1}, q_{r-1}) 解 x^2 - Dy^2 = 1
- r 奇:(p_{r-1}, q_{r-1}) 解 x^2 - Dy^2 = -1(負 Pell)。則 (p_{2r-1}, q_{2r-1}) 解正程
-
自本解 (x1, y1) 生更解:
- 遞:x_{n+1} + y_{n+1} * sqrt(D) = (x1 + y1 * sqrt(D))^{n+1}
- 等:x_{n+1} = x1 * x_n + D * y1 * y_n、y_{n+1} = x1 * y_n + y1 * x_n
-
示本解與生諸解之遞
小 D 之本解:
| D | (x1, y1) | D | (x1, y1) | D | (x1, y1) |
|---|---|---|---|---|---|
| 2 | (3, 2) | 7 | (8, 3) | 13 | (649, 180) |
| 3 | (2, 1) | 8 | (3, 1) | 14 | (15, 4) |
| 5 | (9, 4) | 10 | (19, 6) | 15 | (4, 1) |
| 6 | (5, 2) | 11 | (10, 3) | 17 | (33, 8) |
得:代入驗之本解 (x1, y1),及生諸正解之遞。
敗:續分算不收週→察迭式。週長 r 可大(如 D = 61 有 r = 11 且本解 (1766319049, 226153980))。大 D 宜用算具非手算。
四:施模約驗存/不存(若類=通二次或高階)
經示模阻證程無整解。
-
擇模 m(常 m = 2、3、4、5、7、8、16)
-
列諸餘:算諸變可能餘之左端模 m
-
察諸合否予右端模 m
- 若無合→程無解(模阻)
-
常阻:
- 方模 4:n^2 = 0 或 1 (mod 4)。故 x^2 + y^2 = c 若 c = 3 (mod 4) 無解
- 方模 8:n^2 = 0、1、4 (mod 8)。故 x^2 + y^2 + z^2 = c 若 c = 7 (mod 8) 無解
- 立方模 9:n^3 = 0、1、8 (mod 9)。故 x^3 + y^3 + z^3 = c 於某 c mod 9 或阻
-
無阻:模法不能證無。解或存或不存;試構法或降
二次餘參:
| Mod | Squares (residues) |
|---|---|
| 3 | {0, 1} |
| 4 | {0, 1} |
| 5 | {0, 1, 4} |
| 7 | {0, 1, 2, 4} |
| 8 | {0, 1, 4} |
| 11 | {0, 1, 3, 4, 5, 9} |
| 13 | {0, 1, 3, 4, 9, 10, 12} |
| 16 | {0, 1, 4, 9} |
得:或經模阻證無解,或述於試模未得阻。
敗:模法無結→試無窮降:設解存、推嚴小解、復至與正矛盾。此技典於證 x^4 + y^4 = z^2 無非瑣解。
五:自本解生解族
以本解與整參示諸解。
-
線:族為 x = x0 + (b/g)*k、y = y0 - (a/g)*k(二步)
-
Pell:用三步遞生前數解:
(x1, y1), (x2, y2), (x3, y3), ...列至少 3-5 解為察
-
Pythagorean 三:自參 m > n > 0、gcd(m, n) = 1、m - n 奇 生本三:
- a = m^2 - n^2、b = 2mn、c = m^2 + n^2
- 諸本三皆如此生(容 a 與 b 互易)
-
通族:可則以參式示。若程定 genus 0 曲線→有理參存。若 genus >= 1→解或有限(Faltings 論於 genus >= 2)
-
代入原程驗族中至少 3 員
例(Pell, D = 2):
Fundamental: (x1, y1) = (3, 2). Check: 9 - 2*4 = 1. Correct.
(x2, y2) = (3*3 + 2*2*2, 3*2 + 2*3) = (17, 12). Check: 289 - 2*144 = 1.
(x3, y3) = (3*17 + 2*2*12, 3*12 + 2*17) = (99, 70). Check: 9801 - 2*4900 = 1.
得:諸解之參或遞述,至少 3 解已驗。
敗:生解驗敗→本解或遞式誤。Pell→自續分重推本解。線→重察擴 Euclid 算。
驗
- 程按類正分(線、Pell、Pythagorean、通二次、高階)
- 線:解前察 gcd(a, b) | c
- 擴 Euclid 反代已驗:ax0 + by0 = c 正等
- 通解含諸解(以整 k 或遞參)
- Pell:施續分前驗 D 非方
- Pell:直算確本解滿 x1^2 - D*y1^2 = 1
- 模阻證列諸餘合,非僅部分
- 族中至少 3 員代入驗
- 約(正整、界域)於尋通解後施
- 無解之言以 gcd 或模阻證
忌
- 設凡 gcd | c 之程有正解:通解 x = x0 + (b/g)*k 含負值。縱程於諸整可解,正解或不存
- 混 x^2 - Dy^2 = 1 於 x^2 - Dy^2 = -1:負 Pell 唯續分週奇時有解。施正程式於負程目予誤果
- 忘 Pell 瑣解:(x, y) = (1, 0) 恒滿 x^2 - Dy^2 = 1,然於生非瑣解無用。本解為 y > 0 之最小解
- 模阻不全:僅察 mod 2 或 mod 4 或漏高模之阻。前數模無阻→試 mod 8、9、16、或二次型之判別
- 續分週差一:收斂索須慎追。本解自 p_{r-1}/q_{r-1}(r 為週長)出,非 p_r/q_r
- 無基之無窮降:用降證無存時須示降止於矛盾(如 x = 0 矛 x > 0)。無基案→論不全
- 誤施 Fermat 末論:x^n + y^n = z^n 於 n > 2 無非瑣整解(Wiles, 1995);然不適於異係程如 2x^3 + 3y^3 = z^3
參
analyze-prime-numbers— 因子與 gcd 算為 Diophantine 解之前提solve-modular-arithmetic— 線同餘 ax = c (mod b) 等於線 Diophantinederive-theoretical-result— 證 Diophantine 不可能之形推技
GitHub 仓库
相关推荐技能
content-collections
元Content Collections 是一个 TypeScript 优先的构建工具,可将本地 Markdown/MDX 文件转换为类型安全的数据集合。它专为构建博客、文档站和内容密集型 Vite+React 应用而设计,提供基于 Zod 的自动模式验证。该工具涵盖从 Vite 插件配置、MDX 编译到生产环境部署的完整工作流。
polymarket
元这个Claude Skill为开发者提供完整的Polymarket预测市场开发支持,涵盖API调用、交易执行和市场数据分析。关键特性包括实时WebSocket数据流,可监控实时交易、订单和市场动态。开发者可用它构建预测市场应用、实施交易策略并集成实时市场预测功能。
creating-opencode-plugins
元该Skill帮助开发者创建OpenCode插件,用于接入命令、文件、LSP等25+种事件。它提供了插件结构、事件API规范和JavaScript/TypeScript实现模式,适合需要拦截操作、扩展功能或自定义事件处理的场景。开发者可通过它快速构建响应式模块来增强OpenCode AI助手的能力。
sglang
元SGLang是一个专为LLM设计的高性能推理框架,特别适用于需要结构化输出的场景。它通过RadixAttention前缀缓存技术,在处理JSON、正则表达式、工具调用等具有重复前缀的复杂工作流时,能实现极速生成。如果你正在构建智能体或多轮对话系统,并追求远超vLLM的推理性能,SGLang是理想选择。
