Model agentowy, model oparty na agentach (ang. Agent-Based Model, ABM) – model obliczeniowy służący do symulacji zachowań i interakcji pomiędzy autonomicznymi jednostkami, zwanymi agentami. Modele agentowe mają szereg zastosowań w nauce, ekonomii i biznesie. W niektórych dziedzinach, szczególnie w ekologii, ABM są również nazywane modelami opartymi na jednostkach[1] (ang. Individual-Based Models, IBM). ABM są wykorzystywane do przewidywania zachowań systemów złożonych z wielu oddziałujących na siebie obiektów, szybkiego testowania hipotez, wizualizacji ruchu np. grup zwierząt lub cząsteczek dymu[2], lub studiowania nowych, emergentnych wartości systemów naturalnych. Modele agentowe wykorzystywane są wszędzie tam, gdzie problemy są trudne lub niemożliwe do rozwiązania za pomocą metod analitycznych czy teorii gier ze względu na ich złożoność i konieczność uwzględnienia osobniczych różnic w zachowaniu pomiędzy jednostkami.
Teoria
Agent jest zdefiniowany jako jednostka, osobnik lub obiekt, opisany prostymi regułami zachowań, które pozwalają mu na interakcję ze środowiskiem i innymi osobnikami w modelu. Modele agentowe są wzorowane na mechanice obserwowanej pomiędzy osobnikami w naturalnie występujących systemach (np. oddziaływaniach pomiędzy poruszającymi się zwierzętami), a do ich zdefiniowania potrzebnych jest jedynie kilka założeń:
Autonomia osobników - każdy z osobników lub obiektów uwzględnionych w modelu wykazuje autonomię pod względem zachowań i może reagować na bodźce płynące od innych osobników i ze środowiska. Algorytm w każdej iteracji uwzględnia reakcje każdego z agentów osobno.
Lokalne interakcje - każdy agent jest w stanie reagować wyłącznie na bodźce znajdujące się w jego bezpośrednim otoczeniu. Interakcje osobników umieszczonych w oddalonym miejscu w przestrzeni nie mają bezpośredniego wpływu na zachowanie tego agenta. Poszczególne osobniki w modelu działają aby maksymalizować własne zyski, takie jak reprodukcja lub korzyści ekonomiczne.
Decentralizacja - każdy z osobników ma tę samą rangę, a zachowania żadnego z nich nie wpływają na zachowania innych z większą mocą niż działania pozostałych.
Modele agentowe są zazwyczaj implementowane za pomocą programowania obiektowego. Modelowane osobniki mogą mieć zakodowane reguły uczenia się, a kolejne generacje mogą powstawać dzięki zastosowaniu algorytmu genetycznego.
Szczególną cechą ABM jest to, że działania agentów w mikroskali powodują powstanie dodatkowych, emergentnych cech[2][3], takich jak np. samoorganizacja. Proste zachowania jednostek generują złożone zachowania wielkoskalowe, co można wyrazić zdaniem "całość jest większa niż suma jej części". Innymi słowy, właściwości systemu wyższego poziomu (np. populacji) wyłaniają się z interakcji niższego poziomu (pomiędzy osobnikami).
Przykłady zastosowań
W ekologii, obiekty w ABM zazwyczaj należą do jednej kategorii, np. tego samego taksonu modelowanych zwierząt czy roślin, oraz posiadają te same rodzaje cech i zachowań, jednak z uwzględnieniem indywidualnej wariancji pomiędzy nimi. Przykładowo, za pomocą ABM można wymodelować wzrost lasu[4], w którym każdy agent (w tym przypadku drzewo) opisany jest tymi samymi parametrami (wysokość, całkowita powierzchnia liści, objętość korony), ale poprzez zaimplementowanie różnego tempa zmian dla każdego z parametrów oraz przyjęcia innych wartości początkowych dla każdego osobnika, uzyskujemy znaczne różnice we wzroście końcowym. W tym modelu każdy agent konkuruje z sąsiednimi jednostkami o dostęp do światła. Charakter wzrostu i oddziaływań pomiędzy wieloma osobnikami jest bardzo trudny do przewidzenia innymi metodami matematycznymi. Dzięki ABM można uzyskać wyniki, które pozwolą zrozumieć m.in. jak może wyglądać sukcesja lasu w zależności od warunków początkowych. Taki model można dowolnie rozwijać, wprowadzając np. nachylenie podłoża lub zmienną długość doby. W wyniku symulacji można uzyskać wiarygodny obraz tego, jak będzie wyglądała dana populacja drzew w stosunkowo krótkim czasie (znacząco krótszym, niż skala czasowa wzrostu lasu).
Można spotkać się również z modelami, w których symulowane jednostki należą do jednej kategorii i nie różnią się między sobą cechami, a jedyna różnica w warunkach początkowych dotyczy ich rozmieszczenia w przestrzeni. Do ciekawszych modeli, które badają ruch w przestrzeni należą m.in. model "boidów" (boid, ang. bird-like object) ilustrujący kolektywny ruch stada ptaków lub ryb w ławicy[5], czy model próbujący wyjaśnić mechanizm ucieczki grupy ludzi z pomieszczenia w razie pożaru[6].