-
Notifications
You must be signed in to change notification settings - Fork 99
RoadTrafficModel_step1
This first step Illustrates how to load GIS data (shapefiles) and to read attributes from GIS data.
- Set the time duration of a time step to 10 minutes.
- Load, agentify and display two layers of GIS data (building and road). Agentifying a GIS element will allow us to give it a behavior later on (thus not being simply a static/passive object).
- Read the 'NATURE' attribute of the building data: the buildings of 'Residential' type will be colored in gray, the buildings of 'Industrial' type will be color in blue.
In this first model, we have to define two species of agents: the building
agents and the road
ones. These agents will not have a particular behavior (for the moment), they will just be displayed.
For each of these species, we define a new attribute: color
of type rgb
, with for initial value: "black" for the road
agent and "gray" (by default) for the building
agent. Concerning the building
species, we define a second attribute named type
representing the type of the building ("Residential" or "Industrial").
At last, we define an aspect for these species. In this model, we want to represent the geometry of the agent, we then use the statement draw
that allows to draw a given geometry. In order to draw the geometry of the agent, we use the attribute shape
(which is a built-in attribute of all agents).
species building {
string type;
rgb color <- #gray ;
aspect base {
draw shape color: color ;
}
}
species road {
rgb color <- #black ;
aspect base {
draw shape color: color ;
}
}
GAMA allows to automatically read GIS data that are formatted as shapefiles. In order to let the user chooses his/her shapefiles, we define three parameters. One allowing the user to choose the road shapefile, one allowing him/her to choose the building shapefile, and, at last, one allowing him/her to choose the bounds shapefile. We will come back later on the notion of "bounds" in GAMA.
Definition of the three global variables of type file
concerning the GIS files:
global {
file shape_file_buildings <- file("../includes/building.shp");
file shape_file_roads <- file("../includes/road.shp");
file shape_file_bounds <- file("../includes/bounds.shp");
}
All shapefiles are available in the model library (under Library models -> Tutorials -> Road Traffic) or you can download them by following this GitHub link.
In the experiment section, we add three parameters to allow the user to change the shapefile used directly through the UI:
experiment road_traffic type: gui {
parameter "Shapefile for the buildings:" var: shape_file_buildings category: "GIS" ;
parameter "Shapefile for the roads:" var: shape_file_roads category: "GIS" ;
parameter "Shapefile for the bounds:" var: shape_file_bounds category: "GIS" ;
}
In GAMA, the agentification of GIS data is very straightforward: it only requires to use the create
command with the from
facet to pass the shapefile. Each object of the shapefile will be directly used to instantiate an agent of the specified species. The reading of an attribute in a shapefile is also very simple. It only requires to use the with
facet: the argument of this facet is a dictionary of which the keys are the names of the agent attributes and the value the read
operator followed by the name of the shapefile attribute ("NATURE" in our case).
In the init
block of the global
block, we create the road and building agents from the shapefiles. Concerning the building
agents, we read the "NATURE" attribute of the shapefile to initiate the value of the type
attribute. If the type
attribute is equal to "Industrial" set the color
attribute to "blue".
global {
...
init {
create building from: shape_file_buildings with: [type::read ("NATURE")] {
if type="Industrial" {
color <- #blue ;
}
}
create road from: shape_file_roads ;
}
}
In GAMA, by default, a time step represents 1 second. It is possible to redefine this value by overriding the step
global variable. This value of the time step is used by the moving primitives of GAMA.
In our model, we define that a step represents 10 minutes. Note that it is possible to define the unit of a value by using #
+ unit name, e.g. #mn
for minutes or #km
for kilometers.
global {
...
float step <- 10 #mn;
...
}
Building a GIS environment in GAMA requires nothing special, just to define the bounds of the environment, i.e. the geometry of the world
agent. It is possible to use a shapefile to automatically define it by computing its envelope. In this model, we use a specific shapefile to define it. However, it would be possible to use the road shapefile to define it and let GAMA computes its envelope automatically.
https://github.com/gama-platform/gama/blob/GAMA_1.9.2/msi.gama.models/models/Tutorials/Road%20Traffic/models/Model%2001.gaml
- 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