هوش مصنوعی آزاد:منطق فازی

From بنیاد دانش آزاد
Jump to: navigation, search

خواهشمندیم با اضافه کردن منابع، کتاب‌ها، مقالات و افزودن متن‌های مفید به تکمیل این صفحه کمک کنید.

کلیات منطق فازی

در این قسمت توضیحات مختصر و مفیدی راجع به سرفصل منطق فازی نوشته می‌شود. برای یادگیری بیشتر می‌توانید از لینک‌هایی که قرار داده شده استفاده کنید. برای آموزش می‌توانید از منابع آموزشی معرفی شده در این صفحه استفاده کنید. همچنین می‌توانید برای آموزش بیشتر در قسمت مشارکت آموزشی مشارکت داشته باشید.


منطق فازی

خلاصه‌ای از توضیحات منابع معرفی شده ( منابع استفاده شده در حال حاضر منطق فازی در ویکی‌پدیا و کتاب‌های معرفی شده در قسمت منابع)

منطق فازی (به انگلیسی: fuzzy logic) اولین بار در پی تنظیم نظریهٔ مجموعه‌های فازی به وسیلهٔ پروفسور لطفی زاده (۱۹۶۵ م) در صحنهٔ محاسبات نو ظاهر شد. واژه ی fuzzy به معنای غیر دقیق، ناواضح و مبهم (شناور) است.

کاربرد این مبحث در علوم نرم‌افزاری را می‌توان به طور ساده این‌گونه تعریف کرد: منطق فازی از منطق ارزش‌های "صفر و یک" نرم‌افزارهای کلاسیک فراتر رفته و درگاهی جدید برای دنیای علوم نرم‌افزاری و رایانه‌ها می‌گشاید، زیرا فضای شناور و نامحدود بین اعداد صفر و یک را نیز در منطق و استدلال‌های خود به کار می‌گیرد. منطق فازی از فضای بین دو ارزش "برویم" یا "نرویم"، ارزش های جدید "شاید برویم" یا "می‌رویم اگر" یا حتی "احتمال دارد برویم" را استخراج کرده و به کار می‌گیرد. بدین ترتیب به عنوان مثال مدیر بانک پس از بررسی رایانه‌ای بیلان اقتصادی یک بازرگان می‌تواند فراتر از منطق "وام می‌دهیم" یا "وام نمی‌دهیم" رفته و بگوید: "وام می‌دهیم اگر ..."

دانش مورد نیاز برای بسیاری از مسائل مورد مطالعه به دو صورت متمایز ظاهر می‌شود:

  1. دانش صریح مثل مدل‌ها و معادلات و فرمول‌های ریاضی که از پیش تنظیم شده و برای حل و فصل مسائل معمولی فیزیک، شیمی، یا مهندسی مورد استفاده قرار می‌گیرد.
  2. دانش ضمنی مثل دانستنی‌هایی که تا حدودی قابل توصیف و بیان زبان‌شناختی بوده، ولی امکان کمّی کردن آن‌ها با کمک ریاضیات سنتی معمولاً وجود ندارد. به این نوع دانش، دانش ضمنی یا دانش تلویحی (Tacit knowledge) گفته می‌شود.

از آن جا که در عمل هر دو نوع دانش مورد نیاز است منطق فازی می‌کوشد آن‌ها را به صورتی منظم، منطقی، و ریاضیاتی بایکدیگر هماهنگ گرداند.

منطق فازی از جمله منطق‌های چندارزشی بوده و بر نظریه مجموعه‌های فازی تکیه می‌کند. مجموعه‌های فازی خود از تعمیم و گسترش مجموعه‌های قطعی به صورتی طبیعی حاصل می‌آیند.


