Skip to content
View karesansui-u's full-sized avatar

Block or report karesansui-u

Block user

Prevent this user from interacting with your repositories and sending you notifications. Learn more about blocking users.

You must be logged in to block users.

Maximum 250 characters. Please don’t include any personal information such as legal names or email addresses. Markdown is supported. This note will only be visible to you.
Report abuse

Contact GitHub support about this user’s behavior. Learn more about reporting abuse.

Report abuse
karesansui-u/README.md

LLMの性能劣化は矛盾の蓄積が問題なのではないか。

LLM は長い会話で劣化します。多くの場合はコンテキスト長の問題だと思われています。
本質は長さそのものではなく、未整理の矛盾の蓄積です。

実験では、GPT-4o-mini は 100% → 10%、Gemini は 100% → 0% まで低下しました。
1M トークン級の長大コンテキストでも、構造的な矛盾が入ると性能は大きく崩れます。一方で、矛盾を外部で整理すると精度は回復します。

この枠組みは、単なる比喩ではなく予測を出せる理論です。
たとえば multi-attractor extension では、Gemini の精度が P = 1/(1+K/L) に従うと予測され、3点から導いた式が 5 つの文脈長(32K–512K)で MAE 2% で確認されました。
つまり、公理 → Lean 4 形式検証 → 予測 → 実験 の鎖を一応つないでいます。


🧬 実装

delta-prune — LLM API に送る前に矛盾を検出・整理する軽量ミドルウェアです。3 行で使えます。 PyPI

from delta_prune import DeltaPrune
prune = DeltaPrune(llm=OpenAILLM())
result = prune(messages)  # contradictions resolved

DeltaLint — コードベース内の構造的矛盾を検出するスキャナです。モジュールの前提と実際の振る舞いが食い違う場所を見つけます。


特許関連

本研究に関連する構造維持機構については、日本で既に特許出願済みです。
長期タスクを支える永続状態を土台としつつ、その上に構造持続方程式と矛盾解消原理に基づく整合性維持機構を重ねています。
概要は Patent Notice を参照してください。


📄 論文とデータ

「Context rot は長さの問題ではなく、矛盾の問題である。」

# Paper 要点
1 Structural Collapse as Information Loss 構造持続方程式 S = μ × e^{-δ}。矛盾は指数的な崩壊として現れる。Multi-attractor prediction を確認。Lean 4 検証済み。
2 Predicting Computational Cost from δ 同じ δ が、解の存在だけでなく計算コストにも効く。感度指数はソルバー依存。
3 Contradiction Metabolism for LLMs 外部代謝により context rot を抑制。+52.2pp(n=3, p=0.027; 8-model sign test p=0.0107)。

📊 delta-survival-papers — 論文本文、TeX/PDF、11モデル・1000試行超の生データ、再現スクリプト、Lean 4 証明をまとめたリポジトリです。ダウンロード先は DATA.md を参照してください。

🗂️ Zenodo — 公開済みレコード一覧

📦 OSF Project — 論文・データ・コードの集約先

🔬 Lean 4 formal proofs — 160 propositions, sorry = 0, axiom = 0


Software engineer, Japan

@karesansui-u's activity is private