• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

Qiskit / qiskit / 10197684815
88%

Build:
DEFAULT BRANCH: main
Ran 01 Aug 2024 12:10PM UTC
Jobs 1
Files 858
Run time 2min
Badge
Embed ▾
README BADGES
x

If you need to use a raster PNG badge, change the '.svg' to '.png' in the link

Markdown

Textile

RDoc

HTML

Rst

01 Aug 2024 10:56AM UTC coverage: 89.715% (+0.009%) from 89.706%
10197684815

push

github

web-flow
Move `QuantumCircuit.assign_parameters` to Rust (#12794)

* Move `QuantumCircuit.assign_parameters` to Rust

This is (as far as I could tell), the last really major performance
regression in our asv suite compared to 1.1.0, so with this commit, we
should be at _not worse_ for important utility-scale benchmarks.

This largely rewrites `ParamTable` (renamed back to `ParameterTable`
because I kept getting confused with `Param`) to have more Rust-friendly
interfaces available, so that `assign_parameters` can then use them.

This represents a 2-3x speedup in `assign_parameters` performance over
1.1.0, when binding simple `Parameter` instances.  Approximately 75% of
the time is now spent in Python-space `Parameter.assign` and
`ParameterExpression.numeric` calls; almost all of this could be removed
were we to move `Parameter` and `ParameterExpression` to have their data
exposed directly to Rust space.  The percentage of time spent in Python
space only increases if the expressions to be bound are actual
`ParameterExpression`s and not just `Parameter`.

Most changes in the test suite are because of the use of internal-only
methods that changed with the new `ParameterTable`.  The only
discrepancy is a bug in `test_pauli_feature_map`, which was trying to
assign using a set.

* Add unit test of parameter insertion

This catches a bug that was present in the parent commit, but this PR
fixes.

* Update crates/circuit/src/imports.rs

* Fix assignment to `AnnotatedOperation`

* Rename `CircuitData::num_params` to match normal terminology

* Fix typos and :us:

* Fix lint

485 of 513 new or added lines in 5 files covered. (94.54%)

29 existing lines in 4 files now uncovered.

67264 of 74975 relevant lines covered (89.72%)

388894.18 hits per line

Jobs
ID Job ID Ran Files Coverage
1 10197684815.1 01 Aug 2024 12:10PM UTC 0
89.72
GitHub Action Run
Source Files on build 10197684815
Detailed source file information is not available for this build.
  • Back to Repo
  • a68de4f9 on github
  • Prev Build on gh-readonly-queue/main/pr-12859-0afb06e8ac6d176443cee605849a563286fb1058 (#10195645993)
  • Next Build on main (#10200330215)
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc