QR-kod

QR-kod [a] ( eng.  Snabbsvarskod  - snabbsvarskod [2] ; förkortning QR-kod ) - en typ av matrisstreckkoder (eller tvådimensionella streckkoder ), ursprungligen utvecklad för bilindustrin i Japan . Masahiro Hara [3] anses vara dess skapare . Termen i sig är ett registrerat varumärke som tillhör det japanska företaget Denso . En streckkod är en maskinläsbar optisk etikett som innehåller information om föremålet som den är fäst vid. QR-koden använder fyra standardiserade kodningslägen (numeriska, alfanumeriska, binära och kanji ) för att lagra data effektivt; tillägg [4] kan också användas .

QR-kodsystemet har blivit populärt utanför bilindustrin på grund av dess snabba läsbarhet och högre kapacitet jämfört med UPC standard streckkoder . Tillägg inkluderar produktspårning, artikelidentifiering, tidsspårning, dokumenthantering och allmän marknadsföring [5] .

En QR-kod består av svarta rutor arrangerade i ett kvadratiskt rutnät på en vit bakgrund, som kan läsas av avbildningsenheter som en kamera och bearbetas med Reed-Solomon-koder tills bilden känns igen ordentligt. Nödvändig data extraheras sedan från mönstren som finns i bildens horisontella och vertikala komponenter [5] .

Beskrivning

På den tiden då det inte fanns någon QR-kod utfördes komponentskanning på Densofabriken med olika streckkoder. Men på grund av att det fanns ett 10-tal av dem var arbetseffektiviteten extremt låg, och arbetarna klagade på att de snabbt tröttnade och bad även om att det skulle skapas en kod som kunde innehålla mer information än en vanlig streckkod. För att svara på den här arbetarens förfrågan satte Denso-Wave sig för att skapa en kod som kunde innehålla mer information för att möjliggöra höghastighetskomponentskanning. [6] För att göra detta började Masahiro Hara, som arbetade på utvecklingsavdelningen, utveckla ny kod från 1992. [7] Inspirationen till QR-koden kom från spelet Go som Masahiro Hara spelade under sin lunchrast. [7] Han bestämde sig för att designmålet inte bara var att öka mängden kodinformation, utan också att "läsa exakt och snabbt", samt att göra koden läsbar och motståndskraftig mot oljefläckar, smuts och skador, vilket tyder på att den kommer att användas i respektive bransch. QR-koden introducerades av det japanska företaget Denso-Wave 1994 efter en tvåårig utvecklingsperiod. [8] [9] [10] Den designades med Toyotas produktionssystem Kanban ( just in time ) i åtanke för användning i bildelarfabriker och distributionscenter. Men eftersom den har en hög feldetekterings- och korrigeringsförmåga och är gjord i öppen källkod , har den flyttat utanför Toyotas snäva räckvidd av tillverkningskedjor och har använts inom andra områden, vilket har lett till att den nu är allmänt används inte bara i Japan utan över hela världen. Den enorma populariteten för streckkoder i Japan ledde till att mängden information som krypterats i dem snart upphörde att passa branschen. Japanerna började experimentera med nya moderna sätt att koda små mängder information i en grafisk bild. QR-koden har blivit en av de mest använda typerna av 2D-kod i världen. [11] QR-kodspecifikationen beskriver inte dataformatet .

Till skillnad från den gamla streckkoden, som skannas med en tunn stråle, upptäcks en QR-kod av en sensor eller kamera som en tvådimensionell bild. De tre rutorna i bildens hörn och de mindre tidsrutorna genom hela koden normaliserar bildstorleken och orienteringen, såväl som vinkeln med vilken sensorn är placerad mot bildytan. Poäng omvandlas till binära tal med kontrollsummaverifiering .

Den främsta fördelen med en QR-kod är dess lätta igenkänning genom skanningsutrustning , vilket gör det möjligt att använda den inom handel , produktion och logistik .

Även om beteckningen "QR-kod" är ett registrerat varumärke som tillhör DENSO Corporation, är användningen av koderna inte föremål för någon royalty , och de beskrivs och publiceras själva som ISO-standarder.

