Digitální a kvantové počítače, část 3

Porovnání digitálních a kvantových počítačů, část 3: Problém diskrétního logaritmu

Každého v oblasti IT zajímá, jak velkou hrozbou pro kryptografii jsou kvantové počítače a jak se s daným problémem vyrovnat. Tato série článků se snaží populární formou tento problém vysvětlit. Po Problému faktorizace se můžeme podívat na problém diskrétního logaritmu.

Algoritmy využívající problém diskrétního logaritmu

V současnosti využíváme algoritmy založené na problému diskrétního logaritmu ve dvou hlavních skupinách. V první z těchto skupin je klasický a stále ještě používaný Diffie-Hellman (DH), dále dnes již výběhový algoritmus DSA (Digital Signature Algorithm), algoritmus ElGamal a Schnorrův podpis. Jedná se zde o nejznámější algoritmy, nikoliv celkový přehled. Uvedená skupina algoritmů pracuje nad omezenou skupinou celých čísel (operace modulo prvočíslo). Tato skupina používá klíče o velikosti jednotek kilobitů, což má dopady na rychlost. Jakékoliv operace s takto velkými čísly jsou poměrně složité. Druhou skupinou jsou algoritmy ECDH (Elliptic Curve Diffie-Hellman), ECDSA (Elliptic Curve DSA), ale take EdDSA (Edwards curve DSA). Ty pracují v několika variantách. Buď se jedná o body eliptické křivky nad číselným tělesem, omezené opět nějakým prvočíslem. Dále se může jednat o body eliptické křivky nad polynomy, omezené ireducibilním polynomem, případně jako poslední varianta se používají rozšíření těles. Klíče pro dosažení stejné úrovně bezpečnosti jsou o řád menší než u algoritmu RSA a zpravidla mají velikost maximálně stovek bitů. Teoreticky je možné používat i další přístupy založené na problému diskrétního logaritmu, ale o praktickém nasazení nevím, proto se jim zde nebudu věnovat.

Jsou tu tedy skupiny systémů, které mají podobné vlastnosti, ale stejně jako u algoritmu RSA, jaké jsou možnosti útoku? Co je a není v našich silách?

Pro útok na klasický Diffie-Hellman, DSA, ElGamal i Schnorr je možné použít NFS-DL (Number Field Sieve – Discrete Logarithm). První část výpočtu je třídění, používá řádově desítky tisíc instrukcí na krok s obtížnou predikcí větvení (branch prediction), jedná se zároveň o paměťově intenzivní operace. Dochází tedy často k situaci, kdy se potřebná data nenachází v cache. Dalším krokem je filtrování s náročností okolo 500 instrukcí na krok, opět paměťově intenzivní. Poslední částí je vyhodnocení, které používá sice málo instrukcí, zhruba 50 na krok, ale je opět paměťově intenzivní. Celkovou složitost algoritmu je možné vyjádřit následujícím způsobem.


O\left( \sqrt[3]{\frac{64}{9}} + 2^{n^{\frac{1}{3}}\left( \log n \right)^{\frac{2}{3}}} \right)


Zatížení paměti je u číselného síta je také docela výrazné, s vyjádřením


M \approx O\left( {\sqrt[3]{\frac{64}{9}} + 2}^{n^{\frac{1}{3}}\left( \log n \right)^{\frac{2}{3}}} \right)


Vlastní útok na problém diskrétního logaritmu nad eliptickými křivkami dodnes vychází z algoritmu Pollard 𝜌 (Pollard rho). U něj je možné definovat složitost následujícím způsobem


O \approx \left( \frac{2^{\frac{n}{2}}}{\sqrt[]{m}} \right)


