Skip to content

Commit

Permalink
feat: tested DataHasher
Browse files Browse the repository at this point in the history
  • Loading branch information
Autoparallel committed Nov 13, 2024
1 parent 7c3adfe commit da688d5
Show file tree
Hide file tree
Showing 4 changed files with 32 additions and 11 deletions.
8 changes: 6 additions & 2 deletions circuits/test/common/poseidon.ts
Original file line number Diff line number Diff line change
Expand Up @@ -88,8 +88,12 @@ export function DataHasher(input: number[]): bigint {
packedInput += BigInt(input[16 * i + j]) * BigInt(2 ** (8 * j));
}

// Compute next hash using previous hash and packed input
hashes.push(PoseidonModular([hashes[i], packedInput]));
// Compute next hash using previous hash and packed input, but if packed input is zero, don't hash it.
if (packedInput == BigInt(0)) {
hashes.push(hashes[i]);
} else {
hashes.push(PoseidonModular([hashes[i], packedInput]));
}
}

// Return the last hash
Expand Down
2 changes: 0 additions & 2 deletions circuits/test/full/full.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,6 @@ import { assert } from "chai";
import { circomkit, WitnessTester, toByte } from "../common";
import { DataHasher } from "../common/poseidon";



// HTTP/1.1 200 OK
// content-type: application/json; charset=utf-8
// content-encoding: gzip
Expand Down
31 changes: 25 additions & 6 deletions circuits/test/utils/hash.test.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import assert from "assert";
import { circomkit, WitnessTester } from "../common";
import { PoseidonModular } from "../common/poseidon";
import { DataHasher, PoseidonModular } from "../common/poseidon";

describe("hash", () => {
describe("PoseidonModular_16", () => {
Expand Down Expand Up @@ -83,10 +84,9 @@ describe("hash", () => {

it("witness: in = [0,...x16]", async () => {
const input = Array(16).fill(0);
const hash = PoseidonModular([0, 0]);
await circuit.expectPass(
{ in: input },
{ out: hash }
{ out: 0 }
);
});

Expand Down Expand Up @@ -128,6 +128,20 @@ describe("hash", () => {
10, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 125, 13, 10, 32, 32, 32, 32, 32, 32, 32, 93, 13,
10, 32, 32, 32, 125, 13, 10, 125]

const http_start_line = [
72, 84, 84, 80, 47, 49, 46, 49, 32, 50, 48, 48, 32, 79, 75, 13, 10, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0,
];

describe("DataHasherHTTP", () => {
let circuit: WitnessTester<["in"], ["out"]>;

Expand All @@ -141,10 +155,15 @@ describe("hash", () => {
});

it("witness: TEST HTTP BYTES", async () => {

let hash = DataHasher(TEST_HTTP_BYTES);
assert.deepEqual(String(hash), "2195365663909569734943279727560535141179588918483111718403427949138562480675");
await circuit.expectPass({ in: TEST_HTTP_BYTES }, { out: "2195365663909569734943279727560535141179588918483111718403427949138562480675" });
});


it("witness: TEST HTTP START LINE MASK", async () => {
let hash = DataHasher(http_start_line);
// assert.deepEqual(String(hash), "2195365663909569734943279727560535141179588918483111718403427949138562480675");
await circuit.expectPass({ in: http_start_line }, { out: hash });
});
});
});
});
2 changes: 1 addition & 1 deletion circuits/utils/hash.circom
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ template DataHasher(DATA_BYTES) {
}
not_to_hash[i] <== IsZero()(packedInput);
option_hash[i] <== PoseidonChainer()([hashes[i],packedInput]);
hashes[i+1] <== (1 - not_to_hash[i]) * option_hash[i];
hashes[i+1] <== not_to_hash[i] * (hashes[i] - option_hash[i]) + option_hash[i]; // same as: (1 - not_to_hash[i]) * option_hash[i] + not_to_hash[i] * hash[i];
}
out <== hashes[DATA_BYTES \ 16];
}

0 comments on commit da688d5

Please sign in to comment.