De mest populära QR-kodvisningarna stöder följande dataformat: URL , webbläsarbokmärke , e- post (med ämnesrad), SMS till nummer (med ämnesrad), MeCard, vCard , geografiska koordinater , Wi-Fi- nätverksanslutning .

Vissa program kan också känna igen GIF- , JPG- , PNG- eller MID- filer som är mindre än 4 KB och chiffertext , men dessa format har inte vunnit popularitet. [13]

Applikation

QR-koder är vanligast i Japan. Redan i början av år 2000 blev QR-koder så utbredda i landet att de kunde finnas på ett stort antal affischer, paket och varor, där sådana koder appliceras på nästan alla varor som säljs i butik, de placeras i annonshäften och referensböcker. Med hjälp av en QR-kod anordnar de till och med olika tävlingar och rollspel . Ledande japanska mobiloperatörer släpper gemensamt mobiltelefoner under sitt varumärke med inbyggt stöd för QR-kodsigenkänning [14] .

För närvarande är QR-koden också allmänt distribuerad i asiatiska länder, och utvecklas gradvis i Europa och Nordamerika. Han fick det största erkännandet bland mobilkommunikationsanvändare - genom att installera ett igenkänningsprogram kan abonnenten omedelbart skriva in textinformation i sin telefon, ansluta till ett Wi-Fi-nätverk , skicka brev via e-post , lägga till kontakter i adressboken, följa webblänkar, skicka SMS , etc.

Enligt en studie utförd av comScore 2011 använde 20 miljoner invånare i USA mobiltelefoner för att skanna QR-koder [15] .

I Japan, Österrike och Ryssland används QR-koder även på kyrkogårdar och innehåller information om den avlidne [16] [17] [18] .

I den kinesiska staden Hefei delades märken med QR-koder ut till de äldre, tack vare vilka förbipasserande kan hjälpa vilsna gamla människor att komma hem [19] .

QR-koder används aktivt av museer [20] , såväl som inom turism, både längs turistvägar och vid olika föremål. Plattor gjorda av metall är mer hållbara och motståndskraftiga mot vandalism.

Använda QR-koder för att bekräfta vaccinationer

Samtidigt med starten av massvaccination mot COVID-19 våren 2021 började nästan alla världens länder att utfärda vaccinationsdokument – ​​digitala eller papperscertifikat, på vilka QR-koder placerades överallt. Senast den 9 november 2021 infördes QR-koder för att bekräfta vaccination eller tidigare sjukdom ( COVID-19 ) i 77 beståndsdelar i Ryska federationen (i vissa av dem försenades starten av QR-koder för att ge befolkningen möjlighet att få vaccinerade). I Tatarstan har införandet av QR-koder lett till trängsel vid tunnelbaneentréer och många konflikter mellan passagerare och kollektivtrafikledare [21] .

Allmän teknisk information

Den minsta QR-koden (version 1) har en storlek på 21×21 pixlar (exklusive marginaler), den största (version 40) är 177×177 pixlar. Kopplingen mellan versionsnumret och antalet moduler är enkel - QR-koden för nästa version är större än den föregående med strikt 4 moduler horisontellt och vertikalt.

Det finns fyra huvudkodningar av QR-koder:

Det finns också "pseudo-kodningar": specificera hur data kodas, dela upp ett långt meddelande i flera koder, etc.

För att korrigera fel används Reed-Solomon-koden med ett 8-bitars kodord. Det finns fyra nivåer av redundans: 7, 15, 25 och 30 %. Tack vare felkorrigering är det möjligt att sätta en bild på en QR-kod och ändå låta den vara läsbar.

För att det inte ska finnas några element i koden som kan förvirra skannern läggs dataområdet till modulo 2 med en speciell mask. En korrekt fungerande kodare måste prova alla maskalternativ, beräkna straffpoängen för var och en enligt speciella regler och välja den mest framgångsrika.

Micro QR

Separat finns en mikro QR-kod med en kapacitet på upp till 35 siffror.

