f468e30af0
ci/woodpecker/push/test Pipeline was successful
ci/woodpecker/push/build-2 Pipeline was successful
ci/woodpecker/push/build-1 Pipeline was successful
ci/woodpecker/push/build-3 Pipeline was successful
ci/woodpecker/push/finalize Pipeline was successful
Build and Push / lint-and-test (push) Has been cancelled
Build and Push / build-services (map[cmd:python -m services.adapters.broker_adapter name:broker-adapter]) (push) Has been cancelled
Build and Push / build-services (map[cmd:python -m services.aggregation.worker name:aggregation]) (push) Has been cancelled
Build and Push / build-services (map[cmd:python -m services.extractor.worker name:extractor]) (push) Has been cancelled
Build and Push / build-services (map[cmd:python -m services.ingestion.worker name:ingestion]) (push) Has been cancelled
Build and Push / build-services (map[cmd:python -m services.lake_publisher.worker name:lake-publisher]) (push) Has been cancelled
Build and Push / build-services (map[cmd:python -m services.parser.worker name:parser]) (push) Has been cancelled
Build and Push / build-services (map[cmd:python -m services.recommendation.worker name:recommendation]) (push) Has been cancelled
Build and Push / build-services (map[cmd:python -m services.scheduler.app name:scheduler]) (push) Has been cancelled
Build and Push / build-services (map[cmd:uvicorn services.api.app:app --host 0.0.0.0 --port 8000 name:query-api]) (push) Has been cancelled
Build and Push / build-services (map[cmd:uvicorn services.risk.app:app --host 0.0.0.0 --port 8000 name:risk]) (push) Has been cancelled
Build and Push / build-services (map[cmd:uvicorn services.symbol_registry.app:app --host 0.0.0.0 --port 8000 name:symbol-registry]) (push) Has been cancelled
Build and Push / build-services (map[cmd:uvicorn services.trading.app:app --host 0.0.0.0 --port 8000 name:trading-engine]) (push) Has been cancelled
Build and Push / build-dashboard (push) Has been cancelled
Build and Push / build-superset (push) Has been cancelled
Build and Push / integration-test (push) Has been cancelled
Build and Push / beta-gate (push) Has been cancelled
New service at services/signal_engine/ implementing concurrent heuristic (deterministic scoring) and probabilistic (Bayesian inference) pipelines that evaluate technical signals across 6 timeframes (M30-M) and produce independent BUY/WATCH/SKIP verdicts per ticker per evaluation tick. Components: - Input Normalizer: multi-source data assembly with sentinel fallbacks - Signal Library: Fibonacci, MA Stack, RSI, Cup & Handle, Elliott Wave - Multi-Timeframe Confluence Engine: weighted scoring with D/W/M anchors - Hard Filter Engine: macro_bias, valuation, earnings proximity gating - Heuristic Pipeline: S_total scoring with confidence-gated verdicts - Probabilistic Pipeline: Bayesian log-odds with regime priors, entropy gating, EV_R calculation, and signal correlation penalty - Exit Engine: stop-loss, targets, trailing ATR-based stops - Delta Analyzer: pipeline agreement tracking with rolling Redis metrics - Output Formatter: SignalOutput contract + Recommendation schema mapping - Worker orchestrator: concurrent pipelines with failure isolation - Main entry point: queue polling with fail-safe config loading Infrastructure: - Migration 039: signal_engine_outputs table with 3 indexes - Helm chart: signalEngine service entry (processing tier) - Redis key: QUEUE_SIGNAL_ENGINE constant Tests: 390 tests (unit + property-based) covering all components Config: dual_pipeline_enabled=false by default (safe rollout)
52 lines
1.6 KiB
SQL
52 lines
1.6 KiB
SQL
-- Migration 039: Signal Engine Outputs
|
|
-- Creates the signal_engine_outputs table for persisting dual-pipeline evaluations.
|
|
|
|
CREATE TABLE IF NOT EXISTS signal_engine_outputs (
|
|
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
ticker TEXT NOT NULL,
|
|
evaluated_at TIMESTAMPTZ NOT NULL,
|
|
price NUMERIC NOT NULL,
|
|
|
|
-- Heuristic pipeline
|
|
heuristic_verdict TEXT NOT NULL,
|
|
heuristic_confidence NUMERIC NOT NULL,
|
|
heuristic_s_total NUMERIC NOT NULL,
|
|
|
|
-- Probabilistic pipeline
|
|
probabilistic_verdict TEXT NOT NULL,
|
|
probabilistic_p_up NUMERIC NOT NULL,
|
|
probabilistic_entropy NUMERIC NOT NULL,
|
|
probabilistic_ev_r NUMERIC NOT NULL,
|
|
|
|
-- Delta analysis
|
|
delta_agreement BOOLEAN NOT NULL,
|
|
delta_confidence_delta NUMERIC NOT NULL,
|
|
delta_reasons JSONB NOT NULL DEFAULT '[]'::jsonb,
|
|
|
|
-- Trade plan (null when no BUY verdict)
|
|
trade_plan JSONB,
|
|
|
|
-- Full output for audit
|
|
full_output JSONB NOT NULL,
|
|
|
|
-- Exit signals
|
|
exit_signals JSONB NOT NULL DEFAULT '[]'::jsonb,
|
|
|
|
-- Metadata
|
|
pipeline_mode TEXT NOT NULL DEFAULT 'dual_pipeline',
|
|
shadow_mode BOOLEAN NOT NULL DEFAULT FALSE,
|
|
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
);
|
|
|
|
-- Index for per-ticker time-range queries
|
|
CREATE INDEX IF NOT EXISTS idx_signal_engine_outputs_ticker_time
|
|
ON signal_engine_outputs (ticker, evaluated_at);
|
|
|
|
-- Index for global time-range queries
|
|
CREATE INDEX IF NOT EXISTS idx_signal_engine_outputs_evaluated
|
|
ON signal_engine_outputs (evaluated_at);
|
|
|
|
-- Index for filtering by verdict
|
|
CREATE INDEX IF NOT EXISTS idx_signal_engine_outputs_verdicts
|
|
ON signal_engine_outputs (heuristic_verdict, probabilistic_verdict);
|