CubeHash - CubeHash

CubeHash[1] bir kriptografik karma işlevi teslim NIST karma işlevi rekabeti tarafından Daniel J. Bernstein. CubeHash, 128 baytlık bir duruma sahiptir. geniş boru yapımı, ve bir ARX ​​tabanlı. Mesaj blokları ÖZEL 128 baytlık bir durumun ilk bitlerine, daha sonra bir r-turundan geçer önyargılı bloklar arasında dönüşüm. İlk NIST teklifi ("Cubehash8 / 1") yaklaşık 200 bayt başına döngü.[2] NIST'in açıklamalarının ardından, yazar öneriyi "CubeHash8 / 1'den yaklaşık 16 kat daha hızlı olan, hem SHA-256 hem de SHA-512'yi referans platformda kolayca yakalayan" ve "rahat" güvenlik marjı ".[3]

CubeHash, yarışmanın ikinci turuna yükseldi, ancak 5 finalistten biri olarak seçilmedi. Bernstein o zamandan beri parametreleri daha fazla ayarladı ve ana önerisi CubeHash16 + 16/32 + 32–512 olarak tanımlanan CubeHash512'dir.[4]

Nasıl çalışır

Bu açıklama, NIST sunumuna değil, en son spesifikasyona atıfta bulunur.[4]

CubeHash'ın 5 parametresi vardır, belirli bir örnek CubeHash ile gösterilirben+r/b+f-h.

  • ben ilk turların sayısı
  • r blok başına tur sayısı
  • b bayt cinsinden blok boyutudur, {1, 2, 3, ... 128} için tanımlanmıştır
  • f son turların sayısı
  • h hash çıktısının bit cinsinden boyutudur, {8, 16, 24, 32, ... 512} için tanımlanmıştır

Orijinal NIST sunumunda, ben ve f 10'a sabitlendir. Eski CubeHash gösterimir/b-h gösterir ben ve f örtük olarak 10r.

İç durum, her iki boyutta da 0-1 olmak üzere beş boyutlu bir kelime dizisi (dört baytlık tamsayı) olarak tanımlanır. Kelimeler [00000] ila [11111] koordinatlarıyla belirtilir. Sözler küçük endian muamelesi görüyor.

Dahili durum, ilk üç kelimeyi ([00000], [00001], [00010]) şu şekilde ayarlayarak başlatılır: h/8, b, ve r sırasıyla, diğer tüm kelimeler sıfıra. Devlet daha sonra çalıştırılır ben turlar ve başlatma aşaması tamamlandı. Durum artık Başlatma Vektörüdür (IV). IV, belirli bir kombinasyon için kaydedilebilir ve yeniden kullanılabilir h, b, r.

Mesaj doldurulur ve bölünür b-bayt blokları. Dolgu, 1 bit ekler ve ardından tam bir blok oluşturmak için gerektiği kadar 0 bit ekler.

Her blok tarafından girilir ÖZELLEŞTİRME ilkine b devletin baytları ve ardından performans r dönüşüm turları.

Son olarak, 1 durum kelimesi [11111] 'e XORlanır ve sonra f dönüşüm turları gerçekleştirilir.

Çıktı karması artık ilk h/ Bu son durumun 8 baytı.

Yuvarlak Fonksiyon

Karıştırma işlevi gösterimi
Karıştırma işlevinin on adımı. Beş boyuttan ikisi açıldı.

CubeHash round işlevi aşağıdaki on adımdan oluşur:

  1. X [0jklm] x'e [1jklm] modulo 232, her biri için (j, k, l, m).
  2. X [döndür0jklm] her biri için 7 bit yukarı doğru (j, k, l, m).
  3. X [00klm] ile x [01klm], her biri için (k, l, m).
  4. Xor x [1jklm] x'e [0jklm], her biri için (j, k, l, m).
  5. X [1jk0m] ile x [1jk1m], her biri için (j, k, m).
  6. X [0jklm] x'e [1jklm] modulo 232, her biri için (j, k, l, m).
  7. X [döndür0jklm] her biri için 11 bit yukarı doğru (j, k, l, m).
  8. X [0j0lm] ile x [0j1lm], her biri için (j, l, m).
  9. Xor x [1jklm] x'e [0jklm], her biri için (j, k, l, m).
  10. X [1jkl0] x [1jkl1], her biri için (j, k, l).

