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

[Feature] Adding apply to SummedPauliOp #80

Merged
merged 19 commits into from
Nov 6, 2024
Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
19 commits
Select commit Hold shift + click to select a range
f770736
[feature/SPO_apply] Adding apply (without x_tk weights) for SummedPau…
jamesETsmith Oct 24, 2024
fe016d3
[feature/SPO_apply] Adding C++ tests
jamesETsmith Oct 25, 2024
4be9eaf
[feature/SPO_apply] Adding timers to some of the tests as a sanity ch…
jamesETsmith Oct 28, 2024
bf20dbe
[feature/SPO_apply] Small performance tweaks while profiling SummedPa…
jamesETsmith Oct 29, 2024
f83d39d
[feature/SPO_apply] Adding docs to SummedPauliOp
jamesETsmith Oct 29, 2024
64737a8
[feature/SPO_apply] Adding docstrings to python bindinds for SummedPa…
jamesETsmith Oct 30, 2024
09026fd
[feature/SPO_apply] Added to_tensor for SummedPauliOp
jamesETsmith Oct 30, 2024
f44b89e
[feature/SPO_apply] Small tweaks to get_sparse_repr
jamesETsmith Oct 30, 2024
f117bfd
[feature/SPO_apply] Rounding out python tests
jamesETsmith Oct 30, 2024
14e366a
[feature/SPO_apply] Adding more python tests for SummedPauliOp
jamesETsmith Oct 31, 2024
1e30e84
[feature/SPO_apply] Small tweaks to apply_weighted
jamesETsmith Oct 31, 2024
9322d78
[feature/SPO_apply] Adding a note about the test timings in the C++ t…
jamesETsmith Oct 31, 2024
3d0c2bf
[feature/SPO_apply] Small fixes, include <chrono> in the examples
jamesETsmith Nov 1, 2024
85f1002
[feature/SPO_apply] First stab at C++ impl of optimized squaring of S…
jamesETsmith Nov 1, 2024
d216424
[feature/SPO_apply] Adding benchmark and timers
jamesETsmith Nov 4, 2024
777d8df
[feature/SPO_apply] more efficient version of SummedPauliOp.square()
jamesETsmith Nov 4, 2024
e616935
[feature/SPO_apply] Storing the map to slightly improve speed on the …
jamesETsmith Nov 4, 2024
8e4b999
[feature/SPO_apply] Switching to transform_reduce, because my use of …
jamesETsmith Nov 4, 2024
f1d0045
[feature/SPO_apply] Adding getters for SummedPauliOp functions and ot…
jamesETsmith Nov 5, 2024
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
7 changes: 7 additions & 0 deletions docs/python_api.rst
Original file line number Diff line number Diff line change
Expand Up @@ -27,3 +27,10 @@ PauliOp
.. autoclass:: fast_pauli.PauliOp
:members:
:special-members:

SummedPauliOp
-------------

.. autoclass:: fast_pauli.SummedPauliOp
:members:
:special-members:
32 changes: 19 additions & 13 deletions fast_pauli/cpp/examples/03_summed_pauli_op.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -13,38 +13,35 @@
*/

#include <algorithm>
#include <chrono>
#include <experimental/mdspan>
#include <random>

#include "__pauli.hpp"
#include "__pauli_string.hpp"
#include "fast_pauli.hpp"

using namespace fast_pauli;
namespace fp = fast_pauli;

