Skip to main content

EDA tool for spatio-temporal data

Project description

GeoViz

GeoViz is an Exploratory Data Analysis tool designed to empower data analysts to visualize and interpret spatio-temporal data. It offers a user-friendly, interactive web interface built on Panel, ensuring simplicity and maximal explainability. The software provides visualizations, including 3D geographical coordinates, seasonality analysis, heatmap displays, and categorization/clustering using Natural Language Processing (NLP). With a focus on simplicity and shareability, GeoViz enhances data analysis for a broader audience.

The documentation can be found at our readthedocs page.

Example Usage

First, install GeoViz:

pip install rrcgeoviz

Once done, run the following command to create an config file through a GUI:

rrcgeoviz --init

The config file is JSON that specifies the data to be looked at and visualized. Here's a sample one:

{
    "columns": {
        "latitude_column": "latitude",
        "longitude_column": "longitude",
        "time_column": "date",
        "description_column": "description"
    },
    "features": [
        "search_columns",
        "month_year_heatmap",
        "test_option_name",
        "yearly_range",
        "one_year",
        "all_months",
        "one_year_months",
        "threeD",
        "poi_analysis",
        "nlp_bertopics"
    ],
    "caching": {
        "cache_results": false,
        "use_cache": false
    }
}

To create an options.json file you can use something like what is shown above or run

rrcgeoviz --init

Finally, run GeoViz with the following command:

rrcgeoviz path/to/dataset.csv path/to/options.json

A tab should open in your browser with all of the enabled features!

Brief overview of how it works (for contributers)

image

When running from the command line, the main() function in src/rrcgeoviz/geoviz_cli.py runs. The options and dataset are stored in an Arguments object.

The Arguments object is first passed to the GeneratedData class. The GeneratedData class checks whether to pull data from the cache or not. If it needs new data, then it calls any relevant classes in the DATA_GENERATORS array to make it available. The data is then passed back to the Arguments object as the generateddata attribute.

The Arguments object with the data, options, and generated data is passed to the GeoVizPanelDashboard class. Here, the data is checked (i.e. it is not null, it's in the correct range, etc.) and then the relevant classes in the ALL_FEATURE_CLASSES array are called to create the features for GeoViz. These don't make any data, just render what's there into pretty visualizations.

Here's a general flow of how to add new components:

  • Data Generator: If new data is required (e.g. distance to nearest POI) create a new subclass of the ParentGeneratorClass in src/rrcgeoviz/datagenerators. Look at GeneratorExample for reference. Once it's made, add it to the DATA_GENERATORS array at the top of the src/rrcgeoviz/GeneratedData file.

  • Visualizer: Create the panel component as a subclass of ParentGeovizFeatures in src/rrcgeoviz/features. Look at other features in the directory for a sense of what they look like. Add the new feature to the ALL_FEATURE_CLASSES array at the top of the GeoVizPanelDashboard file.

That's pretty much it!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

rrcgeoviz-0.1.5.tar.gz (44.8 kB view details)

Uploaded Source

Built Distribution

rrcgeoviz-0.1.5-py3-none-any.whl (55.2 kB view details)

Uploaded Python 3

File details

Details for the file rrcgeoviz-0.1.5.tar.gz.

File metadata

  • Download URL: rrcgeoviz-0.1.5.tar.gz
  • Upload date:
  • Size: 44.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.19

File hashes

Hashes for rrcgeoviz-0.1.5.tar.gz
Algorithm Hash digest
SHA256 07ee02ed8ad035fbbab1e206856299eedf2efdcb6f0281a9c512473c06e4abf0
MD5 7d0dc83010919709b1dcd542a8d72199
BLAKE2b-256 b6873db62e2610df613e68efbb51c5ff110692eba1e0cdb5f8ab21f934daf067

See more details on using hashes here.

File details

Details for the file rrcgeoviz-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: rrcgeoviz-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 55.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.19

File hashes

Hashes for rrcgeoviz-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 7fb32434a5c2507e66778dfcc81076aa2098e30d0feb2381b23da5ca78629cd7
MD5 d8d9f8d3e7a659620d64b7a91588efdc
BLAKE2b-256 59b64c1fdc969283b4774fd41e24bbc65474ac3e8780f0eb48c31ca5b7da27e1

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page