Skip to content

Commit

Permalink
chore: update EffectiveBalanceIncrements type (#6763)
Browse files Browse the repository at this point in the history
* chore: update EffectiveBalanceIncrements type

* chore: remove now irrelevant tests
  • Loading branch information
jeluard authored and g11tech committed Aug 9, 2024
1 parent b196ab0 commit f42ba08
Show file tree
Hide file tree
Showing 7 changed files with 12 additions and 204 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -3,26 +3,25 @@ import {BeaconStateAllForks} from "../types.js";

/**
* Alias to allow easier refactoring.
* TODO: Estimate the risk of future proof of MAX_EFFECTIVE_BALANCE_INCREMENT < 255
*/
export type EffectiveBalanceIncrements = Uint8Array;
export type EffectiveBalanceIncrements = Uint16Array;

/** Helper to prevent re-writting tests downstream if we change Uint8Array to number[] */
/** Helper to prevent re-writting tests downstream if we change Uint16Array to number[] */
export function getEffectiveBalanceIncrementsZeroed(len: number): EffectiveBalanceIncrements {
return new Uint8Array(len);
return new Uint16Array(len);
}

/**
* effectiveBalanceIncrements length will always be equal or greater than validatorCount. The
* getEffectiveBalanceIncrementsByteLen() modulo is used to reduce the frequency at which its Uint8Array is recreated.
* getEffectiveBalanceIncrementsByteLen() modulo is used to reduce the frequency at which its Uint16Array is recreated.
* if effectiveBalanceIncrements has length greater than validatorCount it's not a problem since those values would
* never be accessed.
*/
export function getEffectiveBalanceIncrementsWithLen(validatorCount: number): EffectiveBalanceIncrements {
// TODO: Research what's the best number to minimize both memory cost and copy costs
const byteLen = 1024 * Math.ceil(validatorCount / 1024);

return new Uint8Array(byteLen);
return new Uint16Array(byteLen);
}

/**
Expand All @@ -32,7 +31,7 @@ export function getEffectiveBalanceIncrementsWithLen(validatorCount: number): Ef
*/
export function getEffectiveBalanceIncrements(state: BeaconStateAllForks): EffectiveBalanceIncrements {
const validatorsArr = state.validators.getAllReadonlyValues();
const effectiveBalanceIncrements = new Uint8Array(validatorsArr.length);
const effectiveBalanceIncrements = new Uint16Array(validatorsArr.length);
for (let i = 0; i < validatorsArr.length; i++) {
effectiveBalanceIncrements[i] = Math.floor(validatorsArr[i].effectiveBalance / EFFECTIVE_BALANCE_INCREMENT);
}
Expand Down
8 changes: 4 additions & 4 deletions packages/state-transition/src/cache/epochCache.ts
Original file line number Diff line number Diff line change
Expand Up @@ -653,8 +653,8 @@ export class EpochCache {

beforeEpochTransition(): void {
// Clone (copy) before being mutated in processEffectiveBalanceUpdates
// NOTE: Force to use Uint8Array.slice (copy) instead of Buffer.call (not copy)
this.effectiveBalanceIncrements = Uint8Array.prototype.slice.call(this.effectiveBalanceIncrements, 0);
// NOTE: Force to use Uint16Array.slice (copy) instead of Buffer.call (not copy)
this.effectiveBalanceIncrements = Uint16Array.prototype.slice.call(this.effectiveBalanceIncrements, 0);
}

/**
Expand Down Expand Up @@ -1048,13 +1048,13 @@ export class EpochCache {
const newLength =
index >= this.effectiveBalanceIncrements.length ? index + 1 : this.effectiveBalanceIncrements.length;
const effectiveBalanceIncrements = this.effectiveBalanceIncrements;
this.effectiveBalanceIncrements = new Uint8Array(newLength);
this.effectiveBalanceIncrements = new Uint16Array(newLength);
this.effectiveBalanceIncrements.set(effectiveBalanceIncrements, 0);
} else {
if (index >= this.effectiveBalanceIncrements.length) {
// Clone and extend effectiveBalanceIncrements
const effectiveBalanceIncrements = this.effectiveBalanceIncrements;
this.effectiveBalanceIncrements = new Uint8Array(getEffectiveBalanceIncrementsByteLen(index + 1));
this.effectiveBalanceIncrements = new Uint16Array(getEffectiveBalanceIncrementsByteLen(index + 1));
this.effectiveBalanceIncrements.set(effectiveBalanceIncrements, 0);
}
}
Expand Down
4 changes: 2 additions & 2 deletions packages/state-transition/src/util/balance.ts
Original file line number Diff line number Diff line change
Expand Up @@ -56,8 +56,8 @@ export function getEffectiveBalanceIncrementsZeroInactive(
const validatorCount = justifiedState.validators.length;
const {effectiveBalanceIncrements} = justifiedState.epochCtx;
// Slice up to `validatorCount` since it won't be mutated, nor accessed beyond `validatorCount`
// NOTE: Force to use Uint8Array.slice (copy) instead of Buffer.call (not copy)
const effectiveBalanceIncrementsZeroInactive = Uint8Array.prototype.slice.call(
// NOTE: Force to use Uint16Array.slice (copy) instead of Buffer.call (not copy)
const effectiveBalanceIncrementsZeroInactive = Uint16Array.prototype.slice.call(
effectiveBalanceIncrements,
0,
validatorCount
Expand Down

This file was deleted.

Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
import {MutableVector} from "@chainsafe/persistent-ts";

const refs: any[] = [];
const xs: number[] = [];
const arrayBuffersArr: number[] = [];
Expand All @@ -23,7 +21,6 @@ const size = 100;
const testType = TestType.Set;

let arrayNumGlobal: number[] | null = null;
let mutableVectorGlobal: MutableVector<number> | null = null;

for (let i = 0; i < 1e8; i++) {
switch (testType as TestType) {
Expand Down Expand Up @@ -65,49 +62,6 @@ for (let i = 0; i < 1e8; i++) {
break;
}

// size | 100 | 1000 | 10000 |
// ---- | ------ | ------ | ------ |
// rssM | 1817.4 | 15518. | 154335 |
case TestType.MutableVector: {
const items = createArray(size);
const mutableVector = MutableVector.from(items);
refs.push(mutableVector);
break;
}

// size | 100 | 1000 |
// ---- | ------ | ------ |
// rssM | 58.68 | 55.89 |
case TestType.MutableVectorClone: {
if (!mutableVectorGlobal) {
const items = createArray(size);
mutableVectorGlobal = MutableVector.from(items);
}
refs.push(mutableVectorGlobal.clone());
break;
}

// Grid of size / changes, all values = rssM in bytes
// | 100 | 1000 | 10000 |
// ----- | ------ | ------ | ------ |
// 1 | 793.45 | 801.53 | 1137.9 |
// 10 | 803.98 | 802.36 | 1144.9 |
// 100 | 1573.2 | 1826.4 | 2172.0 |
// 1000 | - | 11250. | 11886. |
// 10000 | - | - | 111365 |
case TestType.MutableVectorCloneAndMutate: {
if (!mutableVectorGlobal) {
const items = createArray(size);
mutableVectorGlobal = MutableVector.from(items);
}
const newArr = mutableVectorGlobal.clone();
for (let j = 0; j < 10000; j++) {
newArr.set(j, i);
}
refs.push(newArr);
break;
}

// size | 100 | 1000 |
// ---- | ------ | ------ |
// rssM | 2646.8 | 20855. |
Expand Down Expand Up @@ -161,14 +115,6 @@ for (let i = 0; i < 1e8; i++) {
}
}

function createArray(n: number): number[] {
const items: number[] = [];
for (let i = 0; i < n; i++) {
items.push(i);
}
return items;
}

/**
* From https://github.com/simple-statistics/simple-statistics/blob/d0d177baf74976a2421638bce98ab028c5afb537/src/linear_regression.js
*
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import {itBench, setBenchOpts} from "@dapplion/benchmark";
import {LeafNode, toGindex, Tree, zeroNode} from "@chainsafe/persistent-merkle-tree";
import {MutableVector} from "@chainsafe/persistent-ts";

// Understand the cost of each array-ish data structure to:
// - Get one element
Expand Down Expand Up @@ -99,48 +98,6 @@ describe("Tree (persistent-merkle-tree)", () => {
}
});

describe("MutableVector", () => {
// Don't track regressions in CI
setBenchOpts({noThreshold: true});

let items: number[];
let mutableVector: MutableVector<number>;

before(function () {
items = createArray(n);
mutableVector = MutableVector.from(items);
});

itBench(`MutableVector ${n} create`, () => {
MutableVector.from(items);
});

itBench({id: `MutableVector ${n} get(${ih})`, runsFactor}, () => {
for (let i = 0; i < runsFactor; i++) mutableVector.get(ih - i);
});

itBench({id: `MutableVector ${n} set(${ih})`, runsFactor}, () => {
for (let i = 0; i < runsFactor; i++) mutableVector.set(ih - i, 10000000);
});

itBench(`MutableVector ${n} toArray()`, () => {
mutableVector.toArray();
});

itBench(`MutableVector ${n} iterate all - toArray() + loop`, () => {
const mvArr = mutableVector.toArray();
for (let i = 0; i < n; i++) {
mvArr[i];
}
});

itBench(`MutableVector ${n} iterate all - get(i)`, () => {
for (let i = 0; i < n; i++) {
mutableVector.get(i);
}
});
});

describe("Array", () => {
// Don't track regressions in CI
setBenchOpts({noThreshold: true});
Expand Down

This file was deleted.

0 comments on commit f42ba08

Please sign in to comment.