THMMY's "Optimization Techniques" course assignments.
25'ten fazla konu seçemezsiniz Konular bir harf veya rakamla başlamalı, kısa çizgiler ('-') içerebilir ve en fazla 35 karakter uzunluğunda olabilir.

314 satır
21 KiB

  1. % !TEX TS-program = xelatex
  2. % !TEX encoding = UTF-8 Unicode
  3. % !TEX spellcheck = el-GR
  4. %
  5. % Optimization techniques project report
  6. %
  7. % Requires compilation with pdfLaTeX or XeLaTeX
  8. %
  9. % authors:
  10. % Χρήστος Χουτουρίδης ΑΕΜ 8997
  11. % cchoutou@ece.auth.gr
  12. %
  13. % Options:
  14. %
  15. % 1) mainlang=<language>
  16. % Default: english
  17. % Set the default language of the document which affects hyphenations,
  18. % localization (section, dates, etc...)
  19. %
  20. % example: \documentclass[mainlang=greek]{AUThReport}
  21. %
  22. % 2) <language>
  23. % Add hyphenation and typesetting support for other languages
  24. % Currently supports: english, greek, german, frenc
  25. %
  26. % example: \documentclass[english, greek]{AUThReport}
  27. %
  28. % 3) short: Requests a shorter title for the document
  29. % Default: no short
  30. %
  31. % example: \documentclass[short]{AUThReport}
  32. %
  33. \documentclass[a4paper, 11pt, mainlang=greek, english]{AUThReport}
  34. \CurrentDate{\today}
  35. % Document setup
  36. %---------------------------------
  37. % \WorkGroup{Ομάδα Χ}
  38. \AuthorName{Χρήστος Χουτουρίδης}
  39. \AuthorMail{cchoutou@ece.auth.gr}
  40. \AuthorAEM{8997}
  41. %\CoAuthorName{Όνομα Επίθετο}
  42. %\CoAuthorAEM{AEM}
  43. %\CoAuthorMail{xxx@ece.auth.gr}
  44. \DocTitle{Project: Γενετικοί αλγόριθμοι}
  45. \DocSubTitle{Ελαχιστοποίηση συνάρτησης πολλών μεταβλητών}
  46. \Department{Τμήμα ΗΜΜΥ. Τομέας Ηλεκτρονικής}
  47. \ClassName{Τεχνικές Βελτιστοποίησης}
  48. %
  49. \InstructorName{Γ. Ροβιθάκης}
  50. \InstructorMail{rovithak@auth.gr}
  51. \CoInstructorName{Θ. Αφορόζη}
  52. \CoInstructorMail{taforozi@ece.auth.gr}
  53. % Local package requirements
  54. %---------------------------------
  55. \usepackage{enumitem}
  56. \usepackage{tabularx}
  57. \usepackage{array}
  58. \usepackage{multirow}
  59. \usepackage{float}
  60. \usepackage{xcolor}
  61. \usepackage{soul}
  62. \usepackage{amsmath}
  63. \usepackage{footnote}
  64. \usepackage{footmisc}
  65. \usepackage[labelformat=empty]{subcaption}
  66. \begin{document}
  67. \InsertTitle
  68. %\tableofcontents
  69. \section{Εισαγωγή}
  70. Η παρούσα εργασία αφορά την ελαχιστοποίηση συνάρτησης πολλών μεταβλητών, χρησιμοποιώντας \textbf{γενετικό αλγόριθμο}.
  71. Στην παρούσα εργασία προσπαθήσαμε να βελτιστοποιήσουμε το συνολικό χρόνο διέλευσης από ένα οδικό δίκτυο, το οποίο καλείται να εξυπηρετήσει ένα προκαθορισμένο όγκο οχημάτων ανά λεπτό, ενώ οι οδεύσεις του έχουν πεπερασμένη και προκαθορισμένη χωρητικότητα.
  72. Η προσέγγιση του προβλήματος έγινε βάση δοθέντος από την εκφώνηση μαθηματικού μοντέλου για το χρόνο διέλευσης της κάθε κυκλοφοριακής κατεύθυνσης, το οποίο χρησιμοποιήθηκε ως συνάρτηση αξιολόγησης για το γενετικό αλγόριθμο που τον ελαχιστοποιεί.
  73. \subsection{Παραδοτέα}
  74. Τα παραδοτέα της εργασίας αποτελούνται από:
  75. \begin{itemize}
  76. \item Την παρούσα αναφορά.
  77. \item Τον κατάλογο \textbf{scripts/}, που περιέχει τον κώδικα της MATLAB.
  78. \item Το \href{https://git.hoo2.net/hoo2/OptimizationTechniques/src/branch/master/Project}{σύνδεσμο} με το αποθετήριο που περιέχει όλο το project με τον κώδικα της MATLAB, της αναφοράς και τα παραδοτέα.
  79. \end{itemize}
  80. \section{Γενετικοί Αλγόριθμοι}
  81. Οι γενετικοί αλγόριθμοι (Genetic Algorithms - GAs) είναι αλγόριθμοι βελτιστοποίησης εμπνευσμένοι από τις αρχές της \textbf{φυσικής επιλογής} και της \textbf{γενετικής εξέλιξης}.
  82. Σε αντίθεση με μεθόδους που χρησιμοποιούν παραγώγους, όπως αυτή της μέγιστης καθόδους, του Newtown κλπ, οι γενετικοί αλγόριθμοι αποτελούν τεχνικές ολικής βελτιστοποίησης, δηλαδή της εύρεσης του ολικού ελάχιστου μια συνάρτησης.
  83. \par
  84. Oι γενετικοί αλγόριθμοι λειτουργούν με τη δημιουργία ενός πληθυσμού πιθανών λύσεων, όπου κάθε λύση αναπαριστάται ως ένα χρωμόσωμα (διάνυσμα παραμέτρων).
  85. Ο πληθυσμός εξελίσσεται μέσα από επαναλαμβανόμενες γενιές, εφαρμόζοντας τις εξής διαδικασίες:
  86. \begin{itemize}
  87. \item \textbf{Υπολογισμός καταλληλότητας (fitness evaluation)}: Κάθε λύση αξιολογείται βάσει μιας συνάρτησης καταλληλότητας, η οποία ποσοτικοποιεί πόσο καλή είναι σε σχέση με το πρόβλημα.
  88. \item \textbf{Επιλογή (selection)}: Επιλέγονται οι καλύτερες λύσεις από τον τρέχοντα πληθυσμό, οι οποίες έχουν υψηλότερη πιθανότητα να περάσουν στα επόμενα στάδια.
  89. \item \textbf{Διασταύρωση (crossover)}: Δημιουργούνται νέες λύσεις μέσω συνδυασμού δύο γονικών λύσεων, αναμιγνύοντας τα χαρακτηριστικά τους.
  90. \item \textbf{Μετάλλαξη (mutation)}: Σε ορισμένες λύσεις εφαρμόζονται μικρές, τυχαίες τροποποιήσεις ώστε να διατηρηθεί η ποικιλομορφία του πληθυσμού και να αποφευχθεί η παγίδευση σε τοπικά ελάχιστα.
  91. \item \textbf{Αντικατάσταση (replacement)}: Ο νέος πληθυσμός που προκύπτει αντικαθιστά τον παλιό, συνεχίζοντας τη διαδικασία μέχρι να ικανοποιηθεί κάποιο κριτήριο σύγκλισης.
  92. \end{itemize}
  93. Η συνεχής επανάληψη αυτών των διαδικασιών επιτρέπει στον γενετικό αλγόριθμο να αναζητήσει και να προσεγγίσει την καλύτερη δυνατή λύση μέσα στον χώρο των πιθανών λύσεων.
  94. Στις επόμενες παραγράφους θα περιγράψουμε την υλοποίηση αυτών των διαδικασιών για την παρούσα εργασία.
  95. \section{Μαθηματική διατύπωση του προβλήματος}
  96. Το πρόβλημα μοντελοποιείται ως εξής:
  97. \subsection*{Μεταβλητές Απόφασης}
  98. Ο ρυθμός διέλευσης οχημάτων $x$ σε κάθε δρόμο $i$ για τους $n$ δρόμους δίνεται ως:
  99. \[
  100. x = [x_1, x_2, \dots, x_n]
  101. \]
  102. \subsection*{Χρόνος κίνησης σε κάθε δρόμο}
  103. Ο χρόνος διάσχισης $T_i$ του δρόμου $i$ συναρτήσει του ρυθμού διέλευσης είναι:
  104. \begin{equation}
  105. T_i(x_i) = t_i + \frac{a_i x_i}{1 - \frac{x_i}{c_i}}, \quad 0 \leq x_i < c_i, \quad i=1,2,\dots,n
  106. \label{eq:Ti}
  107. \end{equation}
  108. \subsection*{Συνολικός χρόνος κίνησης}
  109. Ο συνολικός χρόνος $T_total$ του οδικού δικτύου είναι:
  110. \begin{equation}
  111. T_{total} = \sum_{i=1}^{n} T_i(x_i)
  112. \label{eq:Ttotal}
  113. \end{equation}
  114. \subsection*{Στόχος}
  115. Ελαχιστοποίηση του συνολικού χρόνου διάσχισης:
  116. \begin{equation}
  117. \min_{x} T_{total} = \min_{x} \sum_{i=1}^{n} T_i(x_i) = \min_{x} \sum_{i=1}^{n} \left( t_i + \frac{a_i x_i}{1 - \frac{x_i}{c_i}} \right)
  118. \label{eq:problem}
  119. \end{equation}
  120. \par
  121. Εδώ θα πρέπει να τονίσουμε πως κάναμε την υπόθεση ότι ο χρόνος \boldmath $T_i$ αφορά \textbf{όλα τα οχήματα} που κινούνται το δεδομένο στιγμιότυπο στο δρόμο $i$\unboldmath.
  122. Η εκφώνηση της άσκησης δεν ξεκαθαρίζει αν ο χρόνος $T_i$ αφορά το κάθε μεμονωμένο όχημα ή όλα.
  123. Σε περίπτωση πάντως που αφορά το κάθε όχημα ξεχωριστά τότε το άθροισμα θα έπρεπε να τροποποιηθεί σε: $ \sum_{i=1}^{n} T_i(x_i)\cdot x_i = \sum_{i=1}^{n} \left( t_i + \frac{a_i x_i}{1 - \frac{x_i}{c_i}}\right)\cdot x_i $, το οποίο όμως δεν αλλάζει τη συμπεριφορά και τα ευρήματα της εργασίας.
  124. \subsection*{Περιορισμοί}
  125. 1. Ισορροπία εισερχομένων και εξερχομένων ροών σε κάθε κόμβο $j$:
  126. \[
  127. \sum_{i \in incoming(j)} x_i = \sum_{k \in outgoing(j)} x_k, \quad \forall j
  128. \]
  129. 2. Περιορισμός ροής:
  130. \[
  131. 0 \leq x_i \leq c_i, \quad \forall i
  132. \]
  133. 3. Ο συνολικός ρυθμός εισόδου στο δίκτυο:
  134. \[
  135. \sum_{i=1}^{n} x_i = V
  136. \]
  137. \section{Υλοποίηση}
  138. Πριν περάσουμε στην παρουσίαση των αποτελεσμάτων, καλό θα ήταν να περιγράψουμε τις εξελικτικές διαδικασίες που χρησιμοποιήσαμε.
  139. Πιο συγκεκριμένα στην παρούσα εργασία υλοποιήσαμε ένα βρόχο με σταθερό αριθμό γενεών.
  140. Σε κάθε γενιά του βρόχου:
  141. \begin{itemize}
  142. \item Εκτελούμε τη \textbf{συνάρτηση καταλληλότητας} η οποία απλώς χρησιμοποιεί τη μαθηματική μοντελοποίηση που περιγράψαμε στις εξισώσεις \ref{eq:Ti}, \ref{eq:Ttotal} για να αξιολογήσει τη συνολική απόδοση του πληθυσμού.
  143. Με αυτό τον τρόπο έχουμε τον χρόνο σε κάθε δρόμο αλλά και τον συνολικό χρόνο για κάθε ένα χρωμόσωμα ξεχωριστά.
  144. \item Έπειτα εκτελούμε \textbf{διασταύρωση}.
  145. Για το σκοπό αυτό ταξινομούμε τον πληθυσμό με βάση τη συνολική ικανότητα και διαλέγουμε τις μισές καλύτερες λύσεις (χρωμοσώματα).
  146. Αυτά τα χρησιμοποιούμε ως γονείς.
  147. Με τυχαίο τρόπο επιλέγουμε δύο -- δύο κάθε φορά και από αυτό το ζευγάρι δημιουργούμε δύο παιδιά.
  148. Το κάθε παιδί δημιουργείται με τη μέθοδο της \textbf{διακριτής διασταύρωσης}.
  149. Εδώ να πούμε πως το πόσο μεγάλο κομμάτι από τον κάθε γονέα θα περάσει στο κάθε παιδί το επιλέγουμε με τυχαίο τρόπο.
  150. \item Έπειτα ολοκληρώνουμε τη διαδικασία αντικατάσταση, χρησιμοποιώντας τη \textbf{στρατηγική '+'}.
  151. Δηλαδή κρατάμε τους γονείς και συμπληρώνουμε το 2ο μισό του πληθυσμού με τα παιδιά.
  152. \item Τέλος εκτελούμε τη διαδικασία της μετάλλαξης.
  153. Σε αυτή τη διαδικασία συμμετέχουν όλα τα χρωμοσώματα και είναι τυχαίο φαινόμενο.
  154. Με βάση μιας προκαθορισμένης πιθανότητας επιλέγουμε χρωμοσώματα από όλο τον πληθυσμό και τους αλλάζουμε την τιμή μιας τυχαίας παραμέτρου (χρόνος διέλευσης από ένα δρόμο).
  155. Η νέα τιμή επιλέγεται πάλι τυχαία.
  156. \end{itemize}
  157. \section{Εκτέλεση - Συμπεριφορά}
  158. Για την εκτέλεση του αλγόριθμου κινηθήκαμε σε δύο κατευθύνσεις.
  159. Από τη μία κρατήσαμε σταθερό τον πληθυσμό και παρατηρήσαμε τη σύγκλιση του αλγόριθμου για διαφορετικές πιθανότητες μεταλλάξεων και από την άλλη κρατήσαμε την πιθανότητα σταθερή και δοκιμάσαμε διαφορετικό αριθμό χρωμοσωμάτων.
  160. \subsection{Σταθερός αριθμός χρωμοσωμάτων}
  161. Παρακάτω στο σχήμα \ref{fig:constV_pop_50} φαίνεται η πορεία σύγκλισης για την πρώτη περίπτωση.
  162. Εδώ κρατήσαμε τον πληθυσμό στο 50 και δοκιμάσαμε πιθανότητες $0.2\%, 0.5\%, 1\%$ και $2\%$.
  163. \textbf{Επιλέξαμε αρκετά μικρές τιμές για πιθανότητες ώστε να φανεί καλύτερα η συμπεριφορά του αλγόριθμου}.
  164. Παρατηρούμε πως για μικρή πιθανότητα ο αλγόριθμος χρειάζεται πολλές γενεές για να συγκλίνει.
  165. Επίσης, δείχνει να κολλάει σε κάποια υπο-βέλτιστη λύση για αρκετές γενεές.
  166. Και τα δύο αυτά χαρακτηριστικά βέβαια ελαττώνονται με την αύξηση της πιθανότητας.
  167. \par
  168. Να σημειώσουμε εδώ ότι η αύξηση της πιθανότητας μετάλλαξης \textbf{αυξάνει ελάχιστα} τη υπολογιστική πολυπλοκότητα του αλγόριθμου.
  169. \begin{figure}[H]
  170. \centering
  171. % First row
  172. \begin{subfigure}{0.45\textwidth}
  173. \centering
  174. \includegraphics[width=\linewidth]{../scripts/figures/constV_pop_50mut_0.002.png}
  175. \caption{Πιθανότητα: $0.2\%$}
  176. \end{subfigure}
  177. \hfill
  178. \begin{subfigure}{0.45\textwidth}
  179. \centering
  180. \includegraphics[width=\linewidth]{../scripts/figures/constV_pop_50mut_0.005.png}
  181. \caption{Πιθανότητα: $0.5\%$}
  182. \end{subfigure}
  183. % Second row
  184. \vspace{1em}
  185. \begin{subfigure}{0.45\textwidth}
  186. \centering¨
  187. \includegraphics[width=\linewidth]{../scripts/figures/constV_pop_50mut_0.01.png}
  188. \caption{Πιθανότητα: $1\%$}
  189. \end{subfigure}
  190. \hfill
  191. \begin{subfigure}{0.45\textwidth}
  192. \centering
  193. \includegraphics[width=\linewidth]{../scripts/figures/constV_pop_50mut_0.02.png}
  194. \caption{Πιθανότητα: $2\%$}
  195. \end{subfigure}
  196. \caption{Σύγκριση της μεθόδου για σταθερό πληθυσμό $50$.}
  197. \label{fig:constV_pop_50}
  198. \end{figure}
  199. \subsection{Σταθερή πιθανότητα μετάλλαξης}
  200. Παρακάτω στο σχήμα \ref{fig:constV_mut_0.01} φαίνεται η πορεία σύγκλισης για την πρώτη περίπτωση.
  201. Εδώ κρατήσαμε την πιθανότητα στο $1\%$ και δοκιμάσαμε πληθυσμούς των $26, 50, 76$ και $100$ χρωμοσωμάτων.
  202. \textbf{Επιλέξαμε πάλι αρκετά μικρές τιμές για τον πληθυσμό ώστε να φανεί καλύτερα η συμπεριφορά του αλγόριθμου}.
  203. Ομοίως παρατηρούμε πως μικροί πληθυσμοί χρειάζονται πολλές γενεές για να συγκλίνουν και οι μεταλλάξεις παρουσιάζουν απότομες μεταβολές.
  204. Μεγαλύτεροι πληθυσμοί όμως φαίνεται ότι βοηθούν αρκετά στην συνολική πιθανότητα μετάλλαξης προς τη βέλτιστη λύση.
  205. \begin{figure}[H]
  206. \centering
  207. % First row
  208. \begin{subfigure}{0.45\textwidth}
  209. \centering
  210. \includegraphics[width=\linewidth]{../scripts/figures/constV_pop_26mut_0.01.png}
  211. \caption{Πληθυσμός: $26$}
  212. \end{subfigure}
  213. \hfill
  214. \begin{subfigure}{0.45\textwidth}
  215. \centering
  216. \includegraphics[width=\linewidth]{../scripts/figures/constV_pop_50mut_0.01.png}
  217. \caption{Πληθυσμός: $50$}
  218. \end{subfigure}
  219. % Second row
  220. \vspace{1em}
  221. \begin{subfigure}{0.45\textwidth}
  222. \centering
  223. \includegraphics[width=\linewidth]{../scripts/figures/constV_pop_76mut_0.01.png}
  224. \caption{Πληθυσμός: $76$}
  225. \end{subfigure}
  226. \hfill
  227. \begin{subfigure}{0.45\textwidth}
  228. \centering
  229. \includegraphics[width=\linewidth]{../scripts/figures/constV_pop_100mut_0.01.png}
  230. \caption{Πληθυσμός: $100$}
  231. \end{subfigure}
  232. \caption{Σύγκριση της μεθόδου για σταθερή πιθανότητα μετάλλαξης $1\%$.}
  233. \label{fig:constV_mut_0.01}
  234. \end{figure}
  235. \par
  236. Να σημειώσουμε εδώ ότι η αύξηση του πληθυσμού \textbf{αυξάνει σημαντικά} τη υπολογιστική πολυπλοκότητα του αλγόριθμου.
  237. Για αυτό το λόγο, όπως φαίνεται και στο παρακάτω σχήμα \ref{fig:constV_high_mut}, είναι προτιμότερο να επιλέξουμε \textbf{μεγάλη πιθανότητα μετάλλαξης με σχετικά μικρό πληθυσμό}.
  238. Όπου βλέπουμε πως ο αλγόριθμος συμπεριφέρεται αρκετά καλά ακόμα και με μικρό πληθυσμό.
  239. Αυτό θα μας δώσει γρήγορη σύγκλιση με σημαντικά μικρότερη υπολογιστική πολυπλοκότητα.
  240. \begin{figure}[H]
  241. \centering
  242. % First row
  243. \begin{subfigure}{0.45\textwidth}
  244. \centering
  245. \includegraphics[width=\linewidth]{../scripts/figures/constV_pop_50mut_0.05.png}
  246. \caption{Πληθυσμός: $50$, Πιθανότητα: $5\%$}
  247. \end{subfigure}
  248. \hfill
  249. \begin{subfigure}{0.45\textwidth}
  250. \centering
  251. \includegraphics[width=\linewidth]{../scripts/figures/constV_pop_36mut_0.1.png}
  252. \caption{Πληθυσμός: $36$, Πιθανότητα: $10\%$}
  253. \end{subfigure}
  254. \caption{Σύγκριση της μεθόδου για υψηλή πιθανότητα μετάλλαξης.}
  255. \label{fig:constV_high_mut}
  256. \end{figure}
  257. \section{Συμπεράσματα}
  258. Συνοψίζοντας, η χρήση του \textbf{γενετικού αλγορίθμου} για τη βελτιστοποίηση του χρόνου διέλευσης ενός οδικού δικτύου επέδειξε την ικανότητα των εξελικτικών τεχνικών να διαχειρίζονται σύνθετα προβλήματα χωρίς να απαιτούνται παράγωγοι ή άλλες αναλυτικές μέθοδοι.
  259. Από την ανάλυση των αποτελεσμάτων, παρατηρήσαμε πως η \textbf{πιθανότητα μετάλλαξης} και το \textbf{μέγεθος του πληθυσμού} επηρεάζουν άμεσα τη σύγκλιση και την απόδοση του αλγορίθμου.
  260. Μικρές πιθανότητες μετάλλαξης οδηγούν σε πιο αργή σύγκλιση, ενώ αυξημένος πληθυσμός παρέχει καλύτερη εξερεύνηση του χώρου λύσεων αλλά με μεγαλύτερο υπολογιστικό κόστος.
  261. Τα αποτελέσματα δείχνουν πως μια \textbf{ισορροπημένη επιλογή παραμέτρων} επιτρέπει τη βέλτιστη κατανομή της κυκλοφορίας, μειώνοντας σημαντικά τον συνολικό χρόνο διάσχισης.
  262. Επομένως, οι γενετικοί αλγόριθμοι αποτελούν μια αποτελεσματική επιλογή για παρόμοια προβλήματα βελτιστοποίησης, ειδικά όταν η διατύπωση του προβλήματος δεν επιτρέπει κλασικές μαθηματικές μεθόδους.
  263. \end{document}