From c8894e7d3132fa6b60759fc0ab62993d7ce18fe3 Mon Sep 17 00:00:00 2001 From: EntireTwix Date: Mon, 5 Jul 2021 16:01:32 -0700 Subject: [PATCH] :books: GetBal() graph --- docs/features/GetBal().png | Bin 0 -> 35773 bytes docs/features/implementation.md | 5 +++++ 2 files changed, 5 insertions(+) create mode 100644 docs/features/GetBal().png diff --git a/docs/features/GetBal().png b/docs/features/GetBal().png new file mode 100644 index 0000000000000000000000000000000000000000..1665f3f1b834bcedb415948ca787eb12a1e97920 GIT binary patch literal 35773 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 literal 0 HcmV?d00001 diff --git a/docs/features/implementation.md b/docs/features/implementation.md index dc2e4fc..9205ce2 100644 --- a/docs/features/implementation.md +++ b/docs/features/implementation.md @@ -2,6 +2,11 @@ # Implementation Features ## Parallel Hashmap + + +below is `GetBal()` being called where `x` axis grows with # of users reaching 10 million users, `y` axis is time in ns. The name given is random between 0 and max users at that time as to provide more accurate results +![image](GetBal().png) +as the graph demonstrates, regardless of size GetBal remains consistent at around 50ns. ## xxHash ## base64 ## drogon webframework