उत्तल समस्या के लिए एल्गोरिदम

स्टीपेस्ट डिसेंट की विधि

इस विधि को ग्रेडिएंट विधि या कॉची विधि भी कहा जाता है। इस पद्धति में निम्नलिखित शब्दावली शामिल हैं -

$$ x_ {k + 1} = x_k + \ alpha_kd_k $$

$ d_k = - \ bigtriangledown f \ left (x_k \ right) $ या $ d_k = - \ frac {\ bigtriangledown f \ left (x_k \ right)} {\ _ बाएं | \ bigtriangledown f \ left (x_k \ right) \ right \ |} $

$ \ Phi \ left (\ Alpha \ right) = f \ left (x_k + \ alpha d_k \ right) को $ दें

$ \ Phi $ का अंतर करके और इसे शून्य से बराबर करके, हम $ \ अल्फा $ प्राप्त कर सकते हैं।

तो एल्गोरिथ्म निम्नानुसार है -

  • प्रारंभिक $ x_0 $, $ \ varepsilon_1 $, $ \ varepsilon_2 $ शुरू करें और $ k = 0 $ सेट करें।

  • सेट $ d_k = - \ bigtriangledown f \ left (x_k \ right) $ या $ d_k = - \ frac {\ bigtriangledown f \ left (x_k \ right)} {{बाएँ \ _ \ _ bigtriangledown f \ left (x_k \ right) | \ सही \ |} $।

  • $ \ alpha_k $ को ऐसे खोजें कि वह $ \ phi \ left (\ Alpha \ right) = f \ left (x_k + \ alpha d_k \ right) $ को कम से कम कर दे।

  • $ X_ {k + 1} = x_k + \ Alpha_kd_k $ सेट करें।

  • अगर $ \ _ \ _ | x_ {k + 1-x_k} \ right \ | <\ varepsilon_1 $ या $ \ left \ | \ bigtriangledown f \ left (x_ {k + 1} \ right) \ right \ | \ leq \ varepsilon_2 $, चरण 6 पर जाएं, अन्यथा $ k = k + 1 $ सेट करें और चरण 2 पर जाएं।

  • इष्टतम समाधान $ \ hat {x} = x_ {k + 1} $ है।

न्यूटन विधि

न्यूटन विधि निम्नलिखित सिद्धांत पर काम करती है -

$ f \ बाएँ (x \ दाएँ) = y \ बाएँ (x \ दाएँ) = f \ बाएँ (x_k \ दाएँ) + \ बाएँ (x-x_k \ दाएँ) ^ T \ bigtriangledown f \ बाएँ (x_k \ दाएँ) + \ frac {1} {2} \ बाएँ (x-x_k \ दाएँ) ^ TH \ बाएँ (x_k \ दाएँ) \ बाएँ (x-x_k \ दाएँ) $

$ \ bigtriangledown y \ बाएँ (x \ दाएँ) = \ bigtriangledown f \ बाएँ (x_k \ दाएँ) + H \ बाएँ (x_k \ दाएँ) \ बाएँ (x-x_k \ दाएँ) $

$ X_ {k + 1} पर, \ bigtriangledown y \ left (x_ {k + 1} \ right) = \ bigtriangledown f \ left (x_k \ right) + H \ left (x_k \ right) \ left (x_ {k) +1} -x_k \ right) $

$ X_ {k + 1} $ के लिए इष्टतम समाधान होने के लिए $ \ bigtriangledown y \ left (x_k + 1 \ right) = 0 $

इस प्रकार, $ x_ {k + 1} = x_k-H \ left (x_k \ right) ^ {- 1} \ bigtriangledown f \ left (x_k \ right) $

यहां $ H \ बाएँ (x_k \ right) $ गैर-एकवचन होना चाहिए।

इसलिए एल्गोरिथ्म निम्नानुसार है -

Step 1 - प्रारंभिक $ x_0, \ varepsilon $ और सेट करें $ k = 0 $।

Step 2 - $ H \ बाएँ (x_k \ right) \ bigtriangledown f \ left (x_k \ right) $ खोजें।

Step 3 - रैखिक प्रणाली $ H \ बाएँ (x_k \ दाएँ) h \ बाएँ (x_k \ दाएँ) = \ bigtriangledown f \ बाएँ (x_k \ right) $ $ h \ बाएँ (x_k \ दाएँ) $ के लिए हल करें।

Step 4 - $ x_ {k + 1} = x_k-h \ left (x_k \ right) $ खोजें।

Step 5- अगर $ \ _ \ _ | x_ {k + 1} -x_k \ right \ | <\ varepsilon $ या $ \ left \ \ bigtriangledown f \ left (x_k \ right) \ right \ | \ leq \ varepsilon $ तब चरण 6 पर जाएँ, अन्यथा $ k = k + 1 $ सेट करें और चरण 2 पर जाएँ।

Step 6 - इष्टतम समाधान $ \ hat {x} = x_ {k + 1} $ है।

क्रमबद्ध ढाल विधि

इस विधि का उपयोग निम्न प्रकार की समस्याओं को हल करने के लिए किया जाता है -

$ min f \ left (x \ right) = \ frac {1} {2} x ^ T Qx-bx $

जहाँ Q एक धनात्मक निश्चित nXn मैट्रिक्स है और b स्थिर है।

$ X_0, \ varepsilon, $ compute $ g_0 = Qx_0-b $ को देखते हुए

$ D_0 = -g_0 $ $ k = 0,1,2, ..., $ के लिए सेट करें

$ \ Alpha_k = \ frac {g_ {k} ^ {T} g_k} {d_ {k} ^ {T} Q d_k} $ सेट करें

$ X_ {k + 1} = x_k + \ Alpha_kd_k $ की गणना करें

$ G_ {k + 1} = g_k + \ Alpha_kd_k $ सेट करें

गणना $ \ beta_k = \ frac {g_ {k} ^ {T} g_k} {d_ {k} ^ {T} Qd_k} $

$ X_ {k + 1} = x_k + \ Alpha_kd_k $ की गणना करें

$ G_ {k + 1} = x_k + \ Alpha_kQd_k $ सेट करें

गणना $ \ beta_k = \ frac {g_ {k + 1} ^ {T} g_ {k + 1}} {g_ {k} ^ {T} gk} $

$ D_ {k + 1} = - g_ {k + 1} + \ beta_kd_k $ सेट करें।