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
+125
View File
@@ -0,0 +1,125 @@
{
"dashboard_title": "Prediction Accuracy",
"description": "Predicted signals vs realized price moves, confidence calibration, and model accuracy tracking.",
"slug": "prediction-accuracy",
"position_json": {
"HEADER_ID": {"id": "HEADER_ID", "type": "HEADER", "meta": {"text": "Prediction Accuracy"}},
"ROW-1": {
"type": "ROW",
"children": ["CHART-overall-hit-rate-kpi", "CHART-total-predictions-kpi", "CHART-avg-confidence-kpi", "CHART-avg-move-kpi"]
},
"ROW-2": {
"type": "ROW",
"children": ["CHART-hit-rate-timeseries", "CHART-outcome-distribution-pie"]
},
"ROW-3": {
"type": "ROW",
"children": ["CHART-confidence-calibration", "CHART-confidence-vs-move-scatter"]
},
"ROW-4": {
"type": "ROW",
"children": ["CHART-accuracy-by-symbol", "CHART-accuracy-by-action"]
},
"ROW-5": {
"type": "ROW",
"children": ["CHART-recent-predictions-table"]
}
},
"metadata": {
"refresh_frequency": 600,
"default_filters": "{}",
"color_scheme": "supersetColors"
},
"charts": [
{
"slice_name": "Overall Hit Rate",
"viz_type": "big_number_total",
"description": "Fraction of predictions with correct directional outcome over the last 30 days",
"datasource_type": "trino",
"query": "SELECT ROUND(CAST(COUNT(CASE WHEN outcome = 'correct' THEN 1 END) AS DOUBLE) / NULLIF(COUNT(*), 0), 4) AS hit_rate FROM lakehouse.stonks.prediction_vs_outcome WHERE dt >= CURRENT_DATE - INTERVAL '30' DAY"
},
{
"slice_name": "Total Predictions (30d)",
"viz_type": "big_number_total",
"description": "Total evaluated predictions in the last 30 days",
"datasource_type": "trino",
"query": "SELECT COUNT(*) AS total_predictions FROM lakehouse.stonks.prediction_vs_outcome WHERE dt >= CURRENT_DATE - INTERVAL '30' DAY"
},
{
"slice_name": "Avg Predicted Confidence",
"viz_type": "big_number_total",
"description": "Average confidence of predictions in the last 30 days",
"datasource_type": "trino",
"query": "SELECT ROUND(AVG(predicted_confidence), 3) AS avg_confidence FROM lakehouse.stonks.prediction_vs_outcome WHERE dt >= CURRENT_DATE - INTERVAL '30' DAY"
},
{
"slice_name": "Avg Realized Move",
"viz_type": "big_number_total",
"description": "Average absolute realized price move percentage",
"datasource_type": "trino",
"query": "SELECT ROUND(AVG(ABS(actual_move_pct)), 3) AS avg_abs_move FROM lakehouse.stonks.prediction_vs_outcome WHERE dt >= CURRENT_DATE - INTERVAL '30' DAY"
},
{
"slice_name": "Daily Hit Rate",
"viz_type": "echarts_timeseries_line",
"description": "Daily prediction hit rate over the last 30 days",
"datasource_type": "trino",
"query": "SELECT dt AS bucket, COUNT(*) AS total, COUNT(CASE WHEN outcome = 'correct' THEN 1 END) AS correct, ROUND(CAST(COUNT(CASE WHEN outcome = 'correct' THEN 1 END) AS DOUBLE) / NULLIF(COUNT(*), 0), 4) AS hit_rate FROM lakehouse.stonks.prediction_vs_outcome WHERE dt >= CURRENT_DATE - INTERVAL '30' DAY GROUP BY dt ORDER BY dt"
},
{
"slice_name": "Outcome Distribution",
"viz_type": "pie",
"description": "Breakdown of prediction outcomes (correct, incorrect, neutral) over the last 30 days",
"datasource_type": "trino",
"query": "SELECT outcome, COUNT(*) AS count FROM lakehouse.stonks.prediction_vs_outcome WHERE dt >= CURRENT_DATE - INTERVAL '30' DAY GROUP BY outcome ORDER BY count DESC"
},
{
"slice_name": "Confidence Calibration",
"viz_type": "echarts_timeseries_bar",
"description": "Hit rate by confidence bucket to assess calibration quality",
"datasource_type": "trino",
"query": "SELECT CASE WHEN predicted_confidence >= 0.8 THEN '0.8-1.0 (high)' WHEN predicted_confidence >= 0.6 THEN '0.6-0.8 (medium)' WHEN predicted_confidence >= 0.4 THEN '0.4-0.6 (low)' ELSE '0.0-0.4 (very low)' END AS confidence_bucket, COUNT(*) AS total, COUNT(CASE WHEN outcome = 'correct' THEN 1 END) AS correct, ROUND(CAST(COUNT(CASE WHEN outcome = 'correct' THEN 1 END) AS DOUBLE) / NULLIF(COUNT(*), 0), 4) AS hit_rate FROM lakehouse.stonks.prediction_vs_outcome WHERE dt >= CURRENT_DATE - INTERVAL '30' DAY GROUP BY 1 ORDER BY 1",
"params": {
"x_axis": "confidence_bucket",
"metrics": ["hit_rate"]
}
},
{
"slice_name": "Confidence vs Realized Move",
"viz_type": "echarts_timeseries_scatter",
"description": "Scatter plot of predicted confidence vs actual realized move percentage",
"datasource_type": "trino",
"query": "SELECT ticker, predicted_confidence, actual_move_pct, predicted_action, outcome, dt FROM lakehouse.stonks.prediction_vs_outcome WHERE dt >= CURRENT_DATE - INTERVAL '30' DAY ORDER BY dt DESC",
"params": {
"x_axis": "predicted_confidence",
"y_axis": "actual_move_pct",
"groupby": ["outcome"]
}
},
{
"slice_name": "Accuracy by Symbol",
"viz_type": "table",
"description": "Per-symbol prediction accuracy summary",
"datasource_type": "trino",
"query": "SELECT ticker, COUNT(*) AS predictions, COUNT(CASE WHEN outcome = 'correct' THEN 1 END) AS correct, COUNT(CASE WHEN outcome = 'incorrect' THEN 1 END) AS incorrect, ROUND(CAST(COUNT(CASE WHEN outcome = 'correct' THEN 1 END) AS DOUBLE) / NULLIF(COUNT(*), 0), 4) AS hit_rate, ROUND(AVG(predicted_confidence), 3) AS avg_confidence, ROUND(AVG(actual_move_pct), 3) AS avg_move_pct, ROUND(AVG(ABS(actual_move_pct)), 3) AS avg_abs_move_pct FROM lakehouse.stonks.prediction_vs_outcome WHERE dt >= CURRENT_DATE - INTERVAL '30' DAY GROUP BY ticker ORDER BY hit_rate DESC"
},
{
"slice_name": "Accuracy by Action Type",
"viz_type": "echarts_timeseries_bar",
"description": "Hit rate broken down by predicted action (buy, sell, hold, watch)",
"datasource_type": "trino",
"query": "SELECT predicted_action, COUNT(*) AS total, COUNT(CASE WHEN outcome = 'correct' THEN 1 END) AS correct, ROUND(CAST(COUNT(CASE WHEN outcome = 'correct' THEN 1 END) AS DOUBLE) / NULLIF(COUNT(*), 0), 4) AS hit_rate, ROUND(AVG(predicted_confidence), 3) AS avg_confidence FROM lakehouse.stonks.prediction_vs_outcome WHERE dt >= CURRENT_DATE - INTERVAL '30' DAY GROUP BY predicted_action ORDER BY predicted_action",
"params": {
"x_axis": "predicted_action",
"metrics": ["hit_rate"]
}
},
{
"slice_name": "Recent Predictions",
"viz_type": "table",
"description": "Most recent evaluated predictions with outcomes",
"datasource_type": "trino",
"query": "SELECT ticker, predicted_action, ROUND(predicted_confidence, 3) AS confidence, ROUND(actual_move_pct, 3) AS actual_move_pct, outcome, horizon_days, model_version, predicted_at, evaluated_at FROM lakehouse.stonks.prediction_vs_outcome WHERE dt >= CURRENT_DATE - INTERVAL '14' DAY ORDER BY evaluated_at DESC LIMIT 50"
}
]
}