برمجة عشوائية

في مجال النمذجة، تعتبر البرمجة العشوائيه الهيكل الاساسي لحل المشاكل المتعلقه بالنمذجة القائمة علي عدم التأكد.[1][2][3] في حين ان مشاكل النمذجة المحدده تصاغ باستخدام بارامترات معلومه.ان مشاكل الواقع تشمل بعض البارامترات الغير معلومه، في حاله وقوع البارامترات ضمن حدود معينه ; يكون هناك طريقه واحدة لحل هذا النوع من المشاكل تسمى النمذجة القويه (Robust Optimization) الهدف من البرمجة العشوائيه هو العثور علي حل مناسب وأمثل لجميع البيانات. نماذج البرمجة العشوائيه متشابهه في الاسلوب لكن تأخذ في عين الاعتبار حقيقه ان التوزيعات الاحتماليه التي تحكم البيانات معلومه أو يمكن حسابها. الهدف هنا هو ايجاد خطه مناسبه لكل أو بالكاد كل البيانات وهذه الخطة تتوقع بعض القرارات والمتغيرات العشوائيه.عموما هذة النماذج تتم صياغتها وحلها نظريا وعدديا وتحليلها لتوفير معلومات مفيدة لمتخذي القرار.

المشاكل ذات المرحلتين عدل

الفكرة الاساسيه القائم عليها مشاكل البرمجة العشوائيه ذات المرحلتين هي ان القرارات المثلى يجب ان تكون قائمه علي البيانات المتاحه في الوقت الذي تم فيه اتخاذ القرار ويجب ان لا تعتمد علي الملاحظات المستقبلية.

الصيغة العامه لمشاكل ذات المرحلتين توصف كالتالي

 

حيث   هي القيمة المثلى للمشكله ذات المرحلة الثانية

 

مشاكل البرمجة الخطية العشوائيه يمكن صياغتها كالاتي

 

حيث   هي القيمة المثلى للمشكله ذات المرحلة الثانية

 

في هذه الصيغة   هو المتجه الخاص بمتغيرات القرار في المرحلة الاولي و   هو المتجه الخاص بـمتغيرات القرار في المرحلة الثانية. في هذه الصيغة ; في حاله المرحلة الاولي نكون بحاجه لأتخاذ قرار   حالا قبل ادراك المعلومات الغير مؤكدة  . في المرحلة الثانية بعد ادراك  , نقوم بتحسين الاداء عن طريق حل المشكله المناسبة.

في الخطوة الاولي نقوم بأمثله الـ   الخاص ب المرحلة الاولي الي جانب الـ   الخاص بالمرحلة الثانية ووهذا يمكننا من عرض مشاكل المرحلة الثانية علي انها مشكله نمذجه حيث انها تقوم بوصف الحل الافتراضي الامثل في حاله ان تكون المعلومات غير مؤكدة.

فرض التوزيع عدل

صياغه مشاكل المرحلتين التي تم شرحها مسبقا تفترض ان المعلومات الخاصة بالمرحلة الثانية يمكن وصفها علي انها متجه عشوائي ذات توزيع احتمالى معلوم. على سبيل المثال   من الممكن ان يكون معلومات تم الوصول اليها عن طريق معلومات مسبقه مع العلم ان التوزيع لم يتغيرمع طول الفترة الزمنيه. في مثل هذه الحالات من الممكن حساب التوزيع الاحتمالي المطلوب والقيام بالنمذجة ويمكن ان تفسر باستخدام قانون الارقام الكبيرة.

التقسيم عدل

لحل مشاكل النمذجة العشوائيه ذات المرحلتين عددياً، نحتاج غالبا لفرض ان المتجه العشوائي يحتوي على عدد من الحالات الممكنه المسماة بسيناريوهات حيث ان   مناظره للاحتمالات   و بذلك ممكن ان تصاغ داله الهدف (Objective function) الاتي:

 

و بالمثل مشاكل المرحلة الثانية ممكن ان تصاغ كمشكله برمجه خطيه كبيرة (وهذا ما يطلق عليه التحديد المكافئ للمشكله العشوائيه).

البرمجة العشوائيه الخطية عدل

