--- name: detect-fed-unamortized-discount-pattern description: 檢查聯準會持有證券的未攤銷折價(Unamortized Discounts)是否出現與特定歷史危機期間相似的走勢模板,並用多指標交叉驗證是否真的屬於「金融壓力升高」而非單純會計/利率效果。 --- **形狀比對 ≠ 事件預測** 核心認知:把「肉眼類比」轉成可量化的「形狀比對」,但「像」不等於「會發生」: - **相關係數 (corr)**:近期窗口 vs. 基準窗口的線性形狀相似 - **動態時間校正 (DTW)**:允許「快一點/慢一點」但形狀相似 - **形狀特徵 (shape_features)**:趨勢斜率、拐點結構、波動擴張 輸出「pattern_similarity_score」只回答「像不像」,不回答「會不會發生」。 **壓力驗證才能升級風險判斷** 把「形狀相似」與「壓力驗證」拆開: 1. **pattern_similarity_score**:只測量形狀相似度 2. **stress_confirmation_score**:測量交叉驗證指標是否同步惡化 3. **composite_risk_score**:加權合成,但必須附上「哪些指標支持/反對」 **反直覺檢查**: - 若相似度很高,但交叉驗證指標沒有壓力訊號 → 可能只是利率/持有結構/會計攤銷造成的圖形相似 - 若相似度中等,但多數壓力指標同步惡化 → 反而要提高警覺 **理解指標背後機制** **WUDSHO(Unamortized Discounts)成因**: - 聯準會購買債券時,若買入價低於面值,差額計為「未攤銷折價」 - 利率上升期:市價下跌 → 購入債券折價增加 → WUDSHO 上升 - 利率下降期:市價上升 → 購入債券溢價增加 → WUDSHO 下降 **重要**:WUDSHO 變動可能反映: 1. 利率環境變化(最常見) 2. 持有債券久期結構 3. 會計攤銷時程 4. **真正的金融壓力**(需交叉驗證才能確認) **反證優先的分析框架** 社群常見的「圖形類比敘事」往往缺乏反證: - ❌「這條線複製 COVID,60 天內黑天鵝」→ 只有類比,沒有驗證 - ✅ 本技能輸出:「形狀相似度 0.88,但信用利差中性、股市波動偏低 → 不支持系統性壓力假說」 必須輸出的反證項目: 1. 「形狀相似」的替代解釋(利率效果、會計效果) 2. 「壓力指標」的現況(支持/反對風險假說) 3. 「歷史後續」的條件分布(不是預測) **公開資料來源與限制** 本技能使用 FRED 公開週資料: - **WUDSHO**: Fed 持有證券的未攤銷折價 - **交叉驗證指標**:信用利差、波動率、短端利差等 **必須揭露**: - FRED 週資料可能有 T+1 ~ T+3 延遲 - 部分指標(如窗口工具用量)需要替代代理 - 形狀比對結果受 resample 頻率影響 偵測聯準會未攤銷折價走勢是否與歷史危機期間相似: 1. **取得目標序列**:從 FRED 取得 WUDSHO(或指定序列)的週資料 2. **窗口比對**:將近期窗口與歷史基準窗口(如 COVID 2020)做形狀比對 3. **相似度計算**:使用相關係數、DTW、形狀特徵等多種方法 4. **交叉驗證**:檢查信用利差、波動率、流動性指標是否同步惡化 5. **風險分數合成**:輸出可量化的風險分數與反證分析 6. **情境敘事**:描述歷史類比後續發展(非預測) 輸出:形狀相似度、壓力驗證分數、合成風險分數、反證分析、情境推演。 **最快的方式:執行完整分析** ```bash cd skills/detect-fed-unamortized-discount-pattern pip install pandas numpy requests scipy matplotlib # 首次使用 python scripts/pattern_detector.py --quick ``` 輸出: - `output/pattern_analysis_YYYY-MM-DD.json` - JSON 結果 **完整分析(指定參數)**: ```bash python scripts/pattern_detector.py \ --target_series WUDSHO \ --baseline_windows "COVID_2020:2020-01-01:2020-06-30" \ --recent_window_days 120 \ --output result.json ``` **Bloomberg 風格視覺化**(輸出至專案根目錄 output/): ```bash python scripts/visualize_pattern.py ``` 使用現有分析結果生成圖表: ```bash python scripts/visualize_pattern.py --json output/pattern_analysis_YYYY-MM-DD.json ``` 輸出圖表: - `output/fed_unamortized_discount_pattern_YYYY-MM-DD.png` - 形狀比對與壓力儀表板 - `output/fed_unamortized_discount_history_YYYY-MM-DD.png` - 歷史走勢總覽 需要進行什麼操作? 1. **快速檢查(推薦)** - 查看目前的形狀相似度與壓力分數 2. **完整分析** - 執行完整的形狀比對與交叉驗證 3. **視覺化分析** - 生成形狀比對圖表 4. **歷史事件對照** - 深入了解歷史基準窗口的後續發展 5. **方法論學習** - 了解形狀比對與交叉驗證的邏輯 6. **自訂參數** - 指定序列、窗口、門檻等參數 **請選擇或直接提供分析參數。** | Response | Action | |-------------------------------|------------------------------------------------------| | 1, "快速", "quick", "check" | 執行 `python scripts/pattern_detector.py --quick` | | 2, "完整", "full", "analysis" | 閱讀 `workflows/execute-analysis.md` 並執行 | | 3, "視覺化", "chart", "圖表" | 執行 `python scripts/visualize_pattern.py -o output` | | 4, "歷史", "事件", "episodes" | 閱讀 `workflows/historical-episodes.md` 並執行 | | 5, "學習", "方法論", "why" | 閱讀 `references/methodology.md` | | 6, "自訂", "custom", 提供參數 | 閱讀 `workflows/execute-analysis.md` 並使用參數執行 | **路由後,閱讀對應文件並執行。** ``` detect-fed-unamortized-discount-pattern/ ├── SKILL.md # 本文件(路由器) ├── skill.yaml # 前端展示元數據 ├── manifest.json # 技能元數據 ├── workflows/ │ ├── execute-analysis.md # 完整分析工作流 │ ├── visualize-analysis.md # 視覺化分析工作流 │ └── historical-episodes.md # 歷史事件對照工作流 ├── references/ │ ├── methodology.md # 形狀比對與交叉驗證方法論 │ ├── data-sources.md # 資料來源與 FRED 系列代碼 │ ├── wudsho-mechanism.md # WUDSHO 指標機制說明 │ └── input-schema.md # 完整輸入參數定義 ├── templates/ │ ├── output-json.md # JSON 輸出模板 │ └── output-markdown.md # Markdown 報告模板 ├── scripts/ │ ├── pattern_detector.py # 主分析腳本 │ ├── visualize_pattern.py # 視覺化腳本 │ └── fetch_data.py # 資料抓取工具 └── examples/ └── sample_output.json # 範例輸出 ``` **方法論**: references/methodology.md - 形狀比對方法(相關係數、DTW、形狀特徵) - 正規化與窗口對齊 - 相似度分數計算 - 交叉驗證邏輯 **資料來源**: references/data-sources.md - FRED 系列代碼清單 - 資料頻率與延遲 - 公開替代資料說明 **指標機制**: references/wudsho-mechanism.md - WUDSHO 的成因與解讀 - 利率效果 vs. 壓力效果 - 常見誤讀與反證 **輸入參數**: references/input-schema.md - 完整參數定義 - 預設值與建議範圍 | Workflow | Purpose | 使用時機 | |------------------------|------------------|------------------------| | execute-analysis.md | 完整形狀比對分析 | 需要完整報告時 | | visualize-analysis.md | 視覺化分析 | 需要圖表時 | | historical-episodes.md | 歷史事件深度分析 | 理解歷史類比與後續發展 | | Template | Purpose | |--------------------|-------------------| | output-json.md | JSON 輸出結構定義 | | output-markdown.md | Markdown 報告模板 | | Script | Command | Purpose | |----------------------|----------------------|--------------------------------------| | pattern_detector.py | `--quick` | 快速檢查當前狀態 | | pattern_detector.py | `--output FILE` | 完整分析 | | visualize_pattern.py | (無參數) | Bloomberg 風格視覺化(輸出至專案根目錄 output/) | | visualize_pattern.py | `--json FILE` | 使用現有 JSON 結果生成圖表 | | fetch_data.py | `--series WUDSHO` | 抓取 FRED 資料 | **核心參數** | 參數 | 類型 | 預設值 | 說明 | |--------------------|---------------|---------|--------------------| | target_series | string | WUDSHO | 目標 FRED 系列代碼 | | baseline_windows | array[object] | [COVID] | 歷史參考事件窗口 | | recent_window_days | int | 120 | 近期比對窗口長度 | | resample_freq | string | W | 資料頻率 | | normalize_method | string | zscore | 正規化方法 | **相似度參數** | 參數 | 類型 | 預設值 | 說明 | |--------------------|---------------|-----------------------------|--------------| | similarity_metrics | array[string] | [corr, dtw, shape_features] | 相似度指標 | | alert_thresholds | object | {corr_min: 0.7, ...} | 觸發警報門檻 | **交叉驗證參數** | 參數 | 類型 | 預設值 | 說明 | |-------------------------|---------------|---------------|--------------------| | confirmatory_indicators | array[object] | [信用利差...] | 交叉驗證指標清單 | | lookahead_days | int | 60 | 前瞻期(情境敘事) | 完整參數定義見 `references/input-schema.md`。 ```json { "skill": "detect-fed-unamortized-discount-pattern", "as_of_date": "2026-01-26", "target_series": "WUDSHO", "best_match": { "baseline": "COVID_2020", "segment_start": "2020-01-08", "segment_end": "2020-06-17", "corr": 0.91, "dtw": 0.38, "feature_sim": 0.82, "pattern_similarity_score": 0.88 }, "stress_confirmation": { "score": 0.22, "details": [ {"name": "credit_spread", "signal": "neutral", "z": 0.4}, {"name": "equity_vol", "signal": "mild_risk_on", "z": -0.2}, {"name": "funding_stress_proxy", "signal": "neutral", "z": 0.1} ] }, "composite_risk_score": 0.49, "interpretation": { "summary": "走勢形狀與 COVID 早期片段相似度高,但壓力驗證指標偏中性...", "what_to_watch_next_60d": ["..."], "rebuttal_to_claim": ["..."] }, "caveats": [ "形狀相似不代表因果相同;該序列可能強烈受利率、持有期限結構與會計攤銷影響。", "若缺乏壓力指標同步惡化,不應把圖形類比直接升級成『黑天鵝預言』。" ] } ``` 完整輸出結構見 `templates/output-json.md`。 執行成功時應產出: - [ ] 形狀相似度分數(pattern_similarity_score) - [ ] 最佳匹配的歷史片段(baseline、segment_start/end) - [ ] 多維度相似度(corr、dtw、feature_sim) - [ ] 壓力驗證分數(stress_confirmation_score) - [ ] 各驗證指標詳情(名稱、訊號、z-score) - [ ] 合成風險分數(composite_risk_score) - [ ] 解讀框架(summary、what_to_watch、rebuttal) - [ ] 資料品質說明與風險警語(caveats) **視覺化輸出**(使用 visualize_pattern.py,Bloomberg 風格): - [ ] 形狀比對與壓力儀表板圖(`fed_unamortized_discount_pattern_YYYY-MM-DD.png`) - 上左:近期 vs. 歷史基準窗口的正規化形狀比對 - 上右:相似度分數面板(corr、DTW、feature_sim、綜合風險) - 下左:壓力驗證指標水平條圖(Z-Score) - 下右:解讀說明(訊號統計、結論) - [ ] 歷史走勢總覽圖(`fed_unamortized_discount_history_YYYY-MM-DD.png`) - 完整 WUDSHO 歷史走勢 - 歷史基準窗口標記(COVID_2020、GFC_2008、TAPER_2013、RATE_HIKE_2022) - 近期窗口與最佳匹配片段高亮 - 最新值標註