Commit 175696a
committed
deepnsm: address PR #479 review — coref-keyed cam64, expectation lifecycle, P64 dedup
Three findings from codex + CodeRabbit on PR #479:
1. (codex P2, reader_state.rs) Build Cam64 from the resolved subject.
For "John … He …", effective_subject was the antecedent but Cam64 was
built from the raw pronoun triple, so cam64/P64/CAM4096 keyed to the
pronoun bucket while truth fields pointed at John — downstream locality
lookup and basin matching used the wrong entity. Now constructs an
effective triple (subject = resolved antecedent) before from_triple().
No-op when there is no coreference. The code now matches the comment
that already promised "use the effective triple (post-coref)".
Test: cam64_keyed_to_resolved_antecedent_not_pronoun.
2. (codex P2, window.rs) Clear consumed expectations.
Forward-expectation slots were never drained, so across several
relative/anaphora clauses they accumulated to MAX_EXPECTED (4), after
which push_expected silently dropped newer antecedents and stale
expectations could win over the confirmed ring. step() now clears the
expectation buffer at the start of each sentence (expectations are
single-step predictions), bounding it permanently.
Test: expectations_do_not_accumulate_across_sentences.
3. (CodeRabbit, sentence_transformer64.rs) P64 duplicated P64MeaningField.
Both were byte-identical 8-lane u64 meaning fields. Consolidated:
P64 (the richer superset) is now canonical; signed_crystal re-exports
`pub use crate::sentence_transformer64::P64 as P64MeaningField`. Removes
drift risk. Behaviour-preserving (both from_cam64_and_nsm were identical).
Also removed three now-unused imports surfaced by the consolidation
(NO_ROLE in signed_crystal; MorphFlags + SpoTriple in sentence_transformer64).
217 deepnsm tests pass (was 215; +2 new regression tests).
https://claude.ai/code/session_0147hSzjmWZDuy2MSQNrhEK51 parent 0c67aaf commit 175696a
4 files changed
Lines changed: 83 additions & 84 deletions
File tree
- crates/deepnsm/src
- docs/architecture
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
39 | 39 | | |
40 | 40 | | |
41 | 41 | | |
| 42 | + | |
42 | 43 | | |
43 | 44 | | |
44 | 45 | | |
| |||
226 | 227 | | |
227 | 228 | | |
228 | 229 | | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
229 | 236 | | |
230 | 237 | | |
231 | 238 | | |
| |||
286 | 293 | | |
287 | 294 | | |
288 | 295 | | |
289 | | - | |
290 | | - | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
291 | 304 | | |
292 | 305 | | |
293 | | - | |
| 306 | + | |
294 | 307 | | |
295 | 308 | | |
296 | 309 | | |
| |||
423 | 436 | | |
424 | 437 | | |
425 | 438 | | |
426 | | - | |
427 | 439 | | |
428 | 440 | | |
429 | 441 | | |
| |||
628 | 640 | | |
629 | 641 | | |
630 | 642 | | |
| 643 | + | |
| 644 | + | |
| 645 | + | |
| 646 | + | |
| 647 | + | |
| 648 | + | |
| 649 | + | |
| 650 | + | |
| 651 | + | |
| 652 | + | |
| 653 | + | |
| 654 | + | |
| 655 | + | |
| 656 | + | |
| 657 | + | |
| 658 | + | |
| 659 | + | |
| 660 | + | |
| 661 | + | |
| 662 | + | |
| 663 | + | |
| 664 | + | |
| 665 | + | |
| 666 | + | |
| 667 | + | |
| 668 | + | |
| 669 | + | |
| 670 | + | |
| 671 | + | |
| 672 | + | |
| 673 | + | |
| 674 | + | |
| 675 | + | |
| 676 | + | |
| 677 | + | |
| 678 | + | |
| 679 | + | |
| 680 | + | |
| 681 | + | |
| 682 | + | |
| 683 | + | |
| 684 | + | |
| 685 | + | |
| 686 | + | |
| 687 | + | |
| 688 | + | |
| 689 | + | |
| 690 | + | |
| 691 | + | |
| 692 | + | |
| 693 | + | |
631 | 694 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
80 | 80 | | |
81 | 81 | | |
82 | 82 | | |
83 | | - | |
84 | | - | |
| 83 | + | |
85 | 84 | | |
86 | 85 | | |
87 | 86 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
58 | 58 | | |
59 | 59 | | |
60 | 60 | | |
61 | | - | |
62 | 61 | | |
63 | 62 | | |
64 | 63 | | |
| |||
282 | 281 | | |
283 | 282 | | |
284 | 283 | | |
285 | | - | |
| 284 | + | |
286 | 285 | | |
287 | 286 | | |
288 | 287 | | |
289 | | - | |
290 | | - | |
291 | | - | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
292 | 293 | | |
293 | | - | |
294 | | - | |
295 | | - | |
296 | | - | |
297 | | - | |
298 | | - | |
299 | | - | |
300 | | - | |
301 | | - | |
302 | | - | |
303 | | - | |
304 | | - | |
305 | | - | |
306 | | - | |
307 | | - | |
308 | | - | |
309 | | - | |
310 | | - | |
311 | | - | |
312 | | - | |
313 | | - | |
314 | | - | |
315 | | - | |
316 | | - | |
317 | | - | |
318 | | - | |
319 | | - | |
320 | | - | |
321 | | - | |
322 | | - | |
323 | | - | |
324 | | - | |
325 | | - | |
326 | | - | |
327 | | - | |
328 | | - | |
329 | | - | |
330 | | - | |
331 | | - | |
332 | | - | |
333 | | - | |
334 | | - | |
335 | | - | |
336 | | - | |
337 | | - | |
338 | | - | |
339 | | - | |
340 | | - | |
341 | | - | |
342 | | - | |
343 | | - | |
344 | | - | |
345 | | - | |
346 | | - | |
347 | | - | |
348 | | - | |
349 | | - | |
350 | | - | |
351 | | - | |
352 | | - | |
353 | | - | |
354 | | - | |
355 | | - | |
356 | | - | |
357 | | - | |
358 | | - | |
359 | | - | |
360 | | - | |
361 | | - | |
362 | | - | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
363 | 300 | | |
364 | 301 | | |
365 | 302 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
259 | 259 | | |
260 | 260 | | |
261 | 261 | | |
262 | | - | |
263 | | - | |
| 262 | + | |
| 263 | + | |
264 | 264 | | |
265 | 265 | | |
266 | 266 | | |
267 | | - | |
| 267 | + | |
268 | 268 | | |
269 | 269 | | |
270 | 270 | | |
| |||
0 commit comments