هي حاله خاصه بمشاكل المرحلتين الاعتياديه للبرمجة العشوائيه. البرمجة العشوائيه الخطية قائمه علي تجميع المشاكل الخطية ذات الفترات المتعددة كل منها له نفس البناء لكن بأختلاف بسيط في البيانات. البرمجة الخطية ذات الفترتين تقوم بعرض الـ  سيناريو في الصيغة الاتيه:

 

المتجهين   و   يشملان متغيرات الفترة الاولي حيث انه يجب اختيار قيمتهم فورا. المتجه   يحتوي على جميع المتغيرات للفترات التاليه. القيود   تشمل متغيرات الفترة الأولى ولا تتغير من سيناريو لاخر، القيود الخرى تتضمن متغيرات الفترات الأخرى وتختلف من سيناريو لاخر وتعكس عدم التأكد من المستقبل

لاحظ ان حل مشاكل البرمجة الخطية للفترتين مكافئه لفرض الـ   سيناريو في الفترة الثانية مع عدم التأكد.

التحديد المكافئ للمشكله العشوائيه عدل

باستخدام عدد محدود من السيناريوهات، يمكن وصف مشاكل البرمجة الخطية العشوائيه ذات المرحلتين علي انها مشاكل برمجه خطيه كبيرة. هذه الصيغة غالبا ما يطلق عليها التحديد المكافئ للمشكله العشوائيه. التحديد المكافئ هو أي عمليه حسابيه يمكن ان تستخدم لحساب الحل الامثل للمرحله الأولى. على سبيل المثال نجعل الاحتماليه   لكل سيناريو حيث   ثم نقوم بتقليل القيمة المتوقعه للهدف كالأتي

 

لكل سيناريو   يوجد متجه   مختلف والمتغيرات   و   لا تتغير من سيناريو لاخر.

بناء السيناريوهات عدل

من الممكن بناء سيناريوهات عن طريق أراء خبير.يجب ان يكون عدد السيناريوهات معتدل ليكون من السهل حلها بمجهود اقل. غالبا ما يكون الحل الامثل القائم علي بعض السيناريوهات يوفر خطط احسن سيناريو واحد.

في نظريه اخري بعض القياسات تم حسابها لضمان ان الحل الذي تم الحصول عليه يقوم بحل المشكله الاصليه بدقه مناسبه. عادة في التطبيقات، الحل الامثل للمرحله الاولي فقط هو قيمه معينه.

نفترض ان   تشمل   عناصر عشوائيه مستقله، كل منها له ثلاث حالات ممكنه لذلك يكون عدد السيناريوهات   .النموالطبيعى لعدد السيناريوهات يجعل تحسين النماذج بالاستناد الي رأي خبير صعب للغايه.

أخذ العينات بطريقه مونت كارلو عدل

تستخدم طريقه مونت كارلو لتقليل السيناريوهات لحجم معقول. بفرض ان العدد السيناريوهات كبير جدا أو حتي لا نهائي وبفرض أيضا اننا نستطيع استخراج عينات   لعدد   من التكرارات للمتجه العشوائي  

 

حيث ان المشكله ذات المرحلة الاولي تصاغ كالأتي

 

و تعرف هذه الصيغة بتقريب متوسط العينة

الاستدلال الإحصائي عدل

بفرض ان مشكله البرمجة العشوائيه تكون كالتالي

 

بفرض ان هناك عينات   لعدد   حلول للمتجه العشوائي   . العينة العشوائيه من الممكن ان توصف علي انها معطيات سابقه لعدد   ملاحظات ل  أو يمكن استنباطها بطريقه مونت كارلو ويمكن صياغه تقريب متوسط العينة كالأتي:

 

اتساق مقدرات تقريب متوسط العينة عدل

بفرض ان مجموعه   من مشاكل تقريب متوسط العينة ثابته، بمعنى ان تكون مستقله عن العينة. وبجعل   و   القيمة الامثل والمجموعه الامثل للحلول بالترتيب.

  1. بفرض ان   هو تسلسل القيم الحقيقيه للدوال
  2. إذا كان الـ objective الخاص بـ تقريب متوسط العينة   يتقارب مع objective المشكله الحقيقيه حيث تكون الاحتماليه = 1  
  3. • بفرض ان:
    • المجموعه   من الحلول الامثل للمشاكل الحقيقيه واردة في ال 
    • الدالة  محدودة القيمة ومتصله عند الـ  
    • المتسلسله الخاصة بالدالة   تقترب من الـ   ان تكون الاحتماليه 1 لكل  

