メインコンテンツ

Radar Cross Section Benchmarking

This example performs benchmarking of the Radar Cross Section (RCS) computation on three structures: a square plate, a circular plate and the NASA almond. The benchmarking for the square and circular plate is done against the analytical physical optics based solution and in the case of the NASA Almond, the comparison is with the Method of Moments (MoM) solution.

Square Plate RCS Parameters Setup

Define the physical dimensions for the square plate, the wavelength and frequency for analysis. The plate is defined using an STL file.

lambda = 3.25e-2;
f1 = physconst("lightspeed")/lambda;
L = 10.16e-2;
W = 10.16e-2;
p = platform;
p.FileName = "square_plate.stl";
p.Units = "m";

Analyze and Compare with Analytical Result

The RCS computation is done in the elevation plane at azimuth = 0 deg. The electric-field polarization vector is set to HH. This implies a horizontal component on transmit and horizontal component on receive is used for the RCS calculation. The results for the RCS from the toolbox are compared with the analytical results provided in [1].

az = 0;
el = 0.05:1:90;
sigma = rcs(p,f1,az,el,Polarization="HH"); 
asigma1 = rectPlateRCS(L,W,f1,az,90-el);
figure
plot(el,sigma,el,asigma1)
grid on
xlabel("Elevation angle (deg.)")
ylabel("RCS - dBsm")
title("Analytical vs Numerical PO")
legend("PO-Numerical","PO-Analytical",Location="best")

Figure contains an axes object. The axes object with title Analytical vs Numerical PO, xlabel Elevation angle (deg.), ylabel RCS - dBsm contains 2 objects of type line. These objects represent PO-Numerical, PO-Analytical.

Circular Plate RCS Parameters Setup

Define the physical dimensions of the circular plate. The circular plate is described using an STL file. All dimensions are in meters.

R = 10.16e-2;
pc = platform;
pc.FileName = "circular_plate.stl";
pc.Units = "m";

Analyze and Compare with Analytical Result

As before compare the results from the RCS function in the toolbox with the analytical expression provided in [1]. The RCS calculation is done in the elevation plane between 0 and 90 deg.

az = 0;
el = 0.05:1:90;
sigmaV = rcs(pc,f1,az,el,Polarization="HH"); 
asigma1 = circPlateRCS(R,f1,90-el);
figure
plot(el,sigmaV,el,asigma1)
grid on
xlabel("Elevation angle (deg.)")
ylabel("RCS - dBsm")
title("Analytical vs Numerical PO")
legend("PO-Numerical","PO-Analytical",Location="best")

Figure contains an axes object. The axes object with title Analytical vs Numerical PO, xlabel Elevation angle (deg.), ylabel RCS - dBsm contains 2 objects of type line. These objects represent PO-Numerical, PO-Analytical.

NASA Almond Setup

The third structure is the NASA almond shape described in [2]. This is a classic shape for benchmarking the performance of high-frequency electromagnetic solvers. The mathematical expressions in [2] have been used to create the STL file that describes the almond shape.

p = platform;
p.FileName = "NASA-Almond.stl";
p.Units = "m";
figure
show(p)

Figure contains an axes object. The axes object with title Platform object, xlabel x (mm), ylabel y (mm) contains 2 objects of type patch. This object represents PEC.

Analysis Parameters

Since the physical optics solver is only applicable at large ka values, we compare the results produced by the Antenna Toolbox with those published in [2]. The results produced by the toolbox will be from both solvers, the physical optics (PO) and the Method-of-Moments(MoM). The wavelength at 7 GHz is approximately 4.3 cm. We refine the mesh to be slightly finer than this using the λ/10 criterion.

f2 = 7e9;
m = mesh(p,MaxEdgeLength=0.0035)
m = 
  MeshReader with properties:

                Points: [3×4173 double]
             Triangles: [4×8342 double]
            Tetrahedra: []
         MaxEdgeLength: 0.0035
         MinEdgeLength: 0.0026
            GrowthRate: 0.5000
    MinimumMeshQuality: 0.0790
              MeshMode: 'manual'

az = 0:1:180;
el = 0;

RCS Calculation with HH-Polarization

Calculate the RCS for the HH-polarization condition in which the transmitted and received field is horizontally polarized.

sigmahh_po = rcs(p,f2,az,el,Solver="PO",...
    EnableGPU=false,Polarization="HH");
        
sigmahh_mom = rcs(p,f2,az,el,Solver="MoM",...
    Polarization="HH");

RCS Calculation with VV-Polarization

Calculate the RCS for the VV-polarization condition in which the transmitted and received field is vertically polarized.

sigmavv_po = rcs(p,f2,az,el,Solver="PO",...
    EnableGPU=false,Polarization="VV");
      
sigmavv_mom = rcs(p,f2,az,el,Solver="MoM",...
    Polarization="VV");

Plot Results

Overlay the plots from both solvers for both polarizations to compare. Notice that the full-wave MoM solver extracts all the phenomenon that contribute to the scattered field. In contrast the PO solver being a first-order approximation is able to predict the level of RCS but averages out the variations at the different angles. This is expected since the PO solver assumes that the surface current density outside the illuminated region, i.e. the shadow region is zero, thus not contributing to the scattered field.

figure
plot(az,sigmahh_mom,az,sigmahh_po,az,sigmavv_mom,az,sigmavv_po,LineWidth=2)
ax = gca;
ax.YLim = [-70,-15]; 
title("RCS Comparison, MoM vs. PO")
xlabel("Azimuth, deg.")
ylabel("Magnitude, dBsm")
grid on
legend("HH-pol, MoM","HH-pol, PO", "VV-pol, MoM","VV-pol, PO",Location="best")

Figure contains an axes object. The axes object with title RCS Comparison, MoM vs. PO, xlabel Azimuth, deg., ylabel Magnitude, dBsm contains 4 objects of type line. These objects represent HH-pol, MoM, HH-pol, PO, VV-pol, MoM, VV-pol, PO.

Dielectric NASA Almond

The NASA Almond structure results plotted in the previous section was made out of a metal (Perfect Electric Conductor - PEC) and therefore an STL file based description was adequate. To consider the same structure made with a dielectric material as discussed in [3], you need additional information to be provided about the volumetric properties. To describe this use a MAT file based input to specify the structure. In this file specify the Points, Triangles and Tetrahedra fields to completely specify the surface and volume geometry and in addition provide the relative permittivity and loss tangent for material properties.

p = platform;
p.FileName = "NASA_Diel_Almond_24KTri_400KTets.mat"; %f = 2.58e9
p.Units = "m"
p = 
  platform with properties:

         FileName: "NASA_Diel_Almond_24KTri_400KTets.mat"
            Units: "m"
    UseFileAsMesh: 0
             Tilt: 0
         TiltAxis: [1 0 0]

p.UseFileAsMesh = 1;
figure
show(p)

Figure contains an axes object. The axes object with title Platform object, xlabel x (mm), ylabel y (mm) contains 2 objects of type patch. This object represents Dielectric.

This is a structure with close to half a million elements in the mesh. To solve, use the FMM accelerated solver. Since the calculation takes several minutes per angle, the results from the solver are shown in the figure below overlaid with results from [3] for comparison. The frequency of analysis is 2.58 GHz.

RCS Calculation for HH-polarization

Uncomment the lines of code in this section to calculate the RCS for the HH-polarization condition in which the transmitted and received field is horizontally polarized.

f3 = 2.58e9;
sigma_almondHH = -inf*ones(1,numel(az));
h1 = figure;
plot(az,sigma_almondHH,LineWidth=2)
xlabel("Azimuth angle (deg.)")
ylabel("RCS (dBsm)")
title("HH-pol RCS at el =0 deg.")
grid on
for i = 1:numel(az)
    sigma_almondHH(i) = rcs(p,f3,az(i),0,Solver="FMM",Polarization="HH");
    figure(h1)
    plot(az,sigma_almondHH,LineWidth=2)
end

RCS_resinalmond_hhpol_compared.png

RCS Calculation for VV-Polarization

Uncomment the lines of code in this section to calculate the RCS for the VV-polarization condition in which the transmitted and received field is vertically polarized. For this polarization case, the azimuth sweep has been non-uniformly discretized so as to take larger steps for most of the sweep range and closer to the sharp null, as seen in [3], the step size is reduced.

az = [0:2:130,130.5:0.5:150,152:2:180];
sigma_almondVV = -inf*ones(1,numel(az));
h2 = figure;
plot(az,sigma_almondVV,LineWidth=2)
xlabel("Azimuth angle (deg.)")
ylabel("RCS (dBsm)")
title("VV-pol RCS at el =0 deg.")
grid on
tstart = tic
for i = 1:numel(az)
    sigma_almondVV(i) = rcs(p,f3,az(i),0,Solver="FMM",Polarization="VV");    
    figure(h2)
    plot(az,sigma_almondVV,LineWidth=2)
end

RCS_resinalmond_vvpol_compared.png

Summary

The RCS benchmarking results compare favorably with published results using analytical techniques as well as other numerical solvers.

References

[1] Mahafza, Bassem R. Radar Systems Analysis and Design Using Matlab. Boca Raton: Chapman & Hall/CRC, 2000.

[2] Woo, A.C., H.T.G. Wang, M.J. Schuh, and M.L. Sanders. “EM Programmer’s Notebook-Benchmark Radar Targets for the Validation of Computational Electromagnetics Programs.” IEEE Antennas and Propagation Magazine 35, no. 1 (February 1993): 84–89. https://doi.org/10.1109/74.210840.

[3] https://github.com/UTAustinCEMGroup/AustinCEMBenchmarks/tree/master/Austin-RCS-Benchmarks/Problem%20III-Almonds/Problem%20Set%20IIIB-Solid%20Resin%20Almonds

[4] https://github.com/UTAustinCEMGroup/AustinCEMBenchmarks/blob/ba9f243c3210eb3cda78f1bd18971c9c576c53ae/Austin-BioEM-Benchmarks/LICENSE.txt

See Also