惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

宝玉的分享
宝玉的分享
WordPress大学
WordPress大学
博客园 - 司徒正美
美团技术团队
酷 壳 – CoolShell
酷 壳 – CoolShell
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
小众软件
小众软件
量子位
阮一峰的网络日志
阮一峰的网络日志
Apple Machine Learning Research
Apple Machine Learning Research
有赞技术团队
有赞技术团队
博客园 - 【当耐特】
博客园 - Franky
Jina AI
Jina AI
人人都是产品经理
人人都是产品经理
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
T
Threat Research - Cisco Blogs
D
Darknet – Hacking Tools, Hacker News & Cyber Security
F
Fox-IT International blog
T
ThreatConnect
A
Arctic Wolf
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
Last Week in AI
Last Week in AI
C
CERT Recently Published Vulnerability Notes
P
Palo Alto Networks Blog
李成银的技术随笔
Project Zero
Project Zero
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
The Register - Security
The Register - Security
F
Full Disclosure
H
Hacker News: Front Page
雷峰网
雷峰网
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
S
SegmentFault 最新的问题
S
Schneier on Security
T
Tor Project blog
博客园_首页
月光博客
月光博客
大猫的无限游戏
大猫的无限游戏
博客园 - 聂微东
S
Securelist
C
Comments on: Blog
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
Attack and Defense Labs
Attack and Defense Labs
IT之家
IT之家
博客园 - 叶小钗
J
Java Code Geeks
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events

DEV Community

