phase 14-15: docker build validation and helm deployment

This commit is contained in:
Celes Renata
2026-04-11 11:59:45 -07:00
parent 7394d241c9
commit ce10afa034
179 changed files with 32559 additions and 576 deletions
+120
View File
@@ -0,0 +1,120 @@
{
"dashboard_title": "Sentiment Heatmap",
"description": "Market-wide sentiment visualization by sector and symbol, with trend direction and catalyst analysis.",
"slug": "sentiment-heatmap",
"position_json": {
"HEADER_ID": {"id": "HEADER_ID", "type": "HEADER", "meta": {"text": "Sentiment Heatmap"}},
"ROW-1": {
"type": "ROW",
"children": ["CHART-bullish-count-kpi", "CHART-bearish-count-kpi", "CHART-mixed-count-kpi", "CHART-avg-contradiction-kpi"]
},
"ROW-2": {
"type": "ROW",
"children": ["CHART-sentiment-heatmap"]
},
"ROW-3": {
"type": "ROW",
"children": ["CHART-sentiment-timeseries", "CHART-catalyst-breakdown"]
},
"ROW-4": {
"type": "ROW",
"children": ["CHART-contradiction-scatter", "CHART-sentiment-distribution"]
},
"ROW-5": {
"type": "ROW",
"children": ["CHART-symbol-sentiment-detail"]
}
},
"metadata": {
"refresh_frequency": 300,
"default_filters": "{}",
"color_scheme": "supersetColors"
},
"charts": [
{
"slice_name": "Bullish Signals (7d)",
"viz_type": "big_number_total",
"description": "Count of bullish trend signals in the last 7 days",
"datasource_type": "trino",
"query": "SELECT COUNT(*) AS bullish_count FROM lakehouse.stonks.trade_signals WHERE trend_direction = 'bullish' AND dt >= CURRENT_DATE - INTERVAL '7' DAY"
},
{
"slice_name": "Bearish Signals (7d)",
"viz_type": "big_number_total",
"description": "Count of bearish trend signals in the last 7 days",
"datasource_type": "trino",
"query": "SELECT COUNT(*) AS bearish_count FROM lakehouse.stonks.trade_signals WHERE trend_direction = 'bearish' AND dt >= CURRENT_DATE - INTERVAL '7' DAY"
},
{
"slice_name": "Mixed Signals (7d)",
"viz_type": "big_number_total",
"description": "Count of mixed or neutral trend signals in the last 7 days",
"datasource_type": "trino",
"query": "SELECT COUNT(*) AS mixed_count FROM lakehouse.stonks.trade_signals WHERE trend_direction IN ('mixed', 'neutral') AND dt >= CURRENT_DATE - INTERVAL '7' DAY"
},
{
"slice_name": "Avg Contradiction Score (7d)",
"viz_type": "big_number_total",
"description": "Average contradiction score across all signals in the last 7 days",
"datasource_type": "trino",
"query": "SELECT ROUND(AVG(contradiction_score), 3) AS avg_contradiction FROM lakehouse.stonks.trade_signals WHERE dt >= CURRENT_DATE - INTERVAL '7' DAY"
},
{
"slice_name": "Sentiment Heatmap by Symbol",
"viz_type": "heatmap",
"description": "Daily average sentiment impact score by symbol over the last 14 days",
"datasource_type": "trino",
"query": "SELECT de.ticker, de.dt, ROUND(AVG(de.impact_score), 3) AS avg_impact, AVG(CASE WHEN de.sentiment = 'positive' THEN 1.0 WHEN de.sentiment = 'negative' THEN -1.0 ELSE 0.0 END) AS sentiment_score FROM lakehouse.stonks.document_extractions de WHERE de.dt >= CURRENT_DATE - INTERVAL '14' DAY GROUP BY de.ticker, de.dt ORDER BY de.ticker, de.dt",
"params": {
"x_axis": "dt",
"y_axis": "ticker",
"metric": "sentiment_score"
}
},
{
"slice_name": "Sentiment Trend Over Time",
"viz_type": "echarts_timeseries_line",
"description": "Daily average sentiment score across all symbols over the last 30 days",
"datasource_type": "trino",
"query": "SELECT de.dt AS bucket, ROUND(AVG(CASE WHEN de.sentiment = 'positive' THEN 1.0 WHEN de.sentiment = 'negative' THEN -1.0 ELSE 0.0 END), 3) AS avg_sentiment, COUNT(*) AS extraction_count FROM lakehouse.stonks.document_extractions de WHERE de.dt >= CURRENT_DATE - INTERVAL '30' DAY GROUP BY de.dt ORDER BY de.dt"
},
{
"slice_name": "Catalyst Type Breakdown",
"viz_type": "pie",
"description": "Distribution of catalyst types across extractions in the last 14 days",
"datasource_type": "trino",
"query": "SELECT catalyst_type, COUNT(*) AS count FROM lakehouse.stonks.document_extractions WHERE dt >= CURRENT_DATE - INTERVAL '14' DAY AND catalyst_type IS NOT NULL GROUP BY catalyst_type ORDER BY count DESC"
},
{
"slice_name": "Contradiction vs Confidence",
"viz_type": "echarts_timeseries_scatter",
"description": "Scatter of contradiction score vs confidence for recent signals",
"datasource_type": "trino",
"query": "SELECT ticker, confidence, contradiction_score, trend_strength, trend_direction, dt FROM lakehouse.stonks.trade_signals WHERE dt >= CURRENT_DATE - INTERVAL '14' DAY ORDER BY dt DESC",
"params": {
"x_axis": "confidence",
"y_axis": "contradiction_score",
"groupby": ["trend_direction"]
}
},
{
"slice_name": "Sentiment Distribution by Symbol",
"viz_type": "echarts_timeseries_bar",
"description": "Count of positive, negative, and neutral extractions per symbol in the last 14 days",
"datasource_type": "trino",
"query": "SELECT ticker, sentiment, COUNT(*) AS count FROM lakehouse.stonks.document_extractions WHERE dt >= CURRENT_DATE - INTERVAL '14' DAY GROUP BY ticker, sentiment ORDER BY ticker, sentiment",
"params": {
"x_axis": "ticker",
"metrics": ["count"],
"groupby": ["sentiment"]
}
},
{
"slice_name": "Symbol Sentiment Detail",
"viz_type": "table",
"description": "Per-symbol sentiment summary with extraction counts, average impact, and dominant catalysts",
"datasource_type": "trino",
"query": "SELECT de.ticker, COUNT(*) AS extractions, ROUND(AVG(de.impact_score), 3) AS avg_impact, ROUND(AVG(de.confidence), 3) AS avg_confidence, ROUND(AVG(de.novelty_score), 3) AS avg_novelty, COUNT(CASE WHEN de.sentiment = 'positive' THEN 1 END) AS positive_count, COUNT(CASE WHEN de.sentiment = 'negative' THEN 1 END) AS negative_count, COUNT(CASE WHEN de.sentiment = 'neutral' THEN 1 END) AS neutral_count, ts.trend_direction AS latest_trend, ts.trend_strength AS latest_trend_strength FROM lakehouse.stonks.document_extractions de LEFT JOIN lakehouse.stonks.trade_signals ts ON de.ticker = ts.ticker AND ts.dt = (SELECT MAX(dt) FROM lakehouse.stonks.trade_signals WHERE ticker = de.ticker) WHERE de.dt >= CURRENT_DATE - INTERVAL '14' DAY GROUP BY de.ticker, ts.trend_direction, ts.trend_strength ORDER BY de.ticker"
}
]
}