Hairpin filter design

Électronique - 05-07-2020

Update (05/07/2020): added tests with JLCPCB manufactured filters

What is a hairpin filter?

Electronic filters are circuits which remove unwanted frequency components from the signal to enhance the signal-to-noise ratio. They are notably useful in the radio UHF range, to remove undesired transmissions and therefore improve the receiver's relative sensitivity.

An SDR (software design radio) such as the RTL-SDR with good filtering and an adequate antenna (and possibly external amplification), can pick up very low amplitude signals such as satellite transmissions.

Filters are usually made of discrete components (capacitors, inductors, etc.) in certain arrangements to form low-pass, high-pass, band-pass or band-cut. As frequency grows, this becomes increasingly unreliable. Microstrip filters are a higher-frequency alternative that uses the physical shapes and positions of transmission lines to affect their attenuation on specific frequency ranges.

There are several geometries used to construct distributed element filters, but all have the common property of causing a discontinuity on the transmission line. These discontinuities present a reactive impedance to a wavefront traveling down the line, and these reactances can be chosen by design to serve as approximations for lumped inductors, capacitors or resonators, as required by the filter.

My microstrip filter One of my 1090 MHz hairpin microstrip filters, made using this generator.

The hairpin topology uses parallel-coupled lines and behaves like a band-pass filter used to isolate the bandwidth's frequencies from parasitic signals. It takes up relatively low board space and it quite easy to build compared to other band-pass microstrip topologies such as the interdigital filter.

There are a lot of papers describing the mathematical models of microstrip filters. However, it is quite hard to extract a recipe and it will often result in poor performance. Hence, I created this Javascript tool to generate them using a sensible experimental model.

Update (26/05/2020): The generator can now directly generate a Kicad footprint (kicad_mod file).

The microstrip hairpin filter generator

Enter your desired elements length in the following form to generate an SVG or Kicad file. Use the form under to compute the element length for any given frequency.

Preview:

This hairpin must be printed on one side of a standard double sided 1.6 mm thick PCB. The back side must stay copper coated and be connect to the ground. Remove the solder mask on top of the filter.

On the SVG file, the horizontal line at the bottom of the page is 150 mm, to check scaling after printing/importing.

The generated topologies are designed to be used with standard female 50Ω SMA board-edge connectors. Solder the connector center signal pins to the hairpin feeder tracks and the ground pins to the bottom side.

This tool is under MIT license.


Technical details

Video

This video shows the project:


Simulation/Model

I made an openEMS model of my hairpin filter. Thank to finite difference time domain analysis (FDTD), this model can be used to determine the S-parameters S11/S22 (reflected power) and S21/S12 (transferred power) for different element's length. Note that the return loss and transmitted power in either direction should be identical because the construction is completely symmetrical.

This animation shows the wave propagation with a Gaussian excitation function, simulated with this model (viewed in Paraview):


Running this code with Octave/Matlab is a better way to design a hairpin filter than my calculator but it takes tens of minutes per simulation, depending on the frequency range, mesh size and of course computing resources.

Download the code on my GitHub repository: https://github.com/CGrassin/hairpin_filter

Geometry

The following figure shows the structure of the hairpin filter:

A 3 hairpin filter physical structure.

The dimensions I used are given is the following table.

Dimension 3 Hairpin
D1 0.25 mm (10 mil)
D2 2 mm (80 mil)
D3 2 mm (80 mil)
Width 2.54 mm (100 mil)
Length See formula below

The length is computed on a formula I determined with experimental data using a quadratic regression curve fitting:

\text{Length [mil]} = 4554 - 4.23 \times f_{center} + 1.17 \times 10^ {-3} \times f_{center} ^{2}

This gives good results up to about 1.5 GHz - more about this below.

Homemade PCB fabrication

To make my test hairpin filters, I used my quick prototyping method (click here to go to the article).

Photo of the masked hairpin PCB The masked copper board, ready for etching with ferric chloride, and the completed board with the SMA ports soldered

This method is not well suited to achieve the precision that is required for the UHF range. Better PCB quality will result in less losses, improved consistency and a sharper frequency response.

Professional PCB manufacturing

I also manufactured hairpins filters with the JLCPCB service. I fitted two different filters per board on the standard 10 cm×10 cm offer.

Microstrips filters manufactured by JLCPCB

At the time of ordering, JLCPCB's material (FR-4 Standard Tg 130-140/ Tg 155) is specified with a diaelectric constant equal to 4.5. The solder mask's is 3.8.

To measure the transfer function of those filters, I use my DIY scalar network analyzer. I built it with an ADF4351 synthesizer, two RTL-SDR receivers and a VSWR bridge. It is controlled by a Python script. Link to the project: https://github.com/CGrassin/rf_network_analyzer

With this system, I can measure the magnitude of S21, the power transmission and S11, the reflected power.

This plot shows the measurements performed on 3 identical filters:

S11 and S21 graphs from filter #1

There are several interesting pieces of information to note here:

  • The bandwidth is about 50 MHz,
  • The lower cutoff is quite sharp, while the upper cutoff is quite a bit more round.
  • The repeatability is very good, even with this non-RF controlled FR4 material.

It also shows that the bandwidth's attenuation is quite high (about -4/-5 dB). However, this is easily solved with a simple 10 dB LNA (low noise amplifier) added before or after the filter. Alternatively, the internal LNA in RTL-SDR's tuners should be able to deal with this, with a low NF (noise floor).

Four (or more) hairpins filters get a flatter bandwidth at the cost of more losses.

