Ramanujan Frame Expansion and Periodicity Transform
Project description
RamanujanFrame
Ramanujan Frame Expansion and Periodicity Transform (RPT)
Ramanujan Frames are overcomplete dictionaries built from Ramanujan sums and their cyclic shifts, spanning all integer periods 1 to Q (maximum period to be detected) for discrete signals of length N. Decomposing a signal over this frame via sparse ℓ1 minimization (the Ramanujan Periodicity Transform, RPT) identifies the exact integer periods present through the subspace energies. They are particularly useful in detecting hidden periodicities in short discrete sequences that the Discrete Fourier Transform cannot resolve when the period does not divide the signal length.
Install
Install inside a virtual environment.
First install TensorFlow (CPU or GPU) following the official instructions, then:
pip install RamanujanFrame
Usage
import numpy as np
from RamanujanFrame import RamanujanDict
# Build the Ramanujan dictionary
# N : signal length
# Q : search periods 1 ... Q
rd = RamanujanDict(N=64, Q=16)
# Decompose a signal
signal = np.array([1.0, 0.6, -0.2, -0.8, -0.4] * 13, dtype=np.float32) # period-5
coeffs, energy = rd.solve_for_y_optimal(signal)
# coeffs : ndarray (Φ(Q), 1) optimal Ramanujan coefficients y★
# energy : list of Q floats energy per Ramanujan subspace S_q
A dominant peak at energy[q-1] identifies period q in the signal.
See examples/ for runnable demos including a DFT comparison.
How it works
Ramanujan sum
The Ramanujan sum for integer period q at sample n is
$$c_q(n) = \sum_{\substack{k=1 \ \gcd(k,,q)=1}}^{q} e^{,j\frac{2\pi}{q}kn}$$
The sum runs over integers k coprime to q. c_q(n) is real-valued and integer-valued for all n.
Ramanujan dictionary A
For each period q = 1, ..., Q the dictionary includes φ(q) columns: c_q(n) and its
φ(q) − 1 cyclic shifts, where φ is Euler's totient function.
The full matrix A has shape (N, Φ(Q)) where Φ(Q) = Σ_{q=1}^{Q} φ(q).
When Φ(Q) > N the columns form an overcomplete frame for the N-dimensional signal space.
This is the key advantage over the Discrete Fourier Transform (DFT) basis {W_N^k | k divides N} which covers only the
divisors of N and cannot represent all integer periods.
Sparse decomposition (RPT)
Given signal x of length N, RPT solves
$$\min_{y} ;|Dy|_1 \quad \text{subject to} \quad Ay = x$$
D is a diagonal penalty matrix with D_{ii} = φ(P_i), where P_i is the period index of
column i. The ℓ1 norm promotes sparsity across Ramanujan subspaces.
Solved via CVXPY with the ECOS solver.
Subspace energy
The energy of period q is the squared ℓ2 norm of its coefficients in the optimal solution:
$$E_q = \sum_{i:,P_i = q} |y^\star_i|^2$$
References
[1] P. P. Vaidyanathan and S. Tenneti, "Srinivasa Ramanujan and signal-processing problems," Philosophical Transactions of the Royal Society A, vol. 378, no. 2163, p. 20180446, 2020.
License
Apache 2.0 — see LICENSE.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ramanujanframe-0.0.2.tar.gz.
File metadata
- Download URL: ramanujanframe-0.0.2.tar.gz
- Upload date:
- Size: 9.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bfb05f3eb83ed938e6ee7efbdd6ace1ba4798c5635926a1f332c7a05b082bbbb
|
|
| MD5 |
1852decdb2150fd9d98bc8be9745cb79
|
|
| BLAKE2b-256 |
5b74df156cff719b5c5c5c03335574a4d3f5bb8c3dcc1f4b659dbed28a5f446c
|
File details
Details for the file ramanujanframe-0.0.2-py3-none-any.whl.
File metadata
- Download URL: ramanujanframe-0.0.2-py3-none-any.whl
- Upload date:
- Size: 9.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
874cbb75a31c63bf809b19d98f135545696f5df25979ee985a6b4bf32228bd7c
|
|
| MD5 |
be9c1e94d89120f0d4c66ce6a63f6b23
|
|
| BLAKE2b-256 |
159c4682509aff7e115123f1b4378ff133a7fb170c8788523633180d8181de3e
|