లున్ ఆల్గోరిథమ్ కేల్కులేటర్ - నంబర్ల ధృవీకరణ సాధనం
క్రెడిట్ కార్డ్ నంబర్లు, కెనడియన్ సోషల్ ఇన్సూరెన్స్ నంబర్లు మరియు ఇతర గుర్తింపు నంబర్ల కోసం సాధారణంగా ఉపయోగించే లున్ ఆల్గోరిథమ్ ఉపయోగించి నంబర్లను ధృవీకరించడానికి మరియు ఉత్పత్తి చేయడానికి. ఒక నంబరం లున్ తనిఖీని పాస్ చేస్తుందా లేదా ఆల్గోరిథమ్కు అనుగుణంగా ఉన్న చెల్లుబాటు అయ్యే నంబర్లను ఉత్పత్తి చేయండి.
లున్ ఆల్గోరిథమ్ కేల్కులేటర్
దస్త్రపరిశోధన
Luhn ఆల్గోరిథం కాలిక్యులేటర్
పరిచయం
Luhn ఆల్గోరిథం, "మోడులస్ 10" లేదా "మోడు 10" ఆల్గోరిథం అని కూడా పిలువబడుతుంది, క్రెడిట్ కార్డ్ నంబర్లు, కెనడియన్ సోషల్ ఇన్సూరెన్స్ నంబర్లు, IMEI నంబర్లు మరియు యునైటెడ్ స్టేట్స్లో నేషనల్ ప్రొవైడర్ ఐడెంటిఫైర్ నంబర్ల వంటి వివిధ గుర్తింపు నంబర్లను ధృవీకరించడానికి ఉపయోగించే సరళమైన చెక్సమ్ ఫార్ములా. ఈ కాలిక్యులేటర్ Luhn ఆల్గోరిథం ఉపయోగించి నంబర్లను ధృవీకరించడానికి మరియు Luhn చెక్ను పాస్ చేసే చెల్లుబాటు నంబర్లను రూపొందించడానికి అనుమతిస్తుంది.
Luhn ఆల్గోరిథం ఎలా పనిచేస్తుంది
Luhn ఆల్గోరిథం ఈ విధంగా పనిచేస్తుంది:
- కుడి వైపు చివరి అంకె (చెక్ అంకెను మినహాయించి) ప్రారంభించి, ప్రతి రెండవ అంకె యొక్క విలువను డబుల్ చేయండి.
- ఈ డబ్లింగ్ ఆపరేషన్ ఫలితం 9 కంటే ఎక్కువ అయితే, ఫలితానికి 9ను తీసివేయండి.
- ఫలితంగా వచ్చిన క్రమంలో అన్ని అంకెలను జోడించండి.
- మొత్తం మోడులో 10 0 కు సమానం అయితే (మొత్తం 0తో ముగుస్తే), అప్పుడు Luhn ఫార్ములా ప్రకారం సంఖ్య చెల్లుబాటు అవుతుంది; లేకపోతే, ఇది చెల్లుబాటు కాదు.
Luhn ఆల్గోరిథం యొక్క దృశ్య ప్రాతినిధ్యం ఇక్కడ ఉంది:
ఫార్ములా
Luhn ఆల్గోరిథం గణితంగా ఈ విధంగా వ్యక్తీకరించవచ్చు:
ఇక్కడ అనేది మోడులో ఆపరేషన్.
ఉపయోగాల కేసులు
Luhn ఆల్గోరిథం వివిధ రంగాలలో అనేక అనువర్తనాలు కలిగి ఉంది:
- క్రెడిట్ కార్డ్ ధృవీకరణ: ఎక్కువ క్రెడిట్ కార్డ్ నంబర్లు Luhn ఆల్గోరిథం ఉపయోగించి ధృవీకరించబడతాయి.
- కెనడియన్ సోషల్ ఇన్సూరెన్స్ నంబర్లు: ఈ గుర్తింపు నంబర్ల చెల్లుబాటును ధృవీకరించడానికి Luhn ఆల్గోరిథం ఉపయోగించబడుతుంది.
- IMEI నంబర్లు: మొబైల్ ఫోన్ IMEI నంబర్లు Luhn ఆల్గోరిథం ద్వారా ధృవీకరించబడే చెక్ అంకెను కలిగి ఉంటాయి.
- నేషనల్ ప్రొవైడర్ ఐడెంటిఫైర్ (NPI) నంబర్లు: యునైటెడ్ స్టేట్స్ ఆరోగ్య సంరక్షణ వ్యవస్థలో ఉపయోగించబడే ఈ నంబర్లు Luhn ఆల్గోరిథం ఉపయోగించి ధృవీకరించబడతాయి.
- ISBNలు: కొన్ని ISBN-10 నంబర్లు ధృవీకరణ కోసం Luhn ఆల్గోరిథం యొక్క ఒక వేరియంట్ను ఉపయోగిస్తాయి.
ప్రత్యామ్నాయాలు
Luhn ఆల్గోరిథం విస్తృతంగా ఉపయోగించబడుతున్నప్పటికీ, వివిధ ప్రయోజనాల కోసం ఇతర చెక్ డిజిట్ ఆల్గోరిథమ్లు ఉన్నాయి:
- Damm ఆల్గోరిథం: అన్ని సింగిల్-డిజిట్ పొరపాట్లను మరియు అన్ని పక్కన మార్పిడి పొరపాట్లను గుర్తించగల మరో చెక్ డిజిట్ ఆల్గోరిథం.
- Verhoeff ఆల్గోరిథం: అన్ని సింగిల్-డిజిట్ పొరపాట్లను మరియు చాలా మార్పిడి పొరపాట్లను పట్టుకునే మరింత సంక్లిష్టమైన చెక్సమ్ ఆల్గోరిథం.
- ISBN-13 చెక్ డిజిట్: ISBN-10 కంటే వేరే ఆల్గోరిథమ్ను ఉపయోగిస్తుంది, ఇది Luhn ఆల్గోరిథం ఆధారంగా ఉంటుంది.
చరిత్ర
Luhn ఆల్గోరిథం 1954లో IBM కంప్యూటర్ శాస్త్రవేత్త హాన్స్ పీటర్ లున్ ద్వారా సృష్టించబడింది. Luhn సమాచార శాస్త్రంలో పాయనీర్ మరియు KWIC (కీ వర్డ్ ఇన్ కాంటెక్స్) సూచిక వ్యవస్థ వంటి అనేక ఆవిష్కరణలకు క్రెడిట్ ఇవ్వబడింది.
ఈ ఆల్గోరిథం యాదృచ్ఛిక పొరపాట్లను రక్షించడానికి రూపొందించబడింది, దుష్ట దాడులకు కాదు. Luhn ఆల్గోరిథం అనేక సాధారణ పొరపాట్లను గుర్తించగలిగినా, ఇది భద్రతా సంకేతీకరణకు ఒక భద్రతా రూపం కాదు మరియు డేటా భద్రతా ఉద్దేశాల కోసం నమ్మకంగా ఉండకూడదు.
దాని వయస్సు ఉన్నప్పటికీ, Luhn ఆల్గోరిథం సాధారణ పునరావృత పొరపాట్లను పట్టుకోవడంలో దాని సరళత మరియు ప్రభావిత్వం కారణంగా విస్తృతంగా ఉపయోగించబడుతుంది.
అమలు ఉదాహరణలు
వివిధ ప్రోగ్రామింగ్ భాషలలో Luhn ఆల్గోరిథం అమలుకు కొన్ని కోడ్ ఉదాహరణలు ఇక్కడ ఉన్నాయి:
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
1function luhnValidate(number) {
2 const digits = number.toString().split('').map(Number);
3 let checksum = 0;
4 for (let i = digits.length - 1; i >= 0; i--) {
5 let d = digits[i];
6 if ((digits.length - i) % 2 === 0) {
7 d *= 2;
8 if (d > 9) d -= 9;
9 }
10 checksum += d;
11 }
12 return checksum % 10 === 0;
13}
14
15function generateValidNumber(length) {
16 const digits = Array.from({length: length - 1}, () => Math.floor(Math.random() * 10));
17 const checksum = digits.reduce((sum, digit, index) => {
18 if ((length - 1 - index) % 2 === 0) {
19 digit *= 2;
20 if (digit > 9) digit -= 9;
21 }
22 return sum + digit;
23 }, 0);
24 const checkDigit = (10 - (checksum % 10)) % 10;
25 return parseInt(digits.join('') + checkDigit);
26}
27
28// ఉదాహరణ ఉపయోగం:
29console.log(luhnValidate(4532015112830366)); // true
30console.log(luhnValidate(4532015112830367)); // false
31console.log(generateValidNumber(16)); // చెల్లుబాటు అయ్యే 16-అంకెల సంఖ్యను రూపొందిస్తుంది
32
1import java.util.Random;
2
3public class LuhnValidator {
4 public static boolean luhnValidate(long number) {
5 String digits = String.valueOf(number);
6 int checksum = 0;
7 boolean isEven = true;
8 for (int i = digits.length() - 1; i >= 0; i--) {
9 int digit = Character.getNumericValue(digits.charAt(i));
10 if (isEven) {
11 digit *= 2;
12 if (digit > 9) digit -= 9;
13 }
14 checksum += digit;
15 isEven = !isEven;
16 }
17 return checksum % 10 == 0;
18 }
19
20 public static long generateValidNumber(int length) {
21 Random random = new Random();
22 long[] digits = new long[length - 1];
23 for (int i = 0; i < length - 1; i++) {
24 digits[i] = random.nextInt(10);
25 }
26 long checksum = 0;
27 for (int i = digits.length - 1; i >= 0; i--) {
28 long digit = digits[i];
29 if ((length - 1 - i) % 2 == 0) {
30 digit *= 2;
31 if (digit > 9) digit -= 9;
32 }
33 checksum += digit;
34 }
35 long checkDigit = (10 - (checksum % 10)) % 10;
36 long result = 0;
37 for (long digit : digits) {
38 result = result * 10 + digit;
39 }
40 return result * 10 + checkDigit;
41 }
42
43 public static void main(String[] args) {
44 System.out.println(luhnValidate(4532015112830366L)); // true
45 System.out.println(luhnValidate(4532015112830367L)); // false
46 System.out.println(generateValidNumber(16)); // చెల్లుబాటు అయ్యే 16-అంకెల సంఖ్యను రూపొందిస్తుంది
47 }
48}
49
అంచనా కేసులు మరియు ప్రత్యేక పరిగణనలు
Luhn ఆల్గోరిథం అమలులో, ఈ క్రింది అంచనా కేసులు మరియు ప్రత్యేక పరిగణనలను పరిగణించండి:
-
ఇన్పుట్ ధృవీకరణ: ఇన్పుట్ ఒక చెల్లుబాటు అయ్యే సంఖ్యా స్ట్రింగ్ అని నిర్ధారించండి. నాన్-డిజిట్ అక్షరాలను సరైన రీతిలో నిర్వహించాలి (తొలగించబడాలి లేదా చెల్లుబాటు కాని ఇన్పుట్గా పరిగణించాలి).
-
ముందున్న జీరోలు: ముందున్న జీరోలతో ఉన్న సంఖ్యలతో ఆల్గోరిథం సరిగ్గా పనిచేయాలి.
-
పెద్ద సంఖ్యలు: కొన్ని ప్రోగ్రామింగ్ భాషలలో ప్రమాణిత అంకెల రకాలను మించిపోయే చాలా పొడవైన సంఖ్యలను నిర్వహించడానికి సిద్ధంగా ఉండండి.
-
ఖాళీ ఇన్పుట్: ఖాళీ స్ట్రింగ్స్ లేదా నల్ ఇన్పుట్లను మీ అమలుకు ఎలా నిర్వహించాలో నిర్వచించండి.
-
నాన్-స్టాండర్డ్ అక్షర సముదాయాలు: కొన్ని అనువర్తనాలలో, మీరు ప్రమాణిత 0-9 పరిధి వెలుపల అక్షరాలతో ప్రతినిధి చేసిన సంఖ్యలను ఎదుర్కొనవచ్చు. వీటిని ఎలా నిర్వహించాలో నిర్వచించండి.
-
పనితీరు పరిగణనలు: వేగంగా చాలా సంఖ్యల ఇన్పుట్లను ధృవీకరించాల్సిన అనువర్తనాల కోసం, ఆల్గోరిథం అమలును ఆప్టిమైజ్ చేయాలని పరిగణించండి.
సంఖ్యా ఉదాహరణలు
-
చెల్లుబాటు అయ్యే క్రెడిట్ కార్డ్ నంబర్:
- సంఖ్య: 4532015112830366
- Luhn చెక్: చెల్లుబాటు
-
చెల్లుబాటు కాని క్రెడిట్ కార్డ్ నంబర్:
- సంఖ్య: 4532015112830367
- Luhn చెక్: చెల్లుబాటు కాదు
-
చెల్లుబాటు అయ్యే కెనడియన్ సోషల్ ఇన్సూరెన్స్ నంబర్:
- సంఖ్య: 046 454 286
- Luhn చెక్: చెల్లుబాటు
-
చెల్లుబాటు కాని IMEI నంబర్:
- సంఖ్య: 490154203237518
- Luhn చెక్: చెల్లుబాటు కాదు
పరీక్షా కేసులు
Luhn ఆల్గోరిథం అమలును ధృవీకరించడానికి, మీరు క్రింది పరీక్షా కేసులను ఉపయోగించవచ్చు:
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
సూచనలు
- Luhn, H. P. (1960). "Computer for Verifying Numbers". US Patent 2,950,048.
- Gallian, Joseph. "The Mathematics of Identification Numbers." The College Mathematics Journal, vol. 22, no. 3, 1991, pp. 194–202. JSTOR, www.jstor.org/stable/2686878.
- "ISO/IEC 7812-1:2017". International Organization for Standardization. Retrieved August 2, 2024.
- Knuth, Donald. "The Art of Computer Programming, Volume 2: Seminumerical Algorithms". Addison-Wesley, 1997.
అభిప్రాయం
ఈ సాధనం గురించి అభిప్రాయం ఇవ్వడానికి ఫీడ్బ్యాక్ టోస్ట్ను క్లిక్ చేయండి.