Skip to content

Latest commit

 

History

History
100 lines (77 loc) · 3.99 KB

README.md

File metadata and controls

100 lines (77 loc) · 3.99 KB

waggle banner

This github repository holds the source code of the Waggle project. The Waggle project webpage can be found here: www.wa8.gl

A very high level view of the pieces of this project are:

  1. A Node Controller. This is the Linux-based brain for a sensor node. Currently, we are using a hardkernel.com ODROID single-board computer to be the Node Controller. In addition to a mostly stock Linux, the Node Controller has waggle's communication libraries, extra resilience features, and support for in-situ processing

  2. The WagMan system management board for managing a sensor node. This is the failsafe for the node. It can power-cycle components, detect when the waggle node is too hot, etc.

  3. The Waggle Sensor Board (EnvSense)

  4. The Cloud-based software (Beehive)

Directories

The directories are organized as follows (in alphabetical order)

beehive: the software run on the cloud server

  • docs: documentation of the cloud server
  • msging: the cloud-side of the message layer
  • wag-view: A nice front end for browsing the data
  • wag-db: the backend storage scripts

build: all of the pieces are built (compiled, configured) and installed into this directory

comlink: the communication link (wifi router, etc)

devtools: tools needed to build and install waggle

docs: waggle-wide documentation. This directory is the result of building all the docs found in the subdirectories

guestnode: All the software that lives on the guestnodes (ODROID)

  • docs: documentation of guestnodes
  • nc-baseos: The core Linux OS distro from which we start
  • nc-wag-os: The guestnode software stack, including the basic OS
    • waggled: The command controller and client console
    • resilience: tools and scripts, such as heartbeat for deep-space operation
    • personalization: scripts and config files for personalizing a node
    • externs: external packages added to make the basic Waggle OS better
  • in-situ: audio and image computing done inside the guestnode

nodecontroller: All the software that lives on the Node Controller (ODROID)

  • docs: documentation of node controller
  • nc-baseos: The core Linux OS distro from which we start
  • nc-wag-os: The Node Controller software stack, including the basic OS
    • waggled: The command controller and client console
    • msging: The remote messaging service to the cloud
    • resilience: tools and scripts, such as heartbeat for deep-space operation
    • personalization: scripts and config files for personalizing a node
    • externs: external packages added to make the basic Waggle OS better

sensors: all of the code to interact with and read data from sensors

  • envsense: the core environmental sensing board
    • docs: documentation of the envsense software / hardware environment, and sensors
    • reader: code (firmware) running on the envsense board
  • anemometer: an experiemental anemometer
    • docs: documentation of the system
    • reader: code to read and generate a value

testing: the waggle testing framework

wagman: waggle system management board software

  • docs: documentation of the waggle management software / hardware environment
  • manager: code (firmware) loaded onto system management board

other: a temporary holding place for things that have not yet found a home in the structure above.

Developer Notes

git submodules

To clone the repository with submodules use --recursive

git clone --recursive [email protected]:waggle-sensor/waggle.git

or get submodule after you cloned without --recursive option:

cd waggle
git submodule init
git submodule update

To update a submodule use: (example: beehive-server)

cd beehive-server/
git pull origin master
cd ..
git add beehive-server
git commit -m "update submodule" -a
git push

Do such an update only if the code in the remote repository is stable and compatible to the other code in this repository. If you need to point to another commit than the latest commit, do a "git checkout ..." after the "git pull" first.