V tomto vzorci je n bitová šířka klíče a m je hodnota automorfismu. Z používaných křivek mají Weierstrassovy křivky (NIST P-256, NIST P-384 a NIST P-521, dále brainpoolP256r1, brainpoolP384r1, brainpoolP521r1) automorfismus m=2, komunitní křivky používající Twisted Edwards (Ed25519 a Ed448) mají hodnotu m=8. Pro řešení je nutné použít zhruba 4000 instrukcí na jeden krok, navíc velice často dochází k problémům s branch prediction. To znamená zahození fronty instrukcí a pozastavení výpočtu na několik desítek až nižších stovek cyklů.V případě útoku pomocí Pollard 𝜌 je na druhou stranu výhodou extrémně nízké zatížení paměti.


AlgoritmusSložitostOperacíInstrukcíPaměť (B)Doba (roků)Energie (J)
DSA1024248.71.21∙10141.81∙10181.21∙10145.76∙1005.05∙106
DSA2048262.88.09∙10181.21∙10238.09∙10183.84∙1053.37∙1011
DH1024246.71.21∙10141.81∙10181.21∙10145.76∙1005.05∙106
DH2048262.88.09∙10181.21∙10238.09∙10183.84∙1053.37∙1011
DH3072274.42.54∙10223.81∙10262.54∙10221.20∙1091.05∙1015
DH4096283.81.76∙10252.64∙10291.76∙10258.36∙10117.33∙1017
DH6144299.06.77∙10291.01∙10346.77∙10293.21∙10162.82∙1022
DH81922111.43.55∙10335.33∙10373.55∙10331.68∙10201.48∙1026
brainpoolP256r12127.52.40∙10389.62∙104113.05∙10241.0∙1010
brainpoolP384r12191.54.43∙10571.77∙106115.62∙10434.93∙1049
brainpoolP521r12260.01.85∙10787.41∙108112.34∙10642.05∙1070
NIST P-2562127.52.40∙10389.62∙104113.05∙10241.0∙1010
NIST P-3842191.54.43∙10571.77∙106115.62∙10434.93∙1049
NIST P-5212260.01.85∙10787.41∙108112.34∙10642.05∙1070
Curve255192126.08.50∙10373.40∙104111.07∙10249.45∙1029
Curve4482222.59.35∙10663.81∙107011.20∙10531.05∙1059

Opět, jedná se o ideální podmínky. V případě útoků na DH a DSA bude realita bude extrémně odlišná. Paměť je zde opět úzké místo, proto bude přístup k datům v průběhu výpočtu omezen rychlostí úložišť. Jedná se o prodloužení výpočtu v řádu 103 pro NVMe disky, 104 pro SSD disky a 107 pro HDD (magnetické disky). Přitom paměť v řádu TB je potřeba už pro samotné 512b číslo. Samotné paměti mají spotřebu, která odpovídá dalším cca 100 W na 1,5 TB. To odpovídá drobnému zvýšení příkonu na desetinných místech. Dále, zvláště při analýze matice, která má opět obrovský rozsah, budou častým jevem cache miss. Protože se jedná o paměťově intenzivní operace, data se nevejdou do cache procesoru. Přístup k paměti bude díky tomu často pozastaven na zhruba 200 cykly, kdy nebude prováděn výpočet a dojde k opětovnému načtení paměti do cache. To znamená zpomalení o zhruba o 5 řádů (105 až 109 dle použitých technologií). V případě eliptických křivek je problémem pouze branch prediction, zpomalující výpočet až o tři řády (103).

