mirror of
https://github.com/TheAlgorithms/Python.git
synced 2025-01-18 16:27:02 +00:00
2859d4bf3a
* Fix typos * Replace depreciated QasmSimulator in Deutsch-Jozsa algorithm * Replace depreciated QasmSimulator in half adder algorithm * Replace depreciated QasmSimulator in not gate algorithm * Replace depreciated QasmSimulator in full adder algorithm * Simplify qiskit import * Make formatting more consistent * Replace depreciated QasmSimulator in quantum entanglement algorithm * Replace depreciated QasmSimulator in ripple adder algorithm * Replace depreciated QasmSimulator in qubit measure algorithm * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * updating DIRECTORY.md * updating DIRECTORY.md * Remove qiskit import alias for clarity Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> Co-authored-by: github-actions <${GITHUB_ACTOR}@users.noreply.github.com>
59 lines
1.9 KiB
Python
59 lines
1.9 KiB
Python
#!/usr/bin/env python3
|
|
"""
|
|
Build a quantum circuit with pair or group of qubits to perform
|
|
quantum entanglement.
|
|
Quantum entanglement is a phenomenon observed at the quantum scale
|
|
where entangled particles stay connected (in some sense) so that
|
|
the actions performed on one of the particles affects the other,
|
|
no matter the distance between two particles.
|
|
"""
|
|
|
|
import qiskit
|
|
|
|
|
|
def quantum_entanglement(qubits: int = 2) -> qiskit.result.counts.Counts:
|
|
"""
|
|
# >>> quantum_entanglement(2)
|
|
# {'00': 500, '11': 500}
|
|
# ┌───┐ ┌─┐
|
|
# q_0: ┤ H ├──■──┤M├───
|
|
# └───┘┌─┴─┐└╥┘┌─┐
|
|
# q_1: ─────┤ X ├─╫─┤M├
|
|
# └───┘ ║ └╥┘
|
|
# c: 2/═══════════╩══╩═
|
|
# 0 1
|
|
Args:
|
|
qubits (int): number of quibits to use. Defaults to 2
|
|
Returns:
|
|
qiskit.result.counts.Counts: mapping of states to its counts
|
|
"""
|
|
classical_bits = qubits
|
|
|
|
# Using Aer's simulator
|
|
simulator = qiskit.Aer.get_backend("aer_simulator")
|
|
|
|
# Creating a Quantum Circuit acting on the q register
|
|
circuit = qiskit.QuantumCircuit(qubits, classical_bits)
|
|
|
|
# Adding a H gate on qubit 0 (now q0 in superposition)
|
|
circuit.h(0)
|
|
|
|
for i in range(1, qubits):
|
|
# Adding CX (CNOT) gate
|
|
circuit.cx(i - 1, i)
|
|
|
|
# Mapping the quantum measurement to the classical bits
|
|
circuit.measure(list(range(qubits)), list(range(classical_bits)))
|
|
|
|
# Now measuring any one qubit would affect other qubits to collapse
|
|
# their super position and have same state as the measured one.
|
|
|
|
# Executing the circuit on the simulator
|
|
job = qiskit.execute(circuit, simulator, shots=1000)
|
|
|
|
return job.result().get_counts(circuit)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
print(f"Total count for various states are: {quantum_entanglement(3)}")
|