Datalagringseffektiviteten jämfört med den traditionella QR-koden förbättras avsevärt genom att endast använda en positioneringstagg, jämfört med tre taggar i en konventionell QR-kod. På grund av detta frigörs ett visst utrymme som kan användas för data. Dessutom kräver en QR-kod en fri marginal runt koden som är minst 4 moduler bred (minsta konstruktionsenhet för en QR-kod), medan en Micro QR-kod kräver en marginal på två moduler bred. På grund av den större effektiviteten av datalagring ökar storleken på Micro QR-koden inte lika mycket med ökningen av mängden kodad data jämfört med den traditionella QR-koden.

I analogi med felkorrigeringsnivåer i QR-koder kommer Micro QR-kod i fyra versioner, M1-M4 [22] [23] .

Kodversion Antal moduler Felkorrigeringsnivå Tal Siffror och bokstäver Binära data Kanji
M1 elva - 5 - - -
M2 13 L (7 %) tio 6 - -
M (15 %) åtta 5 - -
M3 femton L (7 %) 23 fjorton 9 6
M (15 %) arton elva 7 fyra
M4 17 L (7 %) 35 21 femton 9
M (15 %) trettio arton 13 åtta
Q (25 %) 21 13 9 5

Datakodning

Det finns flera sätt att koda information i en QR-kod, och valet av en specifik metod beror på vilka symboler som används. Om endast siffror från 0 till 9 används, kan numerisk kodning användas, om det, förutom siffror, är nödvändigt att kryptera bokstäver i det latinska alfabetet, mellanslag och symboler $%*+-./:, används alfanumerisk kodning. Det finns också kanji-kodning, som används för att kryptera kinesiska och japanska tecken, och byte-kodning. Före varje kodningsmetod skapas en tom bitsekvens, som sedan fylls i.

Digital kodning

Denna typ av kodning kräver 10 bitar per 3 tecken. Hela teckensekvensen är uppdelad i grupper om 3 siffror, och varje grupp (tresiffrigt nummer) översätts till ett 10-bitars binärt tal och läggs till bitsekvensen. Om det totala antalet tecken inte är en multipel av 3, och om 2 tecken återstår i slutet, kodas det resulterande tvåsiffriga talet med 7 bitar, och om 1 tecken, då med 4 bitar.

Till exempel finns det en sträng "12345678" som måste kodas. Sekvensen är uppdelad i siffror: 123, 456 och 78, sedan konverteras varje nummer till binär form: 0001111011, 0111001000 och 1001110, och kombineras till en bitström: 000111101101110010101.

Alfanumerisk kodning

Till skillnad från digital kodning krävs 11 bitar av information för att koda 2 tecken. Teckensekvensen är uppdelad i grupper om 2, i gruppen kodas varje tecken enligt tabellen "Teckenvärden i alfanumerisk kodning". Värdet på det första tecknet multipliceras med 45, sedan läggs värdet på det andra tecknet till denna produkt. Det resulterande talet omvandlas till ett 11-bitars binärt tal och läggs till bitsekvensen. Om det finns ett tecken kvar i den sista gruppen kodas dess värde som ett 6-bitars nummer. Tänk på ett exempel: "BEVIS". Vi delar upp teckensekvensen i grupper: PR , OO , F . Vi hittar motsvarande värden för symbolerna för varje grupp (titta på tabellen): PR  - (25.27), OO  - (24.24), F  - (15). Hitta värdena för varje grupp: 25 × 45 + 27 = 1152, 24 × 45 + 24 = 1104, 15 = 15. Konvertera varje värde till binärt: 1152 = 10010000000, 1104 = 1000101000, 1000101000, 1,0100,0,0. sekvens: 1001000000010001010000001111.

Bytekodning

Alla tecken kan kodas på detta sätt. Den inmatade teckenströmmen kodas i valfri kodning (rekommenderas i UTF-8 ), konverteras sedan till binär form, varefter den kombineras till en enda bitström.

Till exempel är ordet "World" kodat i Unicode (HEX) i UTF-8 : M - D09C; och - DOB8; p - D180. Vi översätter varje värde till det binära systemet: D0 = 11010000, 9C = 10011100, D0 = 11010000, B8 = 10111000, D1 = 11010001 och 80 = 10000000; kombinera till en bitström: 11010000 10011100 11010000 10111000 11010001 10000000.

Kanji

