geo-agent

geo-agent

Exposes live earth-science data (e.g., earthquakes from USGS) as tools for MCP-compatible AI agents, enabling them to fetch and reason about real-time geophysical events.

Category
Visit Server

README

geo-agent

Live earth-science data, in two shapes: a tool for AI agents, and an app for humans.

  • ๐Ÿ”— Live demo: https://kavyaagarwal-geo-agent.streamlit.app
  • ๐Ÿ”ง MCP server: exposes the same data as tools for any MCP compatible AI client (Claude Desktop, Cursor, etc.)
  • ๐Ÿ“ Writeup: https://kavya855084.substack.com/p/building-geo-agent-an-mcp-server

What this is

This project exposes earth-science data through two interfaces, because they solve different problems.

  • The Streamlit app is for humans. Open it, click around, look at charts, maps, and search results.
  • The MCP server is for agents. It lets an AI assistant decide, on its own, to pull live data or search reference material as one step while reasoning about something else entirely.

Three data sources, both interfaces: live earthquakes (USGS), live climate data (NASA POWER), and semantic search over real climate science reports (IPCC AR6, SR15).

Components

1. MCP server (server.py)

Exposes earth-science data as tools any MCP client can call.

Tools:

  • get_recent_earthquakes(min_magnitude, days): recent significant earthquakes worldwide, via USGS. Read-only, annotated.
  • get_climate_point_data(latitude, longitude, days): recent daily temperature, precipitation, and solar radiation for any location, via NASA POWER. Read-only, annotated. Handles NASA's processing-lag fill values gracefully instead of printing raw placeholder data.
  • search_climate_papers(query, n_results): semantic search over real climate science reports, see Component 3 below.
uv sync
uv run mcp dev server.py

Opens the MCP Inspector in your browser for testing tools directly.

2. Live web app (app.py)

Three tabs, same underlying data sources, built for human exploration:

  • Earthquakes: live filtering by magnitude and time window, a magnitude reference guide, an interactive map, and a raw data table.
  • Climate: pick a location (presets or custom coordinates), see temperature, precipitation, and solar radiation as time series, plus a location map.
  • Paper Search: ask a question, get back cited passages from real climate science reports, the same retrieval pipeline as the MCP tool.
uv run streamlit run app.py

3. Climate paper search

A local retrieval-augmented search system over real climate science reports (IPCC AR6 Synthesis Report, SR15), available both as an MCP tool and as a tab in the web app, so the same retrieval logic is usable by an agent or a person.

Pipeline:

  1. Ingestion (ingest.py, run once): PDFs in papers/ are read page by page with pypdf, split into ~800-character chunks with 100-character overlap so meaning isn't lost at chunk boundaries, and embedded with sentence-transformers (all-MiniLM-L6-v2, runs locally, no API key or cost).
  2. Storage: chunks, their embeddings, and metadata (source filename, page number) are persisted to a local Chroma vector database, just a folder on disk, no server process to run.
  3. Retrieval: a query is embedded with the same model, and Chroma returns the chunks whose embeddings are nearest to it by semantic similarity, not keyword overlap. Every result carries its source and page, so answers are traceable to a real document instead of generated from training data alone.

Two interfaces, same pipeline:

  • search_climate_papers(query, n_results), an MCP tool, callable autonomously by an agent
  • The Paper Search tab in the web app, the same retrieval logic, for direct human use, with a visible note confirming results come from local search, not the internet
uv run python ingest.py
uv run pytest tests/test_retrieval.py -v

Validation: tests/test_retrieval.py checks that 5 real climate questions each return a relevant passage in their top 3 results. This is a lightweight check (keyword presence in top-k), not a full IR evaluation; a more rigorous version would use precision@k, MRR, or a framework like Ragas.

Known limitations, documented honestly rather than hidden:

  • The corpus is small and curated (2 reports), not comprehensive literature coverage.
  • Overlapping chunks can produce near-duplicate results from the same page; results are not currently deduplicated by source/page.
  • PDF text extraction is occasionally noisy (e.g. figure captions interleaved with body text), a known limitation of plain-text PDF extraction, not something this project works around.

Tech stack

Python, MCP SDK, Streamlit, Plotly, httpx, Chroma, sentence-transformers, pytest, uv

Status

See commit history for progress. Connected to Claude Desktop and confirmed it correctly chooses between live-data tools and paper search depending on the question, and correctly recognizes when a question needs more than these three tools can offer. Next: a router agent that makes that same tool-selection decision explicitly, in code, instead of relying on the client's built-in reasoning.

Author

Kavya Agarwal. Website ยท LinkedIn

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured