آموزش زنجیره مارکوف در نرم افزار متلب

05 خرداد 1403 - آخرین بروزرسانی: 05 خرداد 1403
زنجیره مارکوف
زمان تقریبی مطالعه: 4 دقیقه

این روزها بیشتر مسائل در شاخه‌های مختلف، نیاز به تحلیل احتمالی دارند. در این راستا، زنجیره مارکوف مخصوصاً مونت کارلو در اکثر پروژه‌ها بسیار کاربردی عمل می‌کند. اما زنجیره مارکوف مونت کارلو چیست و چه انواعی دارد؟ برای پاسخ به این سوال با ما همراه باشید.

 

زنجیره مارکوف مونت کارلو (MCMC) چیست؟

زنجیره مارکوف مونت کارلو، ابزاری قدرتمند برای نمونه برداری از توزیع‌های احتمالی پیچیده است و به افتخار ریاضی دان روس آندری مارکوف با این اسم شناخته می‌شود.
زنجیره مارکوف با نام الگوریتم مارکوف نیز شناخته می‌شود و یک سیستم ریاضیاتی است. زنجیره‌های مارکوف (Markov Chains) مدل‌های احتمالاتی هستند که در آن‌ها، وضعیت یک سیستم در زمان مورد بررسی به وضوح توسط وضعیت آن در زمان‌های گذشته تعیین می‌شود. در حالت ساده‌تر، زنجیره‌های مارکوف می‌توانند به عنوان یک سری زمانی از وضعیت‌ها باشند که هر وضعیت بر اساس وضعیت قبلی آن مشخص می‌شود. برای درک بهتر زنجیره مارکوف به مثال‌های زیر توجه کنید؛

  • یک موجود زنده، فقط یک بار در روز غذا می‌خورد.
  • اگر امروز هویج بخورد، فردا انگور یا پنیر را با احتمال برابر خواهد خورد.
  • اگر امروز موز بخورد، فردا با احتمال 0.1 کاهو، احتمال 0.5 هویج و احتمال 0.4 پنیر می خورد.

مسابقه

با توجه به مثال‌های ذکر شده، عادات غذایی یک فرد را می‌توان به شکل زنجیره مارکوف در نظر گرفت. چرا که عادات غذایی که شخص برای روز بعد در نظر دارد، به امروزش کاملاً بستگی دارد.

آموزش متلب با بهترین هزینه

 

شبیه سازی مونت کارلو در متلب

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

1. تعریف مساله:

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

2. نمونه گیری تصادفی:

از توابع تصادفی داخلی متلب برای تولید نمونه های تصادفی از فضای ورودی استفاده کنید. تعداد نمونه ها به دقت مورد نظر شما بستگی دارد.

3. محاسبه مقادیر تابع هدف:

برای هر نمونه تصادفی، مقدار تابع هدف را محاسبه کنید.

4. تخمین میانگین:

میانگین مقادیر تابع هدف را به عنوان تخمین میانگین واقعی تابع هدف محاسبه کنید.

5. تخمین واریانس:

واریانس مقادیر تابع هدف را به عنوان تخمین واریانس واقعی تابع هدف محاسبه کنید.

6. تجزیه و تحلیل نتایج:

نتایج را تجزیه و تحلیل کنید و در صورت نیاز شبیه سازی را با نمونه های بیشتر اجرا کنید.

در اینجا چند نمونه کد متلب برای انجام شبیه سازی‌های ساده مونت کارلو آورده شده است:

محاسبه عدد پی:

% تعداد نمونه ها

N = 100000;

% نقاط تصادفی در داخل دایره واحد

x = rand(N, 1);

y = rand(N, 1);

% نقاط داخل مربع

inside = (x.^2 + y.^2) <= 1;

% تخمین عدد پی

pi_estimate = 4 * sum(inside) / N;

% نمایش نتایج

fprintf(‘تخمین عدد پی: %f

‘, pi_estimate);

محاسبه انتگرال:

% تابع برای انتگرال

f = @(x) x.^2;

% حدود انتگرال

a = 0;

b = 1;

% تعداد نمونه ها

N = 100000;

% نقاط تصادفی در بازه انتگرال

x = a + (b – a) * rand(N, 1);

% تخمین انتگرال

integral_estimate = (b – a) * sum(f(x)) / N;

% نمایش نتایج

fprintf(‘تخمین انتگرال: %f

‘, integral_estimate);

اینها فقط نمونه‌های ساده‌ای هستند. شبیه سازی‌های مونت کارلو را می‌توان برای حل طیف گسترده ای از مسائل پیچیده‌تر در متلب استفاده کرد.

 

مطلب پیشنهادی: رگرسیون خطی چیست؟

 

انواع زنجیره مارکوف

نمودار

زنجیره مارکوف دارای انواع مختلفی است که هر کدام ویژگی‌ها و مزایای خود را دارند. در ادامه به بررسی هر یک می‌پردازیم.

زنجیره مارکوف بر اساس زمان

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

زنجیره مارکوف بر اساس حافظه

  • زنجیره مارکوف بدون حافظه (مرتبه صفر): در این نوع زنجیره مارکوف، احتمال وقوع هر حالت فقط به حالت فعلی بستگی دارد و هیچ وابستگی به تاریخچه‌ی قبلی زنجیره وجود ندارد.
  • زنجیره مارکوف با حافظه (مرتبه k): در این نوع زنجیره مارکوف، احتمال وقوع هر حالت به k حالت قبلی زنجیره بستگی دارد.

زنجیره مارکوف بر اساس فضای حالت

  • زنجیره مارکوف گسسته: در این نوع زنجیره مارکوف، فضای حالت مجزا و محدود است.
  • زنجیره مارکوف پیوسته: در این نوع زنجیره مارکوف، فضای حالت نامحدود است.
آیا این مطلب برای شما مفید بود؟
بلهخیر
نویسنده مطلب ژاله برومند
توسعه محتوا، سئو و سوشیال مدیا مارکتینگ از علایق من هست و برای رسیدن به موفقیت و بهترین‌ها همیشه در تلاش هستم. در کنار تلاش برای رسیدن به موفقیت، همواره سعی در بروزرسانی اطلاعاتم دارم و کمک میکنم تا بین رقبای کسب و کار خودتون بدرخشید و برندی متمایز داشته باشید.
دیدگاه شما

بدون دیدگاه