Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Enhancement] Improved animated QR scanning percentage display #541

Merged
merged 4 commits into from
May 1, 2024

Conversation

kdmukai
Copy link
Contributor

@kdmukai kdmukai commented Apr 3, 2024

Overview

  • New animated QR scanning progress display bar.
  • Changes how the percent progress is calculated.
  • Subtle additional green / gray dot decoder indicator:
    • Green = new information gained by the current animated QR frame
    • Gray = successfully decoded the current animated QR frame, but no new info learned
    • (no dot) = no QR of any kind detected in the current camera frame
  • Minor bugfix: Screensaver can kick in as soon as a very long scanning attempt is exited.

In-Depth description

Current progress metric just guesstimates that 1.75 * n animated frames will be needed for an animated QR that has n full frames' worth of data, capped at 99% until all data is read. Unfortunately the metric counts frames that don't add any new data, so for very long animated QRs, useless reads pile up and keep advancing the progress metric until it gets pinned to 99%.

But because of the nature of the mixed / XOR frames in the fountain encoding, there isn't a sensible way to quantify one's current progress. This PR's new metric counts each component in a mixed frame as partial progress, relative to its proportion in each mixed frame, summed across all mixed frames:

e.g.
We need to decode full frames A through Z.

We score a fully decoded frame as 1.0.

Mixed frame i is an XOR of full frames G, K, Q, and Z.

So we count 1/4 G, 1/4 K, 1/4 Q, and 1/4 Z towards our total progress.

Then we receive mixed frame j which is an XOR of full frames A, F, G, P, Y

So frame G's contribution to our progress is now 1/4 + 1/5.

It's possible to have G XORed in so many mixed frames that its summed fractional score might exceed 1.0, so we need to cap G's scoring value until we fully decode it. The cap selected in this PR -- 0.75 -- started from an arbitrary guess and then was tweaked based on how the progress percentage was reported in real-world use (oddly, larger values could result in the progress percentage occasionally decreasing(!!), though I wonder if that might have been more due to some threading artifact?).

This metric accelerates the reported progress in the early stages of decoding a long animated QR vs the original metric. But this metric predictably slows down toward the end as we receive less and less new information and instead are stuck waiting for just the right XOR frame to start being able to unlock the big collection of mixed frames we're holding in memory. So while we don't pin the reported progress at 99% for what could feel like (or actually be) forever, we do still experience a fair bit of agony at, say, 85% as progress begins to crawl.


Design by @easyuxd:

F6UGYaIWsAAew0g (1)

Note: no new screenshots added in this PR because the screenshot generator can't produce screenshots for live camera preview screens.


Very large animated QR for testing

large_psbt_animated_qr_02.mp4

This pull request is categorized as a:

  • Enhacement

Checklist

  • I’ve run pytest and made sure all unit tests pass before sumbitting the PR

If you modified or added functionality/workflow, did you add new unit tests?

  • N/A

Test suite cannot simulate animated QR scanning.


I have tested this PR on the following platforms/os:

@newtonick
Copy link
Collaborator

ACK and Tested

@newtonick newtonick merged commit 62807fd into SeedSigner:dev May 1, 2024
1 check passed
@kdmukai kdmukai deleted the improved_animated_qr_display branch September 2, 2024 14:02
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Development

Successfully merging this pull request may close these issues.

2 participants