Kodningen av hieroglyfer (liksom andra symboler) är baserad på en visuellt uppfattad tabell eller lista över bilder av hieroglyfer med deras koder. En sådan tabell kallas "teckenuppsättning". För japanska är två teckentabeller av primär betydelse: JIS 0208:1997 och JIS 0212:1990. Den andra av dem fungerar som ett komplement till den första. JIS 0208:1997 är uppdelad i 94 sidor med 94 tecken. Till exempel är sidan 4 hiragana, sidan 5 är katakana, 7 är kyrillisk, 16-43 är nivå 1 kanji och 48-83 är nivå 2 kanji. Nivå 1 kanji ("JIS daiichi suijun kanji") ordnas av onm. Nivå 2 kanji ("JIS daini suijun kanji") är ordnade efter nyckel och inom dem efter antalet slag.

Lägga till tjänstinformation

Efter att ha bestämt kodversionen och kodningen är det nödvändigt att bestämma nivån för felkorrigering. Tabellen visar de maximala värdena för korrigeringsnivåer för olika versioner av QR-koden. För att korrigera fel används Reed-Solomon-koden med ett 8-bitars kodord.

Tabell. Den maximala mängden information.
Rad — korrigeringsnivå, kolumn — versionsnummer.

ett 2 3 fyra 5 6 7 åtta 9 tio elva 12 13 fjorton femton 16 17 arton 19 tjugo
L 152 272 440 640 864 1088 1248 1552 1856 2192 2592 2960 3424 3688 4184 4712 5176 5768 6360 6888
M 128 224 352 512 688 864 992 1232 1456 1728 2032 2320 2672 2920 3320 3624 4056 4504 5016 5352
F 104 176 272 384 496 608 704 880 1056 1232 1440 1648 1952 2088 2360 2600 2936 3176 3560 3880
H 72 128 208 288 368 480 528 688 800 976 1120 1264 1440 1576 1784 2024 2264 2504 2728 3080
21 22 23 24 25 26 27 28 29 trettio 31 32 33 34 35 36 37 38 39 40
L 7456 8048 8752 9392 10208 10960 11744 12248 13048 13880 14744 15640 16568 17528 18448 19472 20528 21616 22496 23648
M 5712 6256 6880 7312 8000 8496 9024 9544 10136 10984 11640 12328 13048 13800 14496 15312 15936 16816 17728 18672
F 4096 4544 4912 5312 5744 6032 6464 6968 7288 7880 8264 8920 9368 9848 10288 10832 11408 12016 12656 13328
H 3248 3536 3712 4112 4304 4768 5024 5288 5608 5960 6344 6760 7208 7688 7888 8432 8768 9136 9776 10208

Efter att ha bestämt felkorrigeringsnivån är det nödvändigt att lägga till servicefält, de skrivs före bitsekvensen som erhålls efter kodningssteget. De anger kodningsmetoden och mängden data. Värdet på kodningsmetodfältet består av 4 bitar, det ändras inte, utan fungerar som ett tecken som indikerar vilken kodningsmetod som används. Det har följande betydelser:

Exempel:

Det tidigare exemplet med bytekodning kodade ordet "World", vilket resulterade i följande binära kodsekvens:

11010000 10011100 11010000 10111000 11010001 10000000 som innehåller 48 bitar information.

Låt nivån för felkorrigering H krävas, vilket gör det möjligt att återställa 30 % av den förlorade informationen. Enligt tabellen väljs den optimala versionen av QR-koden från den maximala mängden information (i detta fall version 1, som tillåter kodning av 72 bitar av användbar information vid felkorrigeringsnivå H).

Information om kodningsmetoden: fält 0100 motsvarar byte-kodningen.

Indikering av mängden data (för numerisk och alfanumerisk kodning - antalet tecken, för bytekodning - antalet byte): denna sekvens innehåller 6 byte data (i binärt: 110).

Enligt tabellen bestäms den erforderliga längden på det binära numret - 8 bitar. De saknade nollorna läggs till: 00000110.

Version 1-9 Version 10-26 Version 27-40
Digital 10 bitar 12 bitar 14 bitar
Alfanumerisk 9 bitar 11 bitar 13 bitar
Byte 8 bitar 16 bitar 16 bitar

