Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vega/falcon
Brushing and linking for big data
https://github.com/vega/falcon
scalable-visualization
Last synced: 2 days ago
JSON representation
Brushing and linking for big data
- Host: GitHub
- URL: https://github.com/vega/falcon
- Owner: vega
- License: other
- Created: 2016-10-04T22:14:26.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2025-01-09T00:42:24.000Z (11 days ago)
- Last Synced: 2025-01-09T01:45:07.240Z (10 days ago)
- Topics: scalable-visualization
- Language: Jupyter Notebook
- Homepage: https://vega.github.io/falcon/flights
- Size: 181 MB
- Stars: 952
- Watchers: 25
- Forks: 52
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Citation: CITATION.cff
Awesome Lists containing this project
- awesome-starred - vega/falcon - Brushing and linking for big data (others)
README
# Falcon: Interactive Visual Analysis for Big Data
[![npm version](https://img.shields.io/npm/v/falcon-vis.svg)](https://www.npmjs.com/package/falcon-vis) ![Tests](https://github.com/vega/falcon/workflows/Node.js%20CI/badge.svg) [![code style: prettier](https://img.shields.io/badge/code_style-prettier-ff69b4.svg?style=rounded)](https://github.com/prettier/prettier)
Crossfilter millions of records without latencies. This project is work in progress and not documented yet. Please get in touch if you have questions.
The largest experiments we have done so far is 10M flights in the browser, 33M flights in the browser with [DuckDB](https://github.com/duckdb/duckdb-wasm), and ~180M flights or [~1.7B stars](#falcon-with-17-billion-stars-from-the-gaia-dataset) when connected to [OmniSciDB](https://www.omnisci.com/platform/core/) (formerly known as MapD).
We have written [a paper](https://osf.io/szpqm/) about the research behind Falcon. Please cite us if you use Falcon in a publication.
```bib
@inproceedings{moritz2019falcon,
doi = {10.1145/3290605},
year = {2019},
publisher = {{ACM} Press},
author = {Dominik Moritz and Bill Howe and Jeffrey Heer},
title = {Falcon: Balancing Interactive Latency and Resolution Sensitivity for Scalable Linked Visualizations},
booktitle = {Proceedings of the 2019 {CHI} Conference on Human Factors in Computing Systems - {CHI} {\textquotesingle}19}
}
```## Demos
- 1M flights in the browser: https://vega.github.io/falcon/flights/
- 10M flights in the browser with [DuckDB-WASM](https://github.com/duckdb/duckdb-wasm): https://vega.github.io/falcon/flights-duckdb/
- 7M flights in [OmniSci Core](https://www.omnisci.com/platform/core/): https://vega.github.io/falcon/flights-mapd/
- 500k weather records: https://vega.github.io/falcon/weather/![Falcon demo](images/cross.gif "Falcon demo")
## Usage
Install with `yarn add falcon-vis`. You can use two query engines. First `ArrowDB` reading data from [Apache Arrow](https://arrow.apache.org/). This engine works completely in the browser and scales up to ten million rows. Second, `MapDDB`, which connects to OmniSci Core. The indexes are created as [ndarrays](https://github.com/scijs/ndarray). Check out the examples to see how to set up an app with your own data. More documentation will follow.
## Features
### Zoom
You can zoom histograms. Falcon automatically re-bins the data.
### Show and hide unfiltered data
The original counts without filters, can be displayed behind the filtered counts to provide context. Hiding the unfiltered data shows the relative distribution of the data.
With unfiltered data.
Without unfiltered data.
### Circles or Color Heatmap
Heatmap with circles (default). Can show the data without filters.
Heatmap with colored cells.
### Vertical bar, horizontal bar, or text for counts
Horizontal bar.
Vertical bar.
Text only.
### Timeline visualization
You can visualize the timeline of brush interactions in Falcon.
## Falcon with 1.7 Billion Stars from the GAIA Dataset
The [GAIA spacecraft]() measured the positions and distances of stars with unprecedented precision. It collected about 1.7 billion objects, mainly stars, but also planets, comets, asteroids and quasars among others. Below, we show the dataset loaded in Falcon (with OmniSci Core). There is also a [video of me interacting with the dataset through Falcon](images/gaia.mp4).
## Developers
Install the dependencies with `yarn`. Then run `yarn start` to start the flight demo with in memory data. Have a look at the other `script` commands in [`package.json`](https://github.com/vega/falcon/blob/master/package.json).
## Experiments
First version that turned out to be too complicated is at https://github.com/vega/falcon/tree/complex and the client-server version is at https://github.com/vega/falcon/tree/client-server.