مجموعه‌های قطعی (Crisp sets) در واقع همان مجموعه‌های عادی و معمولی هستند که در ابتدای نظریه مجموعه‌ها معرفی می‌شوند. افزودن صفت قطعی به واقع وجه تمایزی را ایجاد می‌نماید که به کمک آن می‌شود یکی از مفاهیم ابتکاری و حیاتی در منطق فازی موسوم به تابع عضویت را به آسانی در ذهن به وجود آورد.

در حالت مجموعه‌های قطعی، تابع عضویت فقط دو مقدار در برد خود دارد (در ریاضیات، برد یک تابع برابر با مجموعه تمام خروجی‌های تابع است).

آری و خیر (یک و صفر) که همان دو مقدار ممکن در منطق کلاسیک هستند. بنابراین:


1 اگر x مطعلق به مجموعه باشد
0 اگر x مطعلق به مجموعه نباشد


که در اینجا μA تابع عضویت عنصر x در مجموعه قطعی A است.

مجموعه‌های فازی: برد تابع عضویت از {0, 1} در مورد مجموعه‌های قطعی به بازهٔ بستهٔ [0, 1] برای مجموعه‌های فازی تبدیل می‌شود.

منطق فازی دما

متغیر‌های زبانی: متغیرهای زبانی به متغیرهایی گفته می‌شود که مقادیر مورد قبول برای آن‌ها به جای اعداد، کلمات و جملات زبان طبیعی یا زبان ماشینی هستند.

همانگونه که در محاسبات ریاضی از متغیرهای عددی استفاده می‌گردد، در منطق فازی نیز از متغیرهای زبانی (گفتاری یا غیر عددی) استفاده می‌گردد. متغیرهای زبانی بر اساس ارزش‌های زبانی (گفتاری) که در مجموعه عبارت (کلمات/اصطلاحات) قرار دارند بیان می‌شود. عبارت زبانی (Linguistic terms) صفاتی برای متغیرهای زبانی هستند. به عنوان مثال: متغیر زبانی «سن» بسته به تقسیمات مورد نظر شخصی و شرایط می‌تواند مجموعه عباراتی از قبیل «نوجوان»، «جوان»، «میان سال» و «سالمند» باشد.


