frontpage.
newsnewestaskshowjobs

Open Source @Github

fp.

Open in hackernews

Show HN: An interactive demo of QR codes' error correction

https://qris.cool
109•Xiione•1y ago
Hi HN! This is a hobby project of mine that recently landed me my first interview and helped me get my first internship offers.

Draw on a QR code, and the health bars will accurately display how close the QR code is to being unscannable. How few errors does it take to break a QR code? How many errors can a QR code handle? Counters at the bottom track your record minimum and maximum damage. (Can you figure out how to break a QR code with 0.0% damage to the actual data region?)

Also, click on the magnifying glass button to toggle between "draw mode" and "inspect mode". I encourage you to use your phone's camera to scan the code as you draw and undo/redo to verify that the code really does break when the app says it does.

I wrote the underlying decoder in C++, and it's compiled to WebAssembly for the website.

I hope you find it interesting.

Comments

flysand7•1y ago
It's surprising how much data you need to corrupt while still being able to read the QR code, that's what I'd take out from this. The demo is interesting in that respect, but I do think it's somewhat incomplete.

It seems to be missing some explanations regarding how the code is structured and how it performs error correction. I feel like there's little point in interacting with a system you don't understand or not trying to understand. And I also think there are cool ways to make those things interactive as well. Pick an image, then explain what the little squares in the corners are for and provide little interactivity to see how they affect the decoding. Then move on to the error correction. This step-by-step style of interactivity may be better, I'd think about that.

As for what is there, the first thing I don't like here is icons. The four icons in the lower-right corner (result data, format info, ..) are hard to distinguish, and are hard to correlate with the "history" tab. I'd probably either make them slightly different color, or actually simplifying these icons further might be a better option, just because they're so small.

But yeah it is pretty hard to tell what I'm interacting with, unfortunately. I don't know pretty much nothing about QR codes, and I don't know what the different kinds of errors are, what "EC" stands for etc.