All information skrivs i ordningen <kodningsmetod> <mängd data> <data>, vilket resulterar i en sekvens av bitar:

0100 00000110 11010000 10011100 11010000 10111000 11010001 10000000.

Blockerar

Sekvensen av bytes är uppdelad i antalet block definierade för versionen och korrigeringsnivån, vilket anges i tabellen "Antal block". Om antalet block är lika med ett, kan detta steg hoppas över. Och när versionen uppgraderas läggs speciella block till.

Först bestäms antalet byte (data) i vart och ett av blocken. För att göra detta måste du dividera hela antalet byte med antalet datablock. Om detta tal inte är ett heltal, måste du bestämma resten av divisionen. Denna återstod avgör hur många block av alla som är vadderade (sådana block, antalet byte i vilka är en mer än i resten). Tvärtemot förväntan ska de vadderade blocken inte vara de första blocken, utan de sista. Sedan kommer den sekventiella fyllningen av block.

Exempel: för version 9 och korrigeringsnivå M är datamängden 182 byte, antalet block är 5. Om vi ​​dividerar antalet databyte med antalet block får vi 36 byte och 2 byte i resten. Detta betyder att datablocken kommer att ha följande storlekar: 36, 36, 36, 37, 37 (byte). Om det inte fanns någon rest, skulle alla 5 blocken ha en storlek på 36 byte.

Blocket är helt fyllt med bytes från data. När det aktuella blocket är fullt flyttas kön till nästa. Bytes med data bör räcka exakt för alla block, varken mer eller mindre.

Skapande av korrigeringsbytes

Processen är baserad på Reed-Solomon- algoritmen . Den måste tillämpas på varje informationsblock i QR-koden. Först bestäms antalet korrigeringsbytes som ska skapas, och sedan, baserat på dessa data, skapas ett genereringspolynom. Antalet korrigeringsbyte per block bestäms av den valda kodversionen och felkorrigeringsnivån (given i tabellen).

Tabell. Antal korrigeringsbyte per block
Rad — korrigeringsnivå, kolumn — versionsnummer.
ett 2 3 fyra 5 6 7 åtta 9 tio elva 12 13 fjorton femton 16 17 arton 19 tjugo 21 22 23 24 25 26 27 28 29 trettio 31 32 33 34 35 36 37 38 39 40
L 7 tio femton tjugo 26 arton tjugo 24 trettio arton tjugo 24 26 trettio 22 24 28 trettio 28 28 28 28 trettio trettio 26 28 trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio
M tio 16 26 arton 24 16 arton 22 22 26 trettio 22 22 24 24 28 28 26 26 26 26 28 28 28 28 28 28 28 28 28 28 28 28 28 28 28 28 28 28 28
F 13 22 arton 26 arton 24 arton 22 tjugo 24 28 26 24 tjugo trettio 24 28 28 26 trettio 28 trettio trettio trettio trettio 28 trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio
H 17 28 22 16 22 28 26 26 24 28 24 28 22 24 24 trettio 28 28 26 28 trettio 24 trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio trettio

Det genererande polynomet bestäms av antalet korrigeringsbyte (givet i tabellen).


Tabell. Generera polynom.
Antal korrigeringsbytes Genererar polynom
7 87, 229, 146, 149, 238, 102, 21
tio 251, 67, 46, 61, 118, 70, 64, 94, 32, 45
13 74, 152, 176, 100, 86, 100, 106, 104, 130, 218, 206, 140, 78
femton 8, 183, 61, 91, 202, 37, 51, 58, 58, 237, 140, 124, 5, 99, 105
16 120, 104, 107, 109, 102, 161, 76, 3, 91, 191, 147, 169, 182, 194, 225, 120
17 43, 139, 206, 78, 43, 239, 123, 206, 214, 147, 24, 99, 150, 39, 243, 163, 136
arton 215, 234, 158, 94, 184, 97, 118, 170, 79, 187, 152, 148, 252, 179, 5, 98, 96, 153
tjugo 17, 60, 79, 50, 61, 163, 26, 187, 202, 180, 221, 225, 83, 239, 156, 164, 212, 212, 188, 190
22 210, 171, 247, 242, 93, 230, 14, 109, 221, 53, 200, 74, 8, 172, 98, 80, 219, 134, 160, 105, 315,
24 229, 121, 135, 48, 211, 117, 251, 126, 159, 180, 169, 152, 192, 226, 228, 218, 111, 0, 117, 232, 117, 239, 239, 2, 2,
26 173, 125, 158, 2, 103, 182, 118, 17, 145, 201, 111, 28, 165, 53, 161, 21, 245, 142, 13. 70
28 168, 223, 200, 104, 224, 234, 108, 180, 110, 190, 195, 147, 205, 27, 232, 201, 21, 43. 37, 9, 123
trettio 41, 173, 145, 152, 216, 31, 179, 182, 50, 48, 110, 86, 239, 96, 222, 125, 42, 173, 226. 216, 238, 40, 192, 180

