# `FrobeniusPositivity.lean` — Informal Summary

> **Source**: [`OSforGFF/General/FrobeniusPositivity.lean`](../../OSforGFF/General/FrobeniusPositivity.lean)
> **Generated**: 2026-03-03 00:00
> **Note**: Auto-generated by `/lean-summarize`. Re-run to refresh.

## Overview

This file proves Frobenius positivity for real matrices: if $G$ is positive semidefinite
and nonzero, and $B$ is positive definite, then the Frobenius inner product
$\langle G, B \rangle = \sum_{j,l} G_{jl} B_{jl}$ is strictly positive. The proof
proceeds by diagonalizing $B = U D U^\top$ via the spectral theorem, conjugating $G$ to
$H = U^\top G U$ (which remains PSD and nonzero), and then reducing to the fact that
$\langle G, B \rangle = \mathrm{tr}(H D) = \sum_i \lambda_i H_{ii} > 0$.

## Status

**Main result**: Fully proven — file is sorry-free.

**Length**: 236 lines, 0 definition(s) + 5 theorem(s)/lemma(s)

---

### [`frobenius_eq_trace_transpose_mul`](../../OSforGFF/General/FrobeniusPositivity.lean#L36) — Lemma

**Statement**: For real matrices $G, B$ with index type $\iota$,
$$\sum_{j,l} G_{jl} B_{jl} = \mathrm{tr}(G^\top B).$$

**Proof uses**: `Finset.sum_comm`

---

### [`congr_transpose_mul_mul_ne_zero`](../../OSforGFF/General/FrobeniusPositivity.lean#L53) — Lemma

**Statement**: If $U U^\top = 1$ (i.e., $U$ is orthogonal) and $G \neq 0$, then $U^\top G U \neq 0$.

**Proof uses**: *(direct tactic proof)*

---

### [`psd_cauchy_schwarz`](../../OSforGFF/General/FrobeniusPositivity.lean#L69) — Lemma

**Statement**: For a real PSD matrix $H$ and vectors $x, y$, the Cauchy–Schwarz inequality holds for the semi-inner product induced by $H$:
$$(x^\top H y)^2 \leq (x^\top H x)(y^\top H y).$$

**Proof uses**: `Matrix.posSemidef_iff_eq_conjTranspose_mul_self`, `dotProduct_mulVec`, `Matrix.vecMul_transpose`, `Finset.sum_mul_sq_le_sq_mul_sq`

---

### [`psd_offdiag_zero_of_diag_zero`](../../OSforGFF/General/FrobeniusPositivity.lean#L107) — Lemma

**Statement**: If $H$ is a real PSD matrix and $H_{ii} = H_{jj} = 0$, then $H_{ij} = 0$.

**Proof uses**: [`psd_cauchy_schwarz`](../../OSforGFF/General/FrobeniusPositivity.lean#L69)

---

### [`posSemidef_diag_pos_exists_of_ne_zero`](../../OSforGFF/General/FrobeniusPositivity.lean#L127) — Lemma

**Statement**: If $H$ is a real PSD matrix and $H \neq 0$, then there exists an index $i$ with $H_{ii} > 0$.

**Proof uses**: `Matrix.PosSemidef.diag_nonneg`, [`psd_offdiag_zero_of_diag_zero`](../../OSforGFF/General/FrobeniusPositivity.lean#L107)

---

### [`frobenius_pos_of_psd_posdef`](../../OSforGFF/General/FrobeniusPositivity.lean#L158) — Lemma

**Statement**: If $G$ is real PSD with $G \neq 0$ and $B$ is real positive definite, then
$$\sum_{j,l} G_{jl} B_{jl} > 0.$$

**Proof uses**: [`frobenius_eq_trace_transpose_mul`](../../OSforGFF/General/FrobeniusPositivity.lean#L36), `Matrix.PosDef.eigenvalues_pos`, `Matrix.IsHermitian.spectral_theorem`, `Matrix.mem_unitaryGroup_iff`, [`congr_transpose_mul_mul_ne_zero`](../../OSforGFF/General/FrobeniusPositivity.lean#L53), `Matrix.PosSemidef.conjTranspose_mul_mul_same`, `Matrix.trace_mul_comm`, [`posSemidef_diag_pos_exists_of_ne_zero`](../../OSforGFF/General/FrobeniusPositivity.lean#L127), `Finset.add_sum_erase`

---

*This file has **0** definitions and **5** theorems/lemmas (0 with sorry).*