مجموعه عبارات (اصطلاحات) فازی (سن) = { «جوان»، «نه جوان»، «نه چندان جوان»، «خیلی جوان»،... ، «میان سال»، «نه چندان میان سال»...، «پیر»، «نه پیر»، «خیلی پیر»، «کم و بیش پیر»...، «نه خیلی جوان و نه خیلی پیر»، «نه جوان و نه پیر»...



یا در مثالی دیگر، فشار(خون) را می‌توان متغیری زبانی در نظر گرفت، که ارزش‌هایی (خصوصیت‌هایی) از قبیل پایین، بالا، ضعیف، متوسط و قوی را می‌تواند در خود جای دهد. به زبان ریاضی داریم (T = Terms):

{پایین، بالا، ضعیف، متوسط، قوی} = (فشار)T

توابع عضویت: درجه عضویت μA بیانگر میزان عضویت عنصر x به مجموعه فازی Ă است. اگر درجه عضویت یک عنصر از مجموعه برابر با صفر باشد، آن عضو کاملاً از مجموعه خارج است و اگر درجه عضویت یک عضو برابر با یک باشد، آن عضو کاملاً در مجموعه قرار دارد. حال اگر درجه عضویت یک عضو مابین صفر و یک باشد، این عدد بیانگر درجه عضویت تدریجی می‌باشد.

عدم قطعیت : صفت عدم قطعیت، به صورت های گوناگون، در همهٔ زمینه‌ها و پدیده‌ها صرف نظر از روش شناسی مورد کاربرد جهت مطالعه، طراحی، و کنترل پدیدار می‌شود. مفاهیم نادقیق بسیاری در پیرامون ما وجود دارند که آن‌ها را به صورت روزمره در قالب عبارت‌های مختلف بیان می‌کنیم. به عنوان مثال: «هوا خوب است» هیچ کمیتی برای خوب بودن هوا مطرح نیست تا آن را بطور دقیق اندازه‌گیری نماییم، بلکه این یک حس کیفی است. در واقع مغز انسان با در نظر گرفتن عوامل گوناگون و بر پایه تفکر استنتاجی جملات را تعریف و ارزش گذاری می‌نماید که الگوبندی آن‌ها به زبان و فرمول‌های ریاضی اگر غیر ممکن نباشد، کاری بسیار پیچیده خواهد بود. منطق فازی فناوری جدیدی است که شیوه‌هایی را که برای طراحی و مدل سازی یک سیستم نیازمند ریاضیات پیچیده و پیشرفته‌است، با استفاده از مقادیر زبانی و دانش فرد خبره جایگزین می‌سازد.

هدف اصلی آنست که تا حد امکان، رایانه‌ها بتوانند مسائل و مشکلات بسیار پیچیده ی علمی را با همان سهولت و شیوایی بررسی و حل و فصل کنند که ذهن انسان قادر به ادراک و اخذ تصمیمات سریع و مناسب است.

در جهان واقعیات، بسیاری از مفاهیم را آدمی به صورت فازی (به معنای غیر دقیق، ناواضح و مبهم) درک می‌کند و به کار می‌بندد. به عنوان نمونه، هر چند کلمات و مفاهیمی همچون گرم، سرد، بلند، کوتاه، پیر، جوان و نظائر این‌ها به عدد خاص و دقیقی اشاره ندارند، اما ذهن انسان با سرعت و با انعطاف پذیری شگفت‌آوری همه را می‌فهمد و در تصمیمات و نتیجه‌گیریهای خود به کار می‌گیرد. این، در حالی ست که ماشین فقط اعداد را می‌فهمد و اهل دقّت است. اهداف شیوه‌های نو در علوم کامپیوتر آن است که اولاً رمز و راز این‌گونه توانایی‌ها را از انسان بیاموزد و سپس آن‌ها را تا حد امکان به ماشین یاد بدهد.

توضیحات

مجموعهٔ فازی و توابع عضویت

منطق فازی به منظور استنتاج در مورد مجموعه‌های فازی به کار می‌رود که متفاوت از مجموعه‌های قطعی می‌باشند. مجموعه‌های قطعی از طریق اعضایی که در آن عضو هستند شناخته می‌شوند؛ یعنی یک عضو یا به مجموعهٔ قطعی تعلق دارد یا ندارد. در حالی که مجموعه‌های فازی شامل اعضایی با درجه‌ٔ عضویت مخصوص به خود می‌باشند؛ به طوری که یک عضو می‌تواند با درجه‌ٔ عضویت‌های متفاوت عضو مجموعهٔ A و مجموعه مکمل Á باشد. در نتیجه تعریف یک مجموعهٔ فازی خیلی طبیعی می‌نماید و بیشتر به دنیای واقعی شباهت دارد. در دنیای واقعی موجودات فقط در یک حالت یا حالت مقابل آن نیستند.


برای تعریف مجموعه، باید اعضایش دقیقاً را مشخص نمود. مجموعهٔ فازی Ă به وسیلهٔ تابع عضویت μA با رابطهٔ زیر تعریف می شود.

Ă={{x,μx}}

x: عضو ، μx : درجهٔ عضویت

μA ← {۰،۱}


مجموعهٔ فازی بر روی x به وسیلهٔ یک تابع عضویت μx تعریف می‌شود. هیچ محدودیتی در نوع تابع عضویت به جز برد آن که باید [۰،۱] باشد، وجود ندارد.

در حالت مجموعه‌های قطعی، تابع عضویت فقط دو مقدار در برد خود دارد (در ریاضیات، برد یک تابع برابر با مجموعه تمام خروجی‌های تابع است). در حالی که مقدار عضویت مجموعه‌های فازی می‌تواند یک مقدار حقیقی دلخواه بین صفر تا یک باشد. هر چه مقدار درجهٔ عضویت به یک نزدیک‌تر باشد، درجهٔ تعلق x به مجموعهٔ فازی Ă بیشتر است. اگر درجهٔ عضویت یک عنصر از مجموعه برابر با صفر باشد، آن عضو کاملاً از مجموعه خارج است و اگر درجه عضویت یک عضو برابر با یک باشد، آن عضو کاملاً در مجموعه قرار دارد

Fuzzy crisp.svg


  • مجموعه اعداد طبیعی و کوچک تر از ۵ به صورت فازی و قطعی

مجموعهٔ قطعی: {1,2,3,4}

مجموعهٔ فازی: { (1,0.2),(2,0.4),(3,0.6),(4,0.8) }

  • مجموعهٔ فازی دما

اگر بخواهیم دما (سرد، معتدل،گرم) را به صورت یک مجموعهٔ قطعی بنویسیم

    • دمای کمتر از ۲۰ درجه: سرد
    • دمای بین ۲۰ تا ۳۰ درجه:معتدل
    • دمای بالای ۳۰ درجه: گرم

قصد داریم، دماهای ۲۹ درجه، ۲۱ درجه و ۱۹ درجه را بررسی کنیم.


مجموعهٔ قطعی میزان دما
میزان دما سرد معتدل گرم
۲۹ ۰ ۱ ۰
۲۱ ۰ ۱ ۰
۱۹ ۱ ۰ ۰

در مجموعه‌های قطعی دمای ۱۹ درجه متعلق به مجموعهٔ سرد و دمای ۲۱ درجه متعلق به مجموعهٔ معتدل می‌باشد در صورتی که اختلاف دمای این دو تنها ۲ درجه می‌باشد و شاید نتوان در این روش به درستی میزان دما را بر اساس سردی و اعتدال و گرمی بررسی کرد. حال به صورت فازی این سه دما را بررسی کرده و نتایج را مقایسه می‌کنیم


مجموعهٔ فازی میزان دما
میزان دما سرد معتدل گرم
۲۹ ۰ ۰/۴ ۰/۶
۲۱ ۰/۴ ۰/۶ ۰
۱۹ ۰/۸ ۰/۲ ۰

این نمودار این موضوع را به طور دقیق توضیح می‌دهد

منطق فازی دما

به طور مثال دمای ۳۱ درجه با درجهٔ عضویت ۰/۴ به مجموعهٔ معتدل و با درجهٔ عضویت ۰/۶ به مجموعهٔ گرم و به مجموعهٔ سرد اصلاً تعلق ندارد.

این بررسی نشان می‌دهد که مجموعه‌های فازی توصیف دقیق‌تری را از پدیده‌هایی که با آن‌ها روبه‌رو هستیم، می‌دهد.

هنگامی که دما را در مجموعه‌های فازی بیان می‌کنیم، دسته‌بندی موجب ایجاد تفاوت اجباری مثل مجموعه‌های قطعی نمی شود و رضایت خاطر هر فردی با نتایج حاصل برآورده می شود. در کل مجموعه‌های فازی به درک و احساس بشر نزدیک‌تر است.

اعمال اساسی مجموعه‌ها

  • اجتماع: اگر B,A دو مجموعه دلخواه باشند. اجتماع B,A برابر است با ماکزیمم تابع عضویت مجموعه B,A و آن را به صورتμA∪B(x) نشان می‌دهیم.

μA∪B(x) = max(μA(x),μB(x))

  • اشتراک: اگر B,A دو مجموعه دلخواه باشند آنگاه اشتراک آنها برابر است با مینیمم تابع عضویت مجموعه B,A و آن را به صورت A∩B نشان می‌دهند.

μA∩B(x) = min(μA(x),μB(x))

  • متمم: اگر S یک مجموعه باشد و A زیر مجموعه‌ای از آن باشد. آن متمم مجموعهA حاصل کسر تمام اعضای A ازیک است و آن را با Ā یا μnot A(x) نشان می‌دهند.

μĀ(x) = 1-μA(x))