التطبيقات البيولوجية عدل

البرمجة الديناميكيه العشوائيه تستخدم لنمذجه سلوك الحيوان في مجالات مختلفه مثل البيئة السلوكيه. الاختبارات التجريبيه لنمذجه السلوك الامثل للبحث عن المؤن، التحولات الحياتيه مثل الطيور الوليده أو وضع البيض في الطفيليات واظهرت نتائج النمذجة في شرح تطور عمليه أخذ القرار السلوكي. هذه النماذج عاده ما تكون متعدده المراحل وليس مرحلتين فقط.

التطبيقات الاقتصاديه عدل

- التطبيقات الاقتصاديه: البرمجة الديناميكيه العشوائي اداه مهمه في فهم عمليه اتخاذ القرار تحت ظرف عدم التأكد. تراكم رأس المال في حاله عدم التأكد تعتبر مثال. عاده ما يستخدم من قبل الاقتصاديين لتحليل المشاكل الحيويه الاقتصاديه والتي يدخل فيها عدم التأكد مثل المناخ.

مراجع عدل

  1. ^ "Using Polynomial Approximations to Solve Stochastic Dynamic Programming Problems: or A "Betty Crocker " Approach to SDP."[وصلة مكسورة]University of California, Davis, Department of Agricultural and Resource Economics Working Paper. "نسخة مؤرشفة" (PDF). مؤرشف من الأصل في 2006-09-11. اطلع عليه بتاريخ 2017-12-18.{{استشهاد ويب}}: صيانة الاستشهاد: BOT: original URL status unknown (link)[وصلة مكسورة]
  2. ^ Shapiro، Alexander؛ Dentcheva، Darinka؛ Ruszczyński، Andrzej (2009). Lectures on stochastic programming: Modeling and theory (PDF). MPS/SIAM Series on Optimization. Philadelphia, PA: Society for Industrial and Applied Mathematics (SIAM). Mathematical Programming Society (MPS). ج. 9. ص. xvi+436. ISBN:978-0-89871-687-0. MR:2562798. مؤرشف من الأصل (PDF) في 2020-03-24.
  3. ^ Ruszczyński، Andrzej؛ Shapiro، Alexander (2003). Stochastic Programming. Handbooks in Operations Research and Management Science. Philadelphia: إلزيفير. ج. 10. ص. 700. ISBN:978-0444508546.

Stochastic programming

قراءات أخرى عدل

  • John R. Birge and François V. Louveaux. Introduction to Stochastic Programming. Springer Verlag, New York, 1997.
  • Kall، Peter؛ Wallace، Stein W. (1994). Stochastic programming. Wiley-Interscience Series in Systems and Optimization. Chichester: John Wiley & Sons, Ltd. ص. xii+307. ISBN:0-471-95158-7. MR:1315300. مؤرشف من الأصل في 2012-03-20.
  • G. Ch. Pflug: Optimization of Stochastic Models. The Interface between Simulation and Optimization. Kluwer, Dordrecht, 1996.
  • Andras Prekopa. Stochastic Programming. Kluwer Academic Publishers, Dordrecht, 1995.
  • Andrzej Ruszczynski and Alexander Shapiro (eds.) (2003) Stochastic Programming. Handbooks in Operations Research and Management Science, Vol. 10, Elsevier.
  • Shapiro، Alexander؛ Dentcheva، Darinka؛ Ruszczyński، Andrzej (2009). Lectures on stochastic programming: Modeling and theory (PDF). MPS/SIAM Series on Optimization. Philadelphia, PA: Society for Industrial and Applied Mathematics (SIAM). Mathematical Programming Society (MPS). ج. 9. ص. xvi+436. ISBN:978-0-89871-687-0. MR:2562798. مؤرشف من الأصل (PDF) في 2017-03-29.
  • Stein W. Wallace and William T. Ziemba (eds.) (2005) Applications of Stochastic Programming. MPS-SIAM Book Series on Optimization 5
  • King، Alan J.؛ Wallace، Stein W. (2012). Modeling with Stochastic Programming. Springer Series in Operations Research and Financial Engineering. New York: Springer. ISBN:978-0-387-87816-4. مؤرشف من الأصل في 2014-10-04.