summaryrefslogtreecommitdiff
path: root/cnn_v3
diff options
context:
space:
mode:
authorskal <pascal.massimino@gmail.com>2026-03-22 13:10:47 +0100
committerskal <pascal.massimino@gmail.com>2026-03-22 13:10:47 +0100
commitd181e145296a04384850e09be03b697458cd8439 (patch)
tree5b3280253e96e3abcb9dc3889860f02ba8260c1b /cnn_v3
parent96b454743a2eac2ae1d4bdd38d7ca81cc4fd100b (diff)
fix(cnn_v3): fix texture format mismatches in cnn_v3_test sequence
- seq_compiler: add gbuf_albedo/gbuf_rgba32uint to NODE_TYPES - timeline: declare gbuf_feat0/feat1 as gbuf_rgba32uint, route CNNv3Effect output through cnn_v3_out (gbuf_albedo) + Passthrough to sink (dec0 can't write directly to Rgba8Unorm sink) - cnn_v3_effect: fix update_bind_groups using .set() instead of .replace() causing FATAL assert on second frame - TODO: add CNN v3 "2D mode" (G-buffer-free) future task handoff(Gemini): CNNv3Effect now runs without crashes at --seek 48
Diffstat (limited to 'cnn_v3')
-rw-r--r--cnn_v3/src/cnn_v3_effect.cc10
1 files changed, 5 insertions, 5 deletions
diff --git a/cnn_v3/src/cnn_v3_effect.cc b/cnn_v3/src/cnn_v3_effect.cc
index 4aa2c25..bfbb17b 100644
--- a/cnn_v3/src/cnn_v3_effect.cc
+++ b/cnn_v3/src/cnn_v3_effect.cc
@@ -445,7 +445,7 @@ void CNNv3Effect::update_bind_groups(NodeRegistry& nodes) {
bg_buf(e[2], 2, wb, kWeightsBufBytes);
bg_buf(e[3], 3, enc0_params_buf_.get().buffer, sizeof(CnnV3Params4ch));
bg_tex(e[4], 4, enc0_view);
- enc0_bg_.set(make_bg(enc0_pipeline_.get(), e, 5));
+ enc0_bg_.replace(make_bg(enc0_pipeline_.get(), e, 5));
}
// enc1: enc0_tex(B0), weights(B1), params(B2), enc1_out(B3)
@@ -455,7 +455,7 @@ void CNNv3Effect::update_bind_groups(NodeRegistry& nodes) {
bg_buf(e[1], 1, wb, kWeightsBufBytes);
bg_buf(e[2], 2, enc1_params_buf_.get().buffer, sizeof(CnnV3ParamsEnc1));
bg_tex(e[3], 3, enc1_view);
- enc1_bg_.set(make_bg(enc1_pipeline_.get(), e, 4));
+ enc1_bg_.replace(make_bg(enc1_pipeline_.get(), e, 4));
}
// bottleneck: enc1_tex(B0), weights(B1), params(B2), bn_out(B3)
@@ -465,7 +465,7 @@ void CNNv3Effect::update_bind_groups(NodeRegistry& nodes) {
bg_buf(e[1], 1, wb, kWeightsBufBytes);
bg_buf(e[2], 2, bn_params_buf_.get().buffer, sizeof(CnnV3ParamsBn));
bg_tex(e[3], 3, bn_view);
- bn_bg_.set(make_bg(bn_pipeline_.get(), e, 4));
+ bn_bg_.replace(make_bg(bn_pipeline_.get(), e, 4));
}
// dec1: bn_tex(B0), enc1_tex(B1), weights(B2), params(B3), dec1_out(B4)
@@ -476,7 +476,7 @@ void CNNv3Effect::update_bind_groups(NodeRegistry& nodes) {
bg_buf(e[2], 2, wb, kWeightsBufBytes);
bg_buf(e[3], 3, dec1_params_buf_.get().buffer, sizeof(CnnV3Params4ch));
bg_tex(e[4], 4, dec1_view);
- dec1_bg_.set(make_bg(dec1_pipeline_.get(), e, 5));
+ dec1_bg_.replace(make_bg(dec1_pipeline_.get(), e, 5));
}
// dec0: dec1_tex(B0), enc0_tex(B1), weights(B2), params(B3), output(B4)
@@ -487,6 +487,6 @@ void CNNv3Effect::update_bind_groups(NodeRegistry& nodes) {
bg_buf(e[2], 2, wb, kWeightsBufBytes);
bg_buf(e[3], 3, dec0_params_buf_.get().buffer, sizeof(CnnV3Params4ch));
bg_tex(e[4], 4, out_view);
- dec0_bg_.set(make_bg(dec0_pipeline_.get(), e, 5));
+ dec0_bg_.replace(make_bg(dec0_pipeline_.get(), e, 5));
}
}