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.
4x improvement on geospatial tasks with map in the loop.
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 the free tier SaaS.
Run Dekart locally:
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.
- 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.
- 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). - 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.
- Geometry validation. The agent computes total area (polygons) or total length (lines) as a sanity check, and cross-checks against domain knowledge.
- 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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file geosql-0.18.0.tar.gz.
File metadata
- Download URL: geosql-0.18.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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
27d52b206557d7e08ee2ba3427975d0c7ce3e4f92fb39aea2a742b09a201e7c1
|
|
| MD5 |
c333115e6f8ed9682215dd6785ca5d3a
|
|
| BLAKE2b-256 |
bd3d58778714671cfc56720f75c1e69a61f9bd11580a49c66a125fc1958e9af5
|
File details
Details for the file geosql-0.18.0-py3-none-any.whl.
File metadata
- Download URL: geosql-0.18.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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ee9000cbd4ae8106635f2486cb2de1e053b28cfec0964f294605d0645baeea16
|
|
| MD5 |
7c334ffe12593e83880c061e5f620584
|
|
| BLAKE2b-256 |
28eb74c427cd0691e4e3844dca295faa9d0a8c038136a884edd85b77603cd8ce
|