Lineært feedback- skiftregister ( LFSR ) er et skifteregister af bitord , værdien af input (glidende) bit er lig med en lineær boolsk funktion fra værdierne af de resterende bits i registeret før skiftet. Det kan organiseres af både software og hardware. Det bruges til at generere pseudo-tilfældige bitsekvenser , som især bruges i kryptografi [1] . Et skiftregister med bærefeedback fungerer efter et lignende princip. generaliseret feedback-skiftregister .
I skifteregisteret med lineær feedback (RSLOS) er der to dele (moduler):
Registeret består af funktionelle hukommelsesceller (bits af et eller flere maskinord), som hver lagrer den aktuelle tilstand (værdi) af en bit. Antallet af celler kaldes registrets længde. Bits (celler) er normalt nummereret med tal , indholdet af den -th celle er angivet med . Værdien af den nye bit bestemmes før bitforskydningen i registeret og først efter at skiftet er skrevet til cellen , og den næste genererede bit ekstraheres fra cellen.
Feedbackfunktionen for LFSR er en lineær boolesk funktion af værdierne af alle eller nogle bits af registeret. Funktionen multiplicerer registerbittene med koefficienterne , hvor . Antallet af koefficienter er det samme som antallet af registerbits . Koefficienterne tager værdierne , og den sidste koefficient er lig med, da LFSR er givet af det karakteristiske gradpolynomium . Modulo 2-addition (“XOR”-operationen, angivet i formler med symbolet “ ”) eller dens logiske inversion “ XNOR ” er lineære booleske funktioner og bruges oftest i sådanne registre [2] . I dette tilfælde kaldes de bits, der er variable i feedbackfunktionen, taps , og selve registeret kaldes Fibonacci- konfigurationen [3] .
Registerkontrol i hardwareimplementeringer udføres ved at påføre en skiftimpuls (ellers kaldet en clock eller clock puls ) til alle celler. Registerstyring i softwareimplementeringer udføres ved at udføre en loop . Ved hver iteration af sløjfen beregnes feedbackfunktionen, og der udføres et bitskifte i ordet.
Under hver clock-cyklus udfører det lineære feedback-skifteregister følgende operationer:
Hvis feedbackfunktionen udfører den logiske operation " XOR " (eksklusiv ELLER), kan værdierne af bits (celler) beregnes ved hjælp af følgende formler [4] :
Skifteregisterets periode er minimumlængden af den resulterende sekvens, før den begynder at gentages. Længden LFSR har begyndelsestilstande, der definerer værdierne af bits i cellerne. Af disse er tilstandene ikke-nul, så den genererede sekvens har en periode på . Perioden for den genererede sekvens er maksimal og lig med , hvis feedbackpolynomiet (eller karakteristisk polynomium) over feltet er primitivt . For at gøre dette er det nødvendigt (men ikke tilstrækkeligt) at opfylde følgende 2 betingelser:
Antallet af alle mulige primitive polynomier er , hvor er Euler-funktionen [5] . Registeret givet af et sådant polynomium kaldes det maksimale periodeskiftregister (eller pseudo-tilfældige sekvensgenerator ), og de genererede sekvenser kaldes maksimale periodesekvenser (eller M-sekvenser ) [4] [6] .
Den lineære kompleksitet af en uendelig binær sekvens er tallet, som er defineret som følger:
Den lineære kompleksitet af en endelig binær sekvens er et tal svarende til længden af den korteste LFSR, der genererer denne sekvens.
Den lineære kompleksitet af et lineært feedback-skiftregister angiver, hvor tæt den genererede sekvens er på tilfældig . En effektiv algoritme til at bestemme den lineære kompleksitet af en endelig binær sekvens er Berlekamp-Massey-algoritmen .
I et forsøg på at opnå en høj lineær kompleksitet af den genererede sekvens kombinerer kryptografer ikke-lineært output fra flere skifteregistre. I dette tilfælde kan en eller flere outputsekvenser (eller endda output fra individuelle LFSR'er) forbindes med en fælles strøm og åbnes af en kryptoanalytiker . Et hack baseret på en sådan sårbarhed kaldes et korrelationsangreb . Hovedideen med et sådant hack er at finde en vis sammenhæng mellem output fra generatoren og output fra dens komponentdele. Så kan man ved at observere udgangssekvensen få information om disse mellemudgange og dermed hacke generatoren. Thomas Siegenthaler har vist, at det er muligt at definere korrelationsuafhængighed præcist, og at der er en afvejning mellem korrelationsuafhængighed og lineær kompleksitet [7] .
Softwareimplementeringer af RSLOS er ret langsomme og virker hurtigere, hvis de er skrevet i assembler . En af løsningerne er parallel brug af 16 RSLOS (eller 32, afhængig af ordlængden i computerarkitekturen). I et sådant skema bruges et array af ord, hvis størrelse er lig med længden af skifteregisteret, og hver bit af ordet refererer til sin egen LFSR. Da det samme antal tryksekvenser bruges, kan dette give en mærkbar gevinst i generatorens ydeevne [3] .
Overvej et 32-bit skifteregister. Der er en flugtsekvens for det . Dette betyder, at for at generere en ny bit, er det nødvendigt at summere 31., 30., 29., 27., 25. og 0. bit ved hjælp af XOR- operationen. Den resulterende LFSR har en maksimal periode . Koden for et sådant register i C er som følger:
int LFSR_Fibonacci ( ugyldig ) { statisk lang S = 0x00000001 uden fortegn ; S = (((( S >> 31 ) ^ ( S >> 30 ) ^ ( S >> 29 ) ^ ( S >> 27 ) ^ ( S >> 25 ) ^ S ) & 0x00000001 ) << 31 ) | ( S >> 1 ); retur S & 0x00000001 ; }Som i Fibonacci-konfigurationen er tilbagekoblingskredsløbet et sæt XOR-operationer af tap-bittene med output fra generatoren, men rækkefølgen af bits i registeret er omvendt: -th bit er input og -th bit er udgangen . Resultatet af tilføjelsen skrives til den næste celle, og den nye outputbit skrives til -th. Således, hvis den genererede bit er lig nul, så forskydes alle bit i cellerne til højre uden ændringer, hvis den genererede bit er lig med én, så ændrer tap-bittene deres værdi til det modsatte, og alle bits forskydes til højre. Både Fibonacci-konfigurationen og Galois -konfigurationen af samme længde genererer de samme sekvenser, men forskudt i tid fra hinanden (i dette tilfælde kan de interne tilstande af registrene være forskellige) [8] .
Denne generator har ikke større kryptografisk styrke , men den giver en ydelsesforstærkning: alle XOR-operationer gennem parallelisering kan udføres i én operation og ikke sekventielt efter hinanden, som i Fibonacci-konfigurationen. Denne ordning vil også give en gevinst i hardwareimplementering.
Koden for et 32-bit skiftregister i C er som følger:
int LFSR_Galois ( ugyldig ) { // for polynomium 0x80000057, omvendt 0xea000001 statisk uden fortegn lang S = 0x00000001 ; if ( S & 0x00000001 ) { S = (( S ^ 0x80000057 ) >> 1 ) | 0x80000000 ; returner 1 ;} andet { S >>= 1 ; returner 0 ;} }Det er værd at bemærke, at en løkke med et fast antal funktionskald LFSR_Galoisi Galois-konfigurationen er cirka 2 gange hurtigere end en funktion LFSR_Fibonaccii Fibonacci-konfigurationen ( MS VS 2010 compiler på Intel Core i5 ).
Lad LFSR være givet ved det karakteristiske polynomium . Det betyder, at tap- bittene bliver 2. og 0., og enheden i polynomialformlen betyder, at 0. bit er input. Feedbackfunktionen har formen . Lad os sige, at den oprindelige tilstand af skifteregisteret var sekvensen . Yderligere tilstande i registret er vist i tabellen nedenfor:
Trinnummer | Stat | Bit genereret |
---|---|---|
0 | en | |
en | 0 | |
2 | 0 | |
3 | en | |
fire | en | |
5 | en | |
6 | 0 | |
7 | en |
Da den interne tilstand i det syvende trin vendte tilbage til sin oprindelige tilstand, vil bitsene blive gentaget fra næste trin. Det vil sige, at den genererede sekvens er som følger: (rækkefølgen af bits i sekvensen svarer til den rækkefølge, hvori de blev genereret af LFSR). Således er sekvensens periode 7, det vil sige den maksimalt mulige værdi, som skete på grund af primitiviteten af det givne polynomium.
Lad os tage det samme karakteristiske polynomium, det vil sige . Kun 1. bit tilføjes til outputbit. Starttilstanden er den samme. Yderligere tilstande i registret:
Trinnummer | Stat | Bit genereret |
---|---|---|
0 | en | |
en | en | |
2 | en | |
3 | 0 | |
fire | en | |
5 | 0 | |
6 | 0 | |
7 | en |
Registerets interne tilstand i det syvende trin vendte tilbage til sin oprindelige tilstand, derfor er dets periode også lig med 7. I modsætning til Fibonacci-konfigurationen viste de interne tilstande af registeret sig at være forskellige, men den genererede sekvens er den samme , kun forskudt med 4 cyklusser : (rækkefølgen af bits i sekvensen svarer til rækkefølgen af deres generering af LFSR).
afsnit af den engelske artikel
At beregne et primitivt polynomium over et felt er et ret kompliceret matematisk problem: for at generere et primitivt gradspolynomium skal du kende faktorerne for tallet . Det er nemmere at vælge et polynomium tilfældigt og teste det for primitivitet [3] . En anden metode er at bruge færdige tabeller, der viser antallet af tryksekvenser, der giver den maksimale periode for generatoren. Nedenfor er en tabel med primitive polynomier over feltet for skifteregistre med en maksimal periode på op til 19 bit [5] . Det er værd at overveje, at en generator af en given længde kan have mere end et primitivt polynomium i henhold til deres egenskaber . En komplet liste for registre på 4 til 32 bit lange kan findes her .
stykker, | Primitivt polynomium | Periode, | Antal primitive polynomier |
---|---|---|---|
2 | 3 | en | |
3 | 7 | 2 | |
fire | femten | 2 | |
5 | 31 | 6 | |
6 | 63 | 6 | |
7 | 127 | atten | |
otte | 255 | 16 | |
9 | 511 | 48 | |
ti | 1023 | 60 | |
elleve | 2047 | 176 | |
12 | 4095 | 144 | |
13 | 8191 | 630 | |
fjorten | 16383 | 756 | |
femten | 32767 | 1800 | |
16 | 65535 | 2048 | |
17 | 131071 | 7710 | |
atten | 262143 | 7776 | |
19 | 524287 | 27594 | |
20 - 168 | [en] | ||
2 - 786, 1024, 2048, 4096 | [2] |
Denne type generator består af flere lineære feedback-skifteregistre, der genererer bit hhv. Dernæst konverteres de genererede bits af en boolsk funktion . Det skal bemærkes, at for generatorer af denne type er registerlængderne , , relativt prime i forhold til hinanden.
Perioden for denne generator er , hvor er det samlede antal celler. Derfor øger brugen af flere LFSR'er perioden for den genererede sekvens sammenlignet med et enkelt register, hvilket øger generatorens kryptografiske styrke . Det øger også den lineære kompleksitet eller længden af det korteste register svarende til en given generator. Et sådant register findes ved hjælp af Berlekamp-Massey-algoritmen ved hjælp af den genererede sekvens. I bedste fald er dens længde i forhold til perioden for den genererede sekvens [4] .
Blokdiagrammet for en sådan generator er ikke forskelligt fra diagrammet for den tidligere generator. Den største forskel er, at transformationsenheden er givet af en ikke-lineær boolesk funktion . Som sådan en funktion tages for eksempel Zhegalkin-polynomiet (ifølge Zhegalkin- sætningen kan enhver boolsk funktion være entydigt repræsenteret af Zhegalkin-polynomiet).
En ikke-lineær generator kan også implementeres på et skifteregister med ikke-lineær feedback . Det kan give varianter af sekvenser af den maksimale periode , som er mere end den for LFSR [5] .
Den kryptografiske styrke af denne generator øges på grund af den anvendte funktions ikke-linearitet. At bestemme registrenes tilstand ud fra den genererede bitsekvens er et komplekst matematisk problem, fordi der ikke kendes nogen algoritme, der gendanner de oprindelige tilstande.
Denne metode bruges for eksempel i Geff-generatoren og den generaliserede Geff-generator, dog kan sådanne generatorer hackes ved korrelationsanalyse [7] .
Stop-and-Go- generatoren ( eng. Stop-and-Go , Both-Piper ) bruger outputtet fra LFSR-1 til at styre LFSR-2's klokfrekvens , så LFSR-2 ændrer sin tilstand på et tidspunkt kun hvis udgangen af LFSR-1 på det tidspunkt var lig med én. Dette skema modstod ikke korrelationsåbningen [3] .
For at øge kryptografisk styrke blev en interleaved stop-go generator foreslået . Den bruger tre skifteregistre af forskellig længde. Her styrer LFOS-1 klokfrekvensen for 2. og 3. register, dvs. LFSR-2 ændrer sin tilstand, når LFSR-1-udgangen er lig med en, og LFSR-3 - når LFSR-1-udgangen er lig nul. Udgangen af generatoren er driften af modulo to af udgangene på RLOS-2 og RLLS-3. Denne generator har en stor periode og en stor lineær kompleksitet. Der er en metode til korrelationsåbning af RLOS-1, men dette svækker ikke generatorens kryptografiske egenskaber.
Et mere kompliceret clocking-skema bruges i en to-vejs stop-and-go generator , som bruger 2 skifteregistre af samme længde. Hvis outputtet af LFSR-1 på et bestemt tidspunkt er lig med nul, og på et tidspunkt er det lig med én, så klokkes LFSR-2 ikke på tidspunktet . Hvis udgangen af LFSR-2 på tidspunktet for tiden er lig med nul, og på tidspunktet er den lig med én, og hvis dette register er clocket på tidspunktet , så er LFSR-1 i samme øjeblik ikke uret. Den lineære kompleksitet af dette kredsløb er omtrent lig med perioden for den genererede sekvens.
Selvdecimerende generatorSelvdecimerede oscillatorer styrer deres egen frekvens . Der er to typer af sådanne generatorer. Den første blev foreslået af Rainer Rüppel . Det består af et skifteregister og et lineært feedbackkredsløb, der clocker registeret baseret på, hvordan skifteregisteret udsender. Hvis LFSR-udgangen er lig med én, klokkes registeret med én frekvens, og hvis udgangen er nul, så med en anden. Den anden type blev foreslået af Bill Chambers og Dieter Kollman . Feedbackkredsløbet modtager ikke selve udgangssignalet, men resultatet af XOR-driften af visse LFSR-bits.
Der er også krympende og selvkrympende generatorer . _ _ _ De er ret nye, og ikke alle deres egenskaber er velundersøgte. Den første bruger to LFSR'er. Hvis en clock-impuls påføres generatoren, og udgangen af RLOS-1 er én, så vil udgangen af generatoren være udgangen af RLLS-2. Ellers, når en urimpuls påføres, nulstilles begge bit, og uret starter forfra. I den anden generator, i stedet for at kontrollere udgangene fra to registre for 0 eller 1, kontrolleres 2 bits af et register.
Den decimerede generator kan hackes, hvis feedbackpolynomierne decimeres. Derudover er dens generationshastighed ikke konstant. En selvdecimerende generator har brug for omkring 2 gange mindre hukommelse end den første, men den arbejder 2 gange langsommere [7] .
Multirate oscillator med indre produktDenne generator bruger to skifteregistre RSLOS-1 og RSLOS-2. Klokkefrekvensen for RSLOS-2 er flere gange højere end for RSLOS-1. Visse bits af disse registre multipliceres med hinanden ved hjælp af OG- operationen . Resultaterne af multiplikationerne adderes ved XOR-operationen, og outputsekvensen opnås. Denne generator har en høj lineær kompleksitet og har gode statistiske egenskaber. Imidlertid kan dens tilstand bestemmes ud fra udgangssekvensen af længde , hvor og er længderne af henholdsvis LFSR-1 og LFSR-2, og er forholdet mellem deres klokfrekvenser.
Gollmann CascadeDette kredsløb er en forbedret version af stop-go generatoren. Den består af en sekvens af LFSR'er, hvor timingen af hver styres af den foregående LFSR. Hvis udgangen af LFSR-1 på tidspunktet er 1, klokkes LFSR-2. Hvis outputtet af LFSR-2 på tidspunktet er 1, bliver LFSR-3 clocket, og så videre. Outputtet fra den sidste LFSR er outputtet fra generatoren. Hvis længden af alle LFSRs er den samme og lig med , så er perioden for LFSR-systemet , og den lineære kompleksitet er [7] .
Denne idé er enkel og kan bruges til at generere sekvenser med store perioder, store lineære kompleksiteter og gode statistiske egenskaber. Men desværre er de modtagelige for et angreb kaldet lock - in , når en kryptoanalytiker , der først genopretter inputsekvensen for det sidste register i kaskaden, bryder hele kaskaden, register for register. Når antallet af registre stiger, nærmer den genererede sekvens sig tilfældig , så det er bedre at bruge flere LFSR'er med lille længde end færre lange LFSR'er.
Majoritetsgenerator (eller tærskel ) består af et stort antal skifteregistre, hvis udgange går til den enhed, der er specificeret af majoriseringsfunktionen, for eksempel majoritetselementet . Det særlige ved denne generator er, at hvert af skifteregistrene har sin egen clockbit , , som er variablerne for majoritetsfunktionen. For tre registre har en sådan funktion f.eks. formen . Kun de registre forskydes, hvis clock-bits er lig med værdien , det vil sige, at forskydningen af registrene sker på størstedelen af værdierne af sådanne bits: 0 eller 1.
Således får vi en generator med et variabelt antal LFSR'er. Dens lineære kompleksitet er , hvor er længden af det -th register [7] . Ulemperne ved en sådan generator er muligheden for direkte opregning og korrelationsåbning (hver outputbit giver noget information om skifteregisterets tilstand, for at være præcis - 0,189 bit).
Lignende generatorer bruges i A5 - krypteringsalgoritmer (A5/1, A5/2).
Lineære feedback-skiftregistre kan implementeres i hardware, hvilket gør det muligt at bruge dem til hurtig pseudo-tilfældig sekvensgenerering , såsom direkte sekvens spredt spektrum eller støjsignalgenerering [9] .
Lineære feedback-skifteregistre har længe været brugt som pseudo-tilfældige sekvensgeneratorer til strømchiffer (især i militær kryptografi ). LFSR er dog et lineært skema og kan i nogle tilfælde nemt hackes. For eksempel kan en kryptoanalytiker opsnappe en del af chifferteksten og bruge den ved at bruge den ovennævnte Berlekamp-Massey-algoritme til at rekonstruere en minimumsstørrelse LFSR, der efterligner den originale LFSR. Derefter kan den opsnappede tekst føres ind i det modtagne register og dekrypteres. Metoder til at øge den kryptografiske styrke af stream ciphers baseret på LFSR er givet ovenfor .
Det lineære feedback-skiftregister er grundlaget for stream-cifre som A5/1 og A5/2, der bruges i GSM -standarden, og E0 -chifferen , der bruges i Bluetooth . A5/2-cifferet er blevet brudt, og A5/1- og E0-cifferet er alvorligt fejlbehæftet [10] [11] .
Det lineære feedback-skiftregister er tæt forbundet med den lineære kongruentiale generator [12] .
Frekvensen af den genererede LFSR-sekvens giver dig mulighed for at bruge den som en urdeler eller tæller [13] . En tæller baseret på en sådan oscillator har et forenklet feedbackkredsløb, i modsætning til konventionelle binære eller grå kodetællere , og kan derfor fungere ved høje clockhastigheder. Du skal dog sørge for, at en sådan tæller aldrig går i nultilstand.
I modsætning til en konventionel tæller går LFSR ikke fra en tilstand til en anden i rækkefølgen af binær tælling, hvilket gør det muligt at bruge den til at generere et testsignal, når der detekteres fejl i logiske kredsløb [6] .
Ligeledes bruges lineære feedback-skiftregistre i indbygget selvtest ( indbygget selvtest , BIST ) til signaturanalyse (detektion af bitfejl) i logiske kredsløb. Sådanne systemer bruges på grund af det begrænsede antal mikrokredsløbsudgange (ikke alle mellemliggende bitværdier kan anvendes på udgangen). BIST-systemet består af 3 blokke: en testsekvensgenerator og en signaturanalysator, som er bygget på basis af LFSR, og en testcontroller. Skiftregisteret i analysatoren "komprimerer" resultatet af kredsløbet for testsekvensen til en signatur og fortsætter med at arbejde, indtil alle dets bit, bortset fra 0, bliver lig med nul, det vil sige tilstanden . Sammen med LFSR er der en binær tæller, der tæller antallet af cyklusser siden afslutningen af testreaktionskomprimeringen. Hvis registrets begyndelsestilstand svarede til referencesignaturen (signatur af et fejlfrit kredsløb), så svarer tælleraflæsningen til nummeret på den fejlagtige bit [14] [15] .
Da LFSR udfører komprimering med tab, er det sandsynligt, at i et skema med fejl vil den resulterende signatur være lig med referencen. Dette kan undgås ved at bruge en signaturanalysator med flere indgange.
Lineære feedback-skiftregistre bruges i scrambling for at producere en digital strøm med tilfældige sekvensegenskaber . En pseudo-tilfældig LFSR-sekvens med maksimal længde tilføjes modulo 2 til den transmitterede bitstrøm, og sekvensen genereres med samme hastighed som datatransmissionen. Nogle systemer og teknologier, der bruger scrambling er: