Почему Circuit (circom) не может сравнить метку времени?
У меня есть схема, в которой я хочу сравнить две временные метки.
Если я попробую с меньшими числами, это сработает, если я попробую с метками времени, это не сработает.
Вот схема (.circom)
pragma circom 2.0.0;
include "../node_modules/circomlib/circuits/comparators.circom";
include "../node_modules/circomlib/circuits/poseidon.circom";
template drivingLicenseConstraint() {
// public
signal input hashData; //input: is the hash we have in the SBT. is the hash of the hash of every data poseidon.hashData
signal input ownerAddress;
signal input threshold; // threshold: now timestamp, current time. it should be less than expiry date
// private
// idToSBTData[tokenId].encryptedIssuanceDate,
// idToSBTData[tokenId].encryptedExpiryeDate,
// idToSBTData[tokenId].encryptedOwnerName,
// idToSBTData[tokenId].encryptedLicenseNumber,
// idToSBTData[tokenId].encryptedLicenseType
signal input expiryDate;
// true/false
signal output out;
// check hash to be equal to hashData
component hash = Poseidon(2);
hash.inputs[0] <== ownerAddress;
hash.inputs[1] <== expiryDate;
hashData === hash.out;
// check driving license is not expired
// expiryDate should be bigger than current time in order to return true
component greaterEqThan = GreaterEqThan(8);
greaterEqThan.in[0] <== expiryDate;
greaterEqThan.in[1] <== threshold;
out <-- greaterEqThan.out;
out === 1;
}
component main {public [hashData,ownerAddress,threshold]} = drivingLicenseConstraint();
1 ответ
Нужно изменить аргумент для gre:component greaterEqThan = GreaterEqThan(8);
становится
component greaterEqThan = GreaterEqThan(64);
аргумент - это количество бит, которые есть на входе