Jak je vidět, z hlediska možností je útok na DSA1024, DSA2048, DH1024 a DH2048 v našich možnostech. V případě 1024b klíčů a menších se jedná o schopnosti dostupné i jednotlivcům, pro 2048b klíče pak schopnosti dostupné velkým společnostem nebo státním aktérům. Co se týká větších klíčů nebo v současnosti stále ještě používaných eliptických křivek, zde už není situace až tak jednoduchá. Otázkou opět je, jsme schopní takový útok provést i pro tyto algoritmy? Můžeme to vzít z několika hledisek:


  • Pokud budeme uvažovat čas a schopnost vyrobit dostatečné množství počítačů? Společnosti Intel a AMD za celou svou historii (můžeme uvažovat 50 let) vyrobili odhadem miliardy procesorů, tedy pohybujeme se v řádu 109. Protože první procesory měly po několik dekád jedno jádro a až po roce 2006 došlo k využívání více jader, je možné uvažovat 2,5 jádra na procesor. Uvažovaný dostupný výkon odpovídajícím způsobem sníží čas, ale v celkovém rozsahu tento výkon spíše odstraní drobný výkyv, způsobený problémy s dostupností velkých dat v cache procesoru.

  • Pokud budeme uvažovat čistě jenom čas, tak vesmír vznikl před 18 miliardami let. To odpovídá řádu 1010, tedy nejsme schopní takový výpočet provést dostatečně rychle. Výjimkou jsou zde algoritmy DSA a algoritmy DH do velikosti klíčů 3072b.

  • Pokud uvažujeme čistě jenom potřebný příkon, můžeme uvažovat následovně. Celá lidská civilizace měla v roce 2025 elektrický příkon okolo 30 000 TWh, tedy v řádu 1016 Wh. Slunce nám poskytuje zdroj s kapacitou s výkonem 1018 W (co přijímáme na zemském povrchu), takže pokud bychom chtěli zmrznout, můžeme uvedenou energii použít. V případě zapřažení celého slunce se bavíme o zdroji s výkonem 1026 W. Centrální černá díra naší galaxie pak dává 1029 W a celá galaxie potom zhruba 1037W. Je vidět, že ani tyto zdroje nejsou dostatečné.


Pokračování bude v části Útok pomocí kvantových počítačů (2.března 2026)

Reference:

  1. Sage Math script - Pollard rho and NFS-DL
    Zdroj: https://cryptosession.info/ke-stazeni
  2. An algorithm to solve the discrete logarithm problem with the number field sieve
    Zdroj: https://www.acm.org
  3. NFS with Four Large Primes: An Explosive Experiment
    Zdroj: https://link.springer.com/
  4. Computing Individual Discrete Logarithms Faster in GF(p^n) with the NFS-DL Algorithm
    Zdroj: https://eprint.iacr.org
  5. On the Efficiency of Pollard's Rho Method for Discrete Logarithms
    Zdroj: https://maths-people.anu.edu.au/
  6. About Pollard rho
    Zdroj: https://www.ams.org/

Autor článku:

Jan Dušátko
Jan Dušátko

Jan Dušátko se počítačům a počítačové bezpečnosti věnuje již skoro čtvrt století. V oblasti kryptografie spolupracoval s předními odborníky např. s Vlastimilem Klímou, či Tomášem Rosou. V tuto chvíli pracuje jako bezpečnostní konzultant, jeho hlavní náplní jsou témata související s kryptografií, bezpečností, e-mailovou komunikací a linuxovými systémy.

1. Úvodní ustanovení

1.1. Tyto všeobecné obchodní podmínky jsou, není-li ve smlouvě písemně dohodnuto jinak, nedílnou součástí všech smluv týkajících školení, pořádaných nebo poskytovaných školitelem, Jan Dušátko, IČ 434 797 66, DIČ 7208253041, se sídlem Pod Harfou 938/58, Praha 9, zapsané u Úřadu městské části Praha 9 (dále jen „školitel“).
1.2. Smluvními stranami ve všeobecných obchodních podmínkách jsou míněni školitel a objednatel, kdy objednatel může být zároveň zprostředkovatelem smluvního vztahu.
1.3. Záležitosti, které nejsou upravené těmito obchodními podmínkami, se řeší podle Občanského zákoníků, tj. zákon č. 89/2012 Sb.

2. Vznik smlouvy přihlášením ke kurzu

