Skip to main content

Install GeoSQL instructions into local AI CLIs.

Project description

GeoSQL

Claude/Codex skill for data scientists and analysts working with geospatial data on PostGIS, BigQuery, Snowflake, and Wherobots.

Note: No SaaS account needed. Works 100% locally or self-hosted.

GeoSQL demo

4x improvement on geospatial tasks with map in the loop.

Agent with maps loop, 4x performance

Quick Start

With Python (interactive mode):

pip install geosql && geosql

Or in Claude Code:

/plugin marketplace add dekart-xyz/geosql
/plugin install geosql

Install Dekart for map rendering and PostGIS support

GeoSQL optionally uses Dekart: an open-source Kepler.gl backend with connectors for PostGIS, BigQuery, and Snowflake. You can run Dekart locally with one docker command, self-host it on your own infrastructure, or use Dekart Cloud.

Run Dekart locally (skip this step to use Dekart Cloud):

docker run -p 8080:8080 dekartxyz/dekart

Install the Dekart CLI:

pip install dekart && dekart init

Follow CLI and dekart prompts to connect your PostGIS, BigQuery, Snowflake or Wherobots database.

Example prompts to try in Claude Code:

Real estate analysis:

/geosql Show buildings with low school accessibility in Ottawa, render as a map

Site selection:

/geosql Find the top 10 locations for Sporting Goods Store in Seattle based on POI co-location and distance to the nearest competitor. Create a map.

EV charging infrastructure:

/geosql create map EV charger density along major Romanian roads, highlighting how many charging stations are within 5 km of each motorway, trunk, or primary road segment.

How it works

GeoSQL runs an agent loop with a map in it.

  1. Discovery. The skill explores your warehouse metadata (tables, columns, types) instead of guessing schemas. Works with Overture Maps shares on BigQuery and Snowflake, and your private tables on PostGIS, BigQuery, Snowflake, or Wherobots.
  2. SQL. The agent writes spatial SQL using the right functions for your engine (ST_INTERSECTS, ST_DISTANCE, H3, bbox overlap for partition pruning, and so on).
  3. Cost check. On BigQuery, every query is dry-run first to estimate bytes scanned. A 10 GiB billing cap is enforced by default. Over-budget queries get rewritten cheaper (tighter bbox, lower H3 resolution, more filters) instead of executed.
  4. Geometry validation. The agent computes total area (polygons) or total length (lines) as a sanity check, and cross-checks against domain knowledge.
  5. Map feedback. When available, the agent renders the result through Dekart, looks at the rendered image, and corrects geometry mistakes the text-only loop would miss. This is the loop that gets the 4x improvement.

The skill uses your local CLI authentication (bq, snow, dekart), so warehouse credentials never go to the agent.

Benchmarks

GeoSQL ships with a reproducible eval suite under evals/. Each case asserts specific behaviors (cost guardrails, validation steps, correct result), not just "did the agent answer."

Current results on the included suite:

Case Assertions Pass rate
london-boroughs 4 100%
berlin-create-map 3 100%
paris-boundaries 1 100%
Total 8 100%

Average: 3,085 tokens per turn, 72 s duration per turn.

The 4x improvement chart above compares the same task set with and without the map-in-loop step. Without maps, the agent's text-only validation misses geometry-class errors (mistaking a neighborhood polygon for a metro-area perimeter, double-counting overlapping features, picking the wrong join key on coordinate-reference systems). Adding the rendered map as a tool call lets the agent see those mistakes and self-correct.

Run the suite yourself:

python evals/run.py

See evals/RUNBOOK.md for setup and how to add new cases. PRs with new evals welcome.

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

geosql-0.20.0.tar.gz (7.1 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

geosql-0.20.0-py3-none-any.whl (19.5 kB view details)

Uploaded Python 3

File details

Details for the file geosql-0.20.0.tar.gz.

File metadata

  • Download URL: geosql-0.20.0.tar.gz
  • Upload date:
  • Size: 7.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for geosql-0.20.0.tar.gz
Algorithm Hash digest
SHA256 a79e0617260ce2903ad8dbe0f9dcc4f26d3a2f4c799a865f68b0ba1bac28fcfa
MD5 05dbb2dd23291bcdf7f4b69f5b0900d8
BLAKE2b-256 0e9413d7d730bc381e7f10c600fb305417d555231afc9af8f1733a82f8e0eb0b

See more details on using hashes here.

File details

Details for the file geosql-0.20.0-py3-none-any.whl.

File metadata

  • Download URL: geosql-0.20.0-py3-none-any.whl
  • Upload date:
  • Size: 19.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for geosql-0.20.0-py3-none-any.whl
Algorithm Hash digest
SHA256 855149ab790fe8b2643a42c48b6b4e7a106fa01e0f328cde10623e5a7cb64697
MD5 4542bc43386f11d9f9186b870cd7cd0b
BLAKE2b-256 9789e113735d6f89bf3d475a082adc2ce24048202403299b216f4330d7cb9026

See more details on using hashes here.

Supported by

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