Friday, 27 March 2015

pcb design - Why do some PCBs have zig-zag tracks?




I've seen many boads with weird zig-zag shaped tracks just like the one below. Why are they designed like that?
enter image description here



Answer



It's to keep one track or set of tracks the same length as another.


The speed of light is magnificently high. But. The speed at which we use digital electronics these days is also incredibly high. (Ignoring the fact in copper signals go at about 2/3 the speed of light, rather than the full speed).


So, if you send a 1 on one trace that's 10cm, and a 1 on a trace that's 20cm, at GHz frequencies these one's will noticeably arrive after each other, rather than at the same time.


In parallel tracks that's called (timing/clock) Skewing and can cause data-words to be interpreted wrongly, seeing old zeroes or ones, or already seeing new ones on an old clock edge.


What is also possible is that they are differential pairs, although many of the signals in your picture don't seem to be at first sight. A differential pair at high speed, such as Ethernet or USB2.0 or later can be influenced greatly when one of the signal wires is only slightly shorter than the other, creating signal imbalances. In that case you meander the slightly shorter one a tiny bit, along the one that is the longest.


With differential pairs it's a bit more complicated, since a differential pair also needs to maintain some coupling to each other to maintain their characteristic impedance. All of that put together makes modern digital design quite a big box of artistry. (Added to it that high frequency signals sometimes do very silly things if you try to make them go through a PCB from one side to another and such, but that's a whole other, even more complicated subject).





Some keywords that might help prevent even more duplicates (hopefully): high-speed digital; meandering traces; high-frequency digital; serpentine traces; why should I zig-zag traces; differential pair wiggling; wiggling trace


No comments:

Post a Comment

arduino - Can I use TI's cc2541 BLE as micro controller to perform operations/ processing instead of ATmega328P AU to save cost?

I am using arduino pro mini (which contains Atmega328p AU ) along with cc2541(HM-10) to process and transfer data over BLE to smartphone. I...