@proto-kit/protocol • Docs
Documentation / @proto-kit/protocol / ProvableStateTransition
Class: ProvableStateTransition
Provable representation of a State Transition, used to normalize state transitions of various value types for the state transition circuit.
Extends
object
Constructors
new ProvableStateTransition()
new ProvableStateTransition(
value):ProvableStateTransition
Parameters
• value
• value.from: ProvableOption = ProvableOption
• value.path: Field = Field
• value.to: ProvableOption = ProvableOption
Returns
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).constructor
Defined in
node_modules/o1js/dist/node/lib/provable/types/struct.d.ts:103
Properties
from
from:
ProvableOption=ProvableOption
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).from
Defined in
packages/protocol/src/model/StateTransition.ts:14
path
path:
Field=Field
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).path
Defined in
packages/protocol/src/model/StateTransition.ts:11
to
to:
ProvableOption=ProvableOption
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).to
Defined in
packages/protocol/src/model/StateTransition.ts:17
_isStruct
static_isStruct:true
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, })._isStruct
Defined in
node_modules/o1js/dist/node/lib/provable/types/struct.d.ts:104
check()
staticcheck: (value) =>void
Add assertions to the proof to check if value is a valid member of type T.
This function does not return anything, instead it creates any number of assertions to prove that value is a valid member of the type T.
For instance, calling check function on the type Bool asserts that the value of the element is either 1 or 0.
Parameters
• value
the element of type T to put assertions on.
• value.from: ProvableOption = ProvableOption
• value.path: Field = Field
• value.to: ProvableOption = ProvableOption
Returns
void
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).check
Defined in
node_modules/o1js/dist/node/lib/provable/types/provable-intf.d.ts:60
empty()
staticempty: () =>object
Returns
object
from
from:
ProvableOption=ProvableOption
path
path:
Field=Field
to
to:
ProvableOption=ProvableOption
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).empty
Defined in
node_modules/o1js/dist/node/lib/provable/types/struct.d.ts:113
fromFields()
staticfromFields: (fields) =>object
Parameters
• fields: Field[]
Returns
object
from
from:
ProvableOption=ProvableOption
path
path:
Field=Field
to
to:
ProvableOption=ProvableOption
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).fromFields
Defined in
node_modules/o1js/dist/node/lib/provable/types/provable-intf.d.ts:95
fromJSON()
staticfromJSON: (x) =>object
Parameters
• x
• x.from = ProvableOption
• x.from.isSome: boolean = Bool
• x.from.value: string = Field
• x.path: string = Field
• x.to = ProvableOption
• x.to.isSome: boolean = Bool
• x.to.value: string = Field
Returns
object
from
from:
ProvableOption=ProvableOption
path
path:
Field=Field
to
to:
ProvableOption=ProvableOption
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).fromJSON
Defined in
node_modules/o1js/dist/node/lib/provable/types/struct.d.ts:112
fromValue
staticfromValue: (x) =>object& (value) =>object
Convert provable type from a normal JS type.
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).fromValue
Defined in
node_modules/o1js/dist/node/lib/provable/types/provable-intf.d.ts:68
toAuxiliary()
statictoAuxiliary: (value?) =>any[]
A function that takes value (optional), an element of type T, as argument and
returns an array of any type that make up the “auxiliary” (non-provable) data of value.
Parameters
• value?
the element of type T to generate the auxiliary data array from, optional.
If not provided, a default value for auxiliary data is returned.
• value.from?: ProvableOption = ProvableOption
• value.path?: Field = Field
• value.to?: ProvableOption = ProvableOption
Returns
any[]
An array of any type describing how this T element is made up of “auxiliary” (non-provable) data.
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).toAuxiliary
Defined in
node_modules/o1js/dist/node/lib/provable/types/provable-intf.d.ts:34
toCanonical()?
staticoptionaltoCanonical: (x) =>object
Optional method which transforms a provable type into its canonical representation.
This is needed for types that have multiple representations of the same underlying value, and might even not have perfect completeness for some of those representations.
An example is the ForeignField class, which allows non-native field elements to exist in unreduced form.
The unreduced form is not perfectly complete, for example, addition of two unreduced field elements can cause a prover error.
Specific protocols need to be able to protect themselves against incomplete operations at all costs.
For example, when using actions and reducer, the reducer must be able to produce a proof regardless of the input action.
toCanonical() converts any input into a safe form and enables us to handle cases like this generically.
Note: For most types, this method is the identity function.
The identity function will also be used when the toCanonical() is not present on a type.
Parameters
• x
• x.from: ProvableOption = ProvableOption
• x.path: Field = Field
• x.to: ProvableOption = ProvableOption
Returns
object
from
from:
ProvableOption=ProvableOption
path
path:
Field=Field
to
to:
ProvableOption=ProvableOption
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).toCanonical
Defined in
node_modules/o1js/dist/node/lib/provable/types/provable-intf.d.ts:85
toFields()
statictoFields: (value) =>Field[]
A function that takes value, an element of type T, as argument and returns
an array of Field elements that make up the provable data of value.
Parameters
• value
the element of type T to generate the Field array from.
• value.from: ProvableOption = ProvableOption
• value.path: Field = Field
• value.to: ProvableOption = ProvableOption
Returns
Field[]
A Field array describing how this T element is made up of Field elements.
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).toFields
Defined in
node_modules/o1js/dist/node/lib/provable/types/provable-intf.d.ts:24
toInput()
statictoInput: (x) =>object
Parameters
• x
• x.from: ProvableOption = ProvableOption
• x.path: Field = Field
• x.to: ProvableOption = ProvableOption
Returns
object
fields?
optionalfields:Field[]
packed?
optionalpacked: [Field,number][]
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).toInput
Defined in
node_modules/o1js/dist/node/lib/provable/types/struct.d.ts:107
toJSON()
statictoJSON: (x) =>object
Parameters
• x
• x.from: ProvableOption = ProvableOption
• x.path: Field = Field
• x.to: ProvableOption = ProvableOption
Returns
object
from
from:
object=ProvableOption
from.isSome
from.isSome:
boolean=Bool
from.value
from.value:
string=Field
path
path:
string=Field
to
to:
object=ProvableOption
to.isSome
to.isSome:
boolean=Bool
to.value
to.value:
string=Field
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).toJSON
Defined in
node_modules/o1js/dist/node/lib/provable/types/struct.d.ts:111
toValue()
statictoValue: (x) =>object
Convert provable type to a normal JS type.
Parameters
• x
• x.from: ProvableOption = ProvableOption
• x.path: Field = Field
• x.to: ProvableOption = ProvableOption
Returns
object
from
from:
object=ProvableOption
from.isSome
from.isSome:
boolean=Bool
from.value
from.value:
bigint=Field
path
path:
bigint=Field
to
to:
object=ProvableOption
to.isSome
to.isSome:
boolean=Bool
to.value
to.value:
bigint=Field
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).toValue
Defined in
node_modules/o1js/dist/node/lib/provable/types/provable-intf.d.ts:64
Methods
dummy()
staticdummy():ProvableStateTransition
Returns
Defined in
packages/protocol/src/model/StateTransition.ts:19
isDummy()
staticisDummy(stateTransition):Bool
Parameters
• stateTransition: ProvableStateTransition
Returns
Bool
Defined in
packages/protocol/src/model/StateTransition.ts:27
sizeInFields()
staticsizeInFields():number
Return the size of the T type in terms of Field type, as Field is the primitive type.
Returns
number
A number representing the size of the T type in terms of Field type.
Inherited from
Struct({ path: Field,
// must be applied even if `None` from: ProvableOption,
// must be ignored if `None` to: ProvableOption, }).sizeInFields
Defined in
node_modules/o1js/dist/node/lib/provable/types/provable-intf.d.ts:51