2.1. Přihláškou se rozumí jednostranný úkon objednatele adresovaný školiteli prostřednictvím datové schránky s identifikací euxesuf, e-mailu na adresu register@cryptosession.cz nebo register@cryptosession.info, internetových stránek cryptosession.cz, cryptosession.info nebo kontaktním telefonem +420 602 427 840.
2.2. Odesláním přihlášky objednatel souhlasí s těmito všeobecnými podmínkami a prohlašuje, že se s nimi seznámil.
2.3. Přihláška se považuje za přijatou momentem potvrzení (stadnardně do 2 pracovních dní) školitelem nebo zprostředkovatelem. Toto potvrzení je zasláno do datové schránky nebo na kontaktní e-mail.
2.4. Standardní doba pro přihlášení je nejpozději 14 pracovních dní před konáním vzdělávací akce, pokud není uvedeno jinak. V případě fyzické nepodnikající osoby musí být objednávka alespoň 28 pracovních dní před konáním vzdělávací akce.
2.5. Na jednu přihláškou lze přihlásit i více než jednoho účastníka.
2.6. Pokud je více než 10 účastníků od jednoho objednatele, je možné se domluvit na školení v místě sídla zprostředkovatele nebo objednatele.
2.7. Přihlášky jsou přijímány a zpracovávány v pořadí, v jakém došly poskytovateli. Poskytovatel neprodleně informuje objednatele o všech skutečnostech. Těmi se míní naplnění kapacity, příliš nízký počet účastníků, nebo jiný závažný důvod, jako je nemoc lektora nebo zásah vyšší moci. Objednateli bude v tomto případě nabídnut nový termín, případně účast na jiné vzdělávací akci. V případě, že objednatel nebude s přesunutím či účastí na jiné nabídnuté vzdělávací akci souhlasit, poskytovatel mu vrátí účastnický poplatek. Nedostatečný účastníků je oznámen objednateli alespoň 14 dní před začátkem plánovaného termínu.
2.8. Smlouva mezi poskytovatelem a objednatelem vzniká odesláním potvrzení poskytovatelem objednateli.
2.9. Smlouvu lze změnit nebo zrušit pouze za splnění zákonných předpokladů a pouze písemně.

3. Zánik smlouvy zrušením přihlášky

3.1. Přihláška může být objednatelem zrušena pomocí e-mailu, nebo pomocí datové schránky.
3.2. Zákazník má právo stornovat svoji přihlášku na kurz 14 dní před konáním kurzu bez jakýchkoliv poplatků. Pokud se jedná o kratší dobu, dochází k následné změně. V intervalu 7-13 dní je účtován administrativní poplatek 10%, storno účasti v kratším intervalu než 7 dní pak poplatek 25%. V případě storna přihlášky nebo objednávky ze strany zákazníka je nabízena možnost účasti zákazníka v náhradním termínu bez dalšího poplatku. Právo na zrušení přihlášky zaniká realizací objednaného školení.
3.3. Při zrušení přihlášky školitelem náleží objednateli plná náhrada za neuskutečněnou akci.
3.4. Objednatel má právo žádat náhradní termín nebo náhradní školení. V takovém případě bude objednatel informován o všech otevřených kurzech. Náhradní termín si nelze vymáhat ani vynucovat, závisí na aktuální dostupnosti kurzu. Pokud má náhradní školení nižší cenu, objednatel doplatí rozdíl. Pokud má náhradní školení nižší cenu, školitel vrátí rozdíl cen školení objednateli.

4. Cena a platební podmínky

4.1. Odesláním přihlášky objednatel akceptuje smluvní cenu (dále jen účastnický poplatek) uvedenou u daného kurzu.
4.2. V případě více účastníků přihlášených jednou přihláškou je možná sleva.
4.3. Účastnický poplatek musí být uhrazen na bankovní účet společnosti vedený u Komerční banky č. 78-7768770207/0100. Při platbě je nutné uvést variabilní symbol, který je uveden na faktuře, odeslané objednateli školitelem.
4.4. Účastnický poplatek zahrnuje náklady poskytovatele včetně školicích materiálů. Poskytovatel je plátce DPH.
4.5. Účastnický poplatek je objednatel povinen uhradit do 14 pracovních dní od přijetí faktury, pokud nebylo samostatnou smlouvou uvedeno jinak.
4.6. Pokud se přihlášená osoba neúčastní školení a nedošlo k jiné domluvě, je její neúčast považována za storno příhlášku v intervalu kratším než 7 dní, tj. školiteli náleží odměna ve výši 25% z ceny kurzu. Přeplatek je vrácen do 14 dní na platební účet odesílatele, ze kterého byly prostředky odeslány. Platba na jiné číslo účtu není možná.
4.7. Nejdéle do 5 pracovních dní od začátku školení bude školitelem vystavena faktura, která bude dle dohody odeslána e-mailem nebo datovou schránkou.

