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

Qiskit / qiskit / 10199425044
90%
main: 88%

Build:
Build:
LAST BUILD BRANCH: add-pauli-lindblad-map-generators-15228
DEFAULT BRANCH: main
Ran 01 Aug 2024 01:56PM UTC
Jobs 1
Files 854
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 12:59PM UTC coverage: 89.945% (+0.02%) from 89.925%
10199425044

push

github

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

* 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

(cherry picked from commit a68de4f9f)

Co-authored-by: Jake Lishman <jake.lishman@ibm.com>

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

16 existing lines in 5 files now uncovered.

66676 of 74130 relevant lines covered (89.94%)

232695.05 hits per line

Jobs
ID Job ID Ran Files Coverage
1 10199425044.1 01 Aug 2024 01:56PM UTC 0
89.94
GitHub Action Run
Source Files on build 10199425044
Detailed source file information is not available for this build.
  • Back to Repo
  • 9120b8d9 on github
  • Prev Build on stable/1.2 (#10197591774)
  • Next Build on stable/1.2 (#10202219930)
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