Beräkningen görs baserat på värdena för den initiala datamatrisen och värdena för det genererande polynomet, och för varje steg i cykeln separat.

Kombinera informationsblock

I detta skede finns det två färdiga block: initiala data och korrigeringsblock (från föregående steg), de måste kombineras till en byteström. I sin tur är det nödvändigt att ta en byte med information från varje datablock, med början från det första och slutar med det sista. När kön når det sista blocket tas en byte från det och kön flyttas till det första blocket. Detta fortsätter tills varje block tar slut på byte. Det finns undantag när det aktuella blocket hoppas över om det inte finns några byte i det (en situation där vanliga block redan är tomma och det fortfarande finns en byte i de vadderade). Detsamma gäller för block av korrigeringsbytes. De tas i samma ordning som motsvarande datablock.

Resultatet är följande datasekvens: <1:a byten av det 1:a datablocket><1:a byten av det 2:a datablocket>...<1:a byten av det n:e datablocket><2:a byten av det 1:a blockdata>...<(m — 1):e byte av det 1:e datablocket>...<(m — 1):e byte av det n:e datablocket><mth byte av det k:te datablocket>...<mth byte av n:te datablock><1:a byte av 1:a korrigeringsbyte block><1:a byte av 2:a korrigeringsbyteblock>...<1:a byte av n:te korrigeringsbyteblock><2:a byte 1:e korrigeringsbyteblock>...<l:te byte av 1:a korrigeringsbyteblock>...<l:te byte av det n:te korrigeringsbyteblocket>.

Här är n antalet datablock, m är antalet byte per datablock för vanliga block, l är antalet korrigeringsbyte, k är antalet datablock minus antalet vadderade datablock (de med 1 byte mer ).

Stadiet för att placera information i kodfältet

Det finns obligatoriska fält på QR-koden, de innehåller inte kodad information, men innehåller information för avkodning. Det:

samt obligatorisk indrag runt koden . Vadderingen är en ram av vita moduler, dess bredd är 4 moduler.

Sökmönster  är 3 rutor i hörnen förutom längst ner till höger. Används för att bestämma platsen för koden. De består av en 3x3 kvadrat av svarta moduler, runt en ram av vita moduler med en bredd på 1, sedan en annan ram av svarta moduler, också med en bredd på 1, och ett staket från resten av koden - en halv ram av vita moduler med en bredd på 1. Totalt har dessa objekt en storlek på 8×8 moduler.

Justeringsmönster  - visas, från och med den andra versionen, används för ytterligare stabilisering av koden, mer exakt placering av den under avkodning. De består av 1 svart modul, runt vilken det finns en ram av vita moduler med en bredd på 1, och sedan en annan ram av svarta moduler, också med en bredd på 1. Den slutliga storleken på inriktningsmönstret är 5x5. Det finns sådana mönster i olika positioner beroende på versionsnummer. Justeringsmönster kan inte överlappa sökmönster. Nedan finns en tabell över platsen för den centrala svarta modulen, siffrorna anges där - dessa är möjliga koordinater, både horisontellt och vertikalt. Dessa moduler står i skärningspunkten mellan sådana koordinater. Nedräkningen sker från den övre vänstra noden, dess koordinater är (0,0).

ett 2 3 fyra 5 6 7 åtta 9 tio elva 12 13 fjorton femton 16 17 arton 19 tjugo
- arton 22 26 trettio 34 6, 22, 38 6, 24, 42 6, 26, 46 6, 28, 50 6, 30, 54 6, 32, 58 6, 34, 62 6, 26, 46, 66 6, 26, 48, 70 6, 26, 50, 74 6, 30, 54, 78 6, 30, 56, 82 6, 30, 58, 86 6, 34, 62, 90
21 22 23 24 25 26 27 28 29 trettio 31 32 33 34 35 36 37 38 39 40
6, 28, 50, 72, 94 6, 26, 50, 74, 98 6, 30, 54, 78, 102 6, 28, 54, 80, 106 6, 32, 58, 84, 110 6, 30, 58, 86, 114 6, 34, 62, 90, 118 6, 26, 50, 74, 98, 122 6, 30, 54, 78, 102, 126 6, 26, 52, 78, 104, 130 6, 30, 56, 82, 108, 134 6, 34, 60, 86, 112, 138 6, 30, 58, 86, 114, 142 6, 34, 62, 90, 118, 146 6, 30, 54, 78, 102, 126, 150 6, 24, 50, 76, 102, 128, 154 6, 28, 54, 80, 106, 132, 158 6, 32, 58, 84, 110, 136, 162 6, 26, 54, 82, 110, 138, 166 6, 30, 58, 86, 114, 142, 170

Synkroniseringsstaplar  - används för att bestämma storleken på modulerna. De är placerade i ett hörn, en börjar från det nedre vänstra sökmönstret (från kanten av den svarta ramen, men efter att ha korsat den vita), går till det övre vänstra och därifrån börjar den andra, enligt samma regel , den slutar uppe till höger. När den är placerad på utjämningsmodulen ska den förbli oförändrad. Synkroniseringsränder ser ut som linjer med omväxlande svarta och vita moduler.

Masken och korrigeringsnivåkoden  finns bredvid sökmönstren: under det övre högra hörnet (8 moduler) och till höger om det nedre vänstra (7 moduler), och dupliceras på sidorna av det övre vänstra, med ett mellanrum på den 7:e cellen - där synkroniseringsbanden går, dessutom den horisontella koden in i den vertikala delen, och den vertikala koden till den horisontella.

Versionskod  - behövs för att bestämma versionen av koden. De är placerade till vänster om det övre högra hörnet och ovanför det nedre vänstra, och dupliceras. De dupliceras så här - spegelkopian av den övre koden roteras moturs 90 grader. Nedan finns en tabell med koder, 1 - svart modul, 0 - vit.

Version 7 åtta 9 tio elva 12 13 fjorton femton 16 17 arton 19 tjugo 21 22 23
Versionskod 000010 011110 100110 010001 011100 111000 110111 011000 000100 101001 111110 000000 001111 111010 111100 001101 100100 011010 101011 100000 100110 110101 000110 100010 010011 000010 011110 011100 010001 011100 111010 010101 100000 100100 110011 100100 000010 110111 011000 000000 101001 111110 100110 101101 000010 111000 001011 000110 011110 001111 111010
24 25 26 27 28 29 trettio 31 32 33 34 35 36 37 38 39 40
001101 001101 100100 101011 001001 011000 110101 101111 011100 010011 101011 100000 010001 110101 000110 110111 110001 111010 101001 010111 111110 001111 010011 000010 101000 011000 101101 001110 011100 010001 010000 111010 010101 110110 111110 101001 110100 100000 001111 010010 100100 110011 001100 000010 110111 101010 000110 001011 111001 000100 010101

Mata in data

Det återstående lediga utrymmet är uppdelat i kolumner 2 moduler breda och information skrivs in där, och de gör det med en "orm". Först läggs den första informationsbiten in i den nedre högra kvadraten, sedan i sin vänstra granne, sedan i den som var ovanför den första, och så vidare. Kolumner fylls från botten till toppen, och sedan från topp till botten, etc., och längs kanterna fylls bitar från den yttersta delen av en kolumn till den yttersta delen av den intilliggande kolumnen, vilket sätter "ormen" på kolumner med en nedåtgående riktning. Om informationen inte räcker, lämnas fälten helt enkelt tomma (vita moduler). I detta fall appliceras en mask på varje modul.

