qukit
Version:
[](https://www.npmjs.com/package/qukit) [](https://crates.io/crates/qukit) [](https://opensource.org/lice
1,972 lines (1,775 loc) • 63.4 kB
JavaScript
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