Skip to main content

A lightweight complex-valued neural network package built on PyTorch

Project description

ComplexTorch

Homepage | Documentation

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.

Version 1.1.3 Release Notes:

  • Methods have been renamed to reflect identical names in PyTorch, e.g., complextorch.nn.CVConv1d was renamed to complextorch.nn.Conv1d. This change was implemented for quick conversion from PyTorch to complextorch.
  • Use of torch.Tensor is now recommended over complextorch.CVTensor. Previous speed advantages of complextorch.CVTensor are no longer present if using a version of PyTorch newer than 2.1.0.
  • Similarly, previous implementations of complextorch.nn.Conv1d (for 1-D, 2-D, 3-D, and transposed convolution) and complextorch.nn.Lienar have been renamed with the prefix Slow as PyTorch's native convolution and linear operators now outperform that of complextorch. Now, complextorch.nn.Conv1d, for example, uses torch.nn.Conv1d with dtype=torch.float for maximum efficiency.

Documentation

Please see Read the Docs or our arXiv paper, which is also located 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 complextorch as cT

x = cT.randn(64, 5, 7)

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

complextorch-1.1.3-py3-none-any.whl (23.5 kB view details)

Uploaded Python 3

File details

Details for the file complextorch-1.1.3-py3-none-any.whl.

File metadata

  • Download URL: complextorch-1.1.3-py3-none-any.whl
  • Upload date:
  • Size: 23.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for complextorch-1.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 d54b04d28d54a13c79c0fd03f0493ccb59321f9bdb39697e9e4270999a9d9391
MD5 8d214a38511132a292b9195c50dfa785
BLAKE2b-256 8561cff3dbd784bcaccd23e6402b859ab847ea11a0ad4acf27a3b4d3484bfa04

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