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,889 lines (1,703 loc) 61.7 kB
let imports = {}; imports['__wbindgen_placeholder__'] = module.exports; let wasm; const { TextDecoder, TextEncoder } = require(`util`); let cachedTextDecoder = new TextDecoder('utf-8', { ignoreBOM: true, fatal: true }); cachedTextDecoder.decode(); let cachedUint8Memory0; function getUint8Memory0() { if (cachedUint8Memory0.byteLength === 0) { cachedUint8Memory0 = new Uint8Array(wasm.memory.buffer); } return cachedUint8Memory0; } function getStringFromWasm0(ptr, len) { return cachedTextDecoder.decode(getUint8Memory0().subarray(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; let cachedTextEncoder = new TextEncoder('utf-8'); const encodeString = (typeof cachedTextEncoder.encodeInto === 'function' ? function (arg, view) { return cachedTextEncoder.encodeInto(arg, view); } : 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.byteLength === 0) { cachedInt32Memory0 = new Int32Array(wasm.memory.buffer); } return cachedInt32Memory0; } let cachedUint32Memory0; function getUint32Memory0() { if (cachedUint32Memory0.byteLength === 0) { 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 */ module.exports.hadamard = function(qbit) { _assertClass(qbit, QBit); wasm.hadamard(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_hadamard = function(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 */ module.exports.controlled_controlled_hadamard = function(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 */ module.exports.hadamard_same_step = function(qbit) { _assertClass(qbit, QBit); wasm.hadamard_same_step(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_hadamard_same_step = function(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 */ module.exports.controlled_controlled_hadamard_same_step = function(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 */ module.exports.hadamard_same_step_classically_controlled = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.hadamard_same_step_classically_controlled(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit * @param {Bit} bit */ module.exports.hadamard_classically_controlled = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.hadamard_classically_controlled(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit */ module.exports.pauli_x = function(qbit) { _assertClass(qbit, QBit); wasm.pauli_x(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_pauli_x = function(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 */ module.exports.controlled_controlled_pauli_x = function(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 */ module.exports.pauli_x_same_step = function(qbit) { _assertClass(qbit, QBit); wasm.pauli_x_same_step(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_pauli_x_same_step = function(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 */ module.exports.controlled_controlled_pauli_x_same_step = function(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 */ module.exports.pauli_x_same_step_classically_controlled = function(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 */ module.exports.pauli_x_classically_controlled = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.pauli_x_classically_controlled(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit */ module.exports.pauli_y = function(qbit) { _assertClass(qbit, QBit); wasm.pauli_y(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_pauli_y = function(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 */ module.exports.controlled_controlled_pauli_y = function(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 */ module.exports.pauli_y_same_step = function(qbit) { _assertClass(qbit, QBit); wasm.pauli_y_same_step(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_pauli_y_same_step = function(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 */ module.exports.controlled_controlled_pauli_y_same_step = function(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 */ module.exports.pauli_y_same_step_classically_controlled = function(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 */ module.exports.pauli_y_classically_controlled = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.pauli_y_classically_controlled(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit */ module.exports.pauli_z = function(qbit) { _assertClass(qbit, QBit); wasm.pauli_z(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_pauli_z = function(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 */ module.exports.controlled_controlled_pauli_z = function(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 */ module.exports.pauli_z_same_step = function(qbit) { _assertClass(qbit, QBit); wasm.pauli_z_same_step(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_pauli_z_same_step = function(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 */ module.exports.controlled_controlled_pauli_z_same_step = function(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 */ module.exports.pauli_z_same_step_classically_controlled = function(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 */ module.exports.pauli_z_classically_controlled = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.pauli_z_classically_controlled(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit */ module.exports.phase = function(qbit) { _assertClass(qbit, QBit); wasm.phase(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_phase = function(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 */ module.exports.controlled_controlled_phase = function(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 */ module.exports.phase_same_step = function(qbit) { _assertClass(qbit, QBit); wasm.phase_same_step(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_phase_same_step = function(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 */ module.exports.controlled_controlled_phase_same_step = function(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 */ module.exports.phase_same_step_classically_controlled = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.phase_same_step_classically_controlled(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit * @param {Bit} bit */ module.exports.phase_classically_controlled = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.phase_classically_controlled(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit */ module.exports.phase_dagger = function(qbit) { _assertClass(qbit, QBit); wasm.phase_dagger(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_phase_dagger = function(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 */ module.exports.controlled_controlled_phase_dagger = function(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 */ module.exports.phase_dagger_same_step = function(qbit) { _assertClass(qbit, QBit); wasm.phase_dagger_same_step(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_phase_dagger_same_step = function(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 */ module.exports.controlled_controlled_phase_dagger_same_step = function(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 */ module.exports.phase_dagger_same_step_classically_controlled = function(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 */ module.exports.phase_dagger_classically_controlled = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.phase_dagger_classically_controlled(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit */ module.exports.phase_root = function(qbit) { _assertClass(qbit, QBit); wasm.phase_root(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_phase_root = function(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 */ module.exports.controlled_controlled_phase_root = function(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 */ module.exports.phase_root_same_step = function(qbit) { _assertClass(qbit, QBit); wasm.phase_root_same_step(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_phase_root_same_step = function(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 */ module.exports.controlled_controlled_phase_root_same_step = function(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 */ module.exports.phase_root_same_step_classically_controlled = function(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 */ module.exports.phase_root_classically_controlled = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.phase_root_classically_controlled(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit */ module.exports.phase_root_dagger = function(qbit) { _assertClass(qbit, QBit); wasm.phase_root_dagger(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_phase_root_dagger = function(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 */ module.exports.controlled_controlled_phase_root_dagger = function(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 */ module.exports.phase_root_dagger_same_step = function(qbit) { _assertClass(qbit, QBit); wasm.phase_root_dagger_same_step(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_phase_root_dagger_same_step = function(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 */ module.exports.controlled_controlled_phase_root_dagger_same_step = function(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 */ module.exports.phase_root_dagger_same_step_classically_controlled = function(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 */ module.exports.phase_root_dagger_classically_controlled = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.phase_root_dagger_classically_controlled(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit */ module.exports.pauli_x_root = function(qbit) { _assertClass(qbit, QBit); wasm.pauli_x_root(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_pauli_x_root = function(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 */ module.exports.controlled_controlled_pauli_x_root = function(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 */ module.exports.pauli_x_root_same_step = function(qbit) { _assertClass(qbit, QBit); wasm.pauli_x_root_same_step(qbit.ptr); }; /** * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_pauli_x_root_same_step = function(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 */ module.exports.controlled_controlled_pauli_x_root_same_step = function(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 */ module.exports.pauli_x_root_same_step_classically_controlled = function(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 */ module.exports.pauli_x_root_classically_controlled = function(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 */ module.exports.swap = function(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 */ module.exports.controlled_swap = function(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 */ module.exports.controlled_controlled_swap = function(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 */ module.exports.swap_same_step = function(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 */ module.exports.controlled_swap_same_step = function(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 */ module.exports.controlled_controlled_swap_same_step = function(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 */ module.exports.swap_same_step_classically_controlled = function(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 */ module.exports.swap_classically_controlled = function(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 */ module.exports.swap_root = function(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 */ module.exports.controlled_swap_root = function(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 */ module.exports.controlled_controlled_swap_root = function(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 */ module.exports.swap_root_same_step = function(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 */ module.exports.controlled_swap_root_same_step = function(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 */ module.exports.controlled_controlled_swap_root_same_step = function(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 */ module.exports.swap_root_same_step_classically_controlled = function(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 */ module.exports.swap_root_classically_controlled = function(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 */ module.exports.rotation_hadamard = function(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_hadamard(theta, qbit.ptr); }; /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_rotation_hadamard = function(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 */ module.exports.controlled_controlled_rotation_hadamard = function(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 */ module.exports.rotation_hadamard_same_step = function(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_hadamard_same_step(theta, qbit.ptr); }; /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_rotation_hadamard_same_step = function(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 */ module.exports.controlled_controlled_rotation_hadamard_same_step = function(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 */ module.exports.rotation_hadamard_same_step_classically_controlled = function(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 */ module.exports.rotation_hadamard_classically_controlled = function(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 */ module.exports.rotation_pauli_x = function(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_pauli_x(theta, qbit.ptr); }; /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_rotation_pauli_x = function(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 */ module.exports.controlled_controlled_rotation_pauli_x = function(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 */ module.exports.rotation_pauli_x_same_step = function(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 */ module.exports.controlled_rotation_pauli_x_same_step = function(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 */ module.exports.controlled_controlled_rotation_pauli_x_same_step = function(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 */ module.exports.rotation_pauli_x_same_step_classically_controlled = function(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 */ module.exports.rotation_pauli_x_classically_controlled = function(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 */ module.exports.rotation_pauli_y = function(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_pauli_y(theta, qbit.ptr); }; /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_rotation_pauli_y = function(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 */ module.exports.controlled_controlled_rotation_pauli_y = function(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 */ module.exports.rotation_pauli_y_same_step = function(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 */ module.exports.controlled_rotation_pauli_y_same_step = function(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 */ module.exports.controlled_controlled_rotation_pauli_y_same_step = function(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 */ module.exports.rotation_pauli_y_same_step_classically_controlled = function(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 */ module.exports.rotation_pauli_y_classically_controlled = function(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 */ module.exports.rotation_pauli_z = function(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_pauli_z(theta, qbit.ptr); }; /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_rotation_pauli_z = function(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 */ module.exports.controlled_controlled_rotation_pauli_z = function(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 */ module.exports.rotation_pauli_z_same_step = function(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 */ module.exports.controlled_rotation_pauli_z_same_step = function(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 */ module.exports.controlled_controlled_rotation_pauli_z_same_step = function(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 */ module.exports.rotation_pauli_z_same_step_classically_controlled = function(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 */ module.exports.rotation_pauli_z_classically_controlled = function(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 */ module.exports.rotation_x = function(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_x(theta, qbit.ptr); }; /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_rotation_x = function(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 */ module.exports.controlled_controlled_rotation_x = function(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 */ module.exports.rotation_x_same_step = function(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_x_same_step(theta, qbit.ptr); }; /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_rotation_x_same_step = function(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 */ module.exports.controlled_controlled_rotation_x_same_step = function(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 */ module.exports.rotation_x_same_step_classically_controlled = function(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 */ module.exports.rotation_x_classically_controlled = function(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 */ module.exports.rotation_y = function(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_y(theta, qbit.ptr); }; /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_rotation_y = function(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 */ module.exports.controlled_controlled_rotation_y = function(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 */ module.exports.rotation_y_same_step = function(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_y_same_step(theta, qbit.ptr); }; /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_rotation_y_same_step = function(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 */ module.exports.controlled_controlled_rotation_y_same_step = function(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 */ module.exports.rotation_y_same_step_classically_controlled = function(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 */ module.exports.rotation_y_classically_controlled = function(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 */ module.exports.rotation_z = function(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_z(theta, qbit.ptr); }; /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_rotation_z = function(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 */ module.exports.controlled_controlled_rotation_z = function(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 */ module.exports.rotation_z_same_step = function(theta, qbit) { _assertClass(qbit, QBit); wasm.rotation_z_same_step(theta, qbit.ptr); }; /** * @param {number} theta * @param {QBit} c_qbit * @param {QBit} t_qbit */ module.exports.controlled_rotation_z_same_step = function(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 */ module.exports.controlled_controlled_rotation_z_same_step = function(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 */ module.exports.rotation_z_same_step_classically_controlled = function(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 */ module.exports.rotation_z_classically_controlled = function(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 */ module.exports.rotation_swap = function(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 */ module.exports.controlled_rotation_swap = function(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 */ module.exports.controlled_controlled_rotation_swap = function(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 */ module.exports.rotation_swap_same_step = function(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 */ module.exports.controlled_rotation_swap_same_step = function(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 */ module.exports.controlled_controlled_rotation_swap_same_step = function(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 */ module.exports.rotation_swap_same_step_classically_controlled = function(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 */ module.exports.rotation_swap_classically_controlled = function(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 */ module.exports.measurement_x = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.measurement_x(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit * @param {Bit} bit */ module.exports.measurement_y = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.measurement_y(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit * @param {Bit} bit */ module.exports.measurement_z = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.measurement_z(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit * @param {Bit} bit */ module.exports.measurement_x_same_step = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.measurement_x_same_step(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit * @param {Bit} bit */ module.exports.measurement_y_same_step = function(qbit, bit) { _assertClass(qbit, QBit); _assertClass(bit, Bit); wasm.measurement_y_same_step(qbit.ptr, bit.ptr); }; /** * @param {QBit} qbit * @param {Bit} bit */ module.exports.measurement_z_