Skip to content

perf(internal/bits): Speedup extended commit.BitArray() (backport #29… (backport #43)#55

Merged
czarcas7ic merged 1 commit intoosmo-v25/v0.37.4from
mergify/bp/osmo-v25/v0.37.4/pr-43
May 3, 2024
Merged

perf(internal/bits): Speedup extended commit.BitArray() (backport #29… (backport #43)#55
czarcas7ic merged 1 commit intoosmo-v25/v0.37.4from
mergify/bp/osmo-v25/v0.37.4/pr-43

Conversation

@mergify
Copy link

@mergify mergify bot commented May 3, 2024

…59) (cometbft#2983)

Speedup ExtendedCommit.BitArray() by making a direct constructor that does not go through mutexes. I expect this to be a 10x performance improvement. (It also removes the duffcopies and reduces setIndex proportion of time here)

This removes this time (which is mostly coming from mutex calls):

image

Later on we should instead make an API that lets us randomly sample from a bit array with no bit array copying needed. (But that makes the interface messier)


PR checklist



PR checklist

  • Tests written/updated
  • Changelog entry added in .changelog (we use unclog to manage our changelog)
  • Updated relevant documentation (docs/ or spec/) and code comments

This is an automatic backport of pull request #43 done by [Mergify](https://mergify.com).

…etbft#2959) (cometbft#2983) (#43)

Speedup ExtendedCommit.BitArray() by making a direct constructor that
does not go through mutexes. I expect this to be a 10x performance
improvement. (It also removes the duffcopies and reduces setIndex
proportion of time here)

This removes this time (which is mostly coming from mutex calls):

![image](https://github.com/cometbft/cometbft/assets/6440154/da11d57d-6bea-40ea-a0fa-9209ea3e22f8)

Later on we should instead make an API that lets us randomly sample from
a bit array with no bit array copying needed. (But that makes the
interface messier)

---

#### PR checklist

- [x] Tests written/updated
- [x] Changelog entry added in `.changelog` (we use
[unclog](https://github.com/informalsystems/unclog) to manage our
changelog)
- [x] Updated relevant documentation (`docs/` or `spec/`) and code
comments
- [x] Title follows the [Conventional
Commits](https://www.conventionalcommits.org/en/v1.0.0/) spec
<hr>This is an automatic backport of pull request cometbft#2959 done by
[Mergify](https://mergify.com).

---------

Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
Co-authored-by: Dev Ojha <ValarDragon@users.noreply.github.com>
Co-authored-by: Anton Kaliaev <anton.kalyaev@gmail.com>
(cherry picked from commit 88c490f)
@czarcas7ic czarcas7ic merged commit 8855295 into osmo-v25/v0.37.4 May 3, 2024
@mergify mergify bot deleted the mergify/bp/osmo-v25/v0.37.4/pr-43 branch May 3, 2024 00:30
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant