-
Notifications
You must be signed in to change notification settings - Fork 99
LuneraysFlu_step4
This fourth step illustrates how to use a graph to constraint the movements of agents
- Define a new global variable: the road network (graph).
- Build the road network graph from the road agents
- Add new attribute to the people agents (target)
- Define a new reflex for people agents: stay.
- Modify the move reflex of the people agents.
In this model, we want people agents to move from buildings to buildings by using the shortest path in the road network. In order to compute this shortest path, we need to use a graph structure.
We thus define a new global variable called road_network
of type graph
that will represent the road network.
global{
//... other attributes
graph road_network;
//... init
}
In order to compute the graph from the road network, we use, just after having created the road agents, the as_edge_graph operator. This operator automatically built a graph from a set of polylines. Each extremity point of the lines will become a node in the graph, and each polyline an edge. By default, the graph is not oriented and the weights of the edges are the perimeters of the polylines. It is of course possible to change through the use of some operators.
global {
// world variable definition
init{
create road from: roads_shapefile;
road_network <- as_edge_graph(road);
create building from: buildings_shapefile;
create people number:nb_people {
location <- any_location_in(one_of(building));
}
ask nb_infected_init among people {
is_infected <- true;
}
}
}
We want to modify the behavior of the people agents in order to make them move from buildings to buildings by using the shortest path in the road network.
In order to implement this behavior, we will add two variables to our people species:
-
target
of typepoint
that will be the location where the agent wants to go
species people skills:[moving]{
//...the other attributes
point target;
//....
}
First, we add a new reflex called stay
that will be activated when the agent is in a house (i.e. its target is null) and that will define with a probability of 0.05 if the agent has to go or not. If the agent has to go, it will randomly choose a new target (a random location inside one of the building).
reflex stay when: target = nil {
if flip(0.05) {
target <- any_location_in (one_of(building));
}
}
Then, we modify the move
reflex. This one will be only activated when the agent will have to move (target not null). Instead of using the wander
action of the moving
skill, we use the goto
one that allows to make an agent moves toward a given target. In addition, it is possible to add a facet on
to precise on which topology the agent will have to move on. In our case, the topology is the road network.
When the agent reaches its destination (location = target), it sets its target to null.
reflex move when: target != nil{
do goto target: target on: road_network;
if (location = target) {
target <- nil;
}
}
model model4
global {
int nb_people <- 2147;
int nb_infected_init <- 5;
float step <- 5 #mn;
file roads_shapefile <- file("../includes/roads.shp");
file buildings_shapefile <- file("../includes/buildings.shp");
geometry shape <- envelope(roads_shapefile);
graph road_network;
int nb_people_infected <- nb_infected_init update: people count (each.is_infected);
int nb_people_not_infected <- nb_people - nb_infected_init update: nb_people - nb_people_infected;
float infected_rate update: nb_people_infected/nb_people;
init{
create road from: roads_shapefile;
road_network <- as_edge_graph(road);
create building from: buildings_shapefile;
create people number:nb_people {
location <- any_location_in(one_of(building));
}
ask nb_infected_init among people {
is_infected <- true;
}
}
reflex end_simulation when: infected_rate = 1.0 {
do pause;
}
}
species people skills:[moving]{
float speed <- (2 + rnd(3)) #km/#h;
bool is_infected <- false;
point target;
reflex stay when: target = nil {
if flip(0.05) {
target <- any_location_in (one_of(building));
}
}
reflex move when: target != nil{
do goto target: target on: road_network;
if (location = target) {
target <- nil;
}
}
reflex infect when: is_infected{
ask people at_distance 10 #m {
if flip(0.05) {
is_infected <- true;
}
}
}
aspect circle {
draw circle(10) color:is_infected ? #red : #green;
}
}
species road {
aspect geom {
draw shape color: #black;
}
}
species building {
aspect geom {
draw shape color: #gray;
}
}
experiment main type: gui {
parameter "Nb people infected at init" var: nb_infected_init min: 1 max: 2147;
output {
monitor "Infected people rate" value: infected_rate;
display map {
species road aspect:geom;
species building aspect:geom;
species people aspect:circle;
}
display chart_display refresh: every(10 #cycles) {
chart "Disease spreading" type: series {
data "susceptible" value: nb_people_not_infected color: #green;
data "infected" value: nb_people_infected color: #red;
}
}
}
}
- Installation and Launching
- Workspace, Projects and Models
- Editing Models
- Running Experiments
- Running Headless
- Preferences
- Troubleshooting
- Introduction
- Manipulate basic Species
- Global Species
- Defining Advanced Species
- Defining GUI Experiment
- Exploring Models
- Optimizing Model Section
- Multi-Paradigm Modeling
- Manipulate OSM Data
- Diffusion
- Using Database
- Using FIPA ACL
- Using BDI with BEN
- Using Driving Skill
- Manipulate dates
- Manipulate lights
- Using comodel
- Save and restore Simulations
- Using network
- Headless mode
- Using Headless
- Writing Unit Tests
- Ensure model's reproducibility
- Going further with extensions
- Built-in Species
- Built-in Skills
- Built-in Architecture
- Statements
- Data Type
- File Type
- Expressions
- Exhaustive list of GAMA Keywords
- Installing the GIT version
- Developing Extensions
- Introduction to GAMA Java API
- Using GAMA flags
- Creating a release of GAMA
- Documentation generation