Se även

Anteckningar

  1. Ordbildningsspecialisten M. A. Osadchiy föreslår att man använder frasen "grafisk kod" som en ryskspråkig motsvarighet [2] .
  1. QR-koder på Kinas tågbiljetter kan läcka personlig information . Arkiverad från originalet den 12 december 2013. Hämtad 16 mars 2013.
  2. 1 2 Pushkin Institute föreslog att döpa om QR-koden Arkivkopia daterad 10 februari 2022 på Wayback Machine // Radio Sputnik , 02/10/2022
  3. Historien om QR-koden Denna teknik uppfanns av en japansk ingenjör när han spelade Go at work . Hämtad 8 november 2021. Arkiverad från originalet 8 november 2021.
  4. QR  - kodfunktioner . Denso Wave. Hämtad 27 augusti 2017. Arkiverad från originalet 29 januari 2013.
  5. 1 2 QR Code Essentials  (engelska)  (länk ej tillgänglig) . Denso ADC (2011). Hämtad 28 augusti 2017. Arkiverad från originalet 12 maj 2013.
  6. Borko Furht. Handbook of Augmented Reality . - Springer, 2011. - S. 341. - ISBN 9781461400646 .
  7. 1 2 ヒント は 休憩 の の 囲碁 囲碁 だっ た た 『『 qr コード 』開発 生み の 親 明かす「 特許 オープン に し た 」ワケ ワケテレビ 放送 放送 放送 放送 放送 放送 放送 放送 放送 放送 放送 放送 放送 放送 放送 放送 放送 (29 november 2019) . Arkiverad 30 september 2020. Hämtad 29 november 2019.
  8. NHKビジネス特集 「QRコード」生みの親に聞いてみた Arkiverad 20 maj 2019 på Wayback Machine 20519え20
  9. 2D streckkoder . NHK World-Japan (26 mars 2020). Hämtad 24 april 2020. Arkiverad från originalet 7 april 2020.
  10. Denso-Wave webbplats . Hämtad 18 september 2012. Arkiverad från originalet 16 oktober 2012.
  11. QR-kod – Om 2D-kod (nedlänk) . Denso Wave. Hämtad 27 maj 2016. Arkiverad från originalet 5 juni 2016. 
  12. "Eugene Onegin" - nu även i QR-koden (otillgänglig länk) . Hämtad 23 november 2020. Arkiverad från originalet 27 november 2020. 
  13. QR- koders popularitet . Hämtad 8 januari 2022. Arkiverad från originalet 8 januari 2022.
  14. QR-kod: användning . Hämtad 14 mars 2010. Arkiverad från originalet 6 juni 2014.
  15. Leonid Bugaev. 2012, sida 167
  16. QR-koder på kyrkogårdar . Hämtad 24 april 2020. Arkiverad från originalet 15 maj 2021.
  17. QR-koder på kyrkogårdar (otillgänglig länk) . Hämtad 24 oktober 2012. Arkiverad från originalet 6 juni 2014. 
  18. Yury Nikulins barnbarn talar om ett interaktivt minnesmärke (otillgänglig länk) . Digitalt arv (21 augusti 2017). Hämtad 27 augusti 2017. Arkiverad från originalet 23 augusti 2017. 
  19. Märken med QR-koder för att hitta vägen hem . Hämtad 15 oktober 2014. Arkiverad från originalet 19 november 2014.
  20. Annons för museidagen 2012 . Hämtad 2 mars 2012. Arkiverad från originalet 24 april 2014.
  21. Vad är känt om lagförslaget om införande av QR-koder på offentliga platser Arkivexemplar daterat 20 december 2021 på Wayback Machine // TASS , 2021-12-16.
  22. Micro QR-kodbeskrivning | QR-koder av ny generation . qrcc.ru. Hämtad 9 juni 2018. Arkiverad från originalet 12 juni 2018.
  23. Mikro QR-kod | qrcode.com |  DENSO VÅG . www.qrcode.com Hämtad 31 maj 2019. Arkiverad från originalet 31 maj 2019.

Litteratur

Länkar