Skip to main content

Physical Layer Linter — validates RF and physics calculations against hard physical limits

Project description

PhysBound

PhysBound

Physical Layer Linter — An MCP server that validates RF and physics calculations against hard physical limits. Catches AI hallucinations in engineering workflows.

CI codecov PyPI MCP Registry License: MIT Python 3.12+ Ko-fi


What LLMs Get Wrong

LLMs routinely hallucinate physics. PhysBound catches it:

# Category LLM Hallucination PhysBound Truth Verdict
1 Shannon-Hartley "20 MHz 802.11n at 15 dB SNR achieves 500 Mbps" Shannon limit: 100.6 Mbps CAUGHT
2 Shannon-Hartley "100 MHz 5G channel at 20 dB SNR delivers 2 Gbps" Shannon limit: 665.8 Mbps CAUGHT
3 Antenna Aperture "30 cm dish at 1 GHz provides 45 dBi gain" Aperture limit: 7.4 dBi CAUGHT
4 Thermal Noise "Noise floor of -180 dBm/Hz at room temperature" Actual: -174.0 dBm/Hz at 290K CAUGHT
5 Link Budget "Wi-Fi at 2.4 GHz reaches 10 km at -40 dBm" Actual RX power: -94.1 dBm CAUGHT
6 Link Budget "1W to GEO with 0 dBi antennas at -80 dBm" Actual RX power: -175.1 dBm CAUGHT
7 Link Budget "Bluetooth reaches 1 km at -60 dBm" Actual RX power: -100.1 dBm CAUGHT
8 Shannon-Hartley "10 MHz LTE at 10 dB SNR supports 1 Gbps" Shannon limit: 34.6 Mbps CAUGHT
9 Noise Cascade "Stage order doesn't affect system NF" LNA first: 1.66 dB vs mixer first: 8.03 dB CAUGHT
10 Antenna Aperture "10 cm patch at 900 MHz provides 20 dBi" Aperture limit: -3.1 dBi CAUGHT
11 Radar Range "Doubling TX power doubles radar range" Range increases by 1.189x (2^(1/4)), not 2x CAUGHT
12 Radar Range "Drone (0.01 m^2 RCS) at 200 km by 1 kW X-band" Max range: 2.7 km CAUGHT

Generated automatically by pytest tests/test_marketing.py -s


Quick Start

Install

pip install physbound

MCP Client Configuration

Add PhysBound to any MCP-compatible client. For example, in Claude Desktop (claude_desktop_config.json), Cursor, or Windsurf:

{
  "mcpServers": {
    "physbound": {
      "command": "uvx",
      "args": ["physbound"]
    }
  }
}

First run: uvx downloads ~60 MB of dependencies (scipy, numpy) on first launch. Run uvx physbound once in your terminal to pre-cache them — subsequent starts will be instant.

Your AI assistant now has access to physics-validated RF calculations.


Tools

rf_link_budget

Computes a full RF link budget using the Friis transmission equation. Validates antenna gains against aperture limits.

Example: "What's the received power for a 2.4 GHz link at 100 m with 20 dBm TX, 10 dBi TX gain, 3 dBi RX gain?"

Returns: FSPL, received power, wavelength, and optional aperture limit checks. Rejects antenna gains that violate G_max = eta * (pi * D / lambda)^2.

shannon_hartley

Computes Shannon-Hartley channel capacity C = B * log2(1 + SNR) and validates throughput claims.

Example: "Can a 20 MHz channel with 15 dB SNR support 500 Mbps?"

Returns: Theoretical capacity, spectral efficiency, and whether the claim is physically possible. Flags violations with the exact percentage by which the claim exceeds the Shannon limit.

noise_floor

Computes thermal noise power N = k_B * T * B, cascades noise figures through multi-stage receivers using the Friis noise formula, and calculates receiver sensitivity.

Example: "What's the noise floor for a 1 MHz receiver at 290K with a two-stage LNA chain?"

Returns: Thermal noise in dBm and watts, cascaded noise figure, system noise temperature, and receiver sensitivity.

radar_range

Computes the monostatic radar range equation R_max = [P_t G^2 lambda^2 sigma / ((4pi)^3 S_min L)]^(1/4) and validates detection range claims.

Example: "Can a 1 kW X-band radar with 30 dBi gain detect a 0.01 m^2 drone at 200 km?"

Returns: Maximum detection range, minimum detectable signal, wavelength, and intermediate values. Catches the common fourth-root fallacy where doubling power is incorrectly assumed to double range.


Physics Guarantees

Every calculation is validated against hard physical limits:

  • Speed of light: c = 299,792,458 m/s — no exceptions
  • Thermal noise floor: N = -174 dBm/Hz at 290K — the IEEE standard reference
  • Shannon limit: C = B * log2(1 + SNR) — no throughput claim exceeds this
  • Aperture limit: G_max = eta * (pi * D / lambda)^2 — antenna gain is bounded by physics
  • Radar range equation: R_max = [P_t G^2 lambda^2 sigma / ((4pi)^3 S_min)]^(1/4) — range obeys the fourth-root law

Violations return structured PhysicalViolationError responses with LaTeX explanations, not silent failures.


Examples

See PhysBound catching hallucinations in real time:


Development

# Clone and install
git clone https://github.com/JonesRobM/physbound.git
cd physbound
uv sync --all-extras

# Run tests
uv run pytest tests/ -v

# Print hallucination delta table
uv run pytest tests/test_marketing.py -s

# Start MCP server locally
uv run physbound

Why PhysBound?

AI coding assistants are increasingly used in RF engineering, telecommunications, and signal processing workflows. But LLMs have no intrinsic understanding of physics — they generate plausible-sounding numbers that can violate fundamental laws like Shannon-Hartley, thermodynamic noise limits, and antenna aperture bounds.

PhysBound acts as a physics guardrail for any MCP-compatible AI assistant. Every calculation is checked against CODATA physical constants via SciPy, with dimensional analysis enforced through Pint. Violations return structured errors with LaTeX explanations — not silent failures.

Use cases

  • RF system design review — validate link budgets, receiver sensitivity, and noise cascades
  • Telecom proposal vetting — catch impossible throughput claims before they reach a customer
  • Educational tools — teach Shannon-Hartley, Friis transmission, and thermal noise with verified calculations
  • CI/CD for physics — integrate as a validation step in engineering pipelines

Support

If PhysBound is useful in your work, consider buying me a coffee.

License

MIT License. See LICENSE.

Related

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

physbound-0.2.0.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

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

physbound-0.2.0-py3-none-any.whl (25.3 kB view details)

Uploaded Python 3

File details

Details for the file physbound-0.2.0.tar.gz.

File metadata

  • Download URL: physbound-0.2.0.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.6 {"installer":{"name":"uv","version":"0.10.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for physbound-0.2.0.tar.gz
Algorithm Hash digest
SHA256 304e6499e3d4276fc116b75a1ff87f812db53e86f94a678deffaa0c0be4af962
MD5 990d96c00ceabaf7d80c5dabb317ba19
BLAKE2b-256 32e2e24c9a896eaf1b3c893ccc64a5097a07f485e3831233119542970562d4f3

See more details on using hashes here.

File details

Details for the file physbound-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: physbound-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 25.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.6 {"installer":{"name":"uv","version":"0.10.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for physbound-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 13c55db3c88785aa19538e5501cdf5b7ebf1a23ce6f3eb2804215ee346097b17
MD5 b10347dc5d2095abbc226ef039e3c902
BLAKE2b-256 7720e51559dded3cb26b57eed9f6858c009ec5803b8e5a7f8ade6b1f07d8825b

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