Minor fix

This commit is contained in:
Rodrigo Q. Saramago 2022-07-11 14:17:38 +02:00
parent 1ae0bc1119
commit 4e69875311
No known key found for this signature in database
GPG Key ID: 9B36B2525704A359

View File

@ -143,12 +143,7 @@ export class BaseTree {
static nextLayerMultiPathIndices(indices: number[]): number[] { static nextLayerMultiPathIndices(indices: number[]): number[] {
let nextIndices: Set<number> = new Set() let nextIndices: Set<number> = new Set()
for (let i = 0; i < indices.length; i++) { for (let i = 0; i < indices.length; i++) {
let elIdx = indices[i] nextIndices.add(indices[i] >> 1)
if (elIdx % 2 === 0) {
nextIndices.add(Math.ceil(elIdx / 2))
} else {
nextIndices.add(Math.ceil((elIdx ^ 1) / 2))
}
} }
return [...nextIndices] return [...nextIndices]
} }
@ -162,14 +157,18 @@ export class BaseTree {
let pathElements: Element[] = [] let pathElements: Element[] = []
let layerIndices = indices let layerIndices = indices
for (let level = 0; level < this.levels; level++) { for (let level = 0; level < this.levels; level++) {
// find the neighbor idx that is not in layerIndices // find whether there is a neighbor idx that is not in layerIndices
let proofElements = layerIndices let proofElements = layerIndices.reduce((elements, idx) => {
.filter((idx) => !layerIndices.includes(idx ^ 1)) const leafIndex = idx ^ 1
.map((idx) => this._layers[level][idx ^ 1]) if (!layerIndices.includes(leafIndex)) {
if (leafIndex < this._layers[level].length) {
if (proofElements.length == 0) { elements.push(this._layers[level][leafIndex])
break } else {
} elements.push(this._zeros[level])
}
}
return elements
}, [])
pathElements = pathElements.concat(proofElements) pathElements = pathElements.concat(proofElements)
layerIndices = BaseTree.nextLayerMultiPathIndices(layerIndices) layerIndices = BaseTree.nextLayerMultiPathIndices(layerIndices)
} }