Recuita simulada

De testwiki
La revisió el 17:53, 13 maig 2024 per imported>Rebot (neteja i estandardització de codi)
(dif.) ← Versió més antiga | Versió actual (dif.) | Versió més nova → (dif.)
Salta a la navegació Salta a la cerca

La recuita simulada (simulated annealing en anglès) és una tècnica de cerca utilitzada en informàtica o aplicacions d'intel·ligència artificial per trobar solucions aproximades a un problema d'optimització. Està basat en una tècnica de la indústria metal·lúrgica que consisteix a escalfar i refredar lentament un material de manera que els àtoms s'alliberen de les seves posicions inicials i es mouen aleatòriament per l'espai donant-los més possibilitats (durant el refredament) a allotjar-se finalment en estats d'energia menors.

L'algorisme consisteix a partir d'una solució inicial i després seleccionar una nova solució aleatòria propera a la solució inicial. Si la nova solució és millor que l'anterior, l'algorisme es mou cap al nou punt (solució), sinó té una certa probabilitat de quedar-se amb la solució anterior i una altra de moure's cap a la nova solució (encara que aquesta sigui pitjor).[1][2] Aquest procés es repeteix fins que es doni la condició d'acabament que normalment és un temps determinat, un nombre d'iteracions o un cert nivell de qualitat de la solució. La probabilitat de moure's cap a posicions "pitjors" serveix per a evitar que l'algorisme quedi estancat en òptims locals o zones planes i busqui la solució final d'una manera global.

Esquema de l'algorisme

A continuació es mostra un esquema en pseudocodi de la implementació de l'algorisme.

  • Inicialitzar:
    • Establir β=β0 on β=1/T on T és el paràmetre temperatura.
    • Establir k=0 (passos de temperatura)
    • Establir nβ=0 (nombre d'iteracions per pas de temperatura)
  • Generar una configuració aleatòria x0* de l'argument de la funció objectiu a minimitzar.
  • (GEN_RND) Fer evolucionar la configuració inicial x0 cap a una configuració pertorbada, x* fent una modificació petita: x0+δxx*
  • Si f(x*)<f(x0): accepta x*. Sinó, accepta x* amb probabilitat exp(βΔf)
    • Fer nβnβ+1
    • Si nβnβMAX vés a (GEN_RND)
    • Incrementar la temperatura inversa ββ+δβ
    • Fer kk+1. Si k<kMAX vés a (GEN_RND) sinó (Acaba)
    • Acaba

Referències

Plantilla:Referències

Enllaços externs

  1. Torrent-Fontbona, F. Decision support methods for global optimization. M.Sc. Thesis of the University of Girona (2012)
  2. F. Torrent, V. Muñoz, B. López. Solving large immobile location-allocation by affinity propagation and simulated annealing. Application to select which sporting event to watch Expert Systems with Applications, Volume 40, Issue 11, pages 4593-4599, ISSN 0957-4174, Plantilla:Doi(2013)