Open Source Project (No.73): Sub2API - All-in-One Claude/OpenAI/Gemini Subscription-to-API Relay I Made the Wrong Bet on Event Streaming in Our Treasure Hunt Engine #ai #productivity #chatgpt #python Symbolic Constant Conundrum From Manual RAG to Real Retrieval — Embedding-Based RAG with NVIDIA NIM Building an outbound-only WebSocket bridge for local AI agents Our System's Sins in Ghana: Why We Had to Rethink Digital Product Sales Execution Governance, AI Drift, and the Security Paradox of Runtime Enforcement Small AI database questions can become big scans Claude Code 2.1 Agent View & /goal: Autonomous Dev Guide 2026 Your AI database agent should not see every column Rust's Low-Latency Conquest: Why We Ditched C++ for a Treasure Hunt Engine Floating-point will quietly corrupt your emissions math, and 0.1 + 0.2 already warned you Autonomous Agents: what breaks first (and why that's the real product) [2026-05-23] Agent payments are the new cloud bill footgun ORA-00069 오류 원인과 해결 방법 완벽 가이드 How I Built a Local, Multimodal Gemma 4 Visual Regression & Patch Agent: Closed-Loop Validation, Canvas Pixel Diffing, and Reproducible Benchmarks Pressure-testing Ota on Supabase: from setup prose to executable repo readiness VPC CNI en EKS: cómo dejar de pagar nodos que no usás The Future of Text Analysis: Introducing TechnoHelps Semantic Engine I built a Chrome Extension that saves product images + context directly to Google Drive & Sheets 95+ browser-based dev tools that never touch a server Running Qwen 2.5 Coder 14B Locally in Cursor with Ollama From a 10,000-line OpenSearch export script to a log analysis tool Ghost Bugs Cost $40K: A Neural Debugging Postmortem SECPAC: A Lightweight CLI Tool to Password-Protect Your Environment Variables 🚀 PasteCheck v1.7 + v1.8 — Hints that tell you what to fix, and a nudge panel that tells you where to start 8 Real Ways Developers Make Money in 2026 (Ranked by Effort) I built a free AI-powered Git CLI that writes your commit messages for you sds-converter: Converting Safety Data Sheets to MHLW Standard JSON with Rust and LLMs OpenLiDARViewer: A Browser-Based LiDAR and Point-Cloud Viewer Local-First Browser Tools: What You Should Not Upload Online Why most freelancers undercharge (and the maths behind fixing it) We built a mahjong dangerous-tile predictor calibrated on 4.97M real hands Building a Chord Progression Generator in the Browser — Music Theory in JS, Sound via Web Audio API tutorial #10: 148 Opens, 0 Replies — How My Forge Cold Email v1 Completely Failed 9 in 10 Docker Compose files skip the basic security flags How to Forward Android SMS to Telegram Automatically I built the first security scanner for MCP servers — here's what I found Building an Interplanetary Quantum Logic Engine in Rust/Ovie From AI Code Generation to AI System Investigation I gave Gemini 3.5 Flash a CVE-fix PR to review. It found another bug in the same file. When I Realized We Were Throwing Away Half Our Engine's Potential TokenJuice and the 20-Minute Cron: Inside OpenHuman’s Aggressive Context-Harvesting Engine CodeDNA: AI Codebase Archaeologist Built with Gemma 4 Thinking Mode Building a semantic search API in Go with Meilisearch April 2026 DigitalOcean Tutorials: Inference Optimization and AI Infrastructure Looking for DTMF transceiver module Moving Beyond "Tribal Software": Why the Singularity Demands the Interplanetary Hybrid Human Use SVGIcons as a Claude Custom Connector to Find Icons Faster DMARC Is Now a Proper Internet Standard: What Changed in RFC 9989/9990/9991 OpenTelemetry Is Now a CNCF Graduate — and It's Coming for Your AI Stack OpenHuman Follows OpenClaw’s Rise, But With an Obsidian Brain O erro mais caro em programas Solana: PDA sem bump check Build a Live Flight Radar in a Single HTML File DuckDB 1.5.3 Adds Quack Client-Server, SQLite Gets Cypher Graph Extension Custom Copilot Agents: Building Domain-Expert AI Teammates with Skills, MCP Tools, and Custom Knowledge RTX 5090 Cooling, BeeLlama VRAM Opts, Resizable BAR Performance Gains This week in Cursor + .NET — 3 rules + 4 essays (week ending May 22, 2026) RAG Architecture with n8n + PostgreSQL (pgvector) + Ollama Gemma4 on AWS EC2 Keep Your Taste I Built chanprobe Because My Go Queues Were Invisible Building a Live Solana TPS Meter with OrbitFlare's TypeScript SDK Using Gemma 4 to Analyze Bitcoin’s Next 5, 15, and 60 Minutes Security news weekly round-up - 22nd May 2026 When Stress Disguises Itself as Rational Planning (Bite-size Article) A Domain-Driven Notification Microservice — Patterns From Production I Built KubeCrash: Learn Kubernetes by Diagnosing Real Incidents The Real-World Test: How Gemini’s New Interface Won Over My Wife and Mother-in-Law (Who Are Totally Non-Tech) Running a Full Multi-Stage Intrusion Simulation. Every Detection Fired. Spec sheets aren't capabilities: a Day-1 Gemma 4 eval on Telugu vision Design a Clean Form with Floating Labels in Bootstrap 5 Your MCP Server Is Probably Overprivileged - Here's a Scanner For It I built a free developer tools site that works entirely in your browser Maatru: An agentic Telugu literacy app for kids, built with Gemma 4 GitHub confirms internal repository breach via poisoned VS Code extension Gemma 4 Is Not Just Another Open Model — It Changes What Developers Can Build Locally OpenVibe: An Open-Source AI Coding IDE That Works With Any Model I Inspected the System Program and It Looked Just Like My Wallet Hermes vs OpenClaw: The Two Most-Starred AI Agent Frameworks of 2026 Stop retraining YOLO: a developer’s guide to zero-shot object detection with generative VLMs AI, the New UI, Not the New API Sensors and Guides: Two Ways Your Harness Talks to Your Agent Fixing Google BigQuery Auth Proxying We didn't ship a feature, we shipped an agentic opt-in beta Wake-Up Call: Why AI Safety Guardrails Break Under Pressure 🧩 Handling 1,000+ Inputs with Angular Reactive Forms: An Enterprise Architecture Breakdown How to Collect Telegram Media Groups in Node.js I Ran Gemma 4 on an 8GB Laptop — Here’s What the Experience Was Actually Like Lean 4 101 for Python Programmers: A Gentle Introduction to Theorem Proving From Assistants to Agents: My Take on Google I/O 2026 Learning Progress Pt.16 From Unfinished Idea to Real Product: My BuildGenAI Comeback The Quiet Strategy I Revived a 9-Year-Old App with OpenAI Codex with a Product Engineer Mindset What Enterprise RAG Is Ready For Today and What Production Deployment Actually Requires Cursor AI Pricing 2026: Is It Worth $20/Month? The Brilliant Person in Your Pocket Why your Claude API bill is 3x what it should be (and how to fix it) Sloppification Is The New Obfuscation
Differential Pair Impedance: Why USB and HDMI Routing Is a Geometry Problem
NovaSolver · 2026-05-23 · via DEV Community

NovaSolver

Every fast interface on a modern board — USB, HDMI, PCIe, Ethernet, SATA — sends its data as a differential pair: two traces carrying equal and opposite signals. The receiver listens to the difference between them, which rejects noise beautifully. But it only works if the pair presents the right differential impedance to the signal. USB asks for 90 ohms, HDMI and most other high-speed standards for 100 ohms. Miss that target and the edges reflect, the eye diagram closes, and a link that looked fine in simulation fails on the bench.

The catch for newcomers is that differential impedance is not a property of one trace. It emerges from how two coupled traces sit in their geometry. This article explains where that number comes from and how to design for it.

Why this calculation matters

A differential pair is a transmission line, and a transmission line only passes a signal cleanly when its impedance matches the source and load. For a pair, the relevant quantity is the differential impedance Z_diff — the impedance the line presents to the difference signal.

Standards specify it tightly. USB 2.0 high-speed wants 90 ohms differential; HDMI, DisplayPort, PCIe, and SATA cluster around 100 ohms, typically held to plus or minus 10 to 15 percent. "Controlled impedance" means the fabricator builds the stack-up so the pair lands on target — and that only happens if the trace width and spacing were chosen against the real stack-up in the first place. Get it wrong and you are paying for a board respin.

The core method

Start with a single trace. On an outer layer, a trace over a ground plane is a microstrip, and on its own it has a single-ended characteristic impedance Z_0 set by the trace width w, the dielectric height h, and the dielectric constant er. A widely used closed form (Hammerstad) for w/h greater than 1 is:

e_eff = (er + 1)/2 + (er - 1)/2 * 1 / sqrt(1 + 12 h / w)

Z_0 = 120 pi / ( sqrt(e_eff) * [ w/h + 1.393 + 0.667 * ln(w/h + 1.444) ] )

Enter fullscreen mode Exit fullscreen mode

Z_0 falls as the trace gets wider and rises as the dielectric gets thicker. That single-trace number is the foundation.

Now bring a second identical trace alongside it. The two traces couple — each one's field reaches the other — and that splits the behaviour into two modes:

  • Odd mode: the traces driven oppositely, which is the real differential signal. Its impedance is Z_odd.
  • Even mode: the traces driven together, the common-mode case. Its impedance is Z_even.

The differential impedance is simply twice the odd-mode impedance:

Z_diff = 2 * Z_odd

Enter fullscreen mode Exit fullscreen mode

Here is the key effect of coupling: bringing the traces closer lowers Z_odd below the isolated Z_0. Tighter spacing means stronger coupling means lower differential impedance. Spacing is a design knob, not an afterthought.

A worked example

Take a microstrip pair on standard FR-4: er = 4.4, dielectric height h = 1.6 mm. First size a single trace, with width w = 3.0 mm:

w/h   = 1.875
e_eff = 2.70 + 1.70 * 1/sqrt(1 + 12 x 1.6/3.0) = 3.33
Z_0   = 120 pi / ( sqrt(3.33) x 4.07 ) = 50.8 ohms

Enter fullscreen mode Exit fullscreen mode

So one isolated trace is about 51 ohms. If the two traces of the pair were placed far apart — spacing several times the dielectric height — coupling would be negligible, Z_odd would stay close to Z_0, and:

Z_diff  ~  2 * Z_0  ~  102 ohms

Enter fullscreen mode Exit fullscreen mode

That is already close to the 100-ohm HDMI target. But pairs are rarely routed that loosely; they are kept close so they stay matched and reject noise together. As you tighten the spacing toward the dielectric height, coupling grows, Z_odd drops below 51 ohms, and Z_diff falls below 100 ohms. To pull it back up you narrow the traces. That trade — width down, or spacing up, to raise Z_diff — is the entire routing decision, and it depends on the exact dielectric height of the layer you are on.

Common mistakes

Designing impedance without the stack-up. The width and spacing that give 100 ohms depend on the dielectric thickness of the specific layer. Get the stack-up from the fabricator first, then size the pair. Doing it the other way around means a respin.

Treating spacing as cosmetic. Intra-pair spacing directly sets the coupling, and therefore Z_diff. It is a controlled dimension, not a routing convenience.

Trusting the nominal dielectric constant. FR-4's er is not a fixed 4.4 — it varies with the resin-to-glass ratio, with frequency, and between suppliers. For a tight tolerance, use the laminate datasheet value at your operating frequency.

Breaking the reference plane. The impedance model assumes a continuous ground plane under the pair. Route over a plane split or gap and the return current has nowhere to go; the local impedance jumps and the calculation no longer applies.

Ignoring intra-pair skew. If the two traces differ in length, the signal arrives skewed and some differential energy converts to common mode — radiated noise. Length-match the pair.

Try the interactive NovaSolver calculator

Sizing a pair by hand means juggling width, spacing, height, and dielectric constant at once — easy to get wrong, tedious to iterate. The differential pair impedance calculator on NovaSolver computes the single-ended Z_0, the differential Z_diff, and the odd- and even-mode impedances of a surface microstrip pair directly from trace width, spacing, substrate height, and dielectric constant — and shows them against the USB 90-ohm and HDMI 100-ohm targets as you adjust the geometry.

Related calculators

  • Coplanar waveguide — the grounded-coplanar variant, common when you need tighter field confinement.
  • Stripline — for buried inner-layer traces sandwiched between two planes.
  • Transmission line behaviour — to see how an impedance mismatch turns into reflections and standing waves.

Browse the full set in the RF and microwave tools hub.

Closing note

Differential pair impedance is a reminder that on a high-speed board, the geometry is the circuit. A 100-ohm pair is not a property of the copper — it is the combined result of trace width, spacing, dielectric height, and material, all working over a solid reference plane. Size the pair against the real stack-up, treat spacing as the controlled dimension it is, respect the dielectric tolerance, and keep the ground intact beneath the route. Do that and USB, HDMI, and PCIe links stop being a gamble and become ordinary, repeatable engineering.