5. Podmínky školení

5.1. Školitel je povinnen informovat objednatele 14 dní dopředu o místě a času školení, včetně termínu zahájení a ukončení denního programu.
5.2. Pokud objednatel není studentem kurzu, je povinnen zajistit distribuci těchto informací koncovým účastníkům. Za nesplnění těchto podmínek školitel nenese odpovědnost.
5.2. Standardně školení probíhá v čase od 9:00 do 17:00 na předem určeném místě.
5.3. Školitel může být dle aktuálních podmínek k dispozici od 8:00 do 9:00 a následně od 17:00 do 18:00 pro dotazy účastníků.
5.4. Na konci školení je koncovým uživatelům předán certifikát o absolovování.
5.5. Na konci školení koncoví uživatelé vyhodnocují přístup lektora a mají se vyjádřit k ohodnocení jeho prezentace, způsobu přednesení a ohodnotit významn poskytnutých informací.

6. Reklamace

6.1. Pokud je účastník hrubě nespokojen s průběhem kurzu, je školitel o této informaci vyrozuměn.
6.2. Důvody nespokojenosti jsou ten samý den zapsány do protokolu ve dvou kopiích. Jedna je předána objednateli a jednu má školitel.
6.3. Vyjádření k reklamaci bude podáno e-mailem do dvou týdnů. Následně do jednoho týdne bude domluven způsob řešení.
6.4. Nespokojenost zákazníka může být důvodem k rozvázání další spolupráce, nebo finanční kompenzaci až do výše ceny školení po odečtení nákladů.

7. Autorská práva k poskytnutým materiálům

7.1. Školicí materiály poskytnuté školitelem v rámci konání školení splňují znaky autorského díla dle zákona č. 121/2000 Sb.
7.2. Žádný ze školicích materiálů ani jeho část nesmí být bez předchozího písemného souhlasu školitele jakýmkoli způsobem dále zpracovávána, rozmnožována, rozšiřována nebo využívána k dalším prezentacím nebo školením.

8. Zodpovědnost

8.1. Školitel nepřebírá odpovědnost za nedostatky ve službách kterékoliv třetí strany, kterou využívá při školeních.
8.2. Školitel nepřebírá odpovědnost za zranění, škody a ztráty, vzniklé účastníkům vzdělávacích akcí, nebo které byly účastníky způsobeny. Takové náklady, způsobené uvedenými okolnostmi, ponese výhradně účastník vzdělávací akce.

9. Platnost podmínek

9.1 Tyto všeobecné obchodní podmínky jsou platné a účinné od 1. října 2024.

Informace o sběru a zpravování osobních údajů

Zpracovatel Jan Dušátko (dále jen „Správce“), dle nařízení Evropského parlamentu a Rady (EU) č. 2016/679 o ochraně fyzických osob v souvislosti se zpracováním osobních údajů a o volném pohybu těchto údajů a o zrušení směrnice 95/46/ES (obecné nařízení o ochraně osobních údajů, dále jen „Nařízení“) zpracovává osobní údaje. Dále jsou rozepsané jednotlivé osobní údaje, které jsou součástí zpracování při konkrétních aktivitách u této webové prezentace a v rámci obchodního styku.
Přestože je sběr dat všudypřítomný, provoz tohoto webu si zakládá na právu na soukromí každého uživatele. Z uvedeného důvodu sběr informací o uživatelích probíhá v naprosto nezbytné míře a to jen v případě, kdy se uživatel rozhodne kontaktovat provozovatele. Jakýkoliv další sběr a zpracování dat považujeme za neetický.

Informace o záznamech přístupu na webovou prezentaci

