Main Content

Analyze Nolen Matrix for the 2-D Beamforming Application

The Nolen matrix is a novel antenna feeding network composed of only couplers with dedicated coupling ratios and phase shifters. In this example a 2D beamforming array using planar Nolen matrix [1] designed at 2 GHz, is imported and analyzed. The proposed 3 ×3 Nolen matrix is saved in the gerber file and analyzed at 2 GHz with FR4 substrate. All simulation results are matched with the design theory[1] and the measured result.

Import the gerber file and create Nolen Matrix.

The imported 3x3 Nolen matrix planar array with three input ports and three output ports consists of three hybrid couplers and three phase shifters in a layouti, in order to achieve the equal magnitude and progressive phase shifts at output ports. For couplers, one with coupling ratio 2/3 is placed at the top of the layout, while the other two with coupling ratio 1/2 are at the bottom.Three transmission lines with 50-ohm characteristic impedance and electrical length of 90, 90 for symmetry and 125.83deg are used as phase delay lines that connect the adjacent couplers.

Import the gerber file using gerberRead, and convert it to pcbComponent

P = gerberRead("NolenMatrixShape.gtl","NolenMatrixShape.gbl");
S = P.StackUp;
S.Layer3  = dielectric("Name",'FR4',"EpsilonR",4.8,"LossTangent",0.0026,"Thickness",0.0016);
P.StackUp = S;

% Create pcbComponent
Nolen = pcbComponent(P);
L = Nolen.Layers;
substrate = L{3};
% Set Board thickness
Nolen.BoardThickness = substrate.Thickness;
Nolen.Layers = {L{2},L{3},L{4}};

feedloc = [[-0.101 0.03717095 1 3];...
    [-0.101 -0.0002651007 1 3];...
    [-0.101 -0.03752398 1 3];...
    [0.101 0.0371732 1 3];...
    [0.101 4.674166e-05 1 3];...
    [0.101 -0.03748122 1 3]];
Nolen.FeedLocations = feedloc;
Nolen.FeedDiameter = 0.00295/2;

Display PCB structure

figure;show(Nolen)

Figure contains an axes object. The axes object with title pcbComponent element, xlabel x (mm), ylabel y (mm) contains 23 objects of type patch, surface. These objects represent PEC, feed, FR4.

Comparison of simulated result with Measured result

Mesh the structure using manual meshing with MaxEdgeLength of lambda/18.

plotfrequency = 2*1e9;
lambda = 3e8/plotfrequency;
% Manual mesh
figure; mesh(Nolen,'MaxEdgeLength',lambda/18);

Figure contains an axes object and an object of type uicontrol. The axes object with title Metal-Dielectric, xlabel x (m), ylabel y (m) contains 8 objects of type patch, surface. These objects represent PEC, feed.

Compute current at design frequency 2Ghz

% Current at 2Ghz
figure; current(Nolen,2e9,scale="log10")

Figure contains an axes object. The axes object with title Current distribution (log10), xlabel x (m), ylabel y (m) contains 17 objects of type patch.

Measurement - Sparameters and Phase

The designed Nolen matrix planar array is fabricated using FR4 susbtrate. The scattering parameters of fabricated structure is measured using a Network Analyzer. The figure below shows the top view of the fabricated Nolen matrix

Measured sparameters at 2GHz

Load the .mat file with measured data.

SMeasured = load('SparamsMeasured.mat');
SparamsM = SMeasured.SparamsMeasured;

Compute simulated sparameters at 2GHz

The sparameters are analyzed with the frequency sweep of 1-3 Ghz, the insertion loss at output ports w.r.t the input port1, 2 and 3 is analyzed.

frequencyRange = (1:0.03:3)*1e9;
sparSimu = sparameters(Nolen,frequencyRange);

Plot the measured and simulated return loss for input port1, port2 and port3

% Measured Return loss w.r.t input ports
Freq = SparamsM.Freq;
S11_meas = SparamsM.S11_meas;
S22_meas = SparamsM.S22_meas;
S33_meas = SparamsM.S33_meas;
figure; plot(Freq,S11_meas,'b--',"LineWidth",1);
hold on; plot(Freq,S22_meas,'r--',"LineWidth",1);
hold on; plot(Freq,S33_meas,'k--',"LineWidth",1);
% Simulated Return loss w.r.t input ports
hold on; rfplot(sparSimu,1,1,'b');
hold on; rfplot(sparSimu,2,2,'r');
hold on; rfplot(sparSimu,3,3,'k');
legend('S11-Measured','S22-Measured','S33-Measured','S11-Simulated','S22-Simulated','S33-Simulated');

Figure contains an axes object. The axes object with xlabel Frequency (GHz), ylabel Magnitude (dB) contains 6 objects of type line. These objects represent S11-Measured, S22-Measured, S33-Measured, S11-Simulated, S22-Simulated, S33-Simulated.

Plot the measured and simulated insertion loss at output ports 4, 5 and 6 w.r.t input port1

% Measured Insertion loss at port4, port5 and port6 w.r.t port1
S41_meas = SparamsM.S41_meas;
figure; plot(Freq,S41_meas,'b--',"LineWidth",1);
S51_meas = SparamsM.S51_meas;
hold on; plot(Freq,S51_meas,'r--',"LineWidth",1);
S61_meas = SparamsM.S61_meas;
hold on; plot(Freq,S61_meas,'k--',"LineWidth",1);
grid on;
% Simulated Insertion loss at port4, port5 and port6 w.r.t port1
hold on; rfplot(sparSimu,4,1,'b');
hold on; rfplot(sparSimu,5,1,'r');
hold on; rfplot(sparSimu,6,1,'k');
legend('S41-Measured','S51-Measured','S61-Measured','S41-Simulated','S51-Simulated','S61-Simulated');