int main()
{
//
// User settings
//
size_t const n_operators = 10000;
// size_t const n_paulis_per_operator = 631;
size_t const n_qubits = 14;
size_t const n_operators = 1000;
size_t const n_qubits = 12;
size_t const weight = 2;
size_t const n_states = 1000;
// std::string fake_pauli_string = "XYZXYZXYZXYZ";
using fp_type = double;
using fp_type = float;

//
// Setup the summed pauli operator
//
// std::vector<PauliString> pauli_strings(n_paulis_per_operator,
// PauliString(fake_pauli_string));
std::vector<PauliString> pauli_strings = calculate_pauli_strings_max_weight(n_qubits, weight);
std::vector<fp::PauliString> pauli_strings = fp::calculate_pauli_strings_max_weight(n_qubits, weight);

size_t const n_paulis_per_operator = pauli_strings.size();
std::vector<std::complex<fp_type>> coeff_raw(n_paulis_per_operator * n_operators, 1);
SummedPauliOp<fp_type> summed_op{pauli_strings, coeff_raw};
fp::SummedPauliOp<fp_type> summed_op{pauli_strings, coeff_raw};

//
// Setup states
Expand All @@ -67,8 +64,17 @@ int main()
//
// Apply the states
//
// summed_op.apply(new_states, states, weights);
summed_op.apply_weighted(new_states, states, weights);
// auto start_seq = std::chrono::high_resolution_clock::now();
// summed_op.apply_weighted(std::execution::seq, new_states, states, weights);
// auto end_seq = std::chrono::high_resolution_clock::now();
// fmt::println("Time taken for sequential execution: {} seconds",
// std::chrono::duration_cast<std::chrono::seconds>(end_seq - start_seq).count());

auto start_par = std::chrono::high_resolution_clock::now();
summed_op.apply_weighted(std::execution::par, new_states, states, weights);
auto end_par = std::chrono::high_resolution_clock::now();
fmt::println("Time taken for parallel execution: {} seconds",
std::chrono::duration_cast<std::chrono::seconds>(end_par - start_par).count());

return 0;
}
}
17 changes: 17 additions & 0 deletions fast_pauli/cpp/examples/04_get_sparse_repr.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
#include <string>

#include "fast_pauli.hpp"

namespace fp = fast_pauli;

int main()
{
size_t const n_qubits = 24;
std::string pauli_string(n_qubits, 'X');
fp::PauliString ps(pauli_string);
std::vector<size_t> k;
std::vector<std::complex<double>> m;
std::tie(k, m) = get_sparse_repr<double>(ps.paulis);

return 0;
}
6 changes: 3 additions & 3 deletions fast_pauli/cpp/include/__pauli_helpers.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -112,8 +112,8 @@ std::vector<PauliString> calcutate_pauli_strings(size_t const n_qubits, size_t c
size_t n_pauli_strings = nontrivial_paulis.size() * idx_combos.size();
std::vector<PauliString> result(n_pauli_strings);

fmt::println("n_qubits = {} weight = {} n_nontrivial_paulis = {} n_combos = {}", n_qubits, weight,
nontrivial_paulis.size(), idx_combos.size());
// fmt::println("n_qubits = {} weight = {} n_nontrivial_paulis = {} n_combos = {}", n_qubits, weight,
// nontrivial_paulis.size(), idx_combos.size());
stand-by marked this conversation as resolved.
Show resolved Hide resolved

// Iterate through all the nontrivial paulis and all the combinations
for (size_t i = 0; i < nontrivial_paulis.size(); ++i)
Expand Down Expand Up @@ -153,7 +153,7 @@ std::vector<PauliString> calculate_pauli_strings_max_weight(size_t n_qubits, siz
result.insert(result.end(), ps.begin(), ps.end());
}

fmt::println("n_qubits = {} weight = {} n_pauli_strings = {}", n_qubits, weight, result.size());
// fmt::println("n_qubits = {} weight = {} n_pauli_strings = {}", n_qubits, weight, result.size());
return result;
}

Expand Down
11 changes: 3 additions & 8 deletions fast_pauli/cpp/include/__pauli_string.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ std::tuple<std::vector<size_t>, std::vector<std::complex<T>>> get_sparse_repr(st

// Helper function that let's us know if a pauli matrix has diagonal (or
// conversely off-diagonal) elements
auto diag = [](Pauli const &p) {
auto diag = [](Pauli const &p) -> size_t {
if (p.code == 0 || p.code == 3)
{
return 0UL;
Expand Down Expand Up @@ -98,18 +98,13 @@ std::tuple<std::vector<size_t>, std::vector<std::complex<T>>> get_sparse_repr(st
}
m[0] = initial_value();

// Populate the rest of the values in a recursive-like manner
for (size_t l = 0; l < n; ++l)
{
Pauli const &po = ps[l];

T eps = 1.0;
if (po.code == 2 || po.code == 3)
{
eps = -1;
}
T const eps = (po.code == 2 || po.code == 3) ? -1.0 : 1.0;

T sign = diag(po) ? -1.0 : 1.0;
int sign = diag(po) ? -1 : 1;

auto const lower_bound = 1UL << l;
for (size_t li = lower_bound; li < (lower_bound << 1); li++)
Expand Down
Loading
Loading