UI should probably be rethought as well, because before I was writing the comment I had no idea I could switch a brush. Hell, I had no idea I was changing colors (the cursor covered half the space of the pixels, so I couldn't tell)

The idea's cool though, good work

Xiione•1y ago
Thank you so much for the honest feedback. One of the reasons I tried to not get into the math details is because the preliminaries would be somewhat lengthy, some people would not be familiar with what a finite field is so explaining even that succinctly would be its own challenge for me. But for those that the concepts are within reach for (like the folks here on HN), you are right that I ought to make some effort to explain what is going on, at least intuitively. As for the UI considerations, great feedback, I'll definitely take it all into account when re-designing. I'm open to additional suggestions from everybody.

Ultimately I'm glad that I was able to get the main point across. That is, that QR codes can take a lot more abuse than one might assume. Thanks for checking my work out!

boomskats•1y ago
How can you say that you 'don't know pretty much nothing about QR codes' and that you 'feel like there's little point in interacting with a system you don't understand or not trying to understand', while feeling qualified enough to write a critique claiming a demo of said thing you know pretty much nothing about is incomplete?

You don't know what EC stands for but you have an opinion on when the error correction should be demoed? And the first thing you don't like are the icons?

OP, if I were you I would ignore this critique entirely. This is a fantastic demo. The usability was spot on (I learned a lot in a very short amount of time) and your /repos readme is _exactly_ what I wanted to read. It is perfectly executed.

I'm gonna dig into your code a bit more tomorrow, but you should be very proud of this. You have a bright future ahead of you.

Xiione•1y ago
Thanks so much for your kind words! As a principle I try to at least listen to what everyone has to say, I wish I could make everybody happy but in the end I incorporate the feedback I'm convinced of/already agree with. Let me know if you have any thoughts on my code, and thank you for the github follow :)
gen3•1y ago
Very cool work! I really like being able to see the blocks and directly interact with them. It's nice to feel out how the ECC works. I can see myself using this to draw custom QR codes in the future!
myself248•1y ago
Oh, this is cool. My favorite part is being able to mouse over the health bars at the right, and see exactly which bits they draw from in the code itself.
teuobk•1y ago
Awesome! I love seeing how the blocks are affected by twiddling bits.
pveierland•1y ago
Super cool interface to explore. It took a bit of playing around with the UI to understand all the features. My only feedback would be to try to make the "Continue" part of the flow to get to the sandbox easier to discover.
Xiione•1y ago
Thanks! The "continue" was one of those things that started off as a placeholder and didn't change much, I'll definitely be adjusting it.
solardev•1y ago
This is really cool! Thanks for sharing!

Is there a way to get it to compute and visualize the MAXIMUM possible error rate for any given QR code? Like what is the greatest number and arrangement of pixels that could be altered before the QR code is no longer readable?

(Bonus: Is this a setting that can be controlled during QR code generation, based on version number or error correction level, etc.? Can you make some sort of huge and very complex QR code with a lot more redundancy than a smaller one?)

Xiione•1y ago
Thanks for checking it out! Essentially, for any given QR code the maximum error rate is reached when you deplete every block's health bar to 1 remaining slice, making sure to invert every pixel in each codeword you've touched (the individual tetris-piece shaped chunks), and then introduce one more single pixel error in any block. This is actually independent of the arrangement of corrupted codewords within each block.

The amount of redundancy is determined solely by the specific version-ecLevel pair a code has. So, the code with the largest amount of redundancy (in bytes) is one that has version 40 and EC level H - a staggering 2.43kB of redundancy vs. 1.28kB of data! See this particular sample: https://qris.cool/decode?sample=135

Tensordyne makes a big bet on log math to beat Nvidia

https://www.theregister.com/systems/2026/06/19/tensordyne-makes-a-big-bet-on-log-math-to-beat-nvi...
1•galaxyLogic•57s ago•0 comments

Peacock Spider

https://www.peacockspider.org
1•lujz•2m ago•0 comments

Cuckoo Tracking Project

https://www.bto.org/get-involved/volunteer/projects/cuckoo-tracking
1•austinallegro•3m ago•0 comments

Show HN: Generate images from the CLI with a ChatGPT subscription (no API key)

https://github.com/leeguooooo/chatgpt-imagegen
1•leeguoo•5m ago•0 comments

Homeschool

https://pollinatecurriculum.bubbleapps.io
1•LaminaECHSC•5m ago•0 comments

Fine-Tuning and Deploying LLMs on Mobile:F/b to learnings

https://www.youtube.com/watch?v=7N2n7lKtdME
1•thinkevolve•6m ago•0 comments

Free Agentic AI Webinar: From Agent Design to Production

https://simplai.ai/blogs/free-agentic-ai-webinar-from-agent-design-to-production/
2•SimplAI_ai•10m ago•0 comments

The Blu-ray Disc Format Turns 20

https://www.patreon.com/TheDigitalBits/posts/blu-ray-disc-20-161620352
2•lilytweed•12m ago•0 comments

Phones and Phonies: Commodore Shenanigans Through the Ages

https://www.datagubbe.se/commophone/
1•ingve•15m ago•0 comments

Tejas and Jayhawk

https://en.wikipedia.org/wiki/Tejas_and_Jayhawk
1•Teever•15m ago•0 comments

Accenture's crash shows the consultancy racket is finished

https://www.msn.com/en-us/news/technology/accenture-s-crash-shows-the-consultancy-racket-is-finis...
3•galaxyLogic•16m ago•0 comments

Notes on the Industry Job Search

https://alisawuffles.github.io/blog/job-search/
1•cosmoharrigan•16m ago•0 comments

An AI Agent Emailed Me

https://julien.danjou.info/blog/an-ai-agent-emailed-me/
1•enz•19m ago•0 comments

The AI architecture "attention" can't hold attention

https://scitechdaily.com/even-gpt-5-failed-this-human-attention-test/
2•nryoo•23m ago•0 comments

Gen Z earning more than millennials did at the same age

https://www.theguardian.com/money/2026/jun/22/gen-z-earning-more-millennials-same-age-resolution-...
3•sefrost•29m ago•0 comments

Xiaomi YU7 GT achieves the first autonomous driving lap record of Nürburgring

https://twitter.com/DriveGreen80167/status/2068920116671140045
1•gainsurier•35m ago•0 comments

Understanding Skills in AI: The Complete Guide to Building Smarter AI Agents

http://simplai.ai/blogs/understanding-skills-in-ai-the-complete-guide-to-building-smarter-ai-agen...
1•Shanmugaraj-1•38m ago•0 comments

China is having another AI moment

https://www.economist.com/china/2026/06/21/china-is-having-another-ai-moment
3•dataflow•38m ago•1 comments

Describe your trading strategy and we'll automate it for you

https://runhalcyon.com/
1•Entropnt•41m ago•0 comments

Update on CC Signals: What Changed and Why

https://creativecommons.org/2026/04/23/update-on-cc-signals-what-changed-and-why/
1•the-mitr•46m ago•0 comments

Age of Invention: Does History Have a Replication Crisis?

https://www.ageofinvention.xyz/p/age-of-invention-does-history-have
2•prakashqwerty•50m ago•0 comments

Deno Desktop

https://docs.deno.com/runtime/desktop/
48•GeneralMaximus•50m ago•8 comments

Estonia to become first country to create digital identities for AI agents

https://news.err.ee/1610060290/estonia-to-become-first-country-to-issue-id-codes-to-ai-agents
3•agulaya24•52m ago•2 comments

Show HN: NagMeLater – Reminders and to-do list, inside your WhatsApp

https://nagmelater.com
1•mehulfanawala•52m ago•0 comments

What Happens to Your Lessons Learned After the Meeting Ends?

https://www.projectmanagement.com/blog-post/80169/what-happens-to-your-lessons-learned-after-the-...
2•wmeller•54m ago•0 comments

Airbnb CEO Brian Chesky Plans to Start a New AI Company

https://www.bloomberg.com/news/articles/2026-06-04/airbnb-ceo-brian-chesky-plans-to-start-a-new-a...
3•stenlix•57m ago•0 comments

Staggering amounts of fentanyl hit streets as the DEA watched and took no action

https://apnews.com/article/dea-fentanyl-unseized-drugs-new-mexico-8f5b546e668e5007c64078da74b90903
3•petethomas•57m ago•0 comments

2004 Huygens probe to Saturn's Titan: still our only outer Solar System lander

https://spacedaily.com/t-no-spacecraft-has-ever-landed-in-the-outer-solar-system-except-one-the-h...
2•Gaishan•58m ago•0 comments

Debiasing Your Software Design Decision-Making

https://www.youtube.com/watch?v=rcLRzDm8cwQ
1•RebootStr•1h ago•0 comments

Show HN: Checkout the new Customisable Template feature for marketing content

https://www.clickcast.tech/template-editor
1•modulusme•1h ago•0 comments