Figure contains an axes object. The axes object with xlabel Frequency (GHz), ylabel Magnitude (dB) contains 6 objects of type line. These objects represent S41-Measured, S51-Measured, S61-Measured, S41-Simulated, S51-Simulated, S61-Simulated.

Plot the measured and simulated insertion loss at output ports 4, 5 and 6 w.r.t input port2

% Measured Insertion loss at port4, port5 and port6 w.r.t port2
S42_meas = SparamsM.S24_meas;
figure; plot(Freq,S42_meas,'b--',"LineWidth",1);
S52_meas = SparamsM.S25_meas;
hold on; plot(Freq,S52_meas,'r--',"LineWidth",1);
S62_meas = SparamsM.S26_meas;
hold on; plot(Freq,S62_meas,'k--',"LineWidth",1);
grid on;hold on;
% Simulated Insertion loss at port4, port5 and port6 w.r.t port2
rfplot(sparSimu,2,4,'b');hold on;
rfplot(sparSimu,2,5,'r');hold on;
rfplot(sparSimu,2,6,'k');hold on;
legend('S42-Measured','S52-Measured','S62-Measured','S42-Simulated','S52-Simulated','S62-Simulated');

Figure contains an axes object. The axes object with xlabel Frequency (GHz), ylabel Magnitude (dB) contains 6 objects of type line. These objects represent S42-Measured, S52-Measured, S62-Measured, S42-Simulated, S52-Simulated, S62-Simulated.

Plot the measured and simulated insertion loss at output ports 4, 5 and 6 w.r.t input port3

% Measured Output at port4, port5 and port6 w.r.t port3
S43_meas = SparamsM.S34_meas;
figure; plot(Freq,S43_meas,'b--',"LineWidth",1);
S53_meas = SparamsM.S35_meas;
hold on; plot(Freq,S53_meas,'r--',"LineWidth",1);
S63_meas = SparamsM.S36_meas;
hold on; plot(Freq,S63_meas,'k--',"LineWidth",1);
grid on;hold on;
% Simulated Insertion loss at port4, port5 and port6 w.r.t port3
rfplot(sparSimu,3,4,'b');hold on;
rfplot(sparSimu,3,5,'r');hold on;
rfplot(sparSimu,3,6,'k');hold on; legend('S34-Measured','S35-Measured','S36-Measured','S34-Simulated','S35-Simulated','S36-Simulated')

Figure contains an axes object. The axes object with xlabel Frequency (GHz), ylabel Magnitude (dB) contains 6 objects of type line. These objects represent S34-Measured, S35-Measured, S36-Measured, S34-Simulated, S35-Simulated, S36-Simulated.

The designed Nolen Matrix is simulated in the frequency span of 1-3GHz. It is observed that the return loss for three ports are below 14dB while the insertion loss at the outputs is between 6-8dB respectively.

Compute phase at 2GHz

The simulated phase difference that are obtained between output ports due to input ports.

% w.r.t Port1
figure; plot(sparSimu.Frequencies,(((angle(rfparam(sparSimu,5,1)))-(angle(rfparam(sparSimu,4,1))))*180/pi));
hold on;
plot(sparSimu.Frequencies,(((angle(rfparam(sparSimu,6,1)))-(angle(rfparam(sparSimu,5,1))))*180/pi));
legend('(phase51-phase41)simu','(phase61-phase51)simu')
grid on;

Figure contains an axes object. The axes object contains 2 objects of type line. These objects represent (phase51-phase41)simu, (phase61-phase51)simu.

% w.r.t Port2
figure; plot(sparSimu.Frequencies,(((angle(rfparam(sparSimu,5,2)))-(angle(rfparam(sparSimu,4,2))))*180/pi));
hold on;grid on;
plot(sparSimu.Frequencies,(((angle(rfparam(sparSimu,6,2)))-(angle(rfparam(sparSimu,5,2))))*180/pi));
legend('(phase52-phase42)simu','(phase62-phase52)simu')

Figure contains an axes object. The axes object contains 2 objects of type line. These objects represent (phase52-phase42)simu, (phase62-phase52)simu.

% w.r.t Port3
figure; plot(sparSimu.Frequencies,(((angle(rfparam(sparSimu,5,3)))-(angle(rfparam(sparSimu,4,3))))*180/pi));
hold on;grid on;
plot(sparSimu.Frequencies,(((angle(rfparam(sparSimu,6,3)))-(angle(rfparam(sparSimu,5,3))))*180/pi));
legend('(phase53-phase43)simu','(phase63-phase53)simu')

Figure contains an axes object. The axes object contains 2 objects of type line. These objects represent (phase53-phase43)simu, (phase63-phase53)simu.

The below table shows the phase differences between the adjacent output ports, when the input ports P1, P2, and P3 are excited.

Ports Excited

Phase(51)-Phase(41)

(deg)

Phase(61)-Phase(51)

(deg)

Port1

86.86

86.86

Port2

135.23

-206.12 (153.88)

Port3

15.93

33.70

% measured Phase difference between adjacent ports
% Needs to add this 

Conclusion

A 3×3 Nolen matrix is simulated and compared with the measured results. It is observed that the simulated results matched well with the measured results. The structure exhibits relatively equal magnitude and three different phase differences between adjacent outputs by exciting three input ports which makes it a suitable candidate for 2D beamforming application.

Go to top of page