{
  "query": "Compare full-wave simulation and SBR for me.",
  "query-id": 116,
  "gold_response": "Full‑wave vs. SBR (Shooting and Bouncing Rays): technical comparison with SBR math, algorithms, MATLAB usage, and comparative code\n\n1) SBR formulas and algorithms (with assumptions and key parameters)\n- Governing equations and asymptotics\n  - Full‑wave solves frequency‑domain Maxwell/Helmholtz directly\n    ∇×E = iωμH,  ∇×H = (σ + iωε)E + J\n    Vector Helmholtz (source-free): ∇×(μ−1∇×E) − k0²εrE = 0,  k0 = 2π/λ\n  - SBR: high‑frequency (k0L ≫ 1) asymptotics of Helmholtz using the GO ansatz E(r) = A(r) exp(ik0S(r))\n    • Eikonal equation: |∇S(r)|² = n²(r), with n = √(εrμr)\n    • Transport equation (amplitude): 2∇A·∇S + A∇²S = 0 ⇒ A ∝ 1/√J, where J is the ray‑tube Jacobian (cross‑sectional area growth)\n    • Phase accumulation on a path γ: ϕ = k0∫γ n(r) ds + ∑m ψm, with ψm additional phase (e.g., −π for TE reflection at PEC near grazing, UTD transition phases, etc.)\n- Local interactions (per hit)\n  - Reflection/transmission (Fresnel, complex media): let εc = ε0εr − jσ/ω and η = √(μ/εc). For incident angle θi and transmitted angle θt from Snell (n1 sinθi = n2 sinθt):\n    Γ⊥(TE) = (η2 cosθi − η1 cosθt)/(η2 cosθi + η1 cosθt),   Γ∥(TM) = (η2 cosθt − η1 cosθi)/(η2 cosθt + η1 cosθi)\n    T⊥, T∥ analogously. For PEC: Γ⊥ = −1, Γ∥ = +1.\n  - Edge diffraction (UTD on wedge, order‑independent, uniform): sketch for an infinite wedge with exterior angle α (wedge index n = π/α), incident/diffracted face angles φi, φd, and effective distance ρ:\n    Ed ≈ Ei · D(φi, φd) · e−jk0(ri+rd) / √(ri rd)\n    D(φi, φd) = − e−jπ/4 / [2n√(2πk0)] × [ F(ν+) / sin((π + φd − φi)/2n) + F(ν−) / sin((π − φd + φi)/2n) ]\n    where F(·) are UTD transition functions (Fresnel‑type), ensuring uniformity near shadow boundaries.\n  - Creeping/surface waves on convex conductors: asymptotic Fock/Ludwig terms, amplitude ∝ exp[−(2/3)k0a ζ3/2] along geodesics (a: local radius of curvature). Often included as optional corrections in advanced SBR implementations for shadowed regions.\n  - Physical Optics (PO) far‑field for illuminated PEC facets (SBR‑PO hybrid widely used for RCS):\n    Js(r′) = 2 n̂ × Hinc(r′) on lit region S;  Esca(r, r̂) ≈ −j k0η e−jk0r / (4πr) ∫S Js(r′) e^{jk0 r̂·r′} dS′\n    This is the standard way SBR converts bounce hits into radiated/scattered field contributions.\n- End‑to‑end path contribution\n  - Geometrical spreading (free space, 3D): |E| ∝ 1/R, received power via Friis on each path m:\n    Pr,m = Pt Gt(Ωm) Gr(Ωm) (λ/4π)² |Am|² / Lm², with Am = ∏h (Γh or Dh) and Lm the total path length.\n    Total field at Rx: E = ∑m Em = ∑m Em,0 Am e−jk0Lm / Lm, coherent sum over multipath.\n- Algorithmic steps (canonical SBR pipeline)\n  1) Ray emission: sample rays on unit sphere around Tx. Control by angular separation ΔΩ or target number Nrays. Optionally importance sample by antenna pattern Gt.\n  2) Acceleration structures: build BVH/k‑d tree on triangle mesh to accelerate ray–triangle intersection tests (O(log N) per hit).\n  3) Propagation and bounces: advance a ray to first hit; compute local frame (n̂, tangents), Fresnel Γ and phase jump, update direction via specular law; optionally spawn diffracted rays from hit edges (UTD) and refracted rays in dielectrics (Snell).\n  4) Amplitude/phase update: multiply by Γ/T/D, accumulate phase k0ΔL, scale by 1/√J (or 1/L in far‑field) and antenna pattern factors.\n  5) Termination: stop if bounce count > Nmax, amplitude below Amin (power below Pmin), or path length exceeds Lmax.\n  6) Receiver coupling: accept rays entering Rx aperture/solid angle; compute polarization projection and Gr(Ω), sum complex field.\n- Validity and typical settings\n  - Valid when electrical size ≫ 10–20 wavelengths; accuracy improves as size/λ grows.\n  - Key parameters and trade‑offs:\n    • Ray density (angular separation): finer → fewer misses, higher accuracy, higher runtime. Start Δθ ≈ λ/D for platform diameter D, then refine. In urban/channel work, 0.1–1 deg typical; for RCS/installed antenna, 0.05–0.2 deg.\n    • Max bounces: 1–2 for RCS of smooth platforms; 3–5 for indoor/mmWave channels; increases combinatorics and runtime roughly exponentially.\n    • Diffraction on/off: essential near shadow boundaries and for edges; adds a fan of rays per edge; use sparingly with thresholds.\n    • Facet size: PO accuracy requires facet size ≲ 0.1–0.2λ over illuminated regions; too coarse → phase errors, too fine → mesh cost.\n    • Material model: complex εr(ω), μr(ω), σ, and roughness; rough PEC can use Beckmann–Kirchhoff or directive diffuse scattering models when needed.\n    • Thresholds (Pmin/Amin): trims long, weak paths; set relative to dynamic range and noise floor.\n\n2) Where SBR shines (application areas)\n- RCS of electrically large platforms: aircraft, ships, vehicles, wind turbines, missiles. SBR+PO (+UTD/PTD) is the workhorse for monostatic/bistatic RCS vs frequency/aspect because full‑wave is prohibitive when D/λ ≳ 100–1000.\n- Installed antenna performance on large platforms: pattern distortion, blockage, platform coupling, radome effects (with GO/UTD refractions).\n- Automotive radar (24/77/79 GHz): multipath off body panels/roadside, ghost targets; fast what‑if analysis across scenarios.\n- mmWave/THz links and indoor channels: coverage/multipath with reflections, transmissions, and edge diffraction.\n- EMC/EMI shielding effectiveness of large enclosures; satellite links over complex structures.\n\nSummary comparison (full‑wave vs SBR)\n- Principle: full‑wave directly solves Maxwell; SBR uses GO/UTD asymptotics.\n- Equations: full‑wave → vector Helmholtz via FEM/FDTD/MoM; SBR → eikonal + Fresnel/UTD/PTD + optional PO for reradiation.\n- Accuracy: full‑wave highest (captures resonances, surface/creeping waves, mutual coupling automatically); SBR accurate in high‑frequency, large‑scale regimes; needs UTD/PTD/PO to capture diffraction/scattering details.\n- Cost scaling: full‑wave unknowns scale ~ O((D/λ)^p) with p≈2–3; MoM cost ~ O(N²–N³); SBR scales with rays×bounces×hits, far lower for large D/λ.\n- Typical use: full‑wave for antennas/electrically small to moderate models; SBR for electrically large platforms, RCS, installed performance, mmWave channels.\n\n3) MATLAB SBR function analysis (Ray Tracing model)\nMATLAB provides a ray‑tracing propagation model that includes an SBR method.\n- Core objects/functions\n  - pm = propagationModel(\"raytracing\",\"Method\",\"sbr\", ...): constructs an SBR ray‑tracing model.\n  - rays = raytrace(tx, rx, pm, Name,Value...): traces rays between txsite and rxsite through a map/scene.\n  - sig = sigstrength(rx, tx, pm): computes received signal strength by summing resolved paths coherently.\n- Key parameters of propagationModel(\"raytracing\") for SBR\n  - \"Method\": 'sbr' (vs 'image'). SBR supports multi‑bounce, supports diffractions (release‑dependent).\n  - \"MaxNumReflections\": integer ≥ 0. Controls bounce depth.\n  - \"MaxNumDiffractions\": integer ≥ 0. Enables edge diffraction when supported by scene assets.\n  - \"AngularSeparation\": step in degrees for initial ray fan; smaller → denser rays.\n  - \"SurfaceMaterial\": material for geometry (e.g., 'perfect-reflector', 'concrete', 'brick', 'metal'); affects Fresnel coefficients.\n  - \"MinPower\": dBm threshold; prunes weak rays.\n  - \"MaxPropagationDistance\": meters; hard limit on ray length.\n  - Scene/Map: Site Viewer map, glTF/OBJ/STL custom meshes, or built‑in buildings/terrain. Material tags in the scene govern εr, σ used by Fresnel.\n- txsite / rxsite essentials\n  - 'Antenna': pattern (isotropic, Antenna Toolbox object, or custom). Gt/Gr influence launch weighting and Rx coupling.\n  - 'TransmitterFrequency': sets λ; critical for Fresnel/UTD and phase.\n  - Positions/orientations in geodetic or Cartesian coordinates.\n- raytrace outputs (struct array, one per resolved path)\n  - PathLength (m), PathLoss (dB), PropagationDelay (s).\n  - NumReflections, NumDiffractions; InteractionPoints (3D locations), InteractionTypes (e.g., 'reflection','diffraction'), and Materials.\n  - AngleOfDeparture/AngleOfArrival (az,el), PhaseShift (rad), ReflectionCoefficients per hit (complex), and Polarization info (release‑dependent).\n- Practical tips\n  - Start with AngularSeparation ~0.5–1 deg and MaxNumReflections=2; refine until metrics (e.g., RSS, delay spread) converge.\n  - Use material libraries matching frequency band; for metals at mmWave, high |Γ| and possible roughness‑induced diffusion.\n  - If you need edge diffraction, ensure scene meshes include edges and set MaxNumDiffractions≥1; validate by checking rays.InteractionTypes.\n\n4) MATLAB example code for comparative analysis with Full‑wave\nTwo complementary tracks are provided:\n- Track A: SBR using MATLAB’s SBR ray tracer (3D multipath). Requires: RF Toolbox/Communications System Toolbox with RF Propagation (ray tracing), Site Viewer.\n- Track B: Full‑wave benchmark via 2D FEM Helmholtz scattering (PDE Toolbox). This solves Maxwell’s scalar 2D TM problem rigorously and allows quantitative comparison of angle‑dependent scattered field vs a 2D SBR surrogate. It is small yet fully full‑wave.\n\nTrack A — SBR (3D) multipath with reflections/diffractions\n% Requires: MATLAB R2022b+ with RF Propagation (ray tracing) and Site Viewer\n% Scene: use an example mesh or your own glTF/OBJ/STL with material tags.\n\n% 1) Define transmitter/receiver\nfc = 77e9; % Hz (automotive radar band)\ntx = txsite(\"cartesian\", \"AntennaPosition\", [0 0 2], ...\n    \"TransmitterFrequency\", fc, \"Antenna\", 'isotropic');\nrx = rxsite(\"cartesian\", \"AntennaPosition\", [50 0 2]);\n\n% 2) Build SBR propagation model\npm = propagationModel(\"raytracing\", \"Method\",\"sbr\", ...\n    \"AngularSeparation\", 0.25, ...           % deg; start coarse ~1, refine to ~0.1–0.25\n    \"MaxNumReflections\", 3, ...\n    \"MaxNumDiffractions\", 1, ...\n    \"SurfaceMaterial\", \"metal\", ...          % strong reflections (approx. PEC)\n    \"MinPower\", -120, ...                     % dBm path pruning threshold\n    \"MaxPropagationDistance\", 200);\n\n% 3) Load or open scene (uncomment to use a custom mesh)\n% viewer = siteviewer(\"SceneSource\",\"custom\",\"SceneModel\",\"myScene.glb\");\nviewer = siteviewer; % default basemap if no custom scene\n\n% 4) Trace rays and examine contributions\nrays = raytrace(tx, rx, pm, \"Type\", \"pathloss\");\n\n% 5) Summarize resolved paths\nfprintf(\"Resolved paths: %d\\n\", numel(rays));\nfor m = 1:numel(rays)\n    fprintf(\"m=%d: L=%.2f m, PL=%.1f dB, Nrefl=%d, Ndiff=%d, delay=%.2f ns\\n\", ...\n        m, rays(m).PathLength, rays(m).PathLoss, ...\n        rays(m).NumReflections, rays(m).NumDiffractions, rays(m).PropagationDelay*1e9);\nend\n\n% 6) Coherent sum via sigstrength (uses phase)\nP_rx_dBm = sigstrength(rx, tx, pm);\nfprintf(\"Total received power (coherent): %.1f dBm\\n\", P_rx_dBm);\n\nNotes:\n- Increase AngularSeparation (smaller step) until P_rx_dBm converges within your tolerance.\n- Use rays(m).ReflectionCoefficients and InteractionPoints to analyze Fresnel factors and geometrical bounce points.\n- For RCS‑oriented scenarios, place tx=rx (monostatic) and target mesh in the scene; analyze backscatter path loss vs aspect.\n\nTrack B — Full‑wave (2D FEM) scattering vs angle (rigorous benchmark)\nThis example solves the 2D TM Helmholtz scattering of a plane wave by a PEC rectangular obstacle and extracts the scattered field along an observation circle. You can compare the angular scattering pattern to a 2D SBR surrogate (single‑bounce speculars + UTD edges on rectangle) to see where GO/UTD matches or departs.\n\n% Requires: PDE Toolbox\nclear; close all; clc\n\n% Frequency and wavenumber\nf = 10e9;               % Hz (λ = 3 cm)\nlambda = physconst('LightSpeed')/f; k0 = 2*pi/lambda;\n\n% Geometry: big circular domain minus a PEC rectangle (obstacle)\nRdom = 1.0;             % outer radius [m] ~ 33λ for f=10 GHz\naw = 0.2; bh = 0.1;     % rectangle width/height [m] (~6.7λ x 3.3λ)\n\n% Plane wave incidence angle (from +x axis)\nth_inc = deg2rad(0);    % normal incidence\nkhat = [cos(th_inc); sin(th_inc)];\n\n% Build geometry (C1 circle minus R1 rectangle)\nC1 = [1 0 0 Rdom]';     % circle: [1 cx cy R]\nR1 = [3 4 -aw/2  aw/2  aw/2 -aw/2  -bh/2 -bh/2  bh/2  bh/2]';\n% Geometry description matrix\ngeom = decsg([C1 R1],[\"C1-R1\"; '    '],[('C1')';('R1')']);\n\nmodel = createpde(1);\ngeometryFromEdges(model,geom);\n\n% PDE coefficients for scattered field us: ∇^2 us + k0^2 us = 0\nspecifyCoefficients(model,'m',0,'d',0,'c',1,'a',k0^2,'f',0);\n\n% Boundary conditions\n% 1) PEC rectangle boundary: total field u_tot = 0 ⇒ us = -u_inc\nuinc = @(x,y) exp(1j*k0*(khat(1)*x + khat(2)*y));\napplyBoundaryCondition(model,'dirichlet','Edge',edgesOfRectangle(model), ...\n    'u', @(location,~) -uinc(location.x, location.y));\n\n% 2) Outer boundary: first‑order absorbing for scattered field\n%    ∂us/∂n − i k0 us = −(∂uinc/∂n − i k0 uinc)\nqfun = @(~,~) -1j*k0;\n% n·∇uinc = i k0 (khat·n) uinc\ngfun = @(location,~) -(1j*k0*(khat(1)*location.nx + khat(2)*location.ny).* ...\n                       uinc(location.x,location.y) - 1j*k0*uinc(location.x,location.y));\napplyBoundaryCondition(model,'neumann','Edge',edgesOfOuterCircle(model), ...\n    'g', gfun, 'q', qfun);\n\n% Mesh (at least ~10 elements per λ)\nHmax = lambda/8; generateMesh(model,'Hmax',Hmax);\n\n% Solve\nresult = solvepde(model);\nus = result.NodalSolution; % scattered field\n\n% Sample total field along observation circle\nNobs = 720; rObs = Rdom*0.95; th = linspace(0,2*pi,Nobs);\nobsXY = [rObs*cos(th); rObs*sin(th)];\nusObs = interpolateSolution(model,us,obsXY(1,:),obsXY(2,:)).';\nuincObs = uinc(obsXY(1,:),obsXY(2,:)).';\nutotObs = usObs + uincObs;\n\n% Compute angular scattering metric (normalized)\npat = 20*log10( abs(usObs)/max(abs(usObs)) + 1e-12 );\nfigure; polarplot(th, max(pat,-80)); title('2D FEM: |Us| angular pattern (dB, normalized)');\n\nfunction e = edgesOfRectangle(model)\n% Helper: detect rectangle edges by bounding box\nb = model.Geometry; e = [];\nfor k=1:b.NumEdges\n    mid = b.evaluateEdge(b.Edges(k),0.5);\n    x = mid(1); y = mid(2);\n    if abs(abs(x) - 0.1) < 1e-3 || abs(abs(y) - 0.05) < 1e-3\n        e(end+1) = k; %#ok<AGROW>\n    end\nend\nend\n\nfunction e = edgesOfOuterCircle(model)\n% Helper: pick edges whose midpoints lie near radius Rdom\nb = model.Geometry; e = [];\nfor k=1:b.NumEdges\n    mid = b.evaluateEdge(b.Edges(k),0.5);\n    r = hypot(mid(1),mid(2));\n    if r > 0.9*max(abs([b.Vertices(1,:) b.Vertices(2,:)]))\n        e(end+1) = k; %#ok<AGROW>\n    end\nend\nend\n\nHow to compare SBR vs Full‑wave with the above\n- Geometry: use a comparable obstacle (rectangle) and incidence.\n- Metric: compare angular positions/levels of dominant lobes and shadow regions.\n  1) From Track B, use pat(th) to find specular and edge‑diffraction lobes.\n  2) Build a lightweight 2D SBR surrogate: specular from each face + UTD wedge terms on the four rectangle corners (optional). You can parameterize each contribution as Em ∝ Γm e−jk0Lm / √(Lm) (2D spreading) and sum coherently. Validate lobes’ angles vs FEM.\n- Expectation: in lit/specular directions SBR will match well; near shadow and at moderate electrical sizes (only a few λ across), FEM captures effects SBR misses unless you add UTD and sufficient edge detail.\n\nOptional: MoM full‑wave RCS of a PEC plate (Antenna Toolbox)\nIf you have Antenna Toolbox, you can compute 3D RCS of a large PEC plate via MoM and compare to SBR‑PO/scene backscatter:\n% Rectangular PEC plate (approximate, electrically large recommended)\nL = 0.5; W = 0.3; fc = 10e9; lambda = physconst('LightSpeed')/fc;\n% Create a mesh plate using triangulation (dense: ~10 elems/λ)\n[p,t] = createPlateMesh(L,W, max(round(10*L/lambda),50));\nplate = triangulation(t',p');\n% rcs requires release‑specific workflow; refer to rcs(antennaMesh, ...) docs.\n% [sigma,az,el] = rcs(plate, fc, 'Type',' monostatic', ...);\n% Compare sigma(az) to SBR backscatter vs aspect.\nfunction [p,t] = createPlateMesh(L,W,Nx)\nxv = linspace(-L/2,L/2,Nx); yv = linspace(-W/2,W/2,round(Nx*W/L));\n[X,Y] = meshgrid(xv,yv); p = [X(:), Y(:), zeros(numel(X),1)];\nDT = delaunayTriangulation(p(:,1),p(:,2)); t = DT.ConnectivityList'; p = p';\nend\n\nVerification and practical guidance\n- Convergence studies: for SBR, refine AngularSeparation and increase MaxNumReflections until P_rx or key RCS lobes change < 0.5 dB; for FEM, refine mesh to ≥10–12 elements/λ along the obstacle.\n- Parameter sensitivity: quantify how adding UTD (MaxNumDiffractions≥1) reduces deep‑shadow errors; how facet size impacts PO phases; how material εr, σ change Γ⊥/Γ∥.\n- Comparing to measurement: for RCS, compare monostatic cuts at fixed f vs aspect; for links, compare delay/Doppler spreads and received power CDFs.\n\nReferences for deeper implementation\n- J. B. Keller, “Geometrical theory of diffraction,” JOSA, 1962 (UTD foundations).\n- R. F. Harrington, Time-Harmonic Electromagnetic Fields (Helmholtz, boundary conditions).\n- Kouyoumjian & Pathak, “A uniform GTD for edge diffraction,” Proc. IEEE, 1974.\n- Beckmann & Spizzichino, The Scattering of Electromagnetic Waves from Rough Surfaces (roughness models).\n\nSummary\n- For electrically large RCS/platform problems, SBR + PO/UTD is the practical choice; full‑wave is the gold standard for accuracy and for electrically small/medium problems or when resonances/surface waves are decisive.\n- MATLAB’s SBR ray tracer provides controllable ray density, bounce limits, and material‑aware Fresnel/UTD options. The PDE example shows how to build a ground‑truth full‑wave benchmark in 2D to validate SBR logic and parameter choices before scaling up to 3D scenes.",
  "gold_information": [
    "Full-wave methods directly solve the electromagnetic field equations in the frequency or time domain.",
    "SBR approximates high-frequency wave propagation using geometrical optics and diffraction theory.",
    "Full-wave captures resonances, mutual coupling, and surface or creeping waves without extra models.",
    "SBR relies on reflection, transmission, and diffraction coefficients at each surface or edge interaction.",
    "Full-wave typically uses numerical discretizations such as finite elements, finite differences, or boundary integral equations to solve the vector wave equation.",
    "SBR represents fields as rays whose phase and amplitude evolve along paths via eikonal and transport relations.",
    "SBR applies Fresnel reflection and transmission coefficients at each hit based on polarization and incidence angle.",
    "SBR can include uniform edge-diffraction models to handle shadow boundaries and tip effects.",
    "SBR often combines with physical optics to convert illuminated facets into reradiated scattered fields.",
    "SBR can optionally include asymptotic corrections for creeping waves on convex conductors.",
    "SBR forms the received field by coherently summing complex contributions from all resolved paths with geometrical spreading.",
    "A typical SBR pipeline emits rays, accelerates ray–mesh intersections, updates amplitude and phase at interactions, and terminates by thresholds.",
    "SBR accuracy improves when objects are many wavelengths in electrical size.",
    "Full-wave provides the highest fidelity across sizes but becomes computationally prohibitive for electrically large scenes.",
    "Full-wave computational cost grows rapidly with electrical size, whereas SBR cost scales with rays, bounces, and intersections.",
    "SBR is well suited for radar cross section prediction of electrically large platforms.",
    "SBR is effective for assessing installed antenna performance on large structures.",
    "SBR is useful for automotive radar analysis and indoor or urban millimeter-wave channels.",
    "SBR supports studies of electromagnetic compatibility for large enclosures and complex assemblies.",
    "Key SBR controls include ray angular density, maximum number of bounces, and diffraction settings.",
    "Accurate physical optics in SBR requires facet sizes that are a small fraction of a wavelength over illuminated regions.",
    "Material models with complex permittivity, permeability, conductivity, and roughness determine SBR interaction coefficients.",
    "Amplitude, power, or path-length thresholds in SBR prune weak rays to reduce runtime.",
    "SBR convergence is checked by refining ray angular separation and bounce limits until key metrics stabilize.",
    "In illuminated and specular directions SBR can match full-wave well.",
    "Near shadow boundaries or at moderate electrical sizes SBR needs diffraction and edge detail to reduce errors.",
    "A ray-tracing tool implementing SBR typically supports multi-bounce propagation, edge diffraction, angular resolution control, and material-aware coefficients.",
    "Ray-tracing outputs usually include path length, path loss, delay, interaction types, angles, and complex coefficients for coherent summation.",
    "Antenna patterns and polarization projections weight ray launch and receiver coupling in SBR.",
    "Frequency selection sets the wavelength and governs reflection, diffraction, and phase behavior in both approaches.",
    "Verification uses mesh refinement for full-wave and ray-density refinement for SBR to ensure convergence.",
    "Two-dimensional full-wave scattering can benchmark and validate simplified SBR surrogates before scaling to three dimensions.",
    "Full-wave is preferred for electrically small to medium problems or when resonances and surface waves are decisive.",
    "SBR offers tractable simulation of very large scenes with substantially lower memory and runtime."
  ]
}