Télécharger mma_05.dgibi

Retour à la liste

Numérotation des lignes :

  1. * fichier : mma_05.dgibi
  2. ************************************************************************
  3. ************************************************************************
  4.  
  5. ************************************************************************
  6. * Test de l'operateur MMA : Methode des Asymptotes Mobiles *
  7. * Application a l'optimisation d'un treillis a 3 barres *
  8. * *
  9. * Reference : *
  10. * 2008 M. Bruggi *
  11. * On an alternative approach to stress constraints relaxation in *
  12. * topology optimization *
  13. * Struct Multidisc Optim, 36:125–141 *
  14. * https://link.springer.com/article/10.1007/s00158-007-0203-6 *
  15. * *
  16. * On considere un treillis de 3 barres reparties entre 4 noeuds *
  17. * Les noeuds p2, p3 et p4 sont encastres, le noeud p1 est soumis a *
  18. * 2 cas de chargement f1 et f2 *
  19. * *
  20. * Ʌ f1 = [0 1.5]^T *
  21. * ‖ *
  22. * ‖ *
  23. * ‖ *
  24. * p1 *====> f2 = [1 0]^T *
  25. * /|\ *
  26. * / | \ *
  27. * / | \ *
  28. * x1 / | \ x3 *
  29. * / x2| \ *
  30. * * * * *
  31. * p2 p3 p4 *
  32. * *
  33. * Les variables d'optimisation sont les densites des barres x1, x2, x3 *
  34. * Le problème d'optimisation consiste a minimiser le volume de la *
  35. * structure tel que les contraintes ne depassent pas une valeur seuil *
  36. * En choisissant : *
  37. * - des caracteristiques geometriques/mecaniques unitaires *
  38. * - des longueur de barre l1 = l3 = 1. et l2 = sqrt(2) *
  39. * - une limite en contrainte sigy = 3. pour chaque barre *
  40. * - une loi puissance reliant le module d'Young a la densite (SIMP) *
  41. * - d'eliminer la variable x3 (avec x3=x1), car la contrainte dans la *
  42. * barre 3 est superflue pour ce chargement *
  43. * alors, le probleme d'optimisation s'ecrit : *
  44. * *
  45. * Minimiser : f0(x1,x2) = 2sqrt(2) x1 + x2 *
  46. * sur x1,x2 *
  47. * 0.75 x1^p *
  48. * avec : f1(x1,x2) = ---------------------- - 3 x1^p <= 0 *
  49. * x1^p / sqrt(2) + x2^p *
  50. * *
  51. * 1.5 x2^p *
  52. * f2(x1,x2) = ---------------------- - 3 x2^p <= 0 *
  53. * x1^p / sqrt(2) + x2^p *
  54. * *
  55. * f3(x1,x2) = 1/sqrt(2) - 3 x1^p <= 0 *
  56. * *
  57. * 0 < x1 <= 1 0 <= x2 <= 1 *
  58. * *
  59. * Le probleme admet un optimum global en x1 = 0.708 x2 = 0. *
  60. * un optimum local en x1 = 0.617 x2 = 0.7 *
  61. ************************************************************************
  62.  
  63. * Options
  64. OPTI 'ECHO' 0 ;
  65. itrac = FAUX ;
  66.  
  67. * Parametres du probleme
  68. p = 3. ;
  69. q = 3. ;
  70.  
  71. * Procedures pour le calcul de la fonction objectif (f0) des fonctions limitations (f1 f2 f3)
  72. * et de leurs derivees partielles
  73. * Ici, l'exposant q est utilise pour penaliser les contraintes relaxer le probleme original
  74. * Si q < p --> probleme relaxe
  75. * Si q = p --> probleme initial (singulier, avec espaces degeneres)
  76.  
  77. * Juste les valeurs des fonctions
  78. DEBP F0123 x1 x2 p q ;
  79. rac2 = 2. ** 0.5 ;
  80. f0 = (2. * rac2 * x1) + x2 ;
  81. xdeno = ((x1 ** p) / rac2) + (x2 ** p) ;
  82. f1 = (0.75 * (x1 ** p) / xdeno) - (3. * (x1 ** q)) ;
  83. f2 = (1.5 * (x2 ** p) / xdeno) - (3. * (x2 ** q)) ;
  84. f3 = (1. / rac2) - (3. * (x1 ** q)) ;
  85. FINP f0 f1 f2 f3 ;
  86.  
  87. * Les fonctions et leurs derivees
  88. DEBP FONC lx*'LISTREEL' p*'FLOTTANT' q*'FLOTTANT' ;
  89. x1 = EXTR lx 1 ;
  90. x2 = EXTR lx 2 ;
  91. rac2 = 2. ** 0.5 ;
  92. f0 f1 f2 f3 = F0123 x1 x2 p q ;
  93. f = PROG f1 f2 f3 ;
  94. df0dx = PROG (2. * rac2) 1. ;
  95. xdeno = ((x1 ** p) / rac2) + (x2 ** p) ;
  96. dfdx = TABL ;
  97. dfdx . 1 = PROG ((0.75 * p * (x1 ** (p - 1.)) * (x2 ** p) / (xdeno ** 2.)) - (3. * q * (x1 ** (q - 1.))))
  98. (-0.75 * p * (x2 ** (p - 1.)) * (x1 ** p) / (xdeno ** 2.)) ;
  99. dfdx . 2 = PROG ((-1.5 / rac2) * p * (x1 ** (p - 1.)) * (x2 ** p) / (xdeno ** 2.))
  100. ((( 1.5 / rac2) * p * (x2 ** (p - 1.)) * (x1 ** p) / (xdeno ** 2.)) - (3. * q * (x2 ** (q - 1.)))) ;
  101. dfdx . 3 = PROG (-1. * 3. * q * (x1 ** (p - 1.)))
  102. 0. ;
  103. FINP f0 df0dx f dfdx ;
  104.  
  105. * Solution de reference
  106. x1ref = 0.708 ;
  107. x2ref = 0. ;
  108. xref = PROG x1ref x2ref ;
  109. f0ref df0dxref fval0 dfdxref = FONC xref p q ;
  110. MESS 'Solution de reference' ;
  111. MESS ' x1 x2 f0' ;
  112. MESS (CHAI 'FORMAT' '(F10.5)' x1ref /4 x2ref /16 f0ref /28) ;
  113.  
  114. * Choix d'un point initial pour les inconnues
  115. x0 = PROG 0.95 0.45 ;
  116.  
  117. * Calcul de f0(x0), df0dx(x0), fval(x0), dfdx(x0)
  118. f0 df0dx fval dfdx = FONC x0 p q ;
  119.  
  120. * Initialisation de la table pour la MMA
  121. t = TABL ;
  122. t . 'X' = x0 ;
  123. t . 'XMIN' = PROG 1.E-6 0. ;
  124. t . 'XMAX' = 1. ;
  125. t . 'F0VAL' = f0 ;
  126. t . 'DF0DX' = df0dx ;
  127. t . 'FVAL' = fval ;
  128. t . 'DFDX' = dfdx ;
  129. t . 'A0' = 1. ;
  130. t . 'A' = PROG (DIME dfdx)*0. ;
  131. t . 'C' = PROG (DIME dfdx)*1.E5 ;
  132. t . 'D' = PROG (DIME dfdx)*1. ;
  133. t . 'MOVE' = 0.01 ;
  134.  
  135. * Iterations de la MMA
  136. x01 = EXTR x0 1 ;
  137. x02 = EXTR x0 2 ;
  138. lx1 = PROG x01 ;
  139. lx2 = PROG x02 ;
  140. lit = PROG 0. ;
  141. lf0 = PROG f0 ;
  142. li = PROG (MAXI (fval ET 0.)) ;
  143. MESS 'Optimisation par MMA' ;
  144. MESS 'It x1 x2 f0 kktnorm' ;
  145. MESS (CHAI 'FORMAT' '(F10.5)' 0 x01 /4 x02 /16 f0 /28) ;
  146. * Boucle d'optimisation
  147. REPE loop 150 ;
  148. * Appel a MMA
  149. lit = lit ET &loop ;
  150. MMA t ;
  151. xmma = t . 'X' ;
  152. x1 = EXTR xmma 1 ;
  153. x2 = EXTR xmma 2 ;
  154. lx1 = lx1 ET x1 ;
  155. lx2 = lx2 ET x2 ;
  156. * Mise a jour des valeurs des fonctions
  157. f0 df0dx fval dfdx = FONC xmma p q ;
  158. lf0 = lf0 ET f0 ;
  159. li = li ET (MAXI (fval ET 0.)) ;
  160. t . 'F0VAL' = f0 ;
  161. t . 'DF0DX' = df0dx ;
  162. t . 'FVAL' = fval ;
  163. t . 'DFDX' = dfdx ;
  164. * Calcul du residu pour les conditions KKT
  165. res kkt2 kktinf = KKT_MMA t ;
  166. * Bilan de l'iteration
  167. MESS (CHAI 'FORMAT' '(F10.5)' &loop x1 /4 x2 /16 f0 /28 kkt2 /40) ;
  168. FIN loop ;
  169. nit = (DIME lf0) - 1 ;
  170.  
  171. * Verification du resultat
  172. errmax = MAXI 'ABS' ((xmma - xref)) ;
  173. MESS 'Erreur max (sur x)' ;
  174. MESS errmax ;
  175.  
  176. * Évolutions temporelles de f, de l'infaisabilité et des variables
  177. * en fonction des iterations d'optimisation
  178. SI itrac ;
  179. OPTI 'DIME' 2 'ELEM' 'QUA8' ;
  180. xmin = MAXI (t . 'XMIN') ;
  181. xmax = t . 'XMAX' ;
  182. msh = (DROI 100 (xmin xmin) (xmax xmin)) TRAN 100 (0. (xmax - xmin)) ;
  183. cmsh = CONT msh ;
  184. x y = COOR msh ;
  185. f0msh f1msh f2msh f3msh = F0123 x y p q ;
  186. lf1 toto = @ISOSURF msh (PROG 0.) f1msh ;
  187. lf2 toto = @ISOSURF msh (PROG 0.) f2msh ;
  188. lf3 toto = @ISOSURF msh (PROG 0.) f3msh ;
  189. path = QUEL 'SEG2' lx1 lx2 ;
  190. pdep = x01 x02 ;
  191. pfin = x1 x2 ;
  192. cdep = (CERC 10 'ROTA' 360. (pdep PLUS (0.01 0.)) pdep) COUL 'VIOL' ;
  193. cfin = (CERC 10 'ROTA' 360. (pfin PLUS (0.01 0.)) pfin) COUL 'ROUG' ;
  194. annd = ANNO 'ETIQ' pdep 'VIOL' 'NE' 0.1 VRAI 'Depart' ;
  195. annf = ANNO 'ETIQ' pfin 'ROUG' 'NE' 0.1 VRAI 'Arrivee' ;
  196. TRAC f0msh msh (cmsh ET path ET lf1 ET lf2 ET lf3 ET cdep ET cfin) 25
  197. (annd ET annf) 'TITR' 'Isovaleurs de la fonction objectif F0 et chemin au cours de l''optimisation' ;
  198. lit = PROG 0. 'PAS' 1. nit ;
  199. evf0 = EVOL 'ROUG' 'MANU' 'Iteration' lit 'F0' lf0 ;
  200. evfr = EVOL 'ROUG' 'MANU' 'Iteration' (PROG 0. nit) 'F0' (PROG f0ref f0ref) ;
  201. tl = TABL ;
  202. tl . 2 = 'TIRR' ;
  203. tl . 'TITRE' = TABL ;
  204. tl . 'TITRE' . 1 = 'F0 calculee' ;
  205. tl . 'TITRE' . 2 = 'F0 ref.' ;
  206. DESS (evf0 ET evfr) 'TITR' 'Fonction objectif F0(x) VS Iterations' 'LEGE' tl ;
  207. evi = EVOL 'VERT' 'MANU' 'Iteration' lit 'Inf' li ;
  208. tl . 'TITRE' . 1 = 'Infaisabilite' ;
  209. DESS evi 'TITR' 'Infaisabilite VS Iterations' 'LEGE' tl ;
  210. evx1 = EVOL 'ROUG' 'MANU' 'Iteration' lit 'x' lx1 ;
  211. evx1r = EVOL 'ROUG' 'MANU' 'Iteration' (PROG 0. nit) 'x' (PROG x1ref x1ref) ;
  212. evx2 = EVOL 'ORAN' 'MANU' 'Iteration' lit 'x' lx2 ;
  213. evx2r = EVOL 'ORAN' 'MANU' 'Iteration' (PROG 0. nit) 'x' (PROG x2ref x2ref) ;
  214. tl . 4 = 'TIRR' ;
  215. tl . 'TITRE' . 1 = 'x1 calcule' ;
  216. tl . 'TITRE' . 2 = 'x1 ref.' ;
  217. tl . 'TITRE' . 3 = 'x2 calcule' ;
  218. tl . 'TITRE' . 4 = 'x2 ref.' ;
  219. DESS (evx1 ET evx1r ET evx2 ET evx2r) 'TITR' 'Valeurs x VS Iterations' 'LEGE' tl ;
  220. FINSI ;
  221.  
  222. * Sortie en erreur si l'écart aux valeurs de références est trop important
  223. SI (errmax > 1.E-3) ;
  224. ERRE 'Erreur dans le calcul d''optimisation' ;
  225. SINON ;
  226. MESS 'Cas test passe avec succes !' ;
  227. FINSI ;
  228.  
  229.  
  230. FIN ;
  231.  
  232.  
  233.  

© Cast3M 2003 - Tous droits réservés.
Mentions légales