Metadata-Version: 2.4
Name: hilbert_modular_group
Version: 0.2.0
Summary: Algorithms for Hilbert modular groups
Author-email: Fredrik Stromberg <fredrik314@gmail.com>
License-Expression: GPL-3.0-or-later
Project-URL: homepage, https://github.com/fredstro/hilbertmodgroup
Project-URL: bugtracker, https://github.com/fredstro/hilbertmodgroup/issues
Project-URL: sourcecode, https://github.com/fredstro/hilbertmodgroup/
Keywords: hilbert modular groups,reduction algorithms
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Science/Research
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: C
Classifier: Programming Language :: C++
Classifier: Programming Language :: Python
Classifier: Programming Language :: Cython
Classifier: Topic :: Scientific/Engineering :: Mathematics
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: passagemath-standard~=10.8.1
Requires-Dist: passagemath-plot~=10.8.1
Provides-Extra: dev
Requires-Dist: tox; extra == "dev"
Requires-Dist: build; extra == "dev"
Requires-Dist: ruff; extra == "dev"
Requires-Dist: pre-commit; extra == "dev"
Provides-Extra: passagemath
Requires-Dist: passagemath-schemes; extra == "passagemath"
Requires-Dist: passagemath-symbolics; extra == "passagemath"
Requires-Dist: passagemath-repl; extra == "passagemath"
Dynamic: license-file

# Hilbert Modular Groups

This repository contains a python package `hilbert_modgroup` that implements algorithms 
for Hilbert modular groups, in particular a reduction algorithm. 
The implementation is written in Python using classes and libraries from SageMath.

## Supported SageMath versions