Tento web nesbírá žádné cookies. Stránka nepoužívá ani žádné analytické scripty třetích stran (sociální sítě, cloud provideři). Z těchto důvodů je také nabízena volba pro zobrazení mapy formou odkazu, kde primárním zdrojem je OpenStreet a alternativy pak často používané Mapy společnosti Seznam, a.s., případně Google Maps společnosti Google LLC Inc. Využití jakéhokoliv z těchto zdrojů je zcela na libovůli uživatelů těchto stránek. Správce nenese odpovědnost za sběr dat realizovaný těmito společnostmi, neposkytuje jim data o uživatelích a na sběru dat nespolupracuje.
Logování přístupů probíhá pouze na úrovni systému, důvodem je identifikace případných technických nebo bezpečnostních problémů. Dalšími důvody jsou přehledové statistiky přístupů. V této oblasti se nesbírají ani nesledují žádné konkrétní údaje a všechny záznamy o přístupech jsou po třech měsících mazány.

Informace o kontaktování provozovatele stránek

Formulář pro kontaktování provozovatele stránek (správce) obsahuje následující osobní údaje: jméno, příjmení, e-mail. Tyto údaje jsou určeny jen a pouze pro tuto komunikaci, odpovídající oslovení uživatele a jsou udržovány po dobu nezbytnou k naplnění účelu, maximálně pak po dobu jednoho roku, pokud si uživatel neurčí jinak.

Informace o objednávkovém formuláři

Pro případ zájmu o objednávku formulář obsahuje více údajů, tj. jméno, příjmení, e-mail a kontaktní údaje na organizaci. Tyto údaje jsou určeny jen a pouze pro tuto komunikaci, odpovídající oslovení uživatele a jsou udržovány po dobu jednoho roku, pokud si uživatel neurčí jinak. V případě, kdy na základě této objednávky dojde k uzavření obchodního vztahu, budou nadále správcem udržovány pouze informace vyžadované českými zákony na základě obchodních vztahů (název a adresa společnosti, číslo bankovního účtu, typ kurzu a jeho cena).

Informace o dokumentu o absolovování kurzu

V rámci kurzu je vydán zpracovatelem dokument o absolovování kurzu. Tento dokument obsahuje následující údaje: jméno a příjmení studenta, název a datum absolovování kurzu a jméno zaměstnavatele. Uvedené informace se následně používají pro tvorbu lineárního stromu hashí (nemodifikovatelný záznam). Tato databáze obsahuje pouze informace o poskytnutých jménech a názvech společností, které mohou a a nemusí odpovídat realitě a je udržován zpracovatelem pro případné opětovné vystavení nebo ověření vydání dokumentu.

Práva subjektu osobních údajů

Zákazník nebo návštěvník tohoto webu má možnost požádat o informace o zpracování osobních údajů, právo požadovat přístup k osobním údajům, případně právo požádat o opravu nebo výmaz veškerých dat, které by o něm byly vedeny. V případě výmazu tento požadavek není možné splnit pouze pokud se nejedná o data nezbytně nutná v rámci obchodního styku. Zákazník nebo návštěvník webu má dále právo na vysvětlení týkající se zpracování jeho osobních údajů, pokud tento zjistí nebo se domnívá, že zpracování je prováděno v rozporu s ochranou jeho soukromého a osobního života nebo v rozporu s platnými právními předpisy a právo požadovat odstranění takto vzniklého stavu a zajištění nápravy.
Zákazník/návštěvník tohoto webu dále může požadovat omezení zpracování nebo vznést námitku proti zpracování údajů a má právo kdykoliv písemně svůj souhlas se zpracováním osobních údajů odvolat, aniž by tím byla dotčena zákonnost jejich zpracování předcházející takovému odvolání. Pro tyto účel slouží kontaktní e-mail adresa support@cryptosession.cz
Zákazník/návštěvník má právo podat stížnost proti zpracování osobních údajů u dozorového úřadu, kterým je Úřad pro ochranu osobních údajů.