-
Notifications
You must be signed in to change notification settings - Fork 39
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
Add GateImplementationsLM::applyGeneratorDoubleExcitation(Minus/Plus)… #512
Add GateImplementationsLM::applyGeneratorDoubleExcitation(Minus/Plus)… #512
Conversation
Co-authored-by: Amintor Dusko <87949283+AmintorDusko@users.noreply.github.com>
7107a75
to
c0067fb
Compare
Codecov ReportAll modified lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## master #512 +/- ##
=======================================
Coverage 99.13% 99.13%
=======================================
Files 143 143
Lines 16850 16857 +7
=======================================
+ Hits 16704 16711 +7
Misses 146 146
☔ View full report in Codecov by Sentry. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me! Thanks @vincentmr
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me! Let me know if there is any change here.
...ne_lightning/core/src/simulators/lightning_qubit/gates/cpu_kernels/GateImplementationsLM.cpp
Outdated
Show resolved
Hide resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Beautiful! Nice work on that! Double-approved!
… kernels.
Before submitting
Please complete the following checklist when submitting a PR:
All new features must include a unit test.
If you've fixed a bug or added code that should be tested, add a test to the
tests
directory!All new functions and code must be clearly commented and documented.
If you do make documentation changes, make sure that the docs build and
render correctly by running
make docs
.Ensure that the test suite passes, by running
make test
.Add a new entry to the
.github/CHANGELOG.md
file, summarizing thechange, and including a link back to the PR.
Ensure that code is properly formatted by running
make format
.When all the above are checked, delete everything above the dashed
line and fill in the pull request template.
Context:
The
LM
implementation requires less memory and is faster for large state vectors, and hence it is the default implementation for most operations.LM::GeneratorDoubleExcitation
,LM::GeneratorDoubleExcitationMinus
,LM::GeneratorDoubleExcitationPlus
kernels are missing.Description of the Change:
Implement
LM::GeneratorDoubleExcitation
,LM::GeneratorDoubleExcitationMinus
,LM::GeneratorDoubleExcitationPlus
kernels and set all default kernels toLM
.Benefits:
Lower memory footprint and faster calculations for large state vectors.
Possible Drawbacks:
Related GitHub Issues: