/Binning

Exploration of different designs of binning

Primary LanguageJavaScriptCreative Commons Attribution Share Alike 4.0 InternationalCC-BY-SA-4.0

Binning

Exploration of Visual Designs for Binned Aggregation of Multi-Class Data: We survey different possible visual representation of binning and assess suitable tasks for different designs.

Usage

  1. Run app.py and goto localhost:5000.
  2. Try this on: https://binning.herokuapp.com/ (Deploy flask app to heroku. Since this is based on free account, it's slow.)
  3. Alternatively, include binning.js (under static directory), d3.js, d3.hexbin.min.js in your file. Directly use Binning.draw(filename, vistype, binSize) to draw a specific one you like. Note that if you are trying to pull out only the draw function, filename and vistype are required. You could also set up the column name in your csv by Binning.setColAndRange(x, y, category, x_min, x_max, y_min, y_max). The default column names are x, y, category. If you do not specify data range, the range will change according to your dataset (lower bound will be slightly smaller than min value, upper bound will be slightly larger than max value). The following are the enumeration of different vis types:
var VISTYPE = {
	  scatter: 0,
	  blending: 1,
	  pt1: 2, /* randomly subsampled points on color blending bins */
	  pt2: 3, /* similar to pt1, but keep at least one in a class */
	  pt3: 4, /* similar to pt2, but represent the minority as triangles */
	  pie1: 5, /* pie charts with grayscale background */
	  pie2: 6, /* pie charts varying size */
	  weaving1: 7, /* weaving with background color of majority class */
	  weaving2: 8, /* weaving that shows density */
	  texture: 9, /* using color and orientation for different classes */
	  attrblk: 10, /* using color and position to encode class identity */
	  bar: 11 /* using bar charts to show proportion of each class within a bin */
};

More usage example of binning.js can be seen in template/index.html.

Interaction

  1. Use default datasets to see how different types of vis look like.
  2. Upload your own datasets.
  3. Change vis type by using the dropdown list.
  4. Adjust the bin size by changing the value of the slider.
  5. PNG of the current vis will be generated under the current visualization after clicking "generate png" button. Clicking on the generated image allows you to save the image.

Notice

  1. Rendering more than 5000 points in scatterplot will cause extremely bad rendering performance. If you want to have quicker rendering speed, please choose other type of vis first so that you won't get stuck on rendering scatterplots.
  2. Rendering too many points might crash due to exceeding browser memory.

Credit

Our original test implementation from Alper's block