Agent-Based Modeling and Simulation (ABMS) Bertan Badur Department of Management Information Systems Boğaziçi University
Outline Introduction Searching Mushrooms in a Forest
Introduction NetLogo –simple to install and experiment its model library User Manual –Tutorials, Interface Guide and Programming Guide –Dictionary Model Library –code examples
Agents Four kind of agents Moving agents – Turtles Patches – square cells – space in world Links – connect two turtles networks Observer - controler of the model –create other agents –global variables Each type of agents –commands –variables – build-in such as color and location user defined – additional –observer – gloabal variables
Global variables: –all agent can read and change –environment characteristics –model parameters Primitives – build-in procedure or command –commands tell agents something to do – retukrn void –reoprters calculte and report something – return a value or list –Ex: mean reports mean of a list of numbers – neighbors reports list of surrounding patches
Context –each pice of code is “in the contxt of ” one kind or occationally more then one kind of agent –can be changed during execution –Ex: ask turtles [move] agents – directly access variables for their own type Exceptions: –observer varibles by all agents –turtles can access patchs variables they are currenlty on
Searching Mushrooms in a Forest Is there a best strategy for searching mushrooms? observation: –mushrooms in clusters An intuitive strategy: –scanning an area in wide sweeps –upon finding a mushroom turning to smaller scale sweeps –as mushrroms in clusters What is large, small sweeps? and How long to search in smaller sweeps? Humans searching –pizzas, jobs, low prise goods, peace with neighbors
model of the problem try different search strategies Purpose: –what search strategy maximizes musrooms found in a given time Ignore trees and vegitables, soil type Musrooms are distributed as clusters mushroom hunter –moving point –having a sensing radius –track of how many mushrooms found –how much time passed since last mushroom fouınd
clusters of items (mushrooms) If the agent (hunter) finds an item smaller-scale movement If a critical time passes since last item found swithes back to more streight movement so as to find new clusters of items
Demonstrating Program: Mushroom Hunt File/New File/Save with extension “nlogo” Settings World geometry: –0,0 orgin, max-pxcor=16, max-pycor=16 –33x33 squre latice 2 hunters – turtels cluster of mushrooms – red patches all other patches are black setup – initialization go – continuous operations
procedukres – commands to proc name commands end Create a button executing procedure setup Create a button executing procedure go –forever is cheked – forever button write setup procedure code tab
to setup end to go end
to setup ask patches [ set pcolor red ] end ask primitive asks selected agents to do actions by commands in brackets set color of all pathces to red set - primitive is assignment pcolor – variable for patches
to setup ask n-of 4 patches [ ask patches in-radius 5 [ set pcolor red ] end n-of : n-of number ageent set in-radius : agents in-radius number
to setup ask n-of 4 patches [ ask n-of 20 patches in-radius 5 [ set pcolor red ] end 4 patches are randomly selected for each randomly selected pathc for all patches in radius 5 select 20 randomly set their color to red
to setup clear-all ;abriviares as – ca - ask n-of 4 patches [ ask n-of 20 patches in-radius 5 [ set pcolor red ] end clear-all: clear all default values
using parameters globals [ num-clusters ] to setup clear-all set num-clusters 4 ask n-of num-clusters patches [ ask n-of 20 patches in-radius 5 [ set pcolor red ] end
creating 2 hunters - turtles create-tutrles 2 ;crt 2 [ set sıze 2 set color yellow ] create 2 turtles crt create-tutles bnild-in turtle variables size and color
go procedure to go ask turtles [search] end to search ifelse tıme-sınce-last-found <= 20 [right (random 181) - 90] [right (random 21) - 10] forward 1 end cifelse boolean condition [ block whan true ] [ block when false ] right: turn right by angle in degrees
algorithm of move if timelast-found <= critical value make a small turn else make a biger turn if found – come on a red patch set timelasf-fournd to 0 set color to yellow else increment timelast-found by one
variable for turtles tutrles-own [ tıme-sınce-last-found ] tıme-sınce-last-found variable for all turtles time passed since last mushroom has found by the hunter
tıme-sınce-last-found initial value crt 2 [ set sıze 2 set color yellow set tıme-sınce-last-found 999 ] initialze tıme-sınce-last-found to a very high value greater then 20
add to the search procedure ifelse pcolor = red [ set tıme-sınce-last-found 0 set pcolor yellow ] [ set tıme-sınce-last-found tıme-sınce- last-found + 1 ] end if found pcolor is red set tıme-sınce-last-found to 0 set pcolor yellow else increment tıme-sınce-last-found by one
command center select turtles write commands hatch 1 [right 160] show count turtles
firther modifications adding ticks add reset-ticks to the end of setup add tick to the begining of go following motion of hunters add pen-down to the setup procedute when initilizing turtles