Skip to content

Commit

Permalink
Merge branch 'master' into applyControlledMatrix_LGPU
Browse files Browse the repository at this point in the history
  • Loading branch information
multiphaseCFD committed Oct 21, 2024
2 parents 148b8df + f36d97c commit a87d77b
Show file tree
Hide file tree
Showing 7 changed files with 75 additions and 5 deletions.
6 changes: 6 additions & 0 deletions .github/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,9 @@

### Improvements

* Add joint check for the N-controlled wires support in `lightning.qubit`.
[(#949)](https://github.com/PennyLaneAI/pennylane-lightning/pull/949)

* Optimize the cartesian product to reduce the amount of memory necessary to set the StatePrep with LightningTensor.
[(#943)](https://github.com/PennyLaneAI/pennylane-lightning/pull/943)

Expand Down Expand Up @@ -122,6 +125,9 @@

### Bug fixes

* Fix build failure for Lightning-Kokkos editable installation on MacOS due to `liblightning_kokkos_catalyst.so` copy.
[(#947)](https://github.com/PennyLaneAI/pennylane-lightning/pull/947)

* Fix missing `liblightning_kokkos_catalyst.so` in Lightning-Kokkos editable installation.
[(#945)](https://github.com/PennyLaneAI/pennylane-lightning/pull/945)

Expand Down
2 changes: 1 addition & 1 deletion pennylane_lightning/core/_version.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,4 @@
Version number (major.minor.patch[-label])
"""

__version__ = "0.39.0-dev48"
__version__ = "0.39.0-dev47"
Original file line number Diff line number Diff line change
Expand Up @@ -369,6 +369,10 @@ class StateVectorLQubit : public StateVectorBase<PrecisionT, Derived> {
const std::vector<std::size_t> &wires,
bool inverse = false,
const std::vector<PrecisionT> &params = {}) {
PL_ABORT_IF_NOT(
areVecsDisjoint<std::size_t>(controlled_wires, wires),
"`controlled_wires` and `target wires` must be disjoint.");

PL_ABORT_IF_NOT(controlled_wires.size() == controlled_values.size(),
"`controlled_wires` must have the same size as "
"`controlled_values`.");
Expand Down Expand Up @@ -420,6 +424,10 @@ class StateVectorLQubit : public StateVectorBase<PrecisionT, Derived> {
const std::vector<std::size_t> &wires, bool inverse,
const std::vector<PrecisionT> &params,
const std::vector<ComplexT, Alloc> &matrix) {
PL_ABORT_IF_NOT(
areVecsDisjoint<std::size_t>(controlled_wires, wires),
"`controlled_wires` and `target wires` must be disjoint.");

PL_ABORT_IF_NOT(controlled_wires.size() == controlled_values.size(),
"`controlled_wires` must have the same size as "
"`controlled_values`.");
Expand Down Expand Up @@ -569,6 +577,9 @@ class StateVectorLQubit : public StateVectorBase<PrecisionT, Derived> {
const std::vector<bool> &controlled_values,
const std::vector<std::size_t> &wires,
bool inverse = false) {
PL_ABORT_IF_NOT(
areVecsDisjoint<std::size_t>(controlled_wires, wires),
"`controlled_wires` and `target wires` must be disjoint.");
applyControlledMatrix(matrix.data(), controlled_wires,
controlled_values, wires, inverse);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -674,6 +674,14 @@ TEMPLATE_TEST_CASE("StateVectorLQubitManaged::applyOperation non-param "
<< "controls = {" << control << "} "
<< ", wires = {" << wire << "} - "
<< PrecisionToName<PrecisionT>::value) {
if (control == wire) {
REQUIRE_THROWS_AS(
sv0.applyOperation("PauliX", std::vector<std::size_t>{control},
std::vector<bool>{true},
std::vector<std::size_t>{wire}),
LightningException);
}

if (control != wire) {
auto st0 = createRandomStateVectorData<PrecisionT>(re, num_qubits);
sv0.updateData(st0);
Expand All @@ -687,7 +695,7 @@ TEMPLATE_TEST_CASE("StateVectorLQubitManaged::applyOperation non-param "
approx(sv1.getDataVector()).margin(margin));
}

if (control != 0 && wire != 0) {
if (control != 0 && wire != 0 && control != wire) {
sv0.applyOperation("Toffoli", {0, control, wire});
sv1.applyOperation("PauliX", std::vector<std::size_t>{0, control},
std::vector<bool>{true, true},
Expand Down Expand Up @@ -760,6 +768,15 @@ TEMPLATE_TEST_CASE("StateVectorLQubitManaged::applyOperation non-param "
REQUIRE(sv0.getDataVector() ==
approx(sv1.getDataVector()).margin(margin));
}

if (control == wire) {
const auto matrix = getHadamard<std::complex, PrecisionT>();
REQUIRE_THROWS_AS(sv0.applyControlledMatrix(
matrix, std::vector<std::size_t>{control},
std::vector<bool>{true},
std::vector<std::size_t>{wire}),
LightningException);
}
}
DYNAMIC_SECTION("N-controlled S - "
<< "controls = {" << control << "} "
Expand Down
18 changes: 18 additions & 0 deletions pennylane_lightning/core/src/utils/Util.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -574,4 +574,22 @@ std::vector<T1> cast_vector(const std::vector<T0> &vec) {
return result;
}

/**
* @brief Check if two vectors are disjoint.
* @tparam T Data type.
* @param v1 First vector.
* @param v2 Second vector.
*
* @return bool True if the vectors are disjoint, false otherwise.
*/
template <typename T = std::size_t>
bool areVecsDisjoint(const std::vector<T> &v1, const std::vector<T> &v2) {
std::set<T> s0(v1.begin(), v1.end());
for (const auto &element : v2) {
if (s0.find(element) != s0.end()) {
return false;
}
}
return true;
}
} // namespace Pennylane::Util
16 changes: 16 additions & 0 deletions pennylane_lightning/core/src/utils/tests/Test_Util.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -217,3 +217,19 @@ TEMPLATE_TEST_CASE("Util::kronProd", "[Util][LinearAlgebra]", float, double) {
CHECK(vec == expected);
}
}

TEST_CASE("Util::areVecsDisjoint", "[Util][LinearAlgebra]") {
SECTION("Test for disjoint vectors") {
std::vector<std::size_t> vec0{0, 1, 2};
std::vector<std::size_t> vec1{3, 4, 5};

REQUIRE(areVecsDisjoint(vec0, vec1) == true);
}

SECTION("Test for joint vectors") {
std::vector<std::size_t> vec0{0, 1, 2};
std::vector<std::size_t> vec1{2, 4, 5};

REQUIRE(areVecsDisjoint(vec0, vec1) == false);
}
}
8 changes: 5 additions & 3 deletions setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -158,9 +158,11 @@ def build_extension(self, ext: CMakeExtension):

# Ensure that catalyst shared object is copied to the build directory for pip editable install
if backend in ("lightning_kokkos"):
source = os.path.join(f"{extdir}", f"lib{backend}_catalyst.so")
destination = os.path.join(os.getcwd(), "build")
shutil.copy(source, destination)
if platform.system() in ["Linux", "Darwin"]:
shared_lib_ext = {"Linux": ".so", "Darwin": ".dylib"}[platform.system()]
source = os.path.join(f"{extdir}", f"lib{backend}_catalyst{shared_lib_ext}")
destination = os.path.join(os.getcwd(), "build")
shutil.copy(source, destination)

with open(os.path.join("pennylane_lightning", "core", "_version.py"), encoding="utf-8") as f:
version = f.readlines()[-1].split()[-1].strip("\"'")
Expand Down

0 comments on commit a87d77b

Please sign in to comment.