- SageMath v9.6 - 10.5 (https://www.sagemath.org/)
- passagemath 10.5.49 (https://github.com/passagemath/passagemath)

## Installation

### Installation from PyPI

The package can be installed using pip using the modularized passagemath fork 
of SageMath (https://github.com/passagemath/passagemath).

#### In a new virtual environment
The following will install the hilbert-modular-group package together with necessary 
dependencies from passagemath.
```console 
 $ python -m venv hilbertmodgroup
 $ source hilbertmodgroup/bin/activate
 $ pip install hilbert-modular-group
```

#### Using an existing SageMath installation

If SageMath is already installed:
```console
$ sage -pip install hilbert-modular-group
```

#### From git source
You can of course also download and install from source using e.g.:

```console
$ git clone https://github.com/fredstro/hilbertmodgroup.git
$ cd hilbertmodgrup
$ pip install . 
```

### Docker

If you have docker installed you can use install this package
in a docker container built and executed using e.g. `make docker-sage` or `make docker-examples`


## Usage
The package can be imported and used as any other package. 
For example, to find the reduction of the point given by [1+i,1+i] in H^2 
with respect to the Hilbert modular group of Q joint by square-root of 5 write: 

```
sage: from hilbert_modgroup.all import *
sage: H1=HilbertModularGroup(5)
sage: P1=HilbertPullback(H1)
sage: z = UpperHalfPlaneProductElement([1+I,1+I])
sage: P1.reduce(z)
[1.00000000000000*I, 1.00000000000000*I]
sage: z = UpperHalfPlaneProductElement([0.25+I/2,1+I])
sage: P1.reduce(z) # abs tol 1e-10
[0.694427190999916 + 0.611145618000168*I, -0.309016994374947 + 1.30901699437495*I]
sage: P1.reduce(z, return_map=True)[1]
[-1/2*a + 1/2  1/2*a + 1/2]
[-1/2*a + 1/2            0]

```
For more examples see the embedded doctests (search for `EXAMPLES`) as well as
the `/examples` directory which contains Jupyter notebook with more extensive 
examples corresponding to the paper
"Reduction Algorithms for Hilbert Modular Groups" by F. Stromberg. (Reference to appear)

## Examples

The directory `/examples` contains Jupyter notebooks with example code to illustrate the interface and functionality of this package. 
You can either open them manually from SageMath or run one of the following commands:
`make examples`
`make docker-examples`
which will start up a Jupyter notebook server from sagemath either locally or in a docker container. 

## Community Guidelines

### How to Contribute?
- Open an issue on GitHub and create a pull / merge request against the `develop` branch.
### How to report an issue or a problem? 
- First check if the issue is resolved in the `develop` branch. If not, open an issue on GitHub. 
### How to seek help and support?
- Contact the maintainer, Fredrik Stromberg, at: fredrik314@gmail.com (alternatively at fredrik.stromberg@nottingham.ac.uk)

## Development and testing

The make file `Makefile` contains a number of useful commands that you can run using 
```console
$ make <command>
```
The following commands are run in your local SageMath environment:
1. `sage-build` -- builds the package, including wheel and source distribution
2. `sage-sdist` -- build source distribution only
3. `sage-install` -- build and install the package
4. `test` -- run sage's doctests (same as `sage -t src/*`)
5. `tox` -- run `sage -tox` with all environments: `doctest`, `coverage`, `pycodestyle`, `relint`, `codespell` (   Note: If your local SageMath installation does not contain tox this will run `sage -pip install tox`.)
6. `sage-examples` -- run `sage --notebook=jupyterlab` initialised at the `/examples` directory.

The following commands are run in the current virtual environment (an error is raised if you are not in a virtual environment so for global installation please just run `python -m build .` etc.)

6. `build` -- builds the package, including wheel and source distribution
7. `sdist` -- build source distribution only
8. `install` -- build and install the package
9. `examples` -- installs `jupyterlab` and runs `jupyter lab` with the SageMath kernel installed and initialised at the `/examples` directory.

The following commands are run in an isolated docker container 
and requires docker to be installed and running:

1. `docker-build` -- build a docker container with the tag `hilbertmodgroup-{GIT_BRANCH}`
2. `docker-rebuild` -- rebuild the docker container without cache
3. `docker-test` -- run SageMath's doctests in the docker container
4. `docker-examples` -- run a Jupyter notebook with the SageMath kernel initialised at the `/examples` directory 
  and exposing the notebook at http://127.0.0.1:8888. The port used can be modified by 
5. `docker-tox` -- run tox with all environments: `doctest`, `coverage`, `pycodestyle`, `relint`, `codespell`. 
6. `docker-shell` -- run a shell in a docker container
7. `docker-sage` -- run a sage interactive shell in a docker container

General commands:

6. `clean` -- remove all build and temporary files

The following command-line parameters are available 
- `NBPORT` -- set the port of the notebook for `examples` and `docker-examples`  (default is 8888)
- `TOX_ARGS` -- can be used to select one or more of the tox environments (default is all)
- `REMOTE_SRC` -- set to 0 if you want to use the local source instead of pulling from gitHub (default 1)
- `GIT_BRANCH` -- the branch to pull from gitHub (used if REMOTE_SRC=1)

### Example usage
Run tox coverage on the branch `main` from gitHub:

`make docker-tox REMOTE_SRC=1 GIT_BRANCH=main TOX_ARGS=coverage`

Run doctests on the local source with local version of sage:

`make tox TOX_ARGS=doctest`

Run relint on the local source with docker version of sage:

`make docker-tox REMOTE_SRC=0 TOX_ARGS=relint`

## Development

### GitHub Workflow

- There are two long-lived branches `main` and `develop`.
- The `develop` branch is used for development and can contain new / experimental features.
- Pull-requests should be based on `develop`.
- Releases should be based on `main`.
- The `main` branch should always be as stable and functional as possible. In particular, merges should always happen from `develop` into `main`.
- Git-Flow is enabled (and encouraged) with feature branches based on `develop` and hotfixes based on `main`.

### Commit Message Convention

This project follows the [Conventional Commits](https://www.conventionalcommits.org/) specification.
Commit messages should be structured as follows:

```
<type>: <description>

[optional body]

[optional footer(s)]
```

**Allowed types:**
- `feat` - A new feature
- `fix` - A bug fix
- `docs` - Documentation only changes
- `style` - Changes that do not affect the meaning of the code (formatting, etc.)
- `refactor` - A code change that neither fixes a bug nor adds a feature
- `perf` - A code change that improves performance
- `test` - Adding missing tests or correcting existing tests
- `build` - Changes that affect the build system or external dependencies
- `ci` - Changes to CI configuration files and scripts
- `chore` - Other changes that don't modify src or test files
- `revert` - Reverts a previous commit

**Examples:**
```
feat: add support for custom fundamental domains
fix: correct boundary detection in reduction algorithm
docs: update installation instructions for passagemath
refactor: simplify cusp normalization logic
test: add tests for degree 3 number fields
```

A pre-commit hook is configured to enforce this convention. To install the hooks:
```console
$ pip install pre-commit
$ pre-commit install
$ pre-commit install --hook-type commit-msg
```

### GitHub Actions

Each commit is tested and checked using gitHub actions with tox running:
- `doctest` -- run all doctests
- `coverage` -- ensure that all functions and classes are documented 
- `pycodestyle-minimal` -- ensure PEP8 style guide is followed (except we allow max line length 99)
- `relint` -- relint against some patterns taken from the SageMath source (config file .relint.yaml)
- `codespell` -- spellchecker

To make sure that your commit passes all tests you should `make tox` or `make docker-tox REMOTE_SRC=0` on the command line.

### Versions

Versioning of this project is managed by setuptools_scm.
To bump the version create a git tag `x.y.z` and the file 
 `src/hilbert_modgroup/version.py` will then be automatically updated to contain 
```
version = 'x.y.z.???'
version_tuple = (x, y, z, '???')
```
where ??? depends on the state of the current directory. 
If you are creating a new version to release the source directory should be clean.

### Publishing to PyPI

#### Automated Publishing (Recommended)

The project uses GitHub Actions for automated publishing:

- **TestPyPI**: Automatically triggered on pushes to the `develop` branch. After tox checks pass, the package is built and published to [test.pypi.org](https://test.pypi.org/project/hilbert-modular-group/).

- **PyPI**: Automatically triggered when a GitHub Release is published. After tox checks pass, the package is built and published to [pypi.org](https://pypi.org/project/hilbert-modular-group/).

Both workflows can also be triggered manually via the GitHub Actions interface.

**To create a new release:**
1. Ensure all changes are merged to `main`
2. Create a git tag: `git tag x.y.z`
3. Push the tag: `git push origin x.y.z`
4. Create a GitHub Release from the tag:
   - Go to the repository on GitHub
   - Click "Releases" in the right sidebar (or navigate to `https://github.com/fredstro/hilbertmodgroup/releases`)
   - Click "Draft a new release"
   - Select the tag you just pushed from the "Choose a tag" dropdown
   - Enter a release title (e.g., `v1.2.3`)
   - Add release notes describing the changes (you can click "Generate release notes" for auto-generated notes)
   - Click "Publish release"
5. The publish workflow will automatically run and upload to PyPI

#### Manual Publishing

To manually upload to PyPI:
```console
$ pip install build twine
$ python -m build
$ twine check dist/*
$ twine upload --repository testpypi dist/*  # Test first
$ twine upload --repository pypi dist/*      # Production
```

## Contributors

- [Fredrik Strömberg](https://github.com/fredstro) — author and maintainer
- [Sujeet Kumar Singh](https://github.com/Sujeetbahel) — extended Hilbert modular group implementation

## References:

- [![DOI](https://joss.theoj.org/papers/10.21105/joss.03996/status.svg)](https://doi.org/10.21105/joss.03996)
