A lightweight complex-valued neural network package built on PyTorch
Project description
ComplexTorch
Homepage | Documentation | Changelog
Complex PyTorch
(Available on PyPI)
Author: Josiah W. Smith, Ph.D.
A lightweight complex-valued neural network package built on PyTorch.
This is a package built on PyTorch with the intention of implementing light-weight interfaces for common complex-valued neural network operations and architectures. Notably, we include efficient implementations for linear, convolution, and attention modules in addition to activation functions and normalization layers such as batchnorm and layernorm.
Although there is an emphasis on 1-D data tensors, due to a focus on signal processing, communications, and radar data, many of the routines are implemented for 2-D and 3-D data as well.
What's new
See CHANGELOG.md for the full release history. Version 2.0
brings major feature-parity expansion (RNN/LSTM, Transformer, ARD/Variational
Dropout, masked layers, transforms, signal, datasets, models subpackages); see
the changelog for the breaking changes around MultiheadAttention and
default bias=True.
Documentation
Live docs: https://josiahwsmith10.github.io/complextorch/latest/ — including
an executable Getting Started notebook
and a full API reference auto-generated from docstrings. The accompanying
paper is at docs/complextorch_paper.pdf.
Dependencies
This library requires numpy and PyTorch.PyTorch should be installed to your environment using the compute platform (CPU/GPU) settings for your machine. PyTorch will not be automatically installed with the installation of complextorch and MUST be installed manually by the user.
Installation:
IMPORTANT: Prior to installation, install PyTorch to your environment using your preferred method using the compute platform (CPU/GPU) settings for your machine.
Using pip
pip install complextorch
From the source:
git clone https://github.com/josiahwsmith10/complextorch.git
cd complextorch
pip install -r requirements.txt
pip install . --use-pep517
Basic Usage
import torch
import complextorch as cT
x = torch.randn(64, 5, 7, dtype=torch.cfloat)
model = cT.nn.Conv1d(5, 16, kernel_size=3)
y = model(x)
Development
The test suite mirrors complextorch/ 1:1 under tests/ and covers every public class and helper. CI enforces 100% line coverage on Python 3.10 / 3.11 / 3.12 — any PR that drops coverage fails automatically.
pip install '.[test]' # pytest, pytest-cov, pytest-xdist, hypothesis
pytest # auto-parallel (-n auto) from pyproject
pytest --cov=complextorch --cov-report=term-missing --cov-fail-under=100 # mirror CI exactly
pytest --cov=complextorch --cov-report=html && open htmlcov/index.html # browse uncovered lines
When adding a new module, add a matching tests/.../test_<module>.py. Fast/Slow numerical equivalence checks share weights via load_state_dict; loss tests sweep the reduction matrix; round-trip invariants (Fast/Slow, polar, casting, FFT) live under tests/invariants/ and use Hypothesis. Prefer per-line # pragma: no cover over whole-function exclusions so dead code stays visible.
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 complextorch-2.0.0.tar.gz.
File metadata
- Download URL: complextorch-2.0.0.tar.gz
- Upload date:
- Size: 90.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c0c14634c6665e3bbbb20fd03129220c1cb04b8ba4d0eb067d23f64b97ff91ca
|
|
| MD5 |
d03ee271757c74a8d1370d30e0204608
|
|
| BLAKE2b-256 |
5df12446527108c01eb107e43a1cf4a122526f6a00f6950cd415cab3a9c7021f
|
Provenance
The following attestation bundles were made for complextorch-2.0.0.tar.gz:
Publisher:
pypi.yml on josiahwsmith10/complextorch
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
complextorch-2.0.0.tar.gz -
Subject digest:
c0c14634c6665e3bbbb20fd03129220c1cb04b8ba4d0eb067d23f64b97ff91ca - Sigstore transparency entry: 1503889657
- Sigstore integration time:
-
Permalink:
josiahwsmith10/complextorch@8652efd764b1ed3c28b6d81e6fa4d9dc2569cf23 -
Branch / Tag:
refs/tags/2.0.0 - Owner: https://github.com/josiahwsmith10
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi.yml@8652efd764b1ed3c28b6d81e6fa4d9dc2569cf23 -
Trigger Event:
push
-
Statement type:
File details
Details for the file complextorch-2.0.0-py3-none-any.whl.
File metadata
- Download URL: complextorch-2.0.0-py3-none-any.whl
- Upload date:
- Size: 110.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e264d68e0926cbc5ef2040be23ddb742135a872f83878b6ad4444f7667ffe674
|
|
| MD5 |
22e14d96423671476602cc904d65321d
|
|
| BLAKE2b-256 |
fe4c48e02254b5e8f2580da8cac9dc491b7153707e7c90303ab4eae3f9ce3f6d
|
Provenance
The following attestation bundles were made for complextorch-2.0.0-py3-none-any.whl:
Publisher:
pypi.yml on josiahwsmith10/complextorch
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
complextorch-2.0.0-py3-none-any.whl -
Subject digest:
e264d68e0926cbc5ef2040be23ddb742135a872f83878b6ad4444f7667ffe674 - Sigstore transparency entry: 1503889753
- Sigstore integration time:
-
Permalink:
josiahwsmith10/complextorch@8652efd764b1ed3c28b6d81e6fa4d9dc2569cf23 -
Branch / Tag:
refs/tags/2.0.0 - Owner: https://github.com/josiahwsmith10
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi.yml@8652efd764b1ed3c28b6d81e6fa4d9dc2569cf23 -
Trigger Event:
push
-
Statement type: