लुहन अल्गोरिदम वापरून संख्या वैधता आणि निर्माण करा

लुहन अल्गोरिदम वापरून संख्या वैधता आणि निर्माण करा, जो सामान्यतः क्रेडिट कार्ड नंबर, कॅनेडियन सोशल इन्श्युरन्स नंबर आणि इतर ओळख क्रमांकांसाठी वापरला जातो. संख्या लुहन तपासणी पास करते का हे तपासा किंवा अल्गोरिदमच्या नियमांचे पालन करणारे वैध नंबर तयार करा.

लुहन अल्गोरिदम कॅल्क्युलेटर

📚

साहित्यिकरण

लुहन अल्गोरिदम कॅल्क्युलेटर

परिचय

लुहन अल्गोरिदम, ज्याला "मॉड्युलस 10" किंवा "मॉड 10" अल्गोरिदम म्हणूनही ओळखले जाते, हा एक साधा चेकसम सूत्र आहे जो विविध ओळख क्रमांकांचे प्रमाणित करण्यासाठी वापरला जातो, जसे की क्रेडिट कार्ड क्रमांक, कॅनेडियन सोशल इन्शुरन्स क्रमांक, IMEI क्रमांक, आणि अमेरिकेत राष्ट्रीय प्रदाता ओळख क्रमांक. हा कॅल्क्युलेटर तुम्हाला लुहन अल्गोरिदमचा वापर करून क्रमांकांची वैधता तपासण्याची आणि लुहन चेक पास करणारे वैध क्रमांक तयार करण्याची परवानगी देतो.

लुहन अल्गोरिदम कसा कार्य करतो

लुहन अल्गोरिदम खालीलप्रमाणे कार्य करतो:

  1. उजव्या बाजूच्या सर्वात उजव्या अंकापासून (चेक अंक वगळून) सुरुवात करून, प्रत्येक दुसऱ्या अंकाचे मूल्य दुप्पट करा.
  2. जर या दुप्पट ऑपरेशनचा परिणाम 9 पेक्षा जास्त असेल, तर परिणामातून 9 वजा करा.
  3. परिणामी अनुक्रमातील सर्व अंकांची बेरीज करा.
  4. जर एकूण % 10 0 ला सम असले, तर संख्या लुहन सूत्रानुसार वैध आहे; अन्यथा, ती वैध नाही.

लुहन अल्गोरिदमचे दृश्य प्रतिनिधित्व येथे आहे:

1. प्रत्येक दुसऱ्या अंकाचे मूल्य दुप्पट करा 2. अंकांची बेरीज (9 दुप्पट > 9 साठी) 3. एकूण बेरीज गणना करा 4. तपासा की बेरीज % 10 == 0 आहे का

सूत्र

लुहन अल्गोरिदम गणितीयदृष्ट्या खालीलप्रमाणे व्यक्त केला जाऊ शकतो:

(2d2nmod9+d2n1+2d2n2mod9+d2n3++2d2mod9+d1+d0)mod10=0(2d_{2n} \bmod 9 + d_{2n-1} + 2d_{2n-2} \bmod 9 + d_{2n-3} + \cdots + 2d_2 \bmod 9 + d_1 + d_0) \bmod 10 = 0

जिथे mod\bmod हे मॉड्युलो ऑपरेशन आहे.

उपयोग केसेस

लुहन अल्गोरिदमचे विविध क्षेत्रांमध्ये अनेक अनुप्रयोग आहेत:

  1. क्रेडिट कार्ड वैधता: बहुतेक क्रेडिट कार्ड क्रमांक लुहन अल्गोरिदमचा वापर करून प्रमाणित केले जातात.
  2. कॅनेडियन सोशल इन्शुरन्स क्रमांक: या ओळख क्रमांकांची वैधता तपासण्यासाठी लुहन अल्गोरिदमचा वापर केला जातो.
  3. IMEI क्रमांक: मोबाइल फोन IMEI क्रमांकात लुहन अल्गोरिदमने प्रमाणित केलेला चेक अंक समाविष्ट आहे.
  4. राष्ट्रीय प्रदाता ओळख (NPI) क्रमांक: अमेरिकेच्या आरोग्य प्रणालीमध्ये वापरले जाणारे, या क्रमांकांची वैधता लुहन अल्गोरिदमने तपासली जाते.
  5. ISBNs: काही ISBN-10 क्रमांक लुहन अल्गोरिदमच्या एक भिन्न रूपाचा वापर करून प्रमाणित केले जातात.

पर्याय

जरी लुहन अल्गोरिदम व्यापकपणे वापरला जातो, तरीही विविध उद्देशांसाठी इतर चेकसम अल्गोरिदम आहेत:

  1. डॅम अल्गोरिदम: एक अन्य चेक अंक अल्गोरिदम जो सर्व एकल अंक त्रुटी आणि सर्व शेजारील ट्रान्सपोजिशन त्रुटी शोधतो.
  2. वेरहॉफ अल्गोरिदम: एक अधिक जटिल चेकसम अल्गोरिदम जो सर्व एकल अंक त्रुटी आणि बहुतेक ट्रान्सपोजिशन त्रुटी पकडतो.
  3. ISBN-13 चेक अंक: ISBN-10 पेक्षा भिन्न अल्गोरिदम वापरतो, जो लुहन अल्गोरिदमवर आधारित आहे.

इतिहास

लुहन अल्गोरिदम 1954 मध्ये IBM च्या संगणक शास्त्रज्ञ हंस पीटर लुहनने तयार केला. लुहन माहिती विज्ञानाच्या क्षेत्रात एक पायनियर होता आणि KWIC (की वर्ड इन कॉन्टेक्स्ट) अनुक्रमण प्रणालीसह अनेक नवकल्पनांसाठी श्रेय दिले जाते.

या अल्गोरिदमची रचना अनपेक्षित त्रुटींपासून संरक्षण करण्यासाठी करण्यात आली होती, दुष्ट हल्ल्यांपासून नाही. हे लक्षात घेणे महत्त्वाचे आहे की लुहन अल्गोरिदम अनेक सामान्य त्रुटी शोधू शकतो, परंतु हे डेटा सुरक्षेसाठी सुरक्षित रूप नाही आणि यावर अवलंबून राहू नये.

त्याच्या वयाच्या बाबतीत, लुहन अल्गोरिदम अद्याप त्याच्या साधेपणामुळे आणि सामान्य हस्तांतरण त्रुटी पकडण्यात प्रभावीतेमुळे व्यापकपणे वापरला जातो.

कार्यान्वयन उदाहरणे

येथे लुहन अल्गोरिदम विविध प्रोग्रामिंग भाषांमध्ये कार्यान्वित करण्याचे काही कोड उदाहरणे आहेत:

1import random
2
3def luhn_validate(number):
4    digits = [int(d) for d in str(number)]
5    checksum = 0
6    for i in range(len(digits) - 1, -1, -1):
7        d = digits[i]
8        if (len(digits) - i) % 2 == 0:
9            d = d * 2
10            if d > 9:
11                d -= 9
12        checksum += d
13    return checksum % 10 == 0
14
15def generate_valid_number(length):
16    digits = [random.randint(0, 9) for _ in range(length - 1)]
17    checksum = sum(digits[::2]) + sum(sum(divmod(d * 2, 10)) for d in digits[-2::-2])
18    check_digit = (10 - (checksum % 10)) % 10
19    return int(''.join(map(str, digits + [check_digit])))
20
21## उदाहरण वापर:
22print(luhn_validate(4532015112830366))  # True
23print(luhn_validate(4532015112830367))  # False
24print(generate_valid_number(16))  # एक वैध 16-अंकांचा क्रमांक तयार करतो
25

काठाच्या बाबी आणि विशेष विचार

