Difference between revisions of "Energy Wars Display"
Jump to navigation
Jump to search
(→Specifics) |
(→JavaScript) |
||
Line 43: | Line 43: | ||
==JavaScript== | ==JavaScript== | ||
− | + | * the javascript isn't as organized as it could be | |
+ | * visualization.js contains functions that create objects (charts) | ||
+ | * css.js contains functions for manipulating the classes of HTML objects | ||
+ | * chart.js, NationalRoad.js, and CollegeAvenue.js are very similar | ||
+ | *# download daily power readings | ||
+ | *# download baseline power readings | ||
+ | *# create container object hip.data.building for building names, baselines, and power | ||
+ | *# create a new dashboard with appropriate options | ||
+ | *# download cumulative power readings | ||
+ | *# download cumulative baseline power readings | ||
+ | *# create container object hip.data.building for building names, baselines, and power | ||
+ | *# create a new dashboard with appropriate options | ||
+ | *# set the window resize function to redraw the chart | ||
+ | *# draw the chart and intialize buttons | ||
+ | ** setDisplay() changes which buildings are enabled | ||
+ | ** setViewInterval() is for previous week / next week | ||
+ | ** flipViewZoom() is for zooming in / out | ||
+ | * gc_zoom.js changes the interval to switch between zoomed in / zoomed out | ||
+ | * global.js is used to intialize global namespaces and variables | ||
+ | * html_helper has a bunch of functions for getting and modifying the html | ||
+ | ** used to emulate buttons | ||
+ | * interval.js controls what interval is displayed | ||
+ | ** it's just an iterator | ||
+ | ** provides functions for changing instantly or gradually | ||
+ | ** can have its state stored/restored | ||
+ | ** can setView() to the interval | ||
+ | * hip.js contains: | ||
+ | ** get csv / csv to array functions | ||
+ | ** the animation class (for setting a chart's animation to a preset) | ||
+ | ** dashboard creator for this project | ||
+ | ** building container class | ||
==HTML== | ==HTML== |
Revision as of 05:43, 4 March 2014
RPNL
Currently, this is how we're getting data from RPNL.
- RPNL sends an email containing CSV to testcs128@cs.earlham.edu
- testcs128 forwards it to ghcrows13@cs.earlham.edu in its .forward file
- ghcrows13@cs.earlham.edu executes mail.py (in home directory) from its .forward file
- mail.py scrapes off CSV attachments
- mail.py pipes text into parse.py
- parse.py scrapes off data, copies tmp.csv to ghcrows13@proto.cs.earlham.edu:/home/users/energy/contest/daily/tmp.csv
- uses RSA keys to bypass passwords
- user names must be the same for RSA keys to work
- parse.py executes a sql command that pipes this csv file into /home/users/energy/contest/daily/parse_houses.py
- parse_houses.py strips off csv data (again!) and derives the energy change
- parse_houses.py then copies the data into the electrical_energy_rpnl database
Display
The display is written using google charts.
Data
Overview
- Data is generated by ~energy/contest/daily/execute.bash
- executed daily by energy's crontab
- Temporary csv files are stored in ~energy/contest/daily/tmp_data/
- useful for desktop testing
- final csv files are stored in ~energy/public_html/development/EnergyWars/
- execute.bash has some options that you can change, including:
- start and end dates for the baseline and the contest
- the target database
- name -- the prefix for CSV files
- street -- that's the string that RPNL uses
Specifics
- execute.bash generates the daily, baseline, cumulative, and cumulative baseline
- each of these are a different .bash script
- it does this for buildings, national road, and college avenue
- an overview of what each script does:
- generates appropriate file names
- executes a dynamic SQL statement that's based on arguments
- stores the SQL response in a file
- reformats the data using ~energy/contest/daily/reformat.py
- stores the reformatted data in ~energy/contest/daily/tmp_data/
- copies the reformatted data to the destination
JavaScript
- the javascript isn't as organized as it could be
- visualization.js contains functions that create objects (charts)
- css.js contains functions for manipulating the classes of HTML objects
- chart.js, NationalRoad.js, and CollegeAvenue.js are very similar
- download daily power readings
- download baseline power readings
- create container object hip.data.building for building names, baselines, and power
- create a new dashboard with appropriate options
- download cumulative power readings
- download cumulative baseline power readings
- create container object hip.data.building for building names, baselines, and power
- create a new dashboard with appropriate options
- set the window resize function to redraw the chart
- draw the chart and intialize buttons
- setDisplay() changes which buildings are enabled
- setViewInterval() is for previous week / next week
- flipViewZoom() is for zooming in / out
- gc_zoom.js changes the interval to switch between zoomed in / zoomed out
- global.js is used to intialize global namespaces and variables
- html_helper has a bunch of functions for getting and modifying the html
- used to emulate buttons
- interval.js controls what interval is displayed
- it's just an iterator
- provides functions for changing instantly or gradually
- can have its state stored/restored
- can setView() to the interval
- hip.js contains:
- get csv / csv to array functions
- the animation class (for setting a chart's animation to a preset)
- dashboard creator for this project
- building container class