লুন অ্যালগরিদম ক্যালকুলেটর
লুন অ্যালগরিদম ক্যালকুলেটর
পরিচিতি
লুন অ্যালগরিদম, যা "মডুলাস 10" বা "মড 10" অ্যালগরিদম হিসাবেও পরিচিত, এটি একটি সহজ চেকসাম সূত্র যা বিভিন্ন পরিচয় নম্বর যাচাই করতে ব্যবহৃত হয়, যেমন ক্রেডিট কার্ড নম্বর, কানাডিয়ান সোশ্যাল ইনস্যুরেন্স নম্বর, IMEI নম্বর এবং যুক্তরাষ্ট্রের জাতীয় প্রদানকারী শনাক্তকারী নম্বর। এই ক্যালকুলেটর আপনাকে লুন অ্যালগরিদম ব্যবহার করে নম্বর যাচাই করতে এবং লুন চেক পাস করা বৈধ নম্বর তৈরি করতে দেয়।
লুন অ্যালগরিদম কিভাবে কাজ করে
লুন অ্যালগরিদম নিম্নলিখিতভাবে কাজ করে:
- ডান দিকের শেষ ডিজিট (চেক ডিজিট বাদে) থেকে শুরু করে বাম দিকে গিয়ে, প্রতি দ্বিতীয় ডিজিটের মান দ্বিগুণ করুন।
- যদি এই দ্বিগুণ অপারেশনের ফলাফল 9 এর বেশি হয়, তবে ফলাফল থেকে 9 বিয়োগ করুন।
- ফলস্বরূপ সিকোয়েন্সের সমস্ত ডিজিটের যোগফল বের করুন।
- যদি মোটের মডুলো 10 শূন্যের সমান হয় (যদি মোট শূন্যে শেষ হয়), তবে সংখ্যা লুন সূত্র অনুযায়ী বৈধ; অন্যথায়, এটি বৈধ নয়।
লুন অ্যালগরিদমের একটি ভিজ্যুয়াল উপস্থাপনা এখানে:
সূত্র
লুন অ্যালগরিদমটি গণিতের ভাষায় নিম্নরূপ প্রকাশ করা যেতে পারে:
ধরি হল -তম ডিজিট, ডান দিকের শেষ ডিজিট (চেক ডিজিট বাদে) থেকে গণনা করে এবং বাম দিকে গিয়ে। তাহলে চেক ডিজিট এমনভাবে নির্বাচন করা হয় যে:
যেখানে হল মডুলো অপারেশন।
ব্যবহার ক্ষেত্র
লুন অ্যালগরিদমের বিভিন্ন ক্ষেত্রে ব্যবহার রয়েছে:
- ক্রেডিট কার্ড যাচাইকরণ: বেশিরভাগ ক্রেডিট কার্ড নম্বর লুন অ্যালগরিদম ব্যবহার করে যাচাই করা হয়।
- কানাডিয়ান সোশ্যাল ইনস্যুরেন্স নম্বর: এই পরিচয় নম্বরগুলির বৈধতা যাচাই করতে লুন অ্যালগরিদম ব্যবহার করা হয়।
- IMEI নম্বর: মোবাইল ফোনের IMEI নম্বরগুলিতে একটি চেক ডিজিট রয়েছে যা লুন অ্যালগরিদম দ্বারা যাচাই করা হয়।
- জাতীয় প্রদানকারী শনাক্তকারী (NPI) নম্বর: যুক্তরাষ্ট্রের স্বাস্থ্যসেবা ব্যবস্থায় ব্যবহৃত, এই নম্বরগুলি লুন অ্যালগরিদম ব্যবহার করে যাচাই করা হয়।
- ISBNs: কিছু ISBN-10 নম্বর বৈধতা যাচাইয়ের জন্য লুন অ্যালগরিদমের একটি পরিবর্তন ব্যবহার করে।
বিকল্প
যদিও লুন অ্যালগরিদম ব্যাপকভাবে ব্যবহৃত হয়, তবে বিভিন্ন উদ্দেশ্যের জন্য অন্যান্য চেকসাম অ্যালগরিদমও রয়েছে:
- ডাম অ্যালগরিদম: একটি অন্য চেক ডিজিট অ্যালগরিদম যা সমস্ত একক ডিজিটের ত্রুটি এবং সমস্ত পার্শ্ববর্তী স্থানান্তর ত্রুটি সনাক্ত করে।
- ভারহফ অ্যালগরিদম: একটি আরও জটিল চেকসাম অ্যালগরিদম যা সমস্ত একক ডিজিটের ত্রুটি এবং বেশিরভাগ স্থানান্তর ত্রুটি ধরতে পারে।
- ISBN-13 চেক ডিজিট: ISBN-10 এর চেয়ে ভিন্ন অ্যালগরিদম ব্যবহার করে, যা লুন অ্যালগরিদমের উপর ভিত্তি করে।
ইতিহাস
লুন অ্যালগরিদমটি 1954 সালে আইবিএমের কম্পিউটার বিজ্ঞানী হান্স পিটার লুন দ্বারা তৈরি করা হয়েছিল। লুন তথ্য বিজ্ঞান ক্ষেত্রে একজন পথিকৃৎ ছিলেন এবং KWIC (কী ওয়ার্ড ইন কনটেক্সট) ইনডেক্সিং সিস্টেম সহ বেশ কয়েকটি উদ্ভাবনের জন্য পরিচিত।
অ্যালগরিদমটি মূলত দুর্ঘটনাবশত ত্রুটির বিরুদ্ধে সুরক্ষা দেওয়ার জন্য ডিজাইন করা হয়েছিল, ক্ষতিকারক আক্রমণের জন্য নয়। এটি লক্ষ্য করা গুরুত্বপূর্ণ যে যদিও লুন অ্যালগরিদম অনেক সাধারণ ত্রুটি সনাক্ত করতে পারে, এটি একটি নিরাপদ এনক্রিপশন ফর্ম নয় এবং ডেটা সুরক্ষার উদ্দেশ্যে নির্ভর করা উচিত নয়।
এর বয়স সত্ত্বেও, লুন অ্যালগরিদম তার সরলতা এবং সাধারণ লেখার ত্রুটি ধরার কার্যকারিতার কারণে ব্যাপকভাবে ব্যবহৃত হচ্ছে।
বাস্তবায়ন উদাহরণ
বিভিন্ন প্রোগ্রামিং ভাষায় লুন অ্যালগরিদম বাস্তবায়নের কিছু কোড উদাহরণ এখানে রয়েছে:
import random
def luhn_validate(number):
digits = [int(d) for d in str(number)]
checksum = 0
for i in range(len(digits) - 1, -1, -1):
d = digits[i]
if (len(digits) - i) % 2 == 0:
d = d * 2
if d > 9:
d -= 9
checksum += d
return checksum % 10 == 0
def generate_valid_number(length):
digits = [random.randint(0, 9) for _ in range(length - 1)]
checksum = sum(digits[::2]) + sum(sum(divmod(d * 2, 10)) for d in digits[-2::-2])
check_digit = (10 - (checksum % 10)) % 10
return int(''.join(map(str, digits + [check_digit])))
## উদাহরণ ব্যবহার:
print(luhn_validate(4532015112830366)) # সত্য
print(luhn_validate(4532015112830367)) # মিথ্যা
print(generate_valid_number(16)) # একটি বৈধ 16-অঙ্কের নম্বর তৈরি করে
প্রান্তের কেস এবং বিশেষ বিবেচনা
লুন অ্যালগরিদম বাস্তবায়ন করার সময়, নিম্নলিখিত প্রান্তের কেস এবং বিশেষ বিবেচনাগুলি মনে রাখুন:
-
ইনপুট যাচাইকরণ: নিশ্চিত করুন যে ইনপুটটি একটি বৈধ সংখ্যা স্ট্রিং। অ-ডিজিট অক্ষরগুলি যথাযথভাবে পরিচালনা করা উচিত (অথবা মুছে ফেলা বা অবৈধ ইনপুট হিসাবে বিবেচনা করা উচিত)।
-
লিডিং জিরো: অ্যালগরিদমটি লিডিং জিরো সহ নম্বরগুলির সাথে সঠিকভাবে কাজ করা উচিত।
-
বড় সংখ্যা: কিছু প্রোগ্রামিং ভাষার স্ট্যান্ডার্ড পূর্ণসংখ্যা টাইপের ক্ষমতা অতিক্রমকারী খুব দীর্ঘ সংখ্যাগুলিকে পরিচালনা করতে প্রস্তুত থাকুন।
-
খালি ইনপুট: আপনার বাস্তবায়নটি খালি স্ট্রিং বা শূন্য ইনপুট কীভাবে পরিচালনা করবে তা সংজ্ঞায়িত করুন।
-
অ-মানক অক্ষর সেট: কিছু অ্যাপ্লিকেশনে, আপনি এমন সংখ্যাগুলি দেখতে পারেন যা মানক 0-9 পরিসরের বাইরে অক্ষর দ্বারা উপস্থাপিত। এগুলি কীভাবে পরিচালনা করা উচিত তা সংজ্ঞায়িত করুন।
-
পারফরম্যান্স বিবেচনা: এমন অ্যাপ্লিকেশনগুলির জন্য যা দ্রুত অনেক ইনপুট যাচাই করতে প্রয়োজন, অ্যালগরিদম বাস্তবায়ন অপ্টিমাইজ করার কথা বিবেচনা করুন।
সংখ্যাগত উদাহরণ
-
বৈধ ক্রেডিট কার্ড নম্বর:
- নম্বর: 4532015112830366
- লুন চেক: বৈধ
-
অবৈধ ক্রেডিট কার্ড নম্বর:
- নম্বর: 4532015112830367
- লুন চেক: অবৈধ
-
বৈধ কানাডিয়ান সোশ্যাল ইনস্যুরেন্স নম্বর:
- নম্বর: 046 454 286
- লুন চেক: বৈধ
-
অবৈধ IMEI নম্বর:
- নম্বর: 490154203237518
- লুন চেক: অবৈধ
পরীক্ষার কেস
লুন অ্যালগরিদমের বাস্তবায়ন যাচাই করতে, আপনি নিম্নলিখিত পরীক্ষার কেসগুলি ব্যবহার করতে পারেন:
def test_luhn_algorithm():
assert luhn_validate(4532015112830366) == True
assert luhn_validate(4532015112830367) == False
assert luhn_validate(79927398713) == True
assert luhn_validate(79927398714) == False
# তৈরি করা নম্বর পরীক্ষা
for _ in range(10):
assert luhn_validate(generate_valid_number(16)) == True
print("সব পরীক্ষায় সফল হয়েছে!")
test_luhn_algorithm()
রেফারেন্স
- লুন, এইচ. পি. (1960)। "নম্বর যাচাই করার জন্য কম্পিউটার"। মার্কিন পেটেন্ট 2,950,048।
- গ্যালিয়ান, জোসেফ। "পরিচয় নম্বরগুলির গণিত।" দ্য কলেজ ম্যাথমেটিক্স জার্নাল, খণ্ড 22, সংখ্যা 3, 1991, পৃষ্ঠা 194–202। JSTOR, www.jstor.org/stable/2686878।
- "ISO/IEC 7812-1:2017"। আন্তর্জাতিক মান সংস্থা। 2 আগস্ট, 2024 তারিখে প্রাপ্ত।
- কনথ, ডোনাল্ড। "কম্পিউটার প্রোগ্রামিংয়ের শিল্প, খণ্ড 2: সেমিনিউমেরিক্যাল অ্যালগরিদম"। অ্যাডিসন-ওয়েসলি, 1997।