qcs-sdk-python


Nameqcs-sdk-python JSON
Version 0.21.6 PyPI version JSON
download
home_pageNone
SummaryPython interface for the QCS Rust SDK
upload_time2024-12-20 00:37:20
maintainerNone
docs_urlNone
authorNone
requires_pythonNone
licenseApache-2.0
keywords pyquil sdk rigetti quil quantum
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # QCS SDK Python

⚠️ In Development

`qcs-sdk-python` provides an interface to Rigetti [Quantum Cloud Services](https://docs.rigetti.com/qcs/) (QCS), allowing users
to compile and run Quil programs on Rigetti quantum processors. Internally, it is powered by the [QCS Rust SDK](https://github.com/rigetti/qcs-sdk-rust).

While this package can be used directly, [pyQuil](https://pypi.org/project/pyquil/) offers more functionality and a 
higher-level interface for building and executing Quil programs. This package is still in early development and breaking changes should be expected between minor versions.

# Documentation

Documentation for the current release of `qcs_sdk` is published [here](https://rigetti.github.io/qcs-sdk-rust/qcs_sdk.html). Every version of `qcs_sdk` ships [with type stubs](https://github.com/rigetti/qcs-sdk-rust/tree/main/crates/python/qcs_sdk) that can provide type hints and documentation to Python tooling and editors.

## Troubleshooting

### Enabling Debug logging

This package integrates with Python's [logging facility](https://docs.python.org/3/library/logging.html) through a Rust crate called [`pyo3_log`](https://docs.rs/pyo3-log/latest/pyo3_log/). The quickest way to get started is to just enable debug logging:

```python
import logging
logging.basicConfig(level=logging.DEBUG)
```

Because this is implemented with Rust, there are some important differences in regards to log levels and filtering.

#### The `TRACE` log level

Rust has a `TRACE` log level that doesn't exist in Python. It is less severe than `DEBUG` and is set to a value of 5. While the `DEBUG` level is recommended for troubleshooting, you can choose to target `TRACE` level logs and below like so:

```python
import logging
logging.basicConfig(level=5)
```

#### Runtime Configuration and Caching
 
`pyo3_log` caches loggers and their level filters to improve performance. This means that logger re-configuration done at runtime may cause unexpected logging behavior in certain situations. If this is a concern, [this section of the pyo3_log documentation](https://docs.rs/pyo3-log/latest/pyo3_log/#performance-filtering-and-caching) goes into more detail.

These caches can be reset using the following:

```python
qcs_sdk.reset_logging()
```

This will allow the logging handlers to pick up the most recently-applied configuration from the Python side.

#### Filtering Logs

Because the logs are emitted from a Rust library, the logger names will correspond to the fully qualified path of the Rust module in the library where the log occurred. These fully qualified paths all have their own logger, and have to be configured individually.

For example, say you wanted to disable the following log:

```
DEBUG:hyper.proto.h1.io:flushed 124 bytes
```

You could get the logger for `hyper.proto.h1.io` and disable it like so:

```python
logging.getLogger("hyper.proto.h1.io").disabled = True
```

This can become cumbersome, since there are a handful of libraries all logging from a handful of modules that you may not be concerned with. A less cumbersome, but more heavy handed approach is to apply a filter to all logging handlers at runtime. For example, if you only cared about logs from a `qcs` library, you could setup a log filter like so:

```python
class QCSLogFilter(logging.Filter):
    def filter(self, record) -> bool:
        return "qcs" in record.name

for handler in logging.root.handlers:
    handler.addFilter(QCSLogFilter())
```

This applies to all logs, so you may want to tune the `filter` method to include other logs you care about. See the caching section above for important information about the application of these filters.

#### OpenTelemetry Integration

This package supports collection of [OpenTelemetry trace data](https://opentelemetry.io/docs/concepts/signals/traces/). Clients may configure any OpenTelemetry [collector](https://opentelemetry.io/docs/collector/) that supports the [OTLP Specification](https://opentelemetry.io/docs/specs/otlp/). _Rigetti will not have access to the OpenTelemetry data you collect_.

To enable the integration, you should install the `qcs-sdk[tracing-opentelemetry]` extra; this installs [opentelemetry-api](https://pypi.org/project/opentelemetry-api/). By default, no tracing data is collected at runtime. Because the QCS-SDK is built as a pyo3 Rust extension-module, you will need to use [pyo3-tracing-subscriber](https://crates.io/crates/pyo3-tracing-subscriber) to configure collection of your client network requests. See `qcs_sdk._tracing_subscriber` module level documentation for more detail.

```python
import my_module
from qcs_sdk._tracing_subscriber import (
    GlobalTracingConfig,
    SimpleConfig,
    Tracing,
    subscriber,
)
from qcs_sdk._tracing_subscriber.layers import otel_otlp


def main():
    tracing_configuration = GlobalTracingConfig(
        export_process=SimpleConfig(
            subscriber=subscriber.Config(
                # By default this supports the standard OTLP environment variables.
                # See https://opentelemetry.io/docs/specs/otel/protocol/exporter/
                layer=otel_otlp.Config()
            )
        )
    )
    with Tracing(config=config):
        result = my_module.example_function()
        my_module.other_example_function(result)

if __name__ == '__main__':
    main()
```


            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "qcs-sdk-python",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "pyquil, SDK, Rigetti, Quil, Quantum",
    "author": null,
    "author_email": "Rigetti Computing <softapps@rigetti.com>, Mark Skilbeck <mark.skilbeck@rigetti.com>, Marquess Valdez <mvaldez@rigetti.com>, Randall Fulton <rfulton@rigetti.com>",
    "download_url": null,
    "platform": null,
    "description": "# QCS SDK Python\n\n\u26a0\ufe0f In Development\n\n`qcs-sdk-python` provides an interface to Rigetti [Quantum Cloud Services](https://docs.rigetti.com/qcs/) (QCS), allowing users\nto compile and run Quil programs on Rigetti quantum processors. Internally, it is powered by the [QCS Rust SDK](https://github.com/rigetti/qcs-sdk-rust).\n\nWhile this package can be used directly, [pyQuil](https://pypi.org/project/pyquil/) offers more functionality and a \nhigher-level interface for building and executing Quil programs. This package is still in early development and breaking changes should be expected between minor versions.\n\n# Documentation\n\nDocumentation for the current release of `qcs_sdk` is published [here](https://rigetti.github.io/qcs-sdk-rust/qcs_sdk.html). Every version of `qcs_sdk` ships [with type stubs](https://github.com/rigetti/qcs-sdk-rust/tree/main/crates/python/qcs_sdk) that can provide type hints and documentation to Python tooling and editors.\n\n## Troubleshooting\n\n### Enabling Debug logging\n\nThis package integrates with Python's [logging facility](https://docs.python.org/3/library/logging.html) through a Rust crate called [`pyo3_log`](https://docs.rs/pyo3-log/latest/pyo3_log/). The quickest way to get started is to just enable debug logging:\n\n```python\nimport logging\nlogging.basicConfig(level=logging.DEBUG)\n```\n\nBecause this is implemented with Rust, there are some important differences in regards to log levels and filtering.\n\n#### The `TRACE` log level\n\nRust has a `TRACE` log level that doesn't exist in Python. It is less severe than `DEBUG` and is set to a value of 5. While the `DEBUG` level is recommended for troubleshooting, you can choose to target `TRACE` level logs and below like so:\n\n```python\nimport logging\nlogging.basicConfig(level=5)\n```\n\n#### Runtime Configuration and Caching\n \n`pyo3_log` caches loggers and their level filters to improve performance. This means that logger re-configuration done at runtime may cause unexpected logging behavior in certain situations. If this is a concern, [this section of the pyo3_log documentation](https://docs.rs/pyo3-log/latest/pyo3_log/#performance-filtering-and-caching) goes into more detail.\n\nThese caches can be reset using the following:\n\n```python\nqcs_sdk.reset_logging()\n```\n\nThis will allow the logging handlers to pick up the most recently-applied configuration from the Python side.\n\n#### Filtering Logs\n\nBecause the logs are emitted from a Rust library, the logger names will correspond to the fully qualified path of the Rust module in the library where the log occurred. These fully qualified paths all have their own logger, and have to be configured individually.\n\nFor example, say you wanted to disable the following log:\n\n```\nDEBUG:hyper.proto.h1.io:flushed 124 bytes\n```\n\nYou could get the logger for `hyper.proto.h1.io` and disable it like so:\n\n```python\nlogging.getLogger(\"hyper.proto.h1.io\").disabled = True\n```\n\nThis can become cumbersome, since there are a handful of libraries all logging from a handful of modules that you may not be concerned with. A less cumbersome, but more heavy handed approach is to apply a filter to all logging handlers at runtime. For example, if you only cared about logs from a `qcs` library, you could setup a log filter like so:\n\n```python\nclass QCSLogFilter(logging.Filter):\n    def filter(self, record) -> bool:\n        return \"qcs\" in record.name\n\nfor handler in logging.root.handlers:\n    handler.addFilter(QCSLogFilter())\n```\n\nThis applies to all logs, so you may want to tune the `filter` method to include other logs you care about. See the caching section above for important information about the application of these filters.\n\n#### OpenTelemetry Integration\n\nThis package supports collection of [OpenTelemetry trace data](https://opentelemetry.io/docs/concepts/signals/traces/). Clients may configure any OpenTelemetry [collector](https://opentelemetry.io/docs/collector/) that supports the [OTLP Specification](https://opentelemetry.io/docs/specs/otlp/). _Rigetti will not have access to the OpenTelemetry data you collect_.\n\nTo enable the integration, you should install the `qcs-sdk[tracing-opentelemetry]` extra; this installs [opentelemetry-api](https://pypi.org/project/opentelemetry-api/). By default, no tracing data is collected at runtime. Because the QCS-SDK is built as a pyo3 Rust extension-module, you will need to use [pyo3-tracing-subscriber](https://crates.io/crates/pyo3-tracing-subscriber) to configure collection of your client network requests. See `qcs_sdk._tracing_subscriber` module level documentation for more detail.\n\n```python\nimport my_module\nfrom qcs_sdk._tracing_subscriber import (\n    GlobalTracingConfig,\n    SimpleConfig,\n    Tracing,\n    subscriber,\n)\nfrom qcs_sdk._tracing_subscriber.layers import otel_otlp\n\n\ndef main():\n    tracing_configuration = GlobalTracingConfig(\n        export_process=SimpleConfig(\n            subscriber=subscriber.Config(\n                # By default this supports the standard OTLP environment variables.\n                # See https://opentelemetry.io/docs/specs/otel/protocol/exporter/\n                layer=otel_otlp.Config()\n            )\n        )\n    )\n    with Tracing(config=config):\n        result = my_module.example_function()\n        my_module.other_example_function(result)\n\nif __name__ == '__main__':\n    main()\n```\n\n",
    "bugtrack_url": null,
    "license": "Apache-2.0",
    "summary": "Python interface for the QCS Rust SDK",
    "version": "0.21.6",
    "project_urls": {
        "Source Code": "https://github.com/rigetti/qcs-sdk-rust"
    },
    "split_keywords": [
        "pyquil",
        " sdk",
        " rigetti",
        " quil",
        " quantum"
    ],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "0283bd179cac20d1962f62a0d74d5c0370944c1c4669da482c3ff4a6a275aabc",
                "md5": "bfc96ed4aa9c61300909436194d9c45a",
                "sha256": "a5bf2cc7ad4740ff1c44130a8cb323302a385f8a90fb56b8744871bb10fab832"
            },
            "downloads": -1,
            "filename": "qcs_sdk_python-0.21.6-cp310-cp310-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl",
            "has_sig": false,
            "md5_digest": "bfc96ed4aa9c61300909436194d9c45a",
            "packagetype": "bdist_wheel",
            "python_version": "cp310",
            "requires_python": null,
            "size": 11647139,
            "upload_time": "2024-12-20T00:37:20",
            "upload_time_iso_8601": "2024-12-20T00:37:20.491337Z",
            "url": "https://files.pythonhosted.org/packages/02/83/bd179cac20d1962f62a0d74d5c0370944c1c4669da482c3ff4a6a275aabc/qcs_sdk_python-0.21.6-cp310-cp310-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "fb96d9061ec960a9a79b6b64328a826ce39e38427d1fea93ac3c267f68f4789d",
                "md5": "7015c949bc715119bfb524bcf0f41c0d",
                "sha256": "8579293ba158de9adc8f53185f691e08ab624ce17cc62a1d4faf2218caef6e3c"
            },
            "downloads": -1,
            "filename": "qcs_sdk_python-0.21.6-cp310-cp310-manylinux_2_28_aarch64.whl",
            "has_sig": false,
            "md5_digest": "7015c949bc715119bfb524bcf0f41c0d",
            "packagetype": "bdist_wheel",
            "python_version": "cp310",
            "requires_python": null,
            "size": 5973276,
            "upload_time": "2024-12-20T00:37:23",
            "upload_time_iso_8601": "2024-12-20T00:37:23.811812Z",
            "url": "https://files.pythonhosted.org/packages/fb/96/d9061ec960a9a79b6b64328a826ce39e38427d1fea93ac3c267f68f4789d/qcs_sdk_python-0.21.6-cp310-cp310-manylinux_2_28_aarch64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "fe1b515ecf7964b0548872eeaf650e47502e9df7b0b15aa42b94a2624bc8b3c1",
                "md5": "87eb3edb4aa4c563418165855d34daba",
                "sha256": "6ab2d00fbb0f089be19eb7de1bdc456e3c6dbca9f08c7c5fe5a2e7ce802eb035"
            },
            "downloads": -1,
            "filename": "qcs_sdk_python-0.21.6-cp310-cp310-manylinux_2_28_ppc64le.whl",
            "has_sig": false,
            "md5_digest": "87eb3edb4aa4c563418165855d34daba",
            "packagetype": "bdist_wheel",
            "python_version": "cp310",
            "requires_python": null,
            "size": 6396906,
            "upload_time": "2024-12-20T00:37:23",
            "upload_time_iso_8601": "2024-12-20T00:37:23.551191Z",
            "url": "https://files.pythonhosted.org/packages/fe/1b/515ecf7964b0548872eeaf650e47502e9df7b0b15aa42b94a2624bc8b3c1/qcs_sdk_python-0.21.6-cp310-cp310-manylinux_2_28_ppc64le.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "1bfb2d5c6298a7bd38a950a1893dd72129da1728e24543483f901913857eda4d",
                "md5": "f17375e921b71275f89feed162cd8d10",
                "sha256": "e2c7efd89fb233e17430c31dd76f34067e2381f6fafde46893e6b0ff56677b34"
            },
            "downloads": -1,
            "filename": "qcs_sdk_python-0.21.6-cp310-cp310-manylinux_2_28_x86_64.whl",
            "has_sig": false,
            "md5_digest": "f17375e921b71275f89feed162cd8d10",
            "packagetype": "bdist_wheel",
            "python_version": "cp310",
            "requires_python": null,
            "size": 6368314,
            "upload_time": "2024-12-20T00:37:26",
            "upload_time_iso_8601": "2024-12-20T00:37:26.951773Z",
            "url": "https://files.pythonhosted.org/packages/1b/fb/2d5c6298a7bd38a950a1893dd72129da1728e24543483f901913857eda4d/qcs_sdk_python-0.21.6-cp310-cp310-manylinux_2_28_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "3d9816cf54def661293d3b278a30a85b8b27b3fc1cdb58ab6bc5b13502d32f14",
                "md5": "170c2cf3c62b774ee46f8c3853339b73",
                "sha256": "8e26487e87f3ffddb2682ed5d99f3a97dda9db66505b23fc480776a4730e8235"
            },
            "downloads": -1,
            "filename": "qcs_sdk_python-0.21.6-cp310-cp310-win_amd64.whl",
            "has_sig": false,
            "md5_digest": "170c2cf3c62b774ee46f8c3853339b73",
            "packagetype": "bdist_wheel",
            "python_version": "cp310",
            "requires_python": null,
            "size": 6764878,
            "upload_time": "2024-12-20T00:37:28",
            "upload_time_iso_8601": "2024-12-20T00:37:28.990330Z",
            "url": "https://files.pythonhosted.org/packages/3d/98/16cf54def661293d3b278a30a85b8b27b3fc1cdb58ab6bc5b13502d32f14/qcs_sdk_python-0.21.6-cp310-cp310-win_amd64.whl",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-12-20 00:37:20",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "rigetti",
    "github_project": "qcs-sdk-rust",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "qcs-sdk-python"
}
        
Elapsed time: 0.42158s