Skip to content

Language Operations#

Opcodes#

Code Operation Comment
1 \(LT(left: Value[SInt], right: Value[SInt])\)$
2 \(LE(left: Value[SInt], right: Value[SInt])\)
3 \(GT(left: Value[SInt], right: Value[SInt])\)
4 \(GE(left: Value[SInt], right: Value[SInt])\)
5 \(EQ\)[\(T1 <: SType, T2 <: SType\)]\((left: Value[T1], right: Value[T2])\)
6 \(NEQ\)[\(T1 <: SType, T2 <: SType\)]\((left: Value[T1], right: Value[T2])\)
7 \(OR(input: Value[SCollection[SBoolean]])\)
8 \(AND(input: Value[SCollection[SBoolean]])\)
9 \(CAND(sigmaTrees: Seq[SigmaTree])\)
10 \(COR(sigmaTrees: Seq[SigmaTree])\)
11 \(Plus(left: Value[SInt], right: Value[SInt])\)
12 \(Minus(left: Value[SInt], right: Value[SInt])\)
13 \(Xor(left: Value[SByteArray], right: Value[SByteArray])\)
14 \(AppendBytes(left: Value[SByteArray], right: Value[SByteArray])\)
15 \(Exponentiate(left: Value[SGroupElement], right: Value[SBigInt])\)
16 \(MultiplyGroup(left: Value[SGroupElement], right: Value[SGroupElement])\)
17 \(IntToByteArray(input: Value[SInt])\)
18 \(ByteArrayToBigInt(input: Value[SByteArray])\)
19 \(CalcBlake2b256(input: Value[SByteArray])\)
20 \(ProveDiffieHellmanTuple(gv: Value[SGroupElement], hv: Value[SGroupElement], uv: Value[SGroupElement], vv: Value[SGroupElement])\)
21 \(IsMember(tree: Value[SAvlTree], key: Value[SByteArray], proof: Value[SByteArray])\)
22 \(IntConstant(value: Long)\)
23 \(TaggedInt(id: Byte)\)
24 \(BigIntConstant(value: BigInteger)\)
25 \(TaggedBigInt(id: Byte)\)
26 \(ByteArrayConstant(value: Array[Byte])\)
27 \(TaggedByteArray(id: Byte)\)
28 \(PropConstant(value: Array[Byte])\)
29 \(TaggedProp(id: Byte)\)
30 \(AvlTreeConstant(value: AvlTreeData)\)
31 \(TaggedAvlTree(id: Byte)\)
32 \(GroupElementConstant(value: GroupElement)\)
33 \(GroupGenerator\)
34 \(TaggedGroupElement(id: Byte)\)
35 \(BooleanConstant(val value: Boolean)\)
36 \(TaggedBoolean(id: Byte)\)
37 \(TaggedBox(id: Byte)\)
38 \(ConcreteCollection\)[\(V <: SType\)]\((value: IndexedSeq[Value[V]])\)
39 \(MapCollection\)[\(IV <: SType, OV <: SType](input: Value[SCollection[IV]], id: Byte, mapper: Transformer[IV, OV])\)
40 \(Exists\)[\(IV <: SType](input: Value\)[SCollection[IV]], id: Byte, relations: Relation[_, _]*)$
41 \(ForAll\)[\(IV <: SType](input: Value[SCollection[IV]], id: Byte, relations: Relation[_, _])\)
42 \(Fold\)[\(IV <: SType](input: Value[SCollection[IV]], id: Byte, zero: Value[IV], accId: Byte, foldOp: TwoArgumentsOperation[IV, IV, IV])\)
43 \(ByIndex\)[\(V <: SType](input: Value[SCollection[V]], index: Int)\)
44 \(SizeOf\)[\(V <: SType](input: Value[SCollection[V]])\)
45 \(ExtractHeight(input: Value[SBox])\)
46 \(Height\) ???
47 \(ExtractAmount(input: Value[SBox])\)
48 \(ExtractScript(input: Value[SBox])\)
49 \(ExtractBytes(input: Value[SBox])\)
50 \(ExtractId(input: Value[SBox])\)
51 \(ExtractRegisterAs\)[\(V <: SType](input: Value[SBox], registerId: RegisterIdentifier, default: Option[Value[V]] = None)\)
52 \(TxOutput(outIndex: Int)\)
53 \(ProveDlog(value: Value[SGroupElement])\)

UnknownByteArray#

TaggedVariable#

SGroupElement#

The 'S' in front of SGroupElement refers to the sigma state code under the ErgoScript. When working on the ErgoScript directly, you will use GroupElement.

BoxLeafConstant#

SAvlTree (AvlTreeData)#

Height#