로그인하고 있지 않습니다. 편집하면 당신의 IP 주소가 공개적으로 기록됩니다. 계정을 만들고 로그인하면 편집 시 사용자 이름만 보이며, 위키 이용에 여러 가지 편의가 주어집니다.스팸 방지 검사입니다. 이것을 입력하지 마세요!=== 유사 소수 === '''유사 소수(Pseudo-prime)'''란, 어떤 수에 대해 [[페르마의 소정리]]가 성립해서 소수처럼 보이는 수를 말한다. 좀 더 자세히 말하면, 서로소인 두 수 <math>n</math>과 <math>a</math>에 대해, <math>a^{n-1}\equiv1\pmod n</math>이 성립하면, <math>n</math>를 <math>a</math>에 관한 유사 소수(Pseudo-prime Base a)라 부른다. 만약 <math>n</math>이 <math>n</math>과 서로소인 '''모든''' <math>a</math>에 관해 유사 소수라면, <math>n</math>을 '''카마이클 숫자(Carmichael Number)'''라 부른다. 유사 소수와 카마이클 숫자는 매우 희귀하지만, 무한히 많음이 알려져 있다. 문제는, 어떤 수가 유사 소수면 그 수를 소인수 분해하는 있는 방법이 알려져 있다는 것. 이를 '''밀러-라빈 알고리즘(Miller-Rabin Algorithm)'''이라 부르며, 자세한 방법은 다음과 같다. :<math>n</math>을 1보다 큰 홀수라 하자. 그럼, 적당한 홀수 <math>m</math>에 대해 <math>n-1=2^km</math>로 나타낼 수 있다. 이제 적당한 정수 <math>a</math>를 고르고, <math>b_0\equiv a^m\pmod n</math>이라 하자. 이제, 연속 제곱으로 <math>b_{u+1}\equiv {b_u}^2\pmod n</math>을 1이 나올 때까지 반복한다. 연속 제곱을 <math>k</math>번 하면 반드시 1이 나오게 되어있는데, 만약 1이 나오지 않았다면 <math>a</math>가 <math>n</math>과 서로소가 아니라는 뜻이므로 인수를 하나 찾은 것이다. 만약, <math>b_{u+1}\equiv1\pmod n</math>이고, <math>b_u\equiv\pm1\pmod n</math>이면, <math>a</math>를 바꿔 다시 시도한다. 만약 <math>b_{u+1}\equiv1\pmod n</math>이고 <math>b_u\not\equiv\pm1\pmod n</math>이면, <math>\gcd\left(b_u-1,n\right)</math>이 <math>n</math>의 한 인수이다. 보면 알겠지만, 바로 위에서 <math>d</math>가 유출 되었을 때 <math>p,q</math>를 찾는 방법과 동일한 방법이다. 구체적인 예시를 통해 유사 소수가 어떻게 소인수 분해 되는지 확인보자. :561을 소인수 분해 하고 싶다고 가정하자. 참고로 561은 2에 관한 유사 소수이다 (<math>2^{560}\equiv1\pmod{561}</math>). 이제 <math>561-1=560=2^{4}\cdot35</math>이므로, <math>m=35</math>이다. <math>a=2</math>에 대해, <math>b_0\equiv a^m\equiv2^{35}\equiv263\pmod{561}</math>이고, 연속 제곱으로 계속 값을 구하면, <math>b_1\equiv166\pmod{561},b_2\equiv67\pmod{561},b_3\equiv1\pmod{561}</math>이다. 1이 튀어나왔으므로, 그 바로 전 수인 67을 살펴보자. <math>67\not\equiv\pm1\pmod{561}</math>이므로, <math>\gcd\left(67-1,561\right)=33</math>이 561의 한 인수이다. 보면 알겠지만, 컴퓨터를 사용하면 유사 소수를 소인수 분해하는데 오랜 시간이 걸리지 않는다. 이는 곧 RSA에서 사용할 공개키 <math>n</math>이 유사 소수면 털리게 될 것이라는 것을 의미한다. 카마이클 숫자면 더더욱(...). 요약: 리브레 위키에서의 모든 기여는 크리에이티브 커먼즈 저작자표시-동일조건변경허락 3.0 라이선스로 배포됩니다(자세한 내용에 대해서는 리브레 위키:저작권 문서를 읽어주세요). 만약 여기에 동의하지 않는다면 문서를 저장하지 말아 주세요. 글이 직접 작성되었거나 호환되는 라이선스인지 확인해주세요. 리그베다 위키, 나무위키, 오리위키, 구스위키, 디시위키 및 CCL 미적용 사이트 등에서 글을 가져오실 때는 본인이 문서의 유일한 기여자여야 하고, 만약 본인이 문서의 유일한 기여자라는 증거가 없다면 그 문서는 불시에 삭제될 수 있습니다. 취소 편집 도움말 (새 창에서 열림) | () [] [[]] {{}} {{{}}} · <!-- --> · [[분류:]] · [[파일:]] · [[미디어:]] · #넘겨주기 [[]] · {{ㅊ|}} · <onlyinclude></onlyinclude> · <includeonly></includeonly> · <noinclude></noinclude> · <br /> · <ref></ref> · {{각주}} · {|class="wikitable" · |- · rowspan=""| · colspan=""| · |} {{lang|}} · {{llang||}} · {{인용문|}} · {{인용문2|}} · {{유튜브|}} · {{다음팟|}} · {{니코|}} · {{토막글}} {{삭제|}} · {{특정판삭제|}}(이유를 적지 않을 경우 기각될 가능성이 높습니다. 반드시 이유를 적어주세요.) {{#expr:}} · {{#if:}} · {{#ifeq:}} · {{#iferror:}} · {{#ifexist:}} · {{#switch:}} · {{#time:}} · {{#timel:}} · {{#titleparts:}} __NOTOC__ · __FORCETOC__ · __TOC__ · {{PAGENAME}} · {{SITENAME}} · {{localurl:}} · {{fullurl:}} · {{ns:}} –(대시) ‘’(작은따옴표) “”(큰따옴표) ·(가운뎃점) …(말줄임표) ‽(물음느낌표) 〈〉(홑화살괄호) 《》(겹화살괄호) ± − × ÷ ≈ ≠ ∓ ≤ ≥ ∞ ¬ ¹ ² ³ ⁿ ¼ ½ ¾ § € £ ₩ ¥ ¢ † ‡ • ← → ↔ ‰ °C µ(마이크로) Å °(도) ′(분) ″(초) Α α Β β Γ γ Δ δ Ε ε Ζ ζ Η η Θ θ Ι ι Κ κ Λ λ Μ μ(뮤) Ν ν Ξ ξ Ο ο Π π Ρ ρ Σ σ ς Τ τ Υ υ Φ φ Χ χ Ψ ψ Ω ω · Ά ά Έ έ Ή ή Ί ί Ό ό Ύ ύ Ώ ώ · Ϊ ϊ Ϋ ϋ · ΐ ΰ Æ æ Đ(D with stroke) đ Ð(eth) ð ı Ł ł Ø ø Œ œ ß Þ þ · Á á Ć ć É é Í í Ĺ ĺ Ḿ ḿ Ń ń Ó ó Ŕ ŕ Ś ś Ú ú Ý ý Ź ź · À à È è Ì ì Ǹ ǹ Ò ò Ù ù · İ Ż ż ·  â Ĉ ĉ Ê ê Ĝ ĝ Ĥ ĥ Î î Ĵ ĵ Ô ô Ŝ ŝ Û û · Ä ä Ë ë Ï ï Ö ö Ü ü Ÿ ÿ · ǘ ǜ ǚ ǖ · caron/háček: Ǎ ǎ Č č Ď ď Ě ě Ǐ ǐ Ľ ľ Ň ň Ǒ ǒ Ř ř Š š Ť ť Ǔ ǔ Ž ž · breve: Ă ă Ğ ğ Ŏ ŏ Ŭ ŭ · Ā ā Ē ē Ī ī Ō ō Ū ū · à ã Ñ ñ Õ õ · Å å Ů ů · Ą ą Ę ę · Ç ç Ş ş Ţ ţ · Ő ő Ű ű · Ș ș Ț ț