mirror of
https://github.com/darkrenaissance/darkfi.git
synced 2026-01-08 22:28:12 -05:00
transfer transaction based off lead coin
This commit is contained in:
37
proof/tx.zk
37
proof/tx.zk
@@ -17,23 +17,11 @@ contract "tx" {
|
||||
MerklePath c1_cm_path,
|
||||
Uint32 c1_cm_pos,
|
||||
Base c1_sn,
|
||||
# coin (2) witnesses
|
||||
Base c2_root_sk,
|
||||
Base c2_sk,
|
||||
MerklePath c2_sk_path,
|
||||
Uint32 c2_sk_pos,
|
||||
Base c2_rho,
|
||||
Scalar c2_opening,
|
||||
Base c2_value,
|
||||
MerklePath c2_cm_path,
|
||||
Uint32 c2_cm_pos,
|
||||
Base c2_sn,
|
||||
# coin (3) witnesses
|
||||
Base c3_pk,
|
||||
Base c3_rho,
|
||||
Scalar c3_opening,
|
||||
Base c3_value,
|
||||
|
||||
# coin (4) witnesses
|
||||
Base c4_pk,
|
||||
Base c4_rho,
|
||||
@@ -52,9 +40,6 @@ circuit "tx" {
|
||||
# coin (1) pk/public key
|
||||
c1_pk = poseidon_hash(PREFIX_PK, c1_root_sk);
|
||||
constrain_instance(c1_pk);
|
||||
# coin (2) pk/public key
|
||||
c2_pk = poseidon_hash(PREFIX_PK, c2_root_sk);
|
||||
constrain_instance(c2_pk);
|
||||
# coin (1) cm/commitment
|
||||
c1_cm_msg = poseidon_hash(PREFIX_CM, c1_pk, c1_value, c1_rho);
|
||||
c1_cm_v = ec_mul_short(c1_cm_msg, VALUE_COMMIT_VALUE);
|
||||
@@ -65,16 +50,6 @@ circuit "tx" {
|
||||
c1_cm_hash = poseidon_hash(c1_cm_x, c1_cm_y);
|
||||
constrain_instance(c1_cm_x);
|
||||
constrain_instance(c1_cm_y);
|
||||
# coin (2) cm/commitment
|
||||
c2_cm_msg = poseidon_hash(PREFIX_CM, c2_pk, c2_value, c2_rho);
|
||||
c2_cm_v = ec_mul_short(c2_cm_msg, VALUE_COMMIT_VALUE);
|
||||
c2_cm_r = ec_mul(c2_opening, VALUE_COMMIT_RANDOM);
|
||||
c2_cm = ec_add(c2_cm_v, c2_cm_r);
|
||||
c2_cm_x = ec_get_x(c2_cm);
|
||||
c2_cm_y = ec_get_y(c2_cm);
|
||||
c2_cm_hash = poseidon_hash(c2_cm_x, c2_cm_y);
|
||||
constrain_instance(c2_cm_x);
|
||||
constrain_instance(c2_cm_y);
|
||||
# coin (3) cm/commitment
|
||||
c3_cm_msg = poseidon_hash(PREFIX_CM, c3_pk, c3_value, c3_rho);
|
||||
c3_cm_v = ec_mul_short(c3_cm_msg, VALUE_COMMIT_VALUE);
|
||||
@@ -93,25 +68,15 @@ circuit "tx" {
|
||||
constrain_instance(c4_cm_x);
|
||||
c4_cm_y = ec_get_y(c4_cm);
|
||||
constrain_instance(c4_cm_y);
|
||||
v1v2 = base_add(c1_value, c2_value);
|
||||
v2v3 = base_add(c3_value, c4_value);
|
||||
constrain_equal_base(v1v2, v2v3);
|
||||
constrain_equal_base(c1_value, v3v4);
|
||||
# root of path to coin1 commitment at given position
|
||||
c1_root = merkle_root(c1_cm_pos, c1_cm_path, c1_cm_hash);
|
||||
constrain_instance(c1_root);
|
||||
# root of path to coin2n commitment at given position
|
||||
c2_root = merkle_root(c2_cm_pos, c2_cm_path, c2_cm_hash);
|
||||
constrain_instance(c2_root);
|
||||
# root of path to coin(1) sk at given position
|
||||
c1_sk_root = merkle_root(c1_sk_pos, c1_sk_path, c1_sk);
|
||||
constrain_instance(c1_sk_root);
|
||||
# root of path to coin(2) sk at given position
|
||||
c2_sk_root = merkle_root(c2_sk_pos, c2_sk_path, c2_sk);
|
||||
constrain_instance(c2_sk_root);
|
||||
# coin (1) sn/nullifier
|
||||
c1_sn = poseidon_hash(PREFIX_SN, c1_root_sk, c1_rho, ZERO);
|
||||
constrain_instance(c1_sn);
|
||||
# coin (2) sn/nullifier
|
||||
c2_sn = poseidon_hash(PREFIX_SN, c1_root_sk, c2_rho, ZERO);
|
||||
constrain_instance(c2_sn);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user