लुहन अल्गोरिदम कार्यान्वित करताना, खालील काठाच्या बाबी आणि विशेष विचारांचा विचार करा:

  1. इनपुट वैधता: सुनिश्चित करा की इनपुट एक वैध संख्या स्ट्रिंग आहे. नॉन-डिजिट वर्ण योग्यरित्या हाताळले पाहिजेत (किंवा काढले जावे किंवा अमान्य इनपुट म्हणून विचारले जावे).

  2. लीडिंग झिरो: अल्गोरिदमने लीडिंग झिरो असलेल्या क्रमांकांसह योग्यरित्या कार्य करावे.

  3. मोठे क्रमांक: काही प्रोग्रामिंग भाषांमधील मानक पूर्णांक प्रकारांच्या क्षमतेपेक्षा जास्त मोठ्या क्रमांकांचे हाताळण्यासाठी तयार रहा.

  4. रिक्त इनपुट: तुमच्या कार्यान्वयनाने रिक्त स्ट्रिंग किंवा नल इनपुट कसे हाताळावे हे परिभाषित करा.

  5. नॉन-स्टँडर्ड कॅरेक्टर सेट: काही अनुप्रयोगांमध्ये, तुम्हाला मानक 0-9 श्रेणीच्या बाहेर वर्णांद्वारे दर्शविलेले क्रमांक आढळू शकतात. हे कसे हाताळले जावे हे परिभाषित करा.

  6. कार्यक्षमता विचार: ज्या अनुप्रयोगांना जलद गतीने मोठ्या संख्येच्या इनपुट्सची वैधता तपासण्याची आवश्यकता आहे, त्यांच्यासाठी अल्गोरिदम कार्यान्वयन ऑप्टिमाइझ करण्याचा विचार करा.

संख्यात्मक उदाहरणे

  1. वैध क्रेडिट कार्ड क्रमांक:

    • क्रमांक: 4532015112830366
    • लुहन चेक: वैध
  2. अमान्य क्रेडिट कार्ड क्रमांक:

    • क्रमांक: 4532015112830367
    • लुहन चेक: अमान्य
  3. वैध कॅनेडियन सोशल इन्शुरन्स क्रमांक:

    • क्रमांक: 046 454 286
    • लुहन चेक: वैध
  4. अमान्य IMEI क्रमांक:

    • क्रमांक: 490154203237518
    • लुहन चेक: अमान्य

चाचणी प्रकरणे

लुहन अल्गोरिदमच्या कार्यान्वयनाची पडताळणी करण्यासाठी, तुम्ही खालील चाचणी प्रकरणांचा वापर करू शकता:

1def test_luhn_algorithm():
2    assert luhn_validate(4532015112830366) == True
3    assert luhn_validate(4532015112830367) == False
4    assert luhn_validate(79927398713) == True
5    assert luhn_validate(79927398714) == False
6    
7    # तयार केलेल्या क्रमांकांची चाचणी
8    for _ in range(10):
9        assert luhn_validate(generate_valid_number(16)) == True
10    
11    print("सर्व चाचण्या यशस्वी झाल्या!")
12
13test_luhn_algorithm()
14

संदर्भ

  1. लुहन, एच. पी. (1960). "संख्यांची पडताळणी करणारा संगणक". यूएस पेटंट 2,950,048.
  2. गालियन, जोसेफ. "ओळख क्रमांकांचे गणित." कॉलेज गणित जर्नल, खंड 22, संख्यांक 3, 1991, पृष्ठ 194–202. JSTOR, www.jstor.org/stable/2686878.
  3. "ISO/IEC 7812-1:2017". आंतरराष्ट्रीय मानक संघटना. 2 ऑगस्ट 2024 रोजी प्राप्त.
  4. क्नुथ, डोनाल्ड. "संगणक प्रोग्रामिंगची कला, खंड 2: सेमीन्यूमेरिकल अल्गोरिदम". ऍडिसन-वेस्ली, 1997.