Örnek Hashes

Bu örnekte CubeHash80 + 8/1 + 80-512 kullanılmaktadır. Başlatma vektörü, tüm 80 + 8/1 + için aynıdır.f-512 karma ve aşağıdaki gibidir:

5df39869c73009fb108994600f1626e6f37c07360c0d8bb53d19cf57b8e74133  5b8034a3eff9892014c4ff315038ef2a391812fe52a440e9a293527d12ca4570  6e0958933470bf814aa4909adb3ec39384e9c314d0db874af21d45bcacb31252  1ce5ab6a3bf6f05de88abbdd0fcfd3fafb8225d546242eada52540095c3da221 

Hashing ASCII "Merhaba" iletisi (onaltılık: 0x48, 0x65, 0x6c, 0x6c, 0x6f) 6 ileti bloğu kullanır. Mesajdan 5 blok vardır ve bu bayt hizalı bir girdi olduğundan, doldurma için 1 blok vardır. 512 bitlik hash değeri:

7ce309a25e2e1603ca0fc369267b4d43f0b1b744ac45d6213ca08e7567566444  8e2f62fdbf7bbd637ce40fc293286d75b9d09e8dda31bd029113e02ecccfd39b

Mesajdaki küçük bir değişiklik, tek bir biti çevirmek gibi, hash çıktısını çılgınca değiştirecektir. çığ etkisi. "Merhaba" mesajının (sadece 1 bitlik pozisyondaki "Merhaba" den farklı olan) hash değeri aşağıdaki hash değerini verir:

01ee7f4eb0e0ebfdb8bf77460f64993faf13afce01b55b0d3d2a63690d25010f  7127109455a7c143ef12254183e762b15575e0fcc49c79a0471a970ba8a66638

Parametre Değişiklikleri

CubeHash, hash çıktısını belirlemek için birçok farklı parametrenin kullanılmasına izin verir. Hangi parametreleri kullanmak istediğine karar vermek kullanıcıya bağlıdır. Aşağıda, farklı parametreler kullanan farklı mesajların birkaç örnek karması verilmiştir. Mesajların tümü ASCII'de.

