Skip to main content

Ramanujan Frame Expansion and Periodicity Transform

Project description

RamanujanFrame

PyPI Version Python Versions TensorFlow CVXPY License

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ramanujanframe-0.0.2.tar.gz (9.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ramanujanframe-0.0.2-py3-none-any.whl (9.9 kB view details)

Uploaded Python 3

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

Hashes for ramanujanframe-0.0.2.tar.gz
Algorithm Hash digest
SHA256 bfb05f3eb83ed938e6ee7efbdd6ace1ba4798c5635926a1f332c7a05b082bbbb
MD5 1852decdb2150fd9d98bc8be9745cb79
BLAKE2b-256 5b74df156cff719b5c5c5c03335574a4d3f5bb8c3dcc1f4b659dbed28a5f446c

See more details on using hashes here.

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

Hashes for ramanujanframe-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 874cbb75a31c63bf809b19d98f135545696f5df25979ee985a6b4bf32228bd7c
MD5 be9c1e94d89120f0d4c66ce6a63f6b23
BLAKE2b-256 159c4682509aff7e115123f1b4378ff133a7fb170c8788523633180d8181de3e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page