متغیر‌های زبانی

ما در زبان طبیعی و استدلال‌های انسانی از متغیر‌هایی که مقادیر آن‌ها گنگ و مبهم هستند بیشتر استفاده می‌کنیم تا متغیر‌های معمولی که مقادیر آن‌ها دقیق و کامل مشخص اند.متغیرهای زبانی به متغیرهایی گفته می‌شود که مقادیر مورد قبول برای آن‌ها به جای اعداد، کلمات و جملات زبان‌های انسانی یا ماشینی هستند.در منطق فازی از متغیرهای زبانی (گفتاری یا غیر عددی) استفاده می‌گردد. متغیرهای زبانی بر اساس ارزش‌های زبانی (گفتاری) که در مجموعه عبارت (کلمات/اصطلاحات) قرار دارند بیان می‌شود. عبارت زبانی (Linguistic terms) صفاتی برای متغیرهای زبانی هستند. به عنوان مثال: متغیر زبانی «سن» بسته به تقسیمات مورد نظر شخصی و شرایط می‌تواند مجموعه عباراتی از قبیل «نوجوان»، «جوان»، «میان سال» و «سالمند» باشد.

مجموعه عبارات (اصطلاحات) فازی (سن) = { «جوان»، «نه جوان»، «نه چندان جوان»، «خیلی جوان»،... ، «میان سال»، «نه چندان میان سال»...، «پیر»، «نه پیر»، «خیلی پیر»، «کم و بیش پیر»...، «نه خیلی جوان و نه خیلی پیر»، «نه جوان و نه پیر»...}


