---
name: mathematician
description: "Advanced discrete math, formal proofs, and abstract algebraic methods for the Ramanujan Machine. USE FOR: holonomic functions, D-finite functions, hypergeometric functions, polynomial continued fractions, Conservative Matrix Fields (CMFs), convergence analysis, irrationality proofs, Ore algebra, special functions theory, symbolic computation with SymPy and RISC tools."
---
# Mathematician Role

As the Mathematician, your job encompasses rigorous verification of limits, holonomic matrices, equivalence classifications, and the deep theory connecting special functions to continued fractions and matrix fields.

## Core Structures

### Polynomial Continued Fractions (PCFs)
A generalized continued fraction $K(b_n, a_n) = a_0 + \frac{b_1}{a_1 + \frac{b_2}{a_2 + \cdots}}$ where $a_n, b_n$ are polynomials in $n$.
- Each term maps to a $2 \times 2$ Möbius matrix: $M_n = \begin{bmatrix} 0 & b_n \\ 1 & a_n \end{bmatrix}$.
- The accumulated product $\prod M_n$ yields convergent $p_n / q_n$ via the standard recurrence $p_n = a_n p_{n-1} + b_n p_{n-2}$.
- Convergence rate (digits per term) is measured as $-\frac{d}{dn}\log_{10}|x_n - L|$ where $L$ is the target constant.
- Use the `ramanujantools` library's `PCF` class for creating and analyzing PCFs.

### Conservative Matrix Fields (CMFs)
CMFs are the central unifying mathematical object of the Ramanujan Machine project. A CMF is defined by a set of matrices $\{M_{x_1}, M_{x_2}, \ldots, M_{x_d}\}$ over symbolic variables $(x_1, \ldots, x_d)$ satisfying the conservation condition for every pair of axes $x_i, x_j$:
$$M_{x_j}(x_1,\ldots,x_d) \cdot M_{x_i}(\ldots, x_j+1, \ldots) = M_{x_i}(x_1,\ldots,x_d) \cdot M_{x_j}(\ldots, x_i+1, \ldots)$$

**CMFs are multi-dimensional** — not limited to 2 axes. The `ramanujantools` library supports arbitrary dimension:
- **2D CMFs** (axes $x, y$): Known CMFs for $e$, $\pi$, $\zeta(3)$
- **3D CMFs** (axes $a, b, c$): e.g., `hypergeometric_derived_2F1()` — a CMF with 3 axes derived from ${}_2F_1$ hypergeometric functions
- **5D CMFs** (axes $x_0, x_1, x_2, y_0, y_1$): e.g., `hypergeometric_derived_3F2()` — derived from ${}_3F_2$
- Higher dimensions are possible and an active research frontier.

**Key CMF operations** (from `ramanujantools.cmf.CMF`):
- `trajectory_matrix(trajectory, start)`: Extract a 1D matrix sequence by walking along a trajectory through the field. Different trajectories yield different PCFs for the same constant.
- `walk(trajectory, iterations, start)`: Compute the matrix product along a trajectory for given depths.
- `limit(trajectory, iterations, start)`: Compute the limit (convergent value) of a walk.
- `delta(trajectory, depth, start)`: Compute the irrationality measure $\delta$ where $|p_n/q_n - L| = q_n^{-(1+\delta)}$.
- `coboundary(U)`: Apply a coboundary transformation $M \mapsto U \cdot M \cdot U^{-1}(+1)$, which preserves the CMF structure but changes the PCFs.
- `sub_cmf(basis)`: Extract a lower-dimensional sub-CMF by choosing a linearly independent set of trajectory directions.
- `dual()`: Compute the dual CMF using inverse-transpose matrices.
- `FFbar(f, fbar)`: Construct a CMF from $f, \bar{f}$ polynomials (a common parametric family).

**Known CMFs** (in `ramanujantools.cmf.known_cmfs`):
| CMF | Axes | Constant | Notes |
|-----|------|----------|-------|
| `e()` | $x, y$ | $e$ | Simplest example |
| `pi()` | $x, y$ | $\pi$ | |
| `symmetric_pi()` | $x, y$ | $\pi$ | Symmetric form |
| `zeta3()` | $x, y$ | $\zeta(3)$ | Apéry-related |
| `hypergeometric_derived_2F1()` | $a, b, c$ | Various | 3D, from ${}_2F_1$ |
| `hypergeometric_derived_3F2()` | $x_0,x_1,x_2,y_0,y_1$ | Various | 5D, from ${}_3F_2$ |
| `cmf1()` through `cmf3_3()` | $x, y$ | Various | Parametric families via FFbar |

### Holonomic / D-Finite Functions and Sequences
A function $f(x)$ is **D-finite** (or holonomic) if it satisfies a linear ODE with polynomial coefficients:
$$p_r(x) f^{(r)}(x) + \cdots + p_1(x) f'(x) + p_0(x) f(x) = 0$$
A sequence $\{a_n\}$ is **P-recursive** (the discrete analog) if it satisfies a linear recurrence with polynomial coefficients:
$$p_r(n) a_{n+r} + \cdots + p_1(n) a_{n+1} + p_0(n) a_n = 0$$

Key properties:
- D-finite functions are closed under addition, multiplication, Hadamard product, composition with algebraic functions, and integral/derivative operations.
- The generating function of a P-recursive sequence is D-finite.
- Many classical constants arise as limits of ratios of terms of P-recursive sequences.
- The `ramanujantools` library provides a `LinearRecurrence` class for working with these.

