Skip to content

Commit

Permalink
Update README.MD: include a small note about on howto benchmark
Browse files Browse the repository at this point in the history
  • Loading branch information
farooqkz authored May 15, 2024
1 parent e4c994a commit 20c850e
Showing 1 changed file with 18 additions and 4 deletions.
22 changes: 18 additions & 4 deletions README.MD
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ The specification can be found in [spec.md](./spec.md).

WASM Demo: <https://deltachat.github.io/message-parser/>

## Idea behind it
## The idea behind it

Have the same rich message parsing on all platforms.

Expand All @@ -20,9 +20,9 @@ that can then be displayed by the UIs how they see fit, for desktop it will be c
- **many** test cases
- aim to be fast - so also benchmarks to make sure the lib stays fast enough

## Recomendations:
## Recomendations

If used for message parsing, don't parse messages that are over `10 000` chars in size to ensure performance stays excelent. (the lib could and should support more than that and should aim to be fast enough for it, but on slow devices or transpiled to wasm or asmjs limiting it makes sense to avoid laggy/freezed interface)
If used for message parsing, don't parse messages that are over `10 000` chars in size to ensure performance stays excellent. (the lib could and should support more than that and should aim to be fast enough for it, but on slow devices or transpiled to wasm or asmjs limiting it makes sense to avoid laggy/freezed interface)

### Benchmarking:

Expand All @@ -38,6 +38,20 @@ cargo criterion

docs about benchmarking: https://bheisler.github.io/criterion.rs/book/criterion_rs.html

### Changing CPU power settings for consistent results

These days most CPUs change their performance according to some rules to save power.
To produce consistent benchmark results, CPU performance must not change between benchmarks. There are various ways to achieve this.
If you've got a laptop, the first step might be connecting the AC adapter to ensure your laptop won't go on power saving mode and thus changing the
CPU frequency. The next step is to change CPU frequency to a constant value *under the maximum frequency CPU can handle*. Because the CPUs usually can't handle the maximum possible frequency on all cores.

On Linux, you can set the CPU frequency using `cpupower` utility:

```sh
cpupower frequency-set --min 3500 --max 3500 # this to set maximum and minimum to the same value
cpupower frequency-set -f 3500 # set frequency explicitly if the kernel module is available
```

## References

- Older discussion on introducing markdown into deltachat: https://github.com/deltachat/interface/pull/20
Expand All @@ -54,4 +68,4 @@ Additionally to message parsing this crate also contains some useful functions f
- idea: can be used by UI to get the first emoji of a chat name to display it as text avatar
- `parser::is_emoji::count_emojis_if_only_contains_emoji(text)` - counts emojis in texts that contain only emojis
- useful for jumbomoji logic (if you send a small message with just emojis the emojis get displayed larger).
- this function does not fail on too long strings, so to keep good performance check the length beforehand and if it is too long the message would not be big anyway so you don't need to call this function.
- this function does not fail on too long strings, so to keep good performance check the length beforehand and if it is too long the message would not be big anyway so you don't need to call this function.

0 comments on commit 20c850e

Please sign in to comment.