Commit 62f64db
Phase 4.5 C: stratified survey-design support for HAD Stute family
Lifts the NotImplementedError gate on SurveyDesign(strata=...) in
stute_test and stute_joint_pretest (and by inheritance in
joint_pretrends_test, joint_homogeneity_test, did_had_pretest_workflow).
Implements the standard stratified clustered wild bootstrap correction
(Cameron-Gelbach-Miller 2008 / Davidson-Flachaire 2008 / Djogbenou-
MacKinnon-Nielsen 2019 / Kreiss-Lahiri 2012): within-stratum demean +
sqrt(n_h/(n_h-1)) Bessel rescale (Wu 1986; Liu 1988) applied to the PSU
multipliers BEFORE the per-obs broadcast in the wild-residual loop.
New shared helper bootstrap_utils.apply_stratum_centering is called from
BOTH the new Stute path (psu_axis=1 on the multiplier matrix) AND the
existing HAD sup-t event-study cband bootstrap (psu_axis=0 on the
PSU-aggregated influence tensor, refactored bit-exactly from had.py:
2172-2204). Locks the algebraic identity architecturally.
Non-strata Stute paths now also apply the Bessel correction uniformly
(single implicit stratum), mirroring HAD sup-t at had.py:2199-2204.
This is a deliberate calibration improvement (~1-2% p-value shift for
typical n_psu); the pre-PR path was under-corrected by exactly the
sqrt(n_psu/(n_psu-1)) factor.
Methodology derivation in REGISTRY § "Note (Stute stratified survey-
bootstrap calibration)". Remaining deferrals: lonely_psu='adjust' +
singleton-strata (pseudo-stratum centering transform) and replicate-
weight designs (Rao-Wu / JKn bootstrap composition).
Tests: 16 new tests across helper unit suite (bit-parity vs pre-
refactor inline code at atol=1e-14), strata positive smokes,
trivial-stratum reduction, calibration-shift direction pin, MC oracle
consistency under stratified null (200 draws, Type I in [0, 0.10]),
MC power under stratified known alternative (200 draws, rejection >
0.50). 575 tests pass across full touched-file sweep; 29 existing
HAD sup-t cband tests pass bit-exactly post-refactor.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>1 parent b56e232 commit 62f64db
8 files changed
Lines changed: 903 additions & 113 deletions
File tree
- diff_diff
- docs
- methodology
- tests
Large diffs are not rendered by default.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
| 20 | + | |
20 | 21 | | |
21 | 22 | | |
22 | 23 | | |
| |||
654 | 655 | | |
655 | 656 | | |
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 | + | |
| 694 | + | |
| 695 | + | |
| 696 | + | |
| 697 | + | |
| 698 | + | |
| 699 | + | |
| 700 | + | |
| 701 | + | |
| 702 | + | |
| 703 | + | |
| 704 | + | |
| 705 | + | |
| 706 | + | |
| 707 | + | |
| 708 | + | |
| 709 | + | |
| 710 | + | |
| 711 | + | |
| 712 | + | |
| 713 | + | |
| 714 | + | |
| 715 | + | |
| 716 | + | |
| 717 | + | |
| 718 | + | |
| 719 | + | |
| 720 | + | |
| 721 | + | |
| 722 | + | |
| 723 | + | |
| 724 | + | |
| 725 | + | |
| 726 | + | |
| 727 | + | |
| 728 | + | |
| 729 | + | |
| 730 | + | |
| 731 | + | |
| 732 | + | |
| 733 | + | |
| 734 | + | |
| 735 | + | |
| 736 | + | |
| 737 | + | |
| 738 | + | |
| 739 | + | |
| 740 | + | |
| 741 | + | |
| 742 | + | |
| 743 | + | |
| 744 | + | |
| 745 | + | |
| 746 | + | |
| 747 | + | |
| 748 | + | |
| 749 | + | |
| 750 | + | |
| 751 | + | |
| 752 | + | |
| 753 | + | |
| 754 | + | |
| 755 | + | |
| 756 | + | |
| 757 | + | |
| 758 | + | |
| 759 | + | |
| 760 | + | |
| 761 | + | |
| 762 | + | |
| 763 | + | |
| 764 | + | |
| 765 | + | |
| 766 | + | |
| 767 | + | |
| 768 | + | |
| 769 | + | |
| 770 | + | |
| 771 | + | |
| 772 | + | |
| 773 | + | |
| 774 | + | |
| 775 | + | |
| 776 | + | |
| 777 | + | |
| 778 | + | |
| 779 | + | |
| 780 | + | |
| 781 | + | |
| 782 | + | |
| 783 | + | |
| 784 | + | |
| 785 | + | |
| 786 | + | |
| 787 | + | |
| 788 | + | |
657 | 789 | | |
658 | 790 | | |
659 | 791 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
2084 | 2084 | | |
2085 | 2085 | | |
2086 | 2086 | | |
| 2087 | + | |
2087 | 2088 | | |
2088 | 2089 | | |
2089 | 2090 | | |
| |||
2169 | 2170 | | |
2170 | 2171 | | |
2171 | 2172 | | |
2172 | | - | |
2173 | | - | |
2174 | | - | |
2175 | | - | |
2176 | | - | |
2177 | | - | |
2178 | | - | |
2179 | | - | |
2180 | | - | |
2181 | | - | |
2182 | | - | |
2183 | | - | |
2184 | | - | |
2185 | | - | |
2186 | | - | |
2187 | | - | |
2188 | | - | |
2189 | | - | |
2190 | | - | |
2191 | | - | |
2192 | | - | |
2193 | | - | |
2194 | | - | |
2195 | | - | |
2196 | | - | |
2197 | | - | |
2198 | | - | |
2199 | | - | |
2200 | | - | |
2201 | | - | |
2202 | | - | |
2203 | | - | |
2204 | | - | |
| 2173 | + | |
| 2174 | + | |
| 2175 | + | |
| 2176 | + | |
| 2177 | + | |
| 2178 | + | |
| 2179 | + | |
2205 | 2180 | | |
2206 | 2181 | | |
2207 | 2182 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
76 | 76 | | |
77 | 77 | | |
78 | 78 | | |
79 | | - | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
80 | 83 | | |
81 | 84 | | |
82 | 85 | | |
| |||
1912 | 1915 | | |
1913 | 1916 | | |
1914 | 1917 | | |
1915 | | - | |
1916 | | - | |
1917 | | - | |
1918 | | - | |
1919 | | - | |
1920 | | - | |
1921 | | - | |
1922 | | - | |
1923 | | - | |
1924 | | - | |
1925 | | - | |
1926 | | - | |
1927 | | - | |
1928 | | - | |
1929 | | - | |
1930 | | - | |
1931 | | - | |
1932 | | - | |
1933 | | - | |
1934 | | - | |
1935 | | - | |
1936 | | - | |
1937 | | - | |
1938 | | - | |
1939 | | - | |
1940 | | - | |
1941 | | - | |
1942 | | - | |
1943 | | - | |
1944 | | - | |
| 1918 | + | |
| 1919 | + | |
| 1920 | + | |
| 1921 | + | |
| 1922 | + | |
| 1923 | + | |
| 1924 | + | |
| 1925 | + | |
| 1926 | + | |
| 1927 | + | |
| 1928 | + | |
| 1929 | + | |
| 1930 | + | |
1945 | 1931 | | |
1946 | 1932 | | |
1947 | 1933 | | |
| |||
1988 | 1974 | | |
1989 | 1975 | | |
1990 | 1976 | | |
| 1977 | + | |
| 1978 | + | |
| 1979 | + | |
| 1980 | + | |
| 1981 | + | |
| 1982 | + | |
| 1983 | + | |
| 1984 | + | |
| 1985 | + | |
1991 | 1986 | | |
1992 | 1987 | | |
1993 | 1988 | | |
| |||
3253 | 3248 | | |
3254 | 3249 | | |
3255 | 3250 | | |
3256 | | - | |
3257 | | - | |
3258 | | - | |
3259 | | - | |
3260 | | - | |
3261 | | - | |
3262 | | - | |
3263 | | - | |
3264 | | - | |
3265 | | - | |
3266 | | - | |
3267 | | - | |
3268 | | - | |
3269 | | - | |
3270 | | - | |
3271 | | - | |
3272 | | - | |
3273 | | - | |
3274 | | - | |
| 3251 | + | |
| 3252 | + | |
| 3253 | + | |
| 3254 | + | |
| 3255 | + | |
| 3256 | + | |
| 3257 | + | |
| 3258 | + | |
| 3259 | + | |
| 3260 | + | |
| 3261 | + | |
| 3262 | + | |
3275 | 3263 | | |
3276 | 3264 | | |
3277 | 3265 | | |
| |||
3314 | 3302 | | |
3315 | 3303 | | |
3316 | 3304 | | |
| 3305 | + | |
| 3306 | + | |
| 3307 | + | |
| 3308 | + | |
| 3309 | + | |
| 3310 | + | |
| 3311 | + | |
| 3312 | + | |
3317 | 3313 | | |
3318 | 3314 | | |
3319 | 3315 | | |
| |||
0 commit comments