Fava 账本查看 (fava-beancount-viewer)
提供基于Fava/Beancount的投资组合管理能力,支持税务亏损收割优化、资产配置分析与等价证券分组识别,辅助用户制定最优卖出策略。
Pipeline
data_collection -> data_storage -> factor_computation -> target_selection -> trading_execution -> visualization
Top Use Cases (5 total)
Portfolio Management CLI Entry Point (UC-101)
Provides a unified command-line interface for portfolio management operations including tax loss harvesting, asset allocation analysis, cash drag dete
Triggers: portfolio management, CLI, command line
Tax-Optimized Selling Strategy (UC-103)
Determines optimal sell order for securities to minimize realized capital gains by analyzing cost basis and holding periods across multiple lots
Triggers: minimize gains, tax-efficient selling, capital gains optimization
Tax Loss Harvesting Opportunity Detection (UC-105)
Identifies securities with unrealized losses that can be sold to harvest tax losses, typically looking back 30 days to find positions eligible for was
Triggers: tax loss harvesting, loss identification, wash sale
For all 5 use cases, see references/USE_CASES.md.
Execute trigger: When user intent matches intent_router.uc_entries[].positive_terms AND user uses action verb (run/execute/跑/执行/backtest/fetch/collect)
What I'll Ask You
- Target market: A-share (default), HK, or crypto? (US stocks in ZVT are half-baked — stockus_nasdaq_AAPL exists but coverage is thin)
- Data source / provider: eastmoney (free, no account), joinquant (account+paid), baostock (free, good history), akshare, or qmt (broker)?
- Strategy type: MACD golden-cross, MA crossover, volume breakout, fundamental screen, or custom factor?
- Time range: start_timestamp and end_timestamp for backtest period
- Target entity IDs: specific stocks (stock_sh_600000) or index components (SZ1000)?
Semantic Locks (Fatal)
| ID | Rule | On Violation |
|---|
SL-01 | Execute sell orders before buy orders in every trading cycle | halt |
SL-02 | Trading signals MUST use next-bar execution (no look-ahead) | halt |
SL-03 | Entity IDs MUST follow format entity_type_exchange_code | halt |
SL-04 | DataFrame index MUST be MultiIndex (entity_id, timestamp) | halt |
SL-05 | TradingSignal MUST have EXACTLY ONE of: position_pct, order_money, order_amount | halt |
SL-06 | filter_result column semantics: True=BUY, False=SELL, None/NaN=NO ACTION | halt |
SL-07 | Transformer MUST run BEFORE Accumulator in factor pipeline | halt |
SL-08 | MACD parameters locked: fast=12, slow=26, signal=9 | halt |
Full lock definitions: references/LOCKS.md
Top Anti-Patterns (15 total)
AP-ACCOUNTING-001: Using floating-point arithmetic for monetary amounts
AP-ACCOUNTING-002: Skipping initialization calls before VM/script execution
AP-ACCOUNTING-003: Mixing different asset types in monetary operations
All 15 anti-patterns: references/ANTI_PATTERNS.md
Evidence Quality Notice
[QUALITY NOTICE] This crystal was compiled from blueprint finance-bp-078. Evidence verify ratio = 21.6% and audit fail total = 14. Generated results may have uncaptured requirement gaps. Verify critical decisions against source files (LATEST.yaml / LATEST.jsonl).
Reference Files
Compiled by Doramagic crystal-compilation-v6.1 from finance-bp-078 blueprint at 2026-04-22T13:00:29.702985+00:00.
See human_summary.md for non-technical overview.