

منطق کامل
در این مقاله ابتدا تعریف منطقی را به همراه تعدادی مثال بیان میکنیم و منطق کامل بودن مجموعهای از این توابع را تعریف میکنیم. سپس شروطی لازم برای منطق کامل بودن یک مجموعه دلخواه از توابع ارائه میدهیم و پس از آن کافی بودن این شروط را ثابت میکنیم.
معرفی توابع منطقی
تعاریف
بهطور کلی، توابع منطقی دستهای از توابع چندمتغیره هستند که اگر در ورودی آنها ۰ یا ۱ قرار گیرد، خروجی آنها نیز ۰ یا ۱ خواهد بود. این توابع را اینگونه نشان میدهیم:
از معروفترین این توابع که در ساخت مدارهای منطقی کاربرد دارند، میتوان به تابعهای OR ،NOT ،AND اشاره کرد. از این به بعد برای نشان دادن نحوهٔ کار هر تابع، آن را با جدول درستی آن نشان میدهیم. جدول درستی سه تابع ذکرشده را در شکل ۱ میبینید. برای مثال، تابع AND تنها در صورتی برابر با ۱ میشود که هر دو ورودی آن برابر با ۱ باشند؛ و تابع OR تنها زمانی ۰ میشود که هر دو ورودی آن برابر با ۰ باشند.

مسئلهٔ ۱. هر سهٔ این توابع را میتوان به صورت یک چندجملهای دومتغیره از ورودیهایشان نمایش داد. برای مثال AND(x, y) = xy. آیا میتوانید بگویید چندجملهای OR(x, y) چه خواهد بود؟
آشنایی با جبر بول
برای نشان دادن ترکیبهای مختلف توابع AND ،OR ،NOT که توابع ابتدایی ما هستند، نمادهایی تعریف میکنیم.
حال میتوانیم توابع مختلفی با استفاده از ترکیب این توابع با هم ایجاد کنیم. تعدادی از خواص این توابع را معرفی میکنیم که به دلخواه خود میتوانید آنها را اثبات کنید.
این تابع بهازای چه ورودیهایی برابر با ۱ میشود؟
ساخت همهٔ توابع با توابع ابتدایی
قضیهٔ ۱. هر تابع منطقی را میتوانیم با ترکیب تعدادی از توابع AND ،OR ،NOT بسازیم. در اینجا به اثبات دقیق این گزاره نمیپردازیم؛ اما مثالی از تبدیل تابعی به ترکیبی از توابع سادهتر در شکل ۲ میزنیم تا خودتان با استفاده از آن، گزاره را در حالت کلی ثابت کنید.