Mesaj: "" (sıfır uzunluklu dizi) CubeHash160 + 160-512 16/32: 4a1d00bbcfcb5a9562fb981e7f7db3350fe2658639d948b9d57452c22328bb32  f468b072208450bad5ee178271408be0b16e5633ac8a1e3cf9864cfbfc8e043aCubeHash80 + 80-512 8/1: 90bc3f2948f7374065a811f1e47a208a53b1a2f3be1c0072759ed49c9c6c7f28  f26eb30d5b0658c563077d599da23f97df0c2c0ac6cce734ffe87b2e76ff7294CubeHash10 + 10-512 1/1: 3f917707df9acd9b94244681b3812880e267d204f1fdf795d398799b584fa8f1  f4a0b2dbd52fd1c4b6c5e020dc7a96192397dd1bce9b6d16484049f85bb71f2fCubeHash160 + 16 / 32 + 160-256: 44c6de3ac6c73c391bf0906cb7482600ec06b216c7c54a2a8688a6a42676577dCubeHash80 + 8/1 + 80-256: 38d1e8a22d7baac6fd5262d83de89cacf784a02caa866335299987722aeabc59CubeHash10 + 1/1 + 10-256: 80f72e07d04ddadb44a78823e0af2ea9f72ef3bf366fd773aa1fa33fc030e5cb
Mesaj: "Merhaba" CubeHash160 + 16 + 160-512 / 32: dcc0503aae279a3c8c95fa1181d37c418783204e2e3048a081392fd61bace883  a1f7c4c96b16b4060c42104f1ce45a622f1a9abaeb994beb107fed53a78f588cCubeHash80 + / 1 + 80-512 8: 7ce309a25e2e1603ca0fc369267b4d43f0b1b744ac45d6213ca08e7567566444  8e2f62fdbf7bbd637ce40fc293286d75b9d09e8dda31bd029113e02ecccfd39bCubeHash10 + 1 + 10-512 / 1: 13cf99c1a71e40b135f5535bee02e151eb4897e4de410b9cb6d7179c677074eb  6ef1ae9a9e685ef2d2807509541f484d39559525179d53838eda95eb3f6a401dCubeHash160 + 16/32 + 160-256 : e712139e3b892f2f5fe52d0f30d78a0cb16b51b217da0e4acb103dd0856f2db0CubeHash80 + 8/1 + 80-256: 692638db57760867326f851bd2376533f37b640bd47a0ddc607a9456b692f70fCubeHash10 + 1/1 + 10-256: f63041a946aa98bd47f3175e6009dcb2ccf597b2718617ba46d56f27ffe35d49
mesajı: CubeHash160 + 160-512 16/32 "Hızlı kahverengi tilki tembel köpeğin üstünden atlar": bdba44a28cd16b774bdf3c9511def1a2baf39d4ef98b92c27cf5e37beb8990b7  cdb6575dae1a548330780810618b8a5c351c1368904db7ebdf8857d596083a86CubeHash80 + 1/8 + 80-512: ca942b088ed9103726af1fa87b4deb59e50cf3b5c6dcfbcebf5bba22fb39a6be  9936c87bfdd7c52fc5e71700993958fa4e7b5e6e2a3672122475c40f9ec816baCubeHash10 + 1/1 + 10-512: eb7f5f80706e8668c61186c3c710ce57f9094fbfa1dbdc7554842cdbb4d10ce4  2fce72736d10b152f6216f23fc648bce810a7af4d58e571ec1b852fa514a0a8eCubeHash160 + 16/32 + 160-256: 5151e251e348cbbfee46538651c06b138b10eeb71cf6ea6054d7ca5fec82eb79CubeHash80 + 8/1 + 80-256: 94e0c958d85cdfaf554919980f0f50b945b88ad08413e0762d6ff0219aff3e55CubeHash10 + 1/1 + 10-256: 217a4876f2b24cec489c9171f85d53395cc979156ea0254938c4c2c59dfdf8a4

Gösterilen dört varyant için Başlatma Vektörlerinin tümü de farklıdır. Örneğin, CubeHash80 + 8/1 + 80-512 için Başlatma Vektörü yukarıda görülebilir ve CubeHash80 + 8/1 + 80-256 için IV:

830b2bd5273d616fd785876a4a500218a5388963eeb702fb47547842459f8d89  8727a1c8ba40bd48cef47fe82543c2735c033052ae9fcd632d4541bde6b6cb0d  cb8a9cdf579f5b67b2ae00968180af6e51ebdf0ca597cd2bf91f981f7ab29a62  01ad72d946e6c075c6d1337e0a293d6f90c438ac38be153f32aa288ffc5eca8a

Güvenlik

Bu işlevin gücü, b 1'e doğru azalır ve r artışlar. Dolayısıyla CubeHash 8 / 1-512, CubeHash 1 / 1-512'den daha güçlü (daha güvenli) ve CubeHash 1 / 1-512, CubeHash 1 / 2-512'den daha güçlü. Bu algoritmanın olası en zayıf versiyonu CubeHash 1 / 128-h. Ancak, zamana karşı bir güvenlik vardır. Daha güvenli bir sürümün hash değerini hesaplaması, zayıflatılmış bir sürümden daha uzun sürer.

Referanslar

  1. ^ Daniel J. Bernstein (2009-09-14). "CubeHash spesifikasyonu (2.B.1)" (PDF ). Alıntı dergisi gerektirir | günlük = (Yardım)
  2. ^ Daniel J. Bernstein (2008-10-28). "CubeHash verimlilik tahminleri (2.B.2)" (PDF ). Alıntı dergisi gerektirir | günlük = (Yardım)
  3. ^ Daniel J. Bernstein (2009-07-15). "CubeHash parametre ayarı: 16 kat daha hızlı" (PDF ). Alıntı dergisi gerektirir | günlük = (Yardım)
  4. ^ a b Daniel J. Bernstein. "CubeHash'a Giriş".

Dış bağlantılar