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