منطق کامل
تعریف و مثال
تعریف ۱. به مجموعهای از توابع منطقی، منطق کامل گفته میشود اگر که بتوان با استفاده از آن توابع و ترکیبشان با یکدیگر، تمام توابع منطقی را تولید کرد.
برای مثال مجموعهٔ توابع منطق کامل بودند، اما OR(x, y) توسط دو تابع دیگر قابلساخت است. داریم:
پس میتوانیم بگوییم که مجموعهٔ توابع نیز منطق کامل هستند. تابع جدیدی معرفی میکنیم:
با استفاده از تابع NAND، میتوانیم توابع AND و NOT را بسازیم:
و بدینترتیب ثابت کردیم که مجموعهٔ نیز یک منطق کامل است.
مسئلهٔ ۳. ثابت کنید مجموعهٔ توابع زیر نیز منطق کامل هستند:
ناوردا
مسئلهٔ ۴. توابع زیر را در نظر بگیرید:
آیا مجموعهٔ این توابع میتواند منطق کامل باشد؟
جواب این مسئله، خیر است. تابعی در نظر بگیرید که اگر تمام ورودیهایش ۱ باشد خروجی آن برابر با ۰ باشد. به نظر شما، آیا این سه تابع قادر به ساختن آن خواهند بود؟
این سه تابع اگر تمام ورودیهایشان برابر ۱ باشد، خروجیشان نیز برابر با ۱ خواهد بود. پس هر چقدر این توابع را با هم ترکیب کنیم، تابع ساختهشده نیز این خاصیت را خواهد داشت.(چرا؟)
این خاصیت، روی ترکیب توابع ناوردا است. اگر که همهٔ توابع مجموعه در این خاصیت صدق کنند، هر ترکیبی از این توابع نیز در این خاصیت صدق میکند. در این بخش، ۵ خاصیت معرفی خواهیم کرد که نسبت به ترکیب توابع دارای آن خاصیت، بسته هستند.
-
حفظ یک. اگر تمام ورودیهای تابع برابر با ۱ باشد، خروجی آن نیز ۱ شود.
-
حفظ صفر. اگر تمام ورودیهای تابع برابر با ۰ باشد، خروجی آن نیز ۰ شود.
-
صعودی بودن. به ازای هر وضعیتی از ورودیهای تابع، اگر که یک ۰ را در میان ورودیها به ۱ تبدیل کنیم، خروجی کم نشود؛ یعنی اگر خروجی ۱ بود به ۰ تبدیل نشود.
-
خود-دوگان. به ازای هر حالت ورودیهای تابع، اگر تمام ورودیها را نقیض کنیم (اگر ۰ بود ۱ کنیم و اگر ۱ بود ۰ کنیم)، خروجی تابع نیز نقیض شود.
-
خطی بودن. اگر تابع در یکی از شرایط زیر صدق کند، به آن خطی گفته میشود:
- تابع، برابر XOR تعدادی از متغیرهایش باشد (این تعداد میتواند ۰ باشد):
- تابع، برابر نقیض XOR تعدادی از متغیرهایش باشد (این تعداد میتواند ۰ باشد):
ساخت همهٔ توابع منطقی با تعدادی تابع
ابتدا با یک مسئلهٔ ساده شروع میکنیم.
مسئلهٔ ۵. فرض کنید تابع منطقی عضو کلاس توابع حفظکنندهٔ یک، حفظکنندهٔ صفر و خود-دوگان نباشد. ثابت کنید این تابع منطق کامل است.
اثبات. برای اثبات منطق کامل بودن یک تابع، کافیست مجموعهای از توابع را با آن بسازیم که میدانیم منطق کامل هستند. برای مثال اگر بتوانیم NOR یا NAND را بسازیم، اثبات کردهایم که تابع ما نیز منطق کامل است.
میدانیم که تابع ما خود-دوگان نیست. این گزاره یعنی ورودیهایی وجود دارند که اگر همهٔ آنها را نقیض کنیم، تابع نقیض نشود.
دقت کنید که چون تابع حفظکنندهٔ صفر و حفظکنندهٔ یک نبود، پس این ورودی، ورودی تمام صفر یا تمام یک نیست.
حالا به تابعمان به این نحو ورودی دهید: برای ورودی i ام، اگر xi برابر با یک بود ، و در غیر این صورت را قرار دهید. تابع حاصل یک تابع برحسب و مانند است. حالا طبق تعریف، مقادیر به ازای ورودیهای مختلف را بررسی میکنیم:
حالا اگر باشد، در واقع تابع همان NOR است و در غیر این صورت همان NAND است! پس ما با استفاده از این تابع یک مجموعه از توابع منطق کامل ساختیم، در نتیجه خود منطق کامل است.
حالا میخواهیم به مسئلهٔ اصلی این بخش بپردازیم:
مسئلهٔ ۶. اگر مجموعهای از توابع منطقی باشد، و به ازای هر کدام از کلاسهای توابع حفظکنندهٔ صفر، حفظکنندهٔ یک، صعودی، خود-دوگان و خطی، تابعی در وجود داشته باشد که عضو آن کلاس نباشد، آنگاه مجموعهٔ منطق کامل است.
زیرمسئلهٔ ۱: اگر مجموعهای از توابع منطقی باشد و به ازای هر کدام از کلاسهای توابع حفظکنندهٔ صفر، حفظکنندهٔ یک، صعودی و خود-دوگان، تابعی در وجود داشته باشد که عضو آن کلاس نباشد، آنگاه با این توابع میتوان صفر، یک و NOT را ساخت.
حالت ۱: تابعی مانند در وجود داشته باشد که حفظکنندهٔ صفر و حفظکنندهٔ یک نباشد.
- ساخت NOT: چون تابع حفظکنندهٔ صفر و حفظکنندهٔ یک نیست، داریم:
- ساخت صفر و یک: از طرفی تابعی مانند در هست که خود-دوگان نباشد، یعنی:
حالا به تابعمان به این نحو ورودی دهید: برای ورودی ام، اگر برابر ۱ بود ، و در غیر این صورت را قرار دهید. تابع حاصل یک تابع برحسب مانند است. طبق تعریف . حالا اگر باشد، آنگاه یک را ساختیم و با استفاده از تابع NOT که ساختیم، صفر هم داریم. و اگر آنگاه صفر را ساختیم و با استفاده از تابع NOT که ساختیم، یک هم داریم.
حالت ۲: دو تابع مختلف مانند و در وجود داشته باشند كه حفظکنندهٔ صفر نباشد و حفظکننده یک باشد، و حفظکنندهٔ یک نباشد، ولی حفظکنندهٔ صفر باشد.
-
ساخت صفر و یک: طبق فرض و که یعنی صفر و یک ساخته شدهاند.
-
ساخت NOT: از طرفی تابعی مانند در وجود دارد که صعودی نیست. یعنی به ازای یک ورودی، برابر یک است، ولی اگر یکی از ورودیهای صفر آن را به یک تبدیل کنیم خروجی تابع برابر با صفر میشود (بدون کاهش کلیت مسئله فرض میکنیم این اتفاق برای ورودی اول میافتد). یعنی:
حالا که صفر و یک را ساختهایم، میتوانیم به تابعمان همان های خاص را ورودی دهیم. تابع زیر را در نظر بگیرید:
طبق تعریف داریم:
که یعنی این همان تابع NOT است.
زیرمسئلهٔ ۲: اگر تابع خطی نباشد، مجموعهٔ منطق کامل است. ابتدا یک تعریف معادل برای خطی بودن یک تابع میآوریم، اما به اثبات آن نمیپردازیم.
- قضیهٔ ۲. تابع منطقی خطی است اگر و تنها اگر ورودیهای آن به دو دسته افراز شوند. ورودیهایی که مستقل از بقیهٔ ورودیها، تأثیری در خروجی نمیگذارند و ورودیهایی که مستقل از بقیهٔ ورودیها، نقیض کردنشان منجر به نقیض شدن خروجی تابع میشود.
حالا تابع مطابق فرض خطی نیست. این یعنی یکی از ورودیهای (بدون کاستی از کلیت مسئله، در نظر میگیریم ورودی اول) هست که نقیض کردن آن به ازای رشتهای از سایر ورودیها تأثیری در خروجی تابع نداشته باشد و به ازای رشتهای دیگر، نقیض کردن آن خروجی تابع را نیز نقیض کند، یعنی:
حالا تابع را به این صورت تعریف میکنیم: را به ورودی اول بدهید. برای ورودی ام ، اگر ، خود همان عدد را ورودی میدهیم (چون به صفر و یک دسترسی داریم). اگر ، آنگاه را به عنوان ورودی میدهیم. و اگر ، آنگاه را ورودی میدهیم (چون به NOT دسترسی داریم).
طبق این تعریف، و . این یعنی جدول درستی این تابع در سه تا از ستونها یکسان و در دیگری متفاوت است که یعنی تابع به یکی از صورتهای ، ، ، ، ، ، ، است. با استفادهٔ مناسب از تابع NOT در ورودیهای این تابع میتوان این تابع را به یکی از توابع یا تبدیل کرد. چون تابع NOT هم در اختیار داریم، با توابعمان یک مجموعهٔ منطق کامل ساختهایم.