-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsql_demo.sql
More file actions
39 lines (37 loc) · 1.07 KB
/
sql_demo.sql
File metadata and controls
39 lines (37 loc) · 1.07 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
WITH recursive tree_eval AS (
SELECT
f.sample_id,
m.model_name,
m.booster_id,
CASE
WHEN f.feature_values[m.feature_index] < m.split THEN m.node_yes
WHEN f.feature_values[m.feature_index] >= m.split THEN m.node_no
WHEN f.feature_values[m.feature_index] IS NULL THEN m.node_missing
END AS node_id,
m.prediction
FROM gbm.model m
CROSS JOIN gbm.features f
WHERE m.model_name = 'demo_model.xgb'
AND m.node_id = 0
UNION ALL
SELECT
f.sample_id,
p.model_name,
p.booster_id,
CASE
WHEN f.feature_values[m.feature_index] < m.split THEN m.node_yes
WHEN f.feature_values[m.feature_index] >= m.split THEN m.node_no
WHEN f.feature_values[m.feature_index] IS NULL THEN m.node_missing
END AS node_id,
m.prediction
FROM tree_eval p
JOIN gbm.model m USING (model_name, booster_id, node_id)
JOIN gbm.features f USING (sample_id)
)
SELECT
sample_id,
(1 / (1 + exp(-sum(prediction)))) :: NUMERIC(9, 4) AS prediction
FROM tree_eval
WHERE prediction IS NOT NULL
GROUP BY sample_id
ORDER BY sample_id;