یا در مثالی دیگر، فشار(خون) را می‌توان متغیری زبانی در نظر گرفت، که ارزش‌هایی (خصوصیت‌هایی) از قبیل پایین، بالا، ضعیف، متوسط و قوی را می‌تواند در خود جای دهد. به زبان ریاضی داریم (T = Terms):

{پایین، بالا، ضعیف، متوسط، قوی} = (فشار)T

عدم قطعیت

صفت عدم قطعیت، به صورت های گوناگون، در همهٔ زمینه‌ها و پدیده‌ها صرف نظر از روش شناسی مورد کاربرد جهت مطالعه، طراحی، و کنترل پدیدار می‌شود. مفاهیم نادقیق بسیاری در پیرامون ما وجود دارند که آن‌ها را به صورت روزمره در قالب عبارت‌های مختلف بیان می‌کنیم. به عنوان مثال: «هوا خوب است» هیچ کمیتی برای خوب بودن هوا مطرح نیست تا آن را بطور دقیق اندازه‌گیری نماییم، بلکه این یک حس کیفی است. در واقع مغز انسان با در نظر گرفتن عوامل گوناگون و بر پایه تفکر استنتاجی جملات را تعریف و ارزش گذاری می‌نماید که الگوبندی آن‌ها به زبان و فرمول‌های ریاضی اگر غیر ممکن نباشد، کاری بسیار پیچیده خواهد بود. منطق فازی فناوری جدیدی است که شیوه‌هایی را که برای طراحی و مدل سازی یک سیستم نیازمند ریاضیات پیچیده و پیشرفته‌است، با استفاده از مقادیر زبانی و دانش فرد خبره جایگزین می‌سازد.

استدلال فازی

گزاره‌ها در منطق فازی، گزاره‌های فازی نامیده شده و به وسیلهٔ مجموعه‌های فازی نمایش داده می شوند. هدف نهایی منطق فازی فراهم کردن مبنایی برای استدلال تقریبی با گزاره‌های نادقیق ، با استفاده از تئوری مجموعه‌های فازی به عنوان یک ابزار اساسی است.

قواعد استنتاج در منطق فازی «اگر-آن‌گاه فازی» نامیده می‌شوند. روش‌های استدلال فازی به روش‌های مستقیم و غیرمستقیم تقسیم می‌شوند. اکثر روش‌های معروف، روش‌های مستقیم هستند. روش‌های غیرمستقیم،استدلال را توسط فضای ارزش راستی هدایت می‌کنند ( در مورد توضیح روش‌های غیر مستقیم به مطالعات بیشتر برای تکمیل این صفحه نیاز داریم).

استدلال تقریبی

استدلال مستقیم محسوب می‌شود. اساس استدلال و استنتاج در منطق کلاسیک عبارت است از تعدادی اصول به علاوهٔ قانون مهم استنتاج به نام قانون«قیاس استثنایی» به شکل (A ʌ (A→B))→B .

در قانون قیاس استثنایی A و B هر دو ویژگی‌ها و گزاره‌هایی معمولی(غیر فازی) هستند. از طرف دیگر همان‌گونه که بیان شد، استدلال‌های انسانی کم‌تر بر پایهٔ مجموعه‌ها و گزاره‌های دقیق بنا می‌شوند و در اکثر موارد از استدلال‌هایی استفاده می‌کنیم که در قالب قانون قیاس استثنایی نمی‌گنجند، اگر چه به آن شبیه باشند. اما بر پایهٔ متغیر‌های زبانی و منطق فازی، می‌توانیم این استدلال‌ها را که استدلال تقریبی در برابر استدلال دقیق می‌نامیم، صورت‌بندی و تجزیه و تحلیل کنیم ( در این مورد به مثال دقیق و کامل نیاز داریم)

  • عطف(AND) کردن چند شرط: گاهی اوقات چندین شرط جهت تحقق یک رفتار مشخص با یکدیگر «و» (AND) می‌شوند. یعنی B از روی چند شرط منطقی A1 الی An نتیجه می‌شود.
  • فصل (OR) کردن چند شرط: همانند عطف، گاهی اوقات چندین شرط جهت تحقق یک رفتار مشخص با یکدیگر «یا» (OR) می‌شوند.

این قسمت در مورد عدم قطعیت مبتنی بر منطق فازی می‌باشد. در مورد استدلال در کل به مثال‌ها و موارد خیلی دقیق و بهتری نیاز داریم.

موارد کار‌برد

برای کار‌هایی که دستورالعمل شفاف و دقیق ریاضی نداشته باشیم:

  • رباتیک و هوش مصنوعی مانند رفتار هوشمند ربات‌ها
  • هدایت و کنترل هرگونه دستگاه و تاسیسات پویا و حرکت ساز
  • دستگاه‌های سمعی/بصری دیجیتال.
  • جلوگیری از هنگ کردن سرورها
  • کنترل موتورهای جستجوگر در اینترنت
  • سیستم‌های نرم‌افزاری ترجمه
  • مهندسی پزشکی از جمله آسیب شناسی یا هدایت و کنترل تاسیسات سی تی اسکن، سی سی یو و آی سی یو، دستگاه ضربان‌ساز قلب.
  • کارهای ریسک شناسی، آماری و ارزیابی مانند تصمیم‌گیری در مدیریت
  • محاسبات آماری

پروژه‌های مورد استفاده

در این جا فهرستی از پروژه‌هایی را که برای توسعه‌ی آن‌ها از منطق فازی استفاده کردیم، قرار می‌دهیم. همراه با لینک پروژه و مستندات آن.

ایده‌‌های مرتبط با منطق فازی

  • انتخاب ایجنت برای پاس در شبیه‌سازی دو بعدی فوتبال بر اساس منطق فازی

منابع آموزشی

صفحات وب


کتاب‌ها

کتاب‌های غیر قابل دانلود

کتاب‌های قابل دانلود

مقالات

جستار‌های وابسته