محاسبهگر الگوریتم لوهن
محاسبه الگوریتم لون
مقدمه
الگوریتم لون، که به عنوان "مدول ۱۰" یا "مد ۱۰" نیز شناخته میشود، یک فرمول ساده چکسوم است که برای اعتبارسنجی انواع شمارههای شناسایی، مانند شمارههای کارت اعتباری، شمارههای بیمه اجتماعی کانادا، شمارههای IMEI و شمارههای شناسنده ملی ارائهدهندگان در ایالات متحده استفاده میشود. این محاسبهگر به شما این امکان را میدهد که شمارهها را با استفاده از الگوریتم لون اعتبارسنجی کنید و شمارههای معتبری که از چک لون عبور میکنند، تولید کنید.
نحوه کار الگوریتم لون
الگوریتم لون به شرح زیر عمل میکند:
- از سمت راست (به جز رقم چک) شروع کرده و به سمت چپ بروید و مقدار هر دومین رقم را دو برابر کنید.
- اگر نتیجه این عملیات دو برابر کردن بیشتر از ۹ باشد، ۹ را از نتیجه کم کنید.
- تمام ارقام در دنباله حاصل را جمع کنید.
- اگر مجموع ماژولوی ۱۰ برابر با ۰ باشد (اگر مجموع به صفر ختم شود)، آنگاه شماره مطابق با فرمول لون معتبر است؛ در غیر این صورت، معتبر نیست.
در اینجا یک نمایش بصری از الگوریتم لون آورده شده است:
فرمول
الگوریتم لون میتواند به صورت ریاضی به شرح زیر بیان شود:
بگذارید رقم -ام باشد، با شمارش از رقم راستترین (به جز رقم چک) و به سمت چپ حرکت کنید. سپس رقم چک به گونهای انتخاب میشود که:
که در آن عملگر ماژول است.
موارد استفاده
الگوریتم لون در زمینههای مختلف کاربردهای گوناگونی دارد:
- اعتبارسنجی کارتهای اعتباری: بیشتر شمارههای کارت اعتباری با استفاده از الگوریتم لون اعتبارسنجی میشوند.
- شمارههای بیمه اجتماعی کانادا: الگوریتم لون برای تأیید اعتبار این شمارههای شناسایی استفاده میشود.
- شمارههای IMEI: شمارههای IMEI تلفنهای همراه شامل یک رقم چک هستند که با الگوریتم لون اعتبارسنجی میشود.
- شمارههای شناسنده ملی (NPI): در سیستم بهداشت و درمان ایالات متحده، این شمارهها با استفاده از الگوریتم لون اعتبارسنجی میشوند.
- ISBNها: برخی از شمارههای ISBN-10 از یک واریانت الگوریتم لون برای اعتبارسنجی استفاده میکنند.
alternatives
در حالی که الگوریتم لون به طور گستردهای استفاده میشود، الگوریتمهای چکسوم دیگری نیز برای اهداف مختلف وجود دارد:
- الگوریتم دَم: یک الگوریتم رقم چک دیگر که تمام خطاهای یک رقمی و تمام خطاهای جابجایی مجاور را شناسایی میکند.
- الگوریتم ورهوف: یک الگوریتم چکسوم پیچیدهتر که تمام خطاهای یک رقمی و بیشتر خطاهای جابجایی را شناسایی میکند.
- رقم چک ISBN-13: از الگوریتم متفاوتی نسبت به ISBN-10 استفاده میکند که بر اساس الگوریتم لون است.
تاریخچه
الگوریتم لون توسط هانس پتر لون، یک دانشمند کامپیوتر IBM، در سال ۱۹۵۴ ایجاد شد. لون پیشگام در زمینه علم اطلاعات بود و به خاطر چندین نوآوری، از جمله سیستم نمایهسازی 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)) # True
print(luhn_validate(4532015112830367)) # False
print(generate_valid_number(16)) # تولید یک شماره معتبر ۱۶ رقمی
موارد حاشیهای و ملاحظات ویژه
هنگام پیادهسازی الگوریتم لون، به موارد حاشیهای و ملاحظات ویژه زیر توجه کنید:
-
اعتبارسنجی ورودی: اطمینان حاصل کنید که ورودی یک رشته عددی معتبر است. کاراکترهای غیر عددی باید به طور مناسب مدیریت شوند (یا حذف شوند یا به عنوان ورودی نامعتبر در نظر گرفته شوند).
-
صفرهای ابتدایی: الگوریتم باید به درستی با شمارههایی که دارای صفرهای ابتدایی هستند، کار کند.
-
شمارههای بزرگ: آماده باشید که شمارههای بسیار طولانی را که ممکن است از ظرفیت نوعهای استاندارد عددی در برخی زبانهای برنامهنویسی فراتر بروند، مدیریت کنید.
-
ورودی خالی: تعریف کنید که پیادهسازی شما باید چگونه با رشتههای خالی یا ورودیهای null برخورد کند.
-
مجموعههای کاراکتری غیر استاندارد: در برخی برنامهها، ممکن است با شمارههایی روبرو شوید که با کاراکترهایی خارج از محدوده استاندارد ۰-۹ نمایش داده میشوند. تعریف کنید که اینها چگونه باید مدیریت شوند.
-
ملاحظات عملکرد: برای برنامههایی که نیاز به اعتبارسنجی تعداد زیادی ورودی به سرعت دارند، به بهینهسازی پیادهسازی الگوریتم فکر کنید.
مثالهای عددی
-
شماره معتبر کارت اعتباری:
- شماره: 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()
منابع
- Luhn, H. P. (1960). "کامپیوتر برای تأیید شمارهها". پتنت ایالات متحده ۲,۹۵۰,۰۴۸.
- گالیان، جوزف. "ریاضیات شمارههای شناسایی." نشریه ریاضیات کالج، جلد ۲۲، شماره ۳، ۱۹۹۱، صفحات ۱۹۴–۲۰۲. JSTOR، www.jstor.org/stable/2686878.
- "ISO/IEC 7812-1:2017". سازمان بینالمللی استانداردسازی. بازیابی شده در ۲ آگوست ۲۰۲۴.
- کُنث، دونالد. "هنر برنامهنویسی کامپیوتر، جلد ۲: الگوریتمهای نیمه عددی". ادیسون-وِسلی، ۱۹۹۷.