# Static Declaration Local-Reference Graph

This report is generated from the submitted FormalSLT source snapshot. It is a static source proxy, not Lean kernel dependency extraction.

Command:

```bash
python3 scripts/analyze_local_reference_graph.py \
  --tarball formalslt_anonymized.tar.gz \
  --json-out LOCAL_REFERENCE_GRAPH_ANALYSIS.json \
  --markdown-out LOCAL_REFERENCE_GRAPH_ANALYSIS.md \
  --matrix-csv LOCAL_REFERENCE_CHAIN_MATRIX.csv \
  --fig-dir figures
```

## Headline Counts

| Quantity | Value |
|---|---:|
| Theorem/lemma declarations | 412 |
| Static local-reference edges | 463 |
| Declarations with at least one textual local-reference edge | 257 |
| Declarations textually referenced by at least one other declaration | 295 |
| Non-isolated declarations | 366 |
| Weak connected components | 61 |
| Largest weak component | 177 |
| Maximum static local-reference depth | 18 |
| Median static local-reference depth | 2.0 |
| 90th-percentile static local-reference depth | 10.9 |

## By Chain

| Chain | Decls | Edges out | Edges in | Within-chain edges | Cross-chain edges | Decls with refs | Decls referenced | Max depth | Median depth |
|---|---:|---:|---:|---:|---:|---:|---:|---:|---:|
| Azuma | 58 | 50 | 50 | 48 | 2 | 26 | 41 | 12 | 1.0 |
| Covering | 134 | 192 | 188 | 188 | 4 | 98 | 97 | 18 | 3.0 |
| PAC-Bayes | 34 | 43 | 35 | 35 | 8 | 27 | 26 | 9 | 4.0 |
| PAC-VC | 23 | 22 | 18 | 18 | 4 | 13 | 17 | 17 | 2.0 |
| Probability | 16 | 0 | 5 | 0 | 0 | 0 | 4 | 1 | 1.0 |
| Rademacher | 72 | 64 | 68 | 61 | 3 | 40 | 52 | 17 | 2.0 |
| Risk/ERM spine | 21 | 19 | 21 | 16 | 3 | 14 | 15 | 6 | 2.0 |
| Stability | 54 | 73 | 78 | 72 | 1 | 39 | 43 | 17 | 3.0 |

## Most Textually Referenced Local Declarations

| Declaration | Chain | File:line | Incoming refs |
|---|---|---|---:|
| `finiteExpectation_mono` | Covering | `FormalSLT/Covering/FiniteSubGaussianChaining.lean:318` | 10 |
| `dyadicChainingFiniteNetOfTotallyBoundedUniv_pair_radius_le` | Covering | `FormalSLT/Covering/TotalBoundedDudley.lean:276` | 7 |
| `finiteProductSampleWeight_nonneg` | Stability | `FormalSLT/AlgorithmicStability.lean:1095` | 7 |
| `dyadicChainingFiniteNetOfTotallyBoundedUniv_pair_radius_pos` | Covering | `FormalSLT/Covering/TotalBoundedDudley.lean:292` | 7 |
| `expectedFiniteGeneralizationGap_eq_expectedFiniteStabilityGap` | Stability | `FormalSLT/AlgorithmicStability.lean:674` | 6 |
| `dyadic_annulus_width_nonneg` | Covering | `FormalSLT/Covering/FiniteSubGaussianChaining.lean:2417` | 6 |
| `expectedFiniteStabilityGap_le_uniformStability_of_coordinateSwap` | Stability | `FormalSLT/AlgorithmicStability.lean:1347` | 4 |
| `projectionPair_log_card_le_log_coveringNumber_mul` | Covering | `FormalSLT/Covering/FiniteSubGaussianChaining.lean:201` | 4 |
| `dyadicChainingNetRadius_pos` | Covering | `FormalSLT/Covering/TotalBoundedDudley.lean:199` | 4 |
| `finiteExpectation_add` | Covering | `FormalSLT/Covering/FiniteSubGaussianChaining.lean:328` | 4 |

## Deepest Static Local-Reference Spans

| Declaration | Chain | File:line | Depth | Outgoing refs | Incoming refs |
|---|---|---|---:|---:|---:|
| `finite_epsilonizedSup_dudley_totalBounded_globalBudget_of_finiteCoverSupremumBoundaryChoice` | Covering | `FormalSLT/Covering/TotalBoundedDudley.lean:1469` | 18 | 2 | 0 |
| `finite_epsilonizedSup_modulus_dudley_totalBounded_globalBudget` | Covering | `FormalSLT/Covering/TotalBoundedDudley.lean:1415` | 17 | 2 | 1 |
| `vc_erm_sample_complexity` | PAC-VC | `FormalSLT/VC/SampleComplexity.lean:408` | 17 | 1 | 0 |
| `finite_epsilonizedSup_dudley_totalBounded_of_finiteCoverSupremumBoundaryChoice` | Covering | `FormalSLT/Covering/TotalBoundedDudley.lean:1345` | 17 | 2 | 0 |
| `rademacher_erm_excessRisk_tail` | Rademacher | `FormalSLT/Rademacher/ERMGeneralization.lean:115` | 17 | 1 | 0 |
| `bousquet_elisseeff_uniform_stability_corollary_of_boundedLoss` | Stability | `FormalSLT/Stability/BousquetElisseeff.lean:613` | 17 | 1 | 0 |
| `finite_epsilonizedSup_modulus_dudley_totalBounded_dyadic_entropy_truncatedIntervalIntegral_comparison` | Covering | `FormalSLT/Covering/TotalBoundedDudley.lean:1144` | 16 | 1 | 2 |
| `vc_erm_excessRisk_tail` | PAC-VC | `FormalSLT/VC/SampleComplexity.lean:334` | 16 | 2 | 1 |
| `bousquet_elisseeff_azuma_expectedGap_variant_of_boundedLoss` | Stability | `FormalSLT/Stability/BousquetElisseeff.lean:519` | 16 | 5 | 1 |
| `rademacher_erm_comparator_tail` | Rademacher | `FormalSLT/Rademacher/ERMGeneralization.lean:60` | 16 | 2 | 1 |

## Method Boundary

Static declaration local-reference graph. Nodes are comment-skipped line-leading theorem/lemma declarations. An edge A -> B is added when A's declaration span textually references B's unique local theorem/lemma name. Duplicate, short, and common names are ignored. The scan can miss references through duplicate names, notation, generated names, local aliases, defs, instances, or Mathlib declarations. It can also count names appearing in theorem statements rather than proof bodies. Raw chain-to-chain edge counts are not normalized by chain size. Depth is computed after collapsing static cycles. This is not Lean kernel dependency extraction and does not measure proof difficulty, mathematical novelty, or agent productivity.

Use this report as evidence of source-level compositional structure. Do not use it as a theorem-difficulty metric, a novelty claim, an agent-productivity metric, or a substitute for the Lean build and axiom audit.