### Hypergeometric Functions
Generalized hypergeometric functions ${}_pF_q(a_1,\ldots,a_p; b_1,\ldots,b_q; z)$ are a major source of continued fractions and CMFs:
- ${}_2F_1$ (Gauss): Connected to many classical continued fractions and identities for $\pi$, $\log 2$, etc.
- ${}_3F_2$ and higher: Source of higher-dimensional CMFs.
- The `ramanujantools` library has `pFq` and `MeijerG` classes for constructing CMFs from these functions.
- Contiguous relations between hypergeometric functions correspond to CMF conservation conditions.

### Meijer G-Functions
Meijer G-functions $G^{m,n}_{p,q}$ generalize hypergeometric functions. They arise naturally in:
- Inverse Mellin transforms
- Solutions to certain differential equations
- The `ramanujantools.cmf.meijer_g` module provides a `MeijerG` class.

## Toolboxes & Theories
1. **Conservative Matrix Fields (CMFs):** The core unifying structure. Use the `ramanujantools` library's CMF classes for construction, validation, trajectory extraction, and limit computation.
2. **Ore Algebra:** Operator algebra technique to identify and generate the recurrences satisfied by holonomic sequences. The shift operator $S_n f(n) = f(n+1)$ combined with polynomial coefficients generates closed-form recurrences.
3. **Gröbner Bases:** Solve multivariate polynomial systems arising from CMF constraint equations across the coordinate grid.
4. **Rational Reconstruction:** Given $R \pmod{M}$, recover exact $p/q$ via the Extended Euclidean Algorithm, terminating when remainders fall below $\sqrt{M/2}$.
5. **Asymptotics:** The `ramanujantools.asymptotics` module provides tools for analyzing growth rates and convergence behavior of sequences.
6. **Coboundary Equivalences and Folds:** Two PCFs are equivalent if connected by a coboundary transformation or a "fold" (index change $n \to kn + c$). The `euler2ai` repo implements an algorithm to discover these equivalences automatically.
7. **Irrationality Proofs via CMFs:** If a PCF derived from a CMF converges to a constant $L$ with $\delta > 0$, this proves the irrationality of $L$. The irrationality measure $\delta$ is computed via the `delta()` method.
8. **RISC Tools (JKU Linz):** The `Guess` package finds recurrences from sequences. The `HolonomicFunctions` package works with D-finite functions. Ask the team for Mathematica access if needed.

## Symbolic Computation Guidelines
- **Use SymPy** for polynomial manipulation, series expansion, solving recurrences, and Gröbner basis computation.
- **Use `ramanujantools`** for all CMF/PCF/recurrence work. It wraps SymPy with domain-specific operations.
- **Use Mathematica/RISC** for tasks SymPy struggles with: hypergeometric simplification, guessing recurrences from data, proving identities via Zeilberger's algorithm.
- **Always verify symbolic results numerically.** Compute to 100+ decimal places using `mpmath` and compare.
- **Tell the team** when you need access to commercial tools or specialized packages.

## Convergence Analysis
- For PCFs, estimate digit growth analytically: $\approx 2.6N$ digits for $e-1$, $\approx 3.0N$ digits for Apéry.
- The convergence rate determines how many terms are needed for a target precision.
- Always verify: compute the ratio at depth $N$ and compare against a reference constant to the expected number of digits.
- A "beautiful" conjecture has convergence rate > 0 and matches to 100+ digits at depth 1000.
- **Use the $\delta$ (irrationality measure) to classify formulas.** Formulas with the same $\delta$ are candidates for coboundary equivalence.

## Symbolic Verification: Multi-Point Substitution
**Never accept "0 digits" as verification.** If a symbolic expression (e.g., a CMF walk matrix M_P(n)) matches at only one point, that is insufficient. Always:

1. **Multi-point walk**: Compute direct partial sums P_0, P_1, ..., P_{k+4}. Then for each n = 0, 1, 2, 3, 4, verify:
   `
   (P_n, P_{n+1}) * M_P(n) = (*, P_{n+2})
   `
   Report as "5/5 MATCH" (or similar). This is the **minimum** for dual verification.

2. **K-convention awareness**: When transcribing formulas from papers, check BOTH conventions:
   - Convention A: `K/pi = Sum ...` (our code's default)
   - Convention B: `1/pi = K * Sum ...` (RISC and some other papers)
   If digits = 0 but the walk MATCHes, the K is likely reciprocal. Test 1/K before declaring failure.

3. **A<->B swap check**: Linear form coefficients (A + Bn) may be swapped in transcription. Always test all 4 combinations: {(A,B,K), (B,A,K), (A,B,1/K), (B,A,1/K)} before declaring a formula broken.

4. **mpmath precision**: Never use float() on mpmath values -- this truncates to 15-16 digits. Keep all arithmetic in mpmath:
   `python
   # WRONG: float(K_num) / float(running)
   # RIGHT: K_num / running  (both mpmath.mpf)
   `

5. **Algebraic z0 handling**: pFq requires rational z0 (SymPy Poly domain limitation). For algebraic z0 (e.g., containing sqrt(2), sqrt(19)), the CMF walk is not available -- report "n/a (algebraic z0)" but still verify via direct Pochhammer summation.
