The foraging experiment is a common pool resource experiment where participants are placed in randomized groups and interact with a spatially explicit renewable resource. It is built on the Social Ecological Systems Experiment Framework and has been used to conduct research studies at Arizona State University, Indiana University, and the University of Alaska-Anchorage.
- Participants move and interact with a resource in a real-time 2-D grid environment.
- Pluggable resource growth dynamics. The default is a parameterized density-dependent growth function but there are also "patchy" resource growth dynamics where the top half of the grid has a higher chance of regrowth than the bottom half. Arbitrary regrowth dynamics are possible by implementing a Java interface and specifying it in a configuration file.
- Flexible experiment and round scoped parameterization via Java properties files used to define experimental treatments. Experiment scoped parameters apply to the entire experiment whereas round scoped parameters apply to a specific round.
- Support for interactive quizzes, monitored real-time chat with options for censoring, voting, sanctioning, mini trust games in between rounds, embedded links that uniquely and anonymously identify each participant to Qualtrics surveys and limited fields of vision.
- Binary and XML savefiles that store every user action (e.g., movement, harvest events, sanction events, chats) in a time ordered stream that can be converted to a variety of CSV statistics files and into QuickTime movies. Custom data analysis can be done by extending the SaveFileConverter class and analyzing the OrderedSet of user actions.
First, you'll need to clone this git repository via the command-line or a git GUI client, e.g., % git clone https://github.com/virtualcommons/foraging.git
(recommended) or you can download and unpack the latest stable release
Next, you'll need to configure the software. At a minimum, you'll need to customize the build.properties
file and add a set of configuration files representing an experiment treatment to src/main/resources/configuration
. This step is clumsy and could use a lot of improvement.
- customize
build.properties
from thebuild.properties.example
file. At a minimum, make sure you set theserver.address
to the IP address or fully qualified hostname of the machine you are using to serve this application - add configuration files to
src/main/resources/configuration
, see the wiki's Configuration page for more details.
If you install Docker and docker compose you won't need to manually install Java, Ant, and start a webserver to serve the JNLP files, jar files, and static image assets in addition to the experiment server responsible for the experiment logic and generating data files in ./docker/data
.
NOTE: The docker build currently binds to port 80 instead of port 8080 - if you want to change this, modify the port mapping in docker-compose.yml for the nginx web service.
- run
docker-compose build --pull
to build the foraging Docker image - run
docker-compose up -d
to start an experiment server listening on port 16001 and an nginx webserver listening on port 8080 to deliver the foraging client and facilitator applications via Java WebStart. The relevant URLs arehttp://<server.address>
to start a WebStart client andhttp://<server.address>/facilitator.jnlp
to start a WebStart facilitator where<server.address>
is as defined in yourbuild.properties
file. - Back up your data: when you are done running an experiment make sure you back up the binary data saved in
docker/data
. - Convert binary data stored in
DATA_DIR
to a variety of plaintext files viadocker-compose run data
or customize the statistics you see by writing a customSaveFileProcessor
and adding it to the list in ForagingSaveFileConverter. You can select the data directory with theDATA_DIR
environment variable and convert XML XStream savefiles by settingXML=xml
as an environment variable, e.g.,docker-compose run -e DATA_DIR=<data-directory> -eXML=xml data
. - Run
docker-compose down
ordocker system prune
to clean up your docker images when you're done.
You can also install the dependencies directly onto your system (e.g., yum
, apt-get
, or pacman
on your favorite Linux distro) and
You can run a demo from the command-line (e.g., Windows PowerShell or Command Prompt, Mac OSX Terminal.app, or any Linux terminal) after Ant and Java have been installed via
% ant prepare-demo
% ant demo % this will start a server, a facilitator, and 5 clients in the demo treatment
For more detailed instructions, please see the installation instructions on our wiki.
Data generated from the foraging framework has been published in Lab Experiments for the Study of Social-Ecological Systems. Archives of the configuration files used and the experiment data are also available.
If you'd like to add new features or find any bugs, please let us know.