Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Documentation adjustments #5

Merged
merged 11 commits into from
Sep 11, 2024
Merged
Show file tree
Hide file tree
Changes from 8 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
21 changes: 19 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,17 @@
<!-- SHIELDS -->
caleb-johnson marked this conversation as resolved.
Show resolved Hide resolved
<div align="left">

[![Release](https://img.shields.io/pypi/v/qiskit-addon-sqd.svg?label=Release)](https://github.com/Qiskit/qiskit-addon-sqd/releases)
![Platform](https://img.shields.io/badge/%F0%9F%92%BB%20Platform-Linux%20%7C%20macOS%20%7C%20Windows-informational)
[![Python](https://img.shields.io/pypi/pyversions/qiskit-addon-sqd?label=Python&logo=python)](https://www.python.org/)
[![Qiskit](https://img.shields.io/badge/Qiskit%20-%20%3E%3D1.2%20-%20%236133BD?logo=Qiskit)](https://github.com/Qiskit/qiskit)
<br />
[![Docs (stable)](https://img.shields.io/badge/%F0%9F%93%84%20Docs-stable-blue.svg)](https://qiskit.github.io/qiskit-addon-sqd/)
<!-- [![DOI](https://zenodo.org/badge/DOI/TODO](https://zenodo.org/doi/TODO -->
[![License](https://img.shields.io/github/license/Qiskit/qiskit-addon-sqd?label=License)](LICENSE.txt)
[![Downloads](https://img.shields.io/pypi/dm/qiskit-addon-sqd.svg?label=Downloads)](https://pypi.org/project/qiskit-addon-sqd/)
[![Tests](https://github.com/Qiskit/qiskit-addon-sqd/actions/workflows/test_latest_versions.yml/badge.svg)](https://github.com/Qiskit/qiskit-addon-sqd/actions/workflows/test_latest_versions.yml)

# Qiskit addon: sample-based quantum diagonalization (SQD)

### Table of contents
Expand Down Expand Up @@ -68,13 +82,16 @@ We follow [semantic versioning](https://semver.org/) and are guided by the princ
We may occasionally make breaking changes in order to improve the user experience.
When possible, we will keep old interfaces and mark them as deprecated, as long as they can co-exist with the
new ones.
Each substantial improvement, breaking change, or deprecation will be documented in the release notes.
Each substantial improvement, breaking change, or deprecation will be documented in the
caleb-johnson marked this conversation as resolved.
Show resolved Hide resolved
[release notes](https://qiskit.github.io/qiskit-addon-sqd/release-notes.html).

----------------------------------------------------------------------------------------------------

### Contributing

The developer guide is located at [CONTRIBUTING.md](https://github.com/Qiskit/qiskit-addon-sqd/blob/main/CONTRIBUTING.md>)
The source code is available [on GitHub](https://github.com/Qiskit/qiskit-addon-sqd).
caleb-johnson marked this conversation as resolved.
Show resolved Hide resolved

The developer guide is located at [CONTRIBUTING.md](https://github.com/Qiskit/qiskit-addon-sqd/blob/main/CONTRIBUTING.md)
in the root of this project's repository.
By participating, you are expected to uphold Qiskit's [code of conduct](https://github.com/Qiskit/qiskit/blob/main/CODE_OF_CONDUCT.md).

Expand Down
6 changes: 4 additions & 2 deletions docs/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,9 +20,11 @@
# be documented.
sys.path.insert(0, os.path.abspath(".."))

project = "Sample-based Quantum Diagonalization"
project = "Qiskit addon: sample-based quantum diagonalization (SQD)"
project_copyright = "2024, Qiskit addons team"
description = "Classically post-process noisy samples drawn from a quantum processor to produce more accurate energy estimations"
description = (
"Classically postprocess noisy quantum samples to yield more accurate energy estimations"
)
author = "Qiskit addons team"
language = "en"
release = metadata_version("qiskit-addon-sqd")
Expand Down
4 changes: 2 additions & 2 deletions docs/how_tos/choose_subspace_dimension.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -112,12 +112,12 @@
"outputs": [],
"source": [
"from qiskit_addon_sqd.configuration_recovery import recover_configurations\n",
"from qiskit_addon_sqd.subsampling import postselect_and_subsample\n",
"from qiskit_addon_sqd.utils.fermion import (\n",
"from qiskit_addon_sqd.fermion import (\n",
" bitstring_matrix_to_sorted_addresses,\n",
" flip_orbital_occupancies,\n",
" solve_fermion,\n",
")\n",
"from qiskit_addon_sqd.subsampling import postselect_and_subsample\n",
"\n",
"\n",
"def configuration_recovery_loop(\n",
Expand Down
1 change: 1 addition & 0 deletions docs/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -91,3 +91,4 @@ References
How-To Guides <how_tos/index>
API Reference <apidocs/qiskit_addon_sqd>
GitHub <https://github.com/qiskit/qiskit-addon-sqd>
Release Notes <release-notes>
3 changes: 3 additions & 0 deletions docs/release-notes.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
.. _release notes:

.. release-notes:: Release Notes
caleb-johnson marked this conversation as resolved.
Show resolved Hide resolved
2 changes: 1 addition & 1 deletion docs/tutorials/01_chemistry_hamiltonian.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -220,7 +220,7 @@
"source": [
"Next, we recommend the following steps to optimize the ansatz and make it hardware-compatible.\n",
"\n",
"- Select physical qubits (`initial_layout`) from the target harware that adheres to the zig-zag pattern described above. Laying out qubits in this pattern leads to an efficient hardware-compatible circuit with less gates.\n",
"- Select physical qubits (`initial_layout`) from the target hardware that adheres to the zig-zag pattern described above. Laying out qubits in this pattern leads to an efficient hardware-compatible circuit with less gates.\n",
"- Generate a staged pass manager using the [generate_preset_pass_manager](https://docs.quantum.ibm.com/api/qiskit/transpiler_preset#generate_preset_pass_manager) function from qiskit with your choice of `backend` and `initial_layout`.\n",
"- Set the `pre_init` stage of your staged pass manager to `ffsim.qiskit.PRE_INIT`. `ffsim.qiskit.PRE_INIT` includes qiskit transpiler passes that decompose and merge orbitals resulting in fewer gates in the final circuit.\n",
"- Run the pass manager on your circuit. "
Expand Down
41 changes: 32 additions & 9 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,9 @@ build-backend = "hatchling.build"
name = "qiskit-addon-sqd"
version = "0.3.0"
readme = "README.md"
description = "Classically postprocess noisy quantum samples to yield more accurate energy estimations"
caleb-johnson marked this conversation as resolved.
Show resolved Hide resolved
license = {file = "LICENSE.txt"}
classifiers = [
classifiers = [
"Intended Audience :: Developers",
"Intended Audience :: Science/Research",
"License :: OSI Approved :: Apache Software License",
Expand All @@ -34,14 +35,17 @@ dependencies = [
[project.optional-dependencies]
dev = [
"qiskit-addon-sqd[test,nbtest,lint,docs]",
"tox>=4.4.3",
]
test = [
"tox>=4.0",
caleb-johnson marked this conversation as resolved.
Show resolved Hide resolved
basetest = [
"pytest>=8.0",
"pytest-cov>=5.0",
]
test = [
"qiskit-addon-sqd[basetest]",
]
nbtest = [
"qiskit-addon-sqd[test]",
"qiskit-addon-sqd[basetest]",
"nbmake>=1.5.0",
]
style = [
Expand All @@ -50,9 +54,9 @@ style = [
]
lint = [
"qiskit-addon-sqd[style]",
"pydocstyle==6.3.0",
"mypy==1.11.2",
"pylint>=3.2.7",
"pydocstyle==6.3",
"pylint==3.2.7",
caleb-johnson marked this conversation as resolved.
Show resolved Hide resolved
"reno>=4.1",
"toml>=0.9.6",
]
Expand All @@ -75,6 +79,14 @@ docs = [
"reno>=4.1",
]

[tool.coverage.run]
branch = true
parallel = true

[tool.coverage.report]
fail_under = 100
show_missing = true
Comment on lines +82 to +88
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This may need to be amended. See also next comment


[tool.hatch.build.targets.wheel]
only-include = [
"qiskit_addon_sqd",
Expand Down Expand Up @@ -114,7 +126,7 @@ testpaths = ["./qiskit_addon_sqd/", "./test/"]
[tool.ruff]
line-length = 100
src = ["qiskit_addon_sqd", "test"]
target-version = "py39"
target-version = "py310"
caleb-johnson marked this conversation as resolved.
Show resolved Hide resolved

[tool.ruff.lint]
select = [
Expand All @@ -140,5 +152,16 @@ max-args = 6
"E402", # module level import not at top of file
]

[tool.typos.default.extend-words]
IY = "IY"
[tool.ruff.lint.flake8-copyright]
notice-rgx = """
# This code is a Qiskit project.

# \\(C\\) Copyright IBM 2024\\.

# This code is licensed under the Apache License, Version 2\\.0\\. You may
# obtain a copy of this license in the LICENSE\\.txt file in the root directory
# of this source tree or at http\\:\\/\\/www\\.apache\\.org\\/licenses\\/LICENSE\\-2\\.0\\.
# Any modifications or derivative works of this code must retain this
# copyright notice, and modified files need to carry a notice indicating
# that they have been altered from the originals\\.
caleb-johnson marked this conversation as resolved.
Show resolved Hide resolved
"""
2 changes: 1 addition & 1 deletion qiskit_addon_sqd/configuration_recovery.py
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,7 @@ def recover_configurations(
# First, we need to flip the orbitals such that

corrected_dict: dict[str, float] = {}
for bitstring, freq in zip(bitstring_matrix, probabilities):
for bitstring, freq in zip(bitstring_matrix, probabilities, strict=False):
bs_corrected = _bipartite_bitstring_correcting(
bitstring,
avg_occupancies,
Expand Down
6 changes: 3 additions & 3 deletions qiskit_addon_sqd/qubit.py
Original file line number Diff line number Diff line change
Expand Up @@ -113,11 +113,11 @@ def project_operator_to_subspace(
operator = coo_matrix((d, d), dtype="complex128")

for i, pauli in enumerate(hamiltonian.paulis):
coefficent = hamiltonian.coeffs[i]
coefficient = hamiltonian.coeffs[i]
if verbose:
(
print(
f"Projecting term {i+1} out of {hamiltonian.size}: {coefficent} * "
f"Projecting term {i+1} out of {hamiltonian.size}: {coefficient} * "
+ "".join(pauli.to_label())
+ " ..."
)
Expand All @@ -127,7 +127,7 @@ def project_operator_to_subspace(
bitstring_matrix, pauli
)

operator += coefficent * coo_matrix((matrix_elements, (row_coords, col_coords)), (d, d))
operator += coefficient * coo_matrix((matrix_elements, (row_coords, col_coords)), (d, d))

return operator

Expand Down
4 changes: 4 additions & 0 deletions releasenotes/config.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
---
encoding: utf8
default_branch: main
unreleased_version_title: "Upcoming release"
Empty file added releasenotes/notes/.gitkeep
Empty file.
2 changes: 1 addition & 1 deletion test/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ These environments execute all tests using [pytest], which supports its own simp

## Notebook environments

The `notebook` and `py##-notebook` environments invoke [nbmake] to ensure that all the Jupyter notebooks in the [`docs/`](/docs/tutorials) directory execute successfully.
The `notebook` and `py##-notebook` environments invoke [nbmake] to ensure that all Jupyter notebooks in the [`docs/`](/docs/) directory execute successfully.
caleb-johnson marked this conversation as resolved.
Show resolved Hide resolved

```sh
$ tox -e py310-notebook
Expand Down
22 changes: 13 additions & 9 deletions tox.ini
Original file line number Diff line number Diff line change
@@ -1,11 +1,9 @@
[tox]
minversion = 4.0
envlist = py{39,310,311,312}{,-notebook}, lint
minversion = 4.4.3
envlist = py{310,311,312}{,-notebook}, lint, coverage, docs
isolated_build = True

[testenv]
passenv =
SSH_AUTH_SOCK
extras =
test
commands =
Expand All @@ -26,19 +24,26 @@ extras =
commands =
ruff format --check qiskit_addon_sqd/ docs/ test/
ruff check qiskit_addon_sqd/ docs/ test/
ruff check --preview --select CPY001 --exclude "*.ipynb" qiskit_addon_sqd/ test/
nbqa ruff docs/
pydocstyle qiskit_addon_sqd/
mypy qiskit_addon_sqd/
#reno lint
pylint -rn qiskit_addon_sqd/ test/
nbqa pylint -rn docs/
pydocstyle qiskit_addon_sqd/
reno lint
Copy link
Collaborator

@caleb-johnson caleb-johnson Sep 11, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I went ahead and removed typos from the linter. It found one typo and one false positive. I fixed those, and it is now failing in CI and giving no indication why (I can't reproduce locally)

I feel fairly strongly that typos gets in the way more than it helps (Ive had trouble getting dictionaries to be read and trouble getting CI to tell me what happened with typos). Unless you feel strongly about this, I may leave it out of the linter

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It surprises me, that typos caused this trouble. Here are some notes:

  • typos appears to never have been declared as a dependency (smth I overlooked as well) which makes me wonder why trying to execute the command gave an exit code 2 rather than 127, but could be the reason why it kept failing at the end
  • typos does NOT use a dictionary by design. Instead, it keeps an internal list of common typos which it detects and marks. This cuts down a LOT on false positives compared to e.g. pylint's spell checker. See here for more details.


[testenv:{,py-,py3-,py39-,py310-,py311-,py312-}notebook]
[testenv:{,py-,py3-,py310-,py311-,py312-}notebook]
extras =
nbtest
notebook-dependencies
commands =
pytest --nbmake --nbmake-timeout=3000 {posargs} docs/tutorials/
pytest --nbmake \
--nbmake-timeout=3000 \
--ignore=docs/how_tos/benchmark_pauli_projection.ipynb \
--ignore=docs/how_tos/integrate_dice_solver.ipynb \
--ignore=docs/how_tos/use_oo_to_optimize_hamiltonian_basis.ipynb \
--ignore=docs/how_tos/choose_subspace_dimension.ipynb \
{posargs} docs/

[testenv:coverage]
caleb-johnson marked this conversation as resolved.
Show resolved Hide resolved
deps =
Expand All @@ -62,6 +67,5 @@ commands =
skip_install = true
allowlist_externals =
rm
mypy
commands =
rm -rf {toxinidir}/docs/stubs/ {toxinidir}/docs/_build/