UNPKG

qukit

Version:

[![Npm](https://badgen.net/npm/v/qukit)](https://www.npmjs.com/package/qukit) [![Crates](https://badgen.net/crates/v/qukit)](https://crates.io/crates/qukit) [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/lice

1,972 lines (1,775 loc) 63.4 kB
import { startWorkers } from './snippets/wasm-bindgen-rayon-7afa899f36665473/src/workerHelpers.js'; let wasm; const cachedTextDecoder = new TextDecoder('utf-8', { ignoreBOM: true, fatal: true }); cachedTextDecoder.decode(); let cachedUint8Memory0; function getUint8Memory0() { if (cachedUint8Memory0.buffer !== wasm.memory.buffer) { cachedUint8Memory0 = new Uint8Array(wasm.memory.buffer); } return cachedUint8Memory0; } function getStringFromWasm0(ptr, len) { return cachedTextDecoder.decode(getUint8Memory0().slice(ptr, ptr + len)); } const heap = new Array(32).fill(undefined); heap.push(undefined, null, true, false); let heap_next = heap.length; function addHeapObject(obj) { if (heap_next === heap.length) heap.push(heap.length + 1); const idx = heap_next; heap_next = heap[idx]; heap[idx] = obj; return idx; } function getObject(idx) { return heap[idx]; } function dropObject(idx) { if (idx < 36) return; heap[idx] = heap_next; heap_next = idx; } function takeObject(idx) { const ret = getObject(idx); dropObject(idx); return ret; } function debugString(val) { // primitive types const type = typeof val; if (type == 'number' || type == 'boolean' || val == null) { return `${val}`; } if (type == 'string') { return `"${val}"`; } if (type == 'symbol') { const description = val.description; if (description == null) { return 'Symbol'; } else { return `Symbol(${description})`; } } if (type == 'function') { const name = val.name; if (typeof name == 'string' && name.length > 0) { return `Function(${name})`; } else { return 'Function'; } } // objects if (Array.isArray(val)) { const length = val.length; let debug = '['; if (length > 0) { debug += debugString(val[0]); } for(let i = 1; i < length; i++) { debug += ', ' + debugString(val[i]); } debug += ']'; return debug; } // Test for built-in const builtInMatches = /\[object ([^\]]+)\]/.exec(toString.call(val)); let className; if (builtInMatches.length > 1) { className = builtInMatches[1]; } else { // Failed to match the standard '[object ClassName]' return toString.call(val); } if (className == 'Object') { // we're a user defined class or Object // JSON.stringify avoids problems with cycles, and is generally much // easier than looping through ownProperties of `val`. try { return 'Object(' + JSON.stringify(val) + ')'; } catch (_) { return 'Object'; } } // errors if (val instanceof Error) { return `${val.name}: ${val.message}\n${val.stack}`; } // TODO we could test for more things here, like `Set`s and `Map`s. return className; } let WASM_VECTOR_LEN = 0; const cachedTextEncoder = new TextEncoder('utf-8'); const encodeString = function (arg, view) { const buf = cachedTextEncoder.encode(arg); view.set(buf); return { read: arg.length, written: buf.length }; }; function passStringToWasm0(arg, malloc, realloc) { if (realloc === undefined) { const buf = cachedTextEncoder.encode(arg); const ptr = malloc(buf.length); getUint8Memory0().subarray(ptr, ptr + buf.length).set(buf); WASM_VECTOR_LEN = buf.length; return ptr; } let len = arg.length; let ptr = malloc(len); const mem = getUint8Memory0(); let offset = 0; for (; offset < len; offset++) { const code = arg.charCodeAt(offset); if (code > 0x7F) break; mem[ptr + offset] = code; } if (offset !== len) { if (offset !== 0) { arg = arg.slice(offset); } ptr = realloc(ptr, len, len = offset + arg.length * 3); const view = getUint8Memory0().subarray(ptr + offset, ptr + len); const ret = encodeString(arg, view); offset += ret.written; } WASM_VECTOR_LEN = offset; return ptr; } let cachedInt32Memory0; function getInt32Memory0() { if (cachedInt32Memory0.buffer !== wasm.memory.buffer) { cachedInt32Memory0 = new Int32Array(wasm.memory.buffer); } return cachedInt32Memory0; } let cachedUint32Memory0; function getUint32Memory0() { if (cachedUint32Memory0.buffer !== wasm.memory.buffer) { cachedUint32Memory0 = new Uint32Array(wasm.memory.buffer); } return cachedUint32Memory0; } function getArrayJsValueFromWasm0(ptr, len) { const mem = getUint32Memory0(); const slice = mem.subarray(ptr / 4, ptr / 4 + len); const result = []; for (let i = 0; i < slice.length; i++) { result.push(takeObject(slice[i])); } return result; } function _assertClass(instance, klass) { if (!(instance instanceof klass)) { throw new Error(`expected instance of ${klass.name}`); } return instance.ptr; } /** * @param {QBit} qbit */ export function hadamard(qbit) { _assertClass(qbit, QBit); wasm.hadamard(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_hadamard(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_hadamard(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_hadamard(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_hadamard(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit */ export function hadamard_same_step(qbit) { _assertClass(qbit, QBit); wasm.hadamard_same_step(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_hadamard_same_step(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_hadamard_same_step(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_hadamard_same_step(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_hadamard_same_step(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function hadamard_same_step_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.hadamard_same_step_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function hadamard_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.hadamard_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit */ export function pauli_x(qbit) { _assertClass(qbit, QBit); wasm.pauli_x(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_pauli_x(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_pauli_x(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_pauli_x(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_pauli_x(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit */ export function pauli_x_same_step(qbit) { _assertClass(qbit, QBit); wasm.pauli_x_same_step(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_pauli_x_same_step(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_pauli_x_same_step(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_pauli_x_same_step(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_pauli_x_same_step(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function pauli_x_same_step_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.pauli_x_same_step_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function pauli_x_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.pauli_x_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit */ export function pauli_y(qbit) { _assertClass(qbit, QBit); wasm.pauli_y(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_pauli_y(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_pauli_y(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_pauli_y(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_pauli_y(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit */ export function pauli_y_same_step(qbit) { _assertClass(qbit, QBit); wasm.pauli_y_same_step(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_pauli_y_same_step(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_pauli_y_same_step(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_pauli_y_same_step(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_pauli_y_same_step(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function pauli_y_same_step_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.pauli_y_same_step_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function pauli_y_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.pauli_y_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit */ export function pauli_z(qbit) { _assertClass(qbit, QBit); wasm.pauli_z(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_pauli_z(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_pauli_z(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_pauli_z(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_pauli_z(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit */ export function pauli_z_same_step(qbit) { _assertClass(qbit, QBit); wasm.pauli_z_same_step(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_pauli_z_same_step(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_pauli_z_same_step(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_pauli_z_same_step(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_pauli_z_same_step(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function pauli_z_same_step_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.pauli_z_same_step_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function pauli_z_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.pauli_z_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit */ export function phase(qbit) { _assertClass(qbit, QBit); wasm.phase(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_phase(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_phase(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_phase(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_phase(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit */ export function phase_same_step(qbit) { _assertClass(qbit, QBit); wasm.phase_same_step(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_phase_same_step(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_phase_same_step(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_phase_same_step(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_phase_same_step(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function phase_same_step_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.phase_same_step_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function phase_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.phase_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit */ export function phase_dagger(qbit) { _assertClass(qbit, QBit); wasm.phase_dagger(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_phase_dagger(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_phase_dagger(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_phase_dagger(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_phase_dagger(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit */ export function phase_dagger_same_step(qbit) { _assertClass(qbit, QBit); wasm.phase_dagger_same_step(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_phase_dagger_same_step(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_phase_dagger_same_step(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_phase_dagger_same_step(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_phase_dagger_same_step(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function phase_dagger_same_step_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.phase_dagger_same_step_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function phase_dagger_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.phase_dagger_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit */ export function phase_root(qbit) { _assertClass(qbit, QBit); wasm.phase_root(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_phase_root(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_phase_root(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_phase_root(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_phase_root(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit */ export function phase_root_same_step(qbit) { _assertClass(qbit, QBit); wasm.phase_root_same_step(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_phase_root_same_step(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_phase_root_same_step(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_phase_root_same_step(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_phase_root_same_step(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function phase_root_same_step_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.phase_root_same_step_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function phase_root_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.phase_root_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit */ export function phase_root_dagger(qbit) { _assertClass(qbit, QBit); wasm.phase_root_dagger(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_phase_root_dagger(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_phase_root_dagger(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_phase_root_dagger(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_phase_root_dagger(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit */ export function phase_root_dagger_same_step(qbit) { _assertClass(qbit, QBit); wasm.phase_root_dagger_same_step(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_phase_root_dagger_same_step(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_phase_root_dagger_same_step(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_phase_root_dagger_same_step(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_phase_root_dagger_same_step(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function phase_root_dagger_same_step_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.phase_root_dagger_same_step_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function phase_root_dagger_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.phase_root_dagger_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit */ export function pauli_x_root(qbit) { _assertClass(qbit, QBit); wasm.pauli_x_root(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_pauli_x_root(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_pauli_x_root(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_pauli_x_root(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_pauli_x_root(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit */ export function pauli_x_root_same_step(qbit) { _assertClass(qbit, QBit); wasm.pauli_x_root_same_step(qbit.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_pauli_x_root_same_step(c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_pauli_x_root_same_step(c_qbit.ptr, t_qbit.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_pauli_x_root_same_step(c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_pauli_x_root_same_step(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function pauli_x_root_same_step_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.pauli_x_root_same_step_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function pauli_x_root_classically_controlled(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.pauli_x_root_classically_controlled(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit_0 * @param {QBit} qbit_1 */ export function swap(qbit_0, qbit_1) { _assertClass(qbit_0, QBit); _assertClass(qbit_1, QBit); wasm.swap(qbit_0.ptr, qbit_1.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit_0 * @param {QBit} t_qbit_1 */ export function controlled_swap(c_qbit, t_qbit_0, t_qbit_1) { _assertClass(c_qbit, QBit); _assertClass(t_qbit_0, QBit); _assertClass(t_qbit_1, QBit); wasm.controlled_swap(c_qbit.ptr, t_qbit_0.ptr, t_qbit_1.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit_0 * @param {QBit} t_qbit_1 */ export function controlled_controlled_swap(c_qbit_0, c_qbit_1, t_qbit_0, t_qbit_1) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit_0, QBit); _assertClass(t_qbit_1, QBit); wasm.controlled_controlled_swap(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit_0.ptr, t_qbit_1.ptr); } /** * @param {QBit} qbit_0 * @param {QBit} qbit_1 */ export function swap_same_step(qbit_0, qbit_1) { _assertClass(qbit_0, QBit); _assertClass(qbit_1, QBit); wasm.swap_same_step(qbit_0.ptr, qbit_1.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit_0 * @param {QBit} t_qbit_1 */ export function controlled_swap_same_step(c_qbit, t_qbit_0, t_qbit_1) { _assertClass(c_qbit, QBit); _assertClass(t_qbit_0, QBit); _assertClass(t_qbit_1, QBit); wasm.controlled_swap_same_step(c_qbit.ptr, t_qbit_0.ptr, t_qbit_1.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit_0 * @param {QBit} t_qbit_1 */ export function controlled_controlled_swap_same_step(c_qbit_0, c_qbit_1, t_qbit_0, t_qbit_1) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit_0, QBit); _assertClass(t_qbit_1, QBit); wasm.controlled_controlled_swap_same_step(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit_0.ptr, t_qbit_1.ptr); } /** * @param {QBit} qbit_0 * @param {QBit} qbit_1 * @param {Bit} bit */ export function swap_same_step_classically_controlled(qbit_0, qbit_1, bit) { _assertClass(qbit_0, QBit); _assertClass(qbit_1, QBit); _assertClass(bit, Bit); wasm.swap_same_step_classically_controlled(qbit_0.ptr, qbit_1.ptr, bit.ptr); } /** * @param {QBit} qbit_0 * @param {QBit} qbit_1 * @param {Bit} bit */ export function swap_classically_controlled(qbit_0, qbit_1, bit) { _assertClass(qbit_0, QBit); _assertClass(qbit_1, QBit); _assertClass(bit, Bit); wasm.swap_classically_controlled(qbit_0.ptr, qbit_1.ptr, bit.ptr); } /** * @param {QBit} qbit_0 * @param {QBit} qbit_1 */ export function swap_root(qbit_0, qbit_1) { _assertClass(qbit_0, QBit); _assertClass(qbit_1, QBit); wasm.swap_root(qbit_0.ptr, qbit_1.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit_0 * @param {QBit} t_qbit_1 */ export function controlled_swap_root(c_qbit, t_qbit_0, t_qbit_1) { _assertClass(c_qbit, QBit); _assertClass(t_qbit_0, QBit); _assertClass(t_qbit_1, QBit); wasm.controlled_swap_root(c_qbit.ptr, t_qbit_0.ptr, t_qbit_1.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit_0 * @param {QBit} t_qbit_1 */ export function controlled_controlled_swap_root(c_qbit_0, c_qbit_1, t_qbit_0, t_qbit_1) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit_0, QBit); _assertClass(t_qbit_1, QBit); wasm.controlled_controlled_swap_root(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit_0.ptr, t_qbit_1.ptr); } /** * @param {QBit} qbit_0 * @param {QBit} qbit_1 */ export function swap_root_same_step(qbit_0, qbit_1) { _assertClass(qbit_0, QBit); _assertClass(qbit_1, QBit); wasm.swap_root_same_step(qbit_0.ptr, qbit_1.ptr); } /** * @param {QBit} c_qbit * @param {QBit} t_qbit_0 * @param {QBit} t_qbit_1 */ export function controlled_swap_root_same_step(c_qbit, t_qbit_0, t_qbit_1) { _assertClass(c_qbit, QBit); _assertClass(t_qbit_0, QBit); _assertClass(t_qbit_1, QBit); wasm.controlled_swap_root_same_step(c_qbit.ptr, t_qbit_0.ptr, t_qbit_1.ptr); } /** * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit_0 * @param {QBit} t_qbit_1 */ export function controlled_controlled_swap_root_same_step(c_qbit_0, c_qbit_1, t_qbit_0, t_qbit_1) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit_0, QBit); _assertClass(t_qbit_1, QBit); wasm.controlled_controlled_swap_root_same_step(c_qbit_0.ptr, c_qbit_1.ptr, t_qbit_0.ptr, t_qbit_1.ptr); } /** * @param {QBit} qbit_0 * @param {QBit} qbit_1 * @param {Bit} bit */ export function swap_root_same_step_classically_controlled(qbit_0, qbit_1, bit) { _assertClass(qbit_0, QBit); _assertClass(qbit_1, QBit); _assertClass(bit, Bit); wasm.swap_root_same_step_classically_controlled(qbit_0.ptr, qbit_1.ptr, bit.ptr); } /** * @param {QBit} qbit_0 * @param {QBit} qbit_1 * @param {Bit} bit */ export function swap_root_classically_controlled(qbit_0, qbit_1, bit) { _assertClass(qbit_0, QBit); _assertClass(qbit_1, QBit); _assertClass(bit, Bit); wasm.swap_root_classically_controlled(qbit_0.ptr, qbit_1.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit */ export function rotation_hadamard(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_hadamard(theta, qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_rotation_hadamard(theta, c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_rotation_hadamard(theta, c_qbit.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_rotation_hadamard(theta, c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_rotation_hadamard(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} qbit */ export function rotation_hadamard_same_step(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_hadamard_same_step(theta, qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_rotation_hadamard_same_step(theta, c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_rotation_hadamard_same_step(theta, c_qbit.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_rotation_hadamard_same_step(theta, c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_rotation_hadamard_same_step(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} qbit * @param {Bit} bit */ export function rotation_hadamard_same_step_classically_controlled(theta, qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.rotation_hadamard_same_step_classically_controlled(theta, qbit.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit * @param {Bit} bit */ export function rotation_hadamard_classically_controlled(theta, qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.rotation_hadamard_classically_controlled(theta, qbit.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit */ export function rotation_pauli_x(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_pauli_x(theta, qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_rotation_pauli_x(theta, c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_rotation_pauli_x(theta, c_qbit.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_rotation_pauli_x(theta, c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_rotation_pauli_x(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} qbit */ export function rotation_pauli_x_same_step(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_pauli_x_same_step(theta, qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_rotation_pauli_x_same_step(theta, c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_rotation_pauli_x_same_step(theta, c_qbit.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_rotation_pauli_x_same_step(theta, c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_rotation_pauli_x_same_step(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} qbit * @param {Bit} bit */ export function rotation_pauli_x_same_step_classically_controlled(theta, qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.rotation_pauli_x_same_step_classically_controlled(theta, qbit.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit * @param {Bit} bit */ export function rotation_pauli_x_classically_controlled(theta, qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.rotation_pauli_x_classically_controlled(theta, qbit.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit */ export function rotation_pauli_y(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_pauli_y(theta, qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_rotation_pauli_y(theta, c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_rotation_pauli_y(theta, c_qbit.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_rotation_pauli_y(theta, c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_rotation_pauli_y(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} qbit */ export function rotation_pauli_y_same_step(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_pauli_y_same_step(theta, qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_rotation_pauli_y_same_step(theta, c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_rotation_pauli_y_same_step(theta, c_qbit.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_rotation_pauli_y_same_step(theta, c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_rotation_pauli_y_same_step(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} qbit * @param {Bit} bit */ export function rotation_pauli_y_same_step_classically_controlled(theta, qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.rotation_pauli_y_same_step_classically_controlled(theta, qbit.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit * @param {Bit} bit */ export function rotation_pauli_y_classically_controlled(theta, qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.rotation_pauli_y_classically_controlled(theta, qbit.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit */ export function rotation_pauli_z(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_pauli_z(theta, qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_rotation_pauli_z(theta, c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_rotation_pauli_z(theta, c_qbit.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_rotation_pauli_z(theta, c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_rotation_pauli_z(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} qbit */ export function rotation_pauli_z_same_step(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_pauli_z_same_step(theta, qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_rotation_pauli_z_same_step(theta, c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_rotation_pauli_z_same_step(theta, c_qbit.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_rotation_pauli_z_same_step(theta, c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_rotation_pauli_z_same_step(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} qbit * @param {Bit} bit */ export function rotation_pauli_z_same_step_classically_controlled(theta, qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.rotation_pauli_z_same_step_classically_controlled(theta, qbit.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit * @param {Bit} bit */ export function rotation_pauli_z_classically_controlled(theta, qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.rotation_pauli_z_classically_controlled(theta, qbit.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit */ export function rotation_x(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_x(theta, qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_rotation_x(theta, c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_rotation_x(theta, c_qbit.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_rotation_x(theta, c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_rotation_x(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} qbit */ export function rotation_x_same_step(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_x_same_step(theta, qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_rotation_x_same_step(theta, c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_rotation_x_same_step(theta, c_qbit.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_rotation_x_same_step(theta, c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_rotation_x_same_step(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} qbit * @param {Bit} bit */ export function rotation_x_same_step_classically_controlled(theta, qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.rotation_x_same_step_classically_controlled(theta, qbit.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit * @param {Bit} bit */ export function rotation_x_classically_controlled(theta, qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.rotation_x_classically_controlled(theta, qbit.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit */ export function rotation_y(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_y(theta, qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_rotation_y(theta, c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_rotation_y(theta, c_qbit.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_rotation_y(theta, c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_rotation_y(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} qbit */ export function rotation_y_same_step(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_y_same_step(theta, qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_rotation_y_same_step(theta, c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_rotation_y_same_step(theta, c_qbit.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_rotation_y_same_step(theta, c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_rotation_y_same_step(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} qbit * @param {Bit} bit */ export function rotation_y_same_step_classically_controlled(theta, qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.rotation_y_same_step_classically_controlled(theta, qbit.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit * @param {Bit} bit */ export function rotation_y_classically_controlled(theta, qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.rotation_y_classically_controlled(theta, qbit.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit */ export function rotation_z(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_z(theta, qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_rotation_z(theta, c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_rotation_z(theta, c_qbit.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_rotation_z(theta, c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_rotation_z(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} qbit */ export function rotation_z_same_step(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_z_same_step(theta, qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ export function controlled_rotation_z_same_step(theta, c_qbit, t_qbit) { _assertClass(c_qbit, QBit); _assertClass(t_qbit, QBit); wasm.controlled_rotation_z_same_step(theta, c_qbit.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit */ export function controlled_controlled_rotation_z_same_step(theta, c_qbit_0, c_qbit_1, t_qbit) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit, QBit); wasm.controlled_controlled_rotation_z_same_step(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit.ptr); } /** * @param {number} theta * @param {QBit} qbit * @param {Bit} bit */ export function rotation_z_same_step_classically_controlled(theta, qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.rotation_z_same_step_classically_controlled(theta, qbit.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit * @param {Bit} bit */ export function rotation_z_classically_controlled(theta, qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.rotation_z_classically_controlled(theta, qbit.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit_0 * @param {QBit} qbit_1 */ export function rotation_swap(theta, qbit_0, qbit_1) { _assertClass(qbit_0, QBit); _assertClass(qbit_1, QBit); wasm.rotation_swap(theta, qbit_0.ptr, qbit_1.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit_0 * @param {QBit} t_qbit_1 */ export function controlled_rotation_swap(theta, c_qbit, t_qbit_0, t_qbit_1) { _assertClass(c_qbit, QBit); _assertClass(t_qbit_0, QBit); _assertClass(t_qbit_1, QBit); wasm.controlled_rotation_swap(theta, c_qbit.ptr, t_qbit_0.ptr, t_qbit_1.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit_0 * @param {QBit} t_qbit_1 */ export function controlled_controlled_rotation_swap(theta, c_qbit_0, c_qbit_1, t_qbit_0, t_qbit_1) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit_0, QBit); _assertClass(t_qbit_1, QBit); wasm.controlled_controlled_rotation_swap(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit_0.ptr, t_qbit_1.ptr); } /** * @param {number} theta * @param {QBit} qbit_0 * @param {QBit} qbit_1 */ export function rotation_swap_same_step(theta, qbit_0, qbit_1) { _assertClass(qbit_0, QBit); _assertClass(qbit_1, QBit); wasm.rotation_swap_same_step(theta, qbit_0.ptr, qbit_1.ptr); } /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit_0 * @param {QBit} t_qbit_1 */ export function controlled_rotation_swap_same_step(theta, c_qbit, t_qbit_0, t_qbit_1) { _assertClass(c_qbit, QBit); _assertClass(t_qbit_0, QBit); _assertClass(t_qbit_1, QBit); wasm.controlled_rotation_swap_same_step(theta, c_qbit.ptr, t_qbit_0.ptr, t_qbit_1.ptr); } /** * @param {number} theta * @param {QBit} c_qbit_0 * @param {QBit} c_qbit_1 * @param {QBit} t_qbit_0 * @param {QBit} t_qbit_1 */ export function controlled_controlled_rotation_swap_same_step(theta, c_qbit_0, c_qbit_1, t_qbit_0, t_qbit_1) { _assertClass(c_qbit_0, QBit); _assertClass(c_qbit_1, QBit); _assertClass(t_qbit_0, QBit); _assertClass(t_qbit_1, QBit); wasm.controlled_controlled_rotation_swap_same_step(theta, c_qbit_0.ptr, c_qbit_1.ptr, t_qbit_0.ptr, t_qbit_1.ptr); } /** * @param {number} theta * @param {QBit} qbit_0 * @param {QBit} qbit_1 * @param {Bit} bit */ export function rotation_swap_same_step_classically_controlled(theta, qbit_0, qbit_1, bit) { _assertClass(qbit_0, QBit); _assertClass(qbit_1, QBit); _assertClass(bit, Bit); wasm.rotation_swap_same_step_classically_controlled(theta, qbit_0.ptr, qbit_1.ptr, bit.ptr); } /** * @param {number} theta * @param {QBit} qbit_0 * @param {QBit} qbit_1 * @param {Bit} bit */ export function rotation_swap_classically_controlled(theta, qbit_0, qbit_1, bit) { _assertClass(qbit_0, QBit); _assertClass(qbit_1, QBit); _assertClass(bit, Bit); wasm.rotation_swap_classically_controlled(theta, qbit_0.ptr, qbit_1.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function measurement_x(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.measurement_x(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function measurement_y(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.measurement_y(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function measurement_z(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.measurement_z(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function measurement_x_same_step(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.measurement_x_same_step(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function measurement_y_same_step(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.measurement_y_same_step(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit * @param {Bit} bit */ export function measurement_z_same_step(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.measurement_z_same_step(qbit.ptr, bit.ptr); } /** * @param {QBit} qbit */ export function reset(qbit) { _assertClass(qbit, QBit); wasm.reset(qbit.ptr); } /** * @param {QBit} qbit */ export function reset_same_step(qbit) { _assertClass(qbit, QBit); wasm.reset_same_step(qbit.ptr); } function notDefined(what) { return () => { throw new Error(`${what} is not defined`); }; } /** * @param {number} num_threads * @returns {Promise<any>} */ export function initThreadPool(num_threads) { const ret = wasm.initThreadPool(num_threads); return takeObject(ret); } /** * @param {number} receiver */ export function wbg_rayon_start_worker(receiver) { wasm.wbg_rayon_start_worker(receiver); } /** */ export class Algorithm { static __wrap(ptr) { const obj = Object.create(Algorithm.prototype); obj.ptr = ptr; return obj; } __destroy_into_raw() { const ptr = this.ptr; this.ptr = 0; return ptr; } free() { const ptr = this.__destroy_into_raw(); wasm.__wbg_algorithm_free(ptr); } /** * @returns {AlgorithmResult} */ run() { const ptr = this.__destroy_into_raw(); const ret = wasm.algorithm_run(ptr); return AlgorithmResult.__wrap(ret); } /** * @returns {AlgorithmResult | undefined} */ step() { const ret = wasm.algorithm_step(this.ptr); return ret === 0 ? undefined : AlgorithmResult.__wrap(ret); } /** * @param {number} steps * @returns {Algorithm} */ intoStepper(steps) { const ptr = this.__destroy_into_raw(); const ret = wasm.algorithm_intoStepper(ptr, steps); return Algorithm.__wrap(ret); } } /** */ export class Algo