I also ran another set of measurement on the other, shorter geometry (higher frequency band, note the range of the x-axis):

S11 and S21 graphs from filter #2

As expected, the center frequency is higher: about 1160 MHz vs 1050 MHz. The average loss in the bandwidth is about the same. However, it is less linear, which might be undesirable. The roll-off (in decibels per decade) is comparable to the first geometry.

Note: Solder mask should be removed on top of the filter. It may interact with the EM field. I forgot to do it in this case.

EMI mapping scan

I used my DIY EMI mapping method on one of my hairpin filters: see article here. This is the result, with an H-field loop probe:

EMI map from an homemade hairpin filter EMI near-field scan of Hairpin RF filter. A signal fully out of filter bandwidth is fed from the bottom SMA.

Fine tuning

The response of the filter depend of the diaelectric constant of the PCB material. To get a good estimation of your PCB's characteristic, the best way is to empirically determine your PCB coefficients by:

  • Manufacturing a filter using my calculator at your desired center frequency -20% (length=l1) and measure its true center frequency (f1),
  • Manufacturing a second filter at your desired center frequency +20% (length=l2) and measure its true center frequency (f2),
  • Compute your PCB material characteristic with the simple linear regression formula:

Length(f)={\frac{l_2-l_1}{f_2-f_1}}f+{\frac{f_2l_1-f_1l_2}{f_2-f_1}}

You can then use this function to compute the length.

Because the relation between length and center frequency is nearly linear as long as the values are close, this gives very good results.

Using good quality PCB, my generator alone should get your center frequency within the bandwidth.

Limits

The lower frequency limit to hairpin filters is simply due to their physical size: below 900 MHz, it gets quite big and therefore expensive in terms of board space. Of course, with some tuning, it is possible to get much lower than this but discrete components may be a better choice.

The upper frequency limit is a bit more tricky: as frequency grows, the PCB material losses also grow. Above around 1.5 GHz, with conventional FR4, they usually get out of control. Additionally, the filter's cutoff shape gets gradually rounder and rounder. These two effects combined defeat the purpose of a filter.

However, distributed elements filters like the microstrip hairpin are commonly used in test equipment and satellite television reception for frequencies well above 5 GHz. This is made possible thank to well controlled PCB material, high quality manufacturing processes and a lot of engineering!

The PCB inside a 20 GHz Agilent N9344C spectrum analyzer The PCB inside a 20 GHz Agilent N9344C spectrum analyzer, photo by Binarysequence on Wikipedia

Source code

The source-code for both the generator/calculator and the openEMS model is available on this GitHub repository: https://github.com/CGrassin/hairpin_filter

Sources

Auteur :


What is on your mind?

  • #1 Duncan

    Hey Charles, I appreciate all the material you have on here! Its very helpful. Im actually a systems engineer as well for Northrop Grumman. We just did a bunch of work for Thales on their Iridium satellites!

    on May 10 2019, 6:34

  • #2 Malik

    Hi Charles, its great work you done here.. I am a electronic engineer and always interested in low cost /DIY tools to do the basic emc measurement. I liked your post about EMI mapper as well. In this post you mentioned DIY scalar network analyser, I am interested in design your SNA ?

    on July 25 2020, 14:43

  • #3 Author Charles

    Hi Malik,
    I am currently editing a video on this project. I show a bit more how I do this kind of measurements. It is not the most elegant way, but I am pleased with the S-parameters plots I get.

    on July 29 2020, 10:14

  • #4 Eugene Fischer

    Hi, I am interested of purchasing the design software.
    What is the cost for the software and how will it be delivered?
    Thank you for your time and consideration.
    Best Regards,
    Eugene Fischer
    Clermont, Florida

    on November 17 2020, 5:13

  • #5 Author Charles

    Hi Eugene,
    Like most of my work, both the generator and the simulation model are open-source (MIT License). This means that can use, modify and redistribute it as you wish, and free of charge. The link to the GiHub repository is at the end of the article.
    I'll send you an email with additional info.

    on November 17 2020, 7:48

  • #6 ukins

    안녕하세요. 헤어핀 필터에 대해서 검색하다가 우연히 찰스씨가 올려주신 글 덕분에 헤어핀 필터에 대해서 알수 있었습니다.
    감사합니다.

    on April 1 2021, 7:17

  • #7 ukins

    Hello, I was searching for hairpin filters and I was able to learn about hairpin filters thanks to Charles' posting.
    Thank you.

    on April 1 2021, 7:18

  • #8 Jerry

    Hi, With the KiCad design I don't see any bottom layer copper specified. Is the back all copper and is it connected to the shield of the SMA Connectors?
    My application uses 75 ohm cable and antenna using F connectors. I see there is a facility in the matlab code to specify input impedance. Does that also apply to output impedance? Finally, any recommendation on a low cost LNA IC for 1090 MHz?

    on April 5 2021, 1:34

  • #9 Gerik

    is there a possibility to use this by doing any tweaks to be able to use it with 350MHz - 470MHz

    on May 4 2021, 15:28

  • #10 Gerik

    is there a possibility to use this by doing any tweaks to be able to use it with 350MHz - 470MHz

    on May 4 2021, 15:28

  • #11 Eddie

    Hi Charles,
    good to see the material you provided, but I ran the code in github , the s parameter plot is different from the one in the video, the return loss is greater than 1 in some frequency. How do you get the S11 like the one you have in the vedio ?

    on October 24 2022, 6:37

  Retour aux projets

Projets similaires