Keywords:
Waveguide, Dispersion Relation, Fourier Transform, Phase Shifting Boundary ConditionsThis VSimMD example demonstrates several unique capabilities of VSim that can be used to efficiently model waveguides. One unique capability is the use of phase shifting periodic boundary conditions. These work by adding a phase to a wave at a boundary to mimic a much longer physical dimension. We also demonstrate how to use an analyzer called extractModesViaOperator.py to accurately compute the excited modes in the waveguide, even if some of the modes are much weaker than the dominant mode. In this example, we use extractModesViaOperator.py to compute the dispersion relation (\(\omega\) vs \(k\)) and compare the numerically determined dispersion relation with the theoretical dispersion relation using standard waveguide theory.
This example involves five steps. In the first step, the waveguide is “pinged” with a short pulse in the current density that excites a range of modes. The Fourier transform then shows the range of frequencies of the modes. In the second step, the waveguide is excited using a sinc pulse function multiplied by a Gaussian envelope to excite a flat band of frequencies with sharp cutoffs at either end. The excitation current density is in the transverse directions (\(z\) and \(y\)) which excites an electric field primarily in the transverse direction. In the third step, the data is restarted from the end of the second run and saved at shorter time intervals in order to resolve the frequencies of interest. The output from the third step is used by the extractModesViaOperator.py analyzer to compute the eigenmodes in step 4. Finally, in step 5, the dispersion relation is computed by varying the wavelength which is resolved in the simulation.
This simulation can be performed with a VSimMD or VSimEM license.
The rectMetalWaveguideDisp example is accessed from within VSimComposer by the following actions:
The properties and values that create the simulation are accessible in the left pane when the Setup Window is selected as shown in Fig. 355. The right pane shows a 3D view of the selected geometry components, grids and current distributions.
The geometry can be visualized by expanding “Geometries” in the left pane. The hollow rectangular waveguide can be seen more clearly by de-selecting the “Grid” option. The length in the direction of propagation (\(x\)) is a small fraction of either transverse direction. This is possible because we are using “phase shifting periodic” boundary conditions in the x -direction. The phase shifting BCs are selected under “Basic Settings”.
The simulation is excited with a sinc hat function, which has a formula of
\(\delta_f\) is calculated according to. frequencyGap = (frequency high - frequency low)*frequency gap factor
numSigma = sqrt(-2.0*log(suppression factor))
sigmaT = (TWOPI*frequencyGap)/numSigma
As mentioned in the introduction, this function has a Fourier spectrum that is fairly flat over the desired range, \(f_l < f < f_h\), of frequencies and falls off rapidly over a frequency width of \(\delta_f\), so that it is nearly zero for \(f < f_l - \delta_f\) or \(f > f_h + \delta_f\).
Before discussing phase-shifting periodic boundary conditions, we first review ordinary periodic BCs. In this discussion, periodic BC’s are applied in the x-direction. With normal periodic BC’s, there are two criteria in resolving a wave (or mode) of interest. (1) There must by enough grid points along the wavelength to resolve the spatial profile. Typically we sample at least 20 cells along a wavelength (\(\lambda_x\)), or \(DX = \lambda_x/20\), and (2) The length of the simulation domain, represented by \(L_x\), must be one wavelength long, \(L_x=\lambda_x\). Periodic BC’s in the x-direction means that \(F(0)=F(L_x)\), where \(F\) is any field quantity. Now introduce a grid that extends from 0,1,…,nx and let \(x=0\) at grid point 0 and \(x=L_x\) at grid point nx. Periodicity on the grid implies \(F(0)=F(nx)\). Finally, lets assume that \(F(x)\sim \sin(k_x x)\). Then, applying the condition for periodicity, \(\sin(0) = \sin(k_x L_x)\), which is exactly met if \(L_x=\lambda_x\).
With phase-shifting periodic BC’s, we are no longer required to meet the second criteria discussed in the preceding paragraph. To see this, assume \(L_x < \lambda_x\). Then the periodicity condition can still be met by setting \(k_x L_x - \phi_0=0\), where \(\phi_0\) is the phase shift equal to \(k_x L_x\), which is the exact phase shift we have chosen to apply in VSim for this example. The numerical implementation is more challenging than the conceptual picture we just discussed. To implement phase-shifting periodic BC’s, we need to treat the fields as complex numbers and set \(F(L_x)=\exp(i \phi_0)F(0)\). For the grid, we pick 2 cells such that \(L_x=2DX\).
By using phase-shifting periodic BC’s, we can simulate different physical lengths without changing the simulation length \(L_x\) through the phase shift \(\phi_0=k_x L_x\). Because \(k_x=2\pi/L_x\), we can solve for \(\omega(k_x)\) without requiring a simulation of length \(L_x\).
We now walk through the five steps discussed in the Introduction. In the first step, we test to determine the minimum frequency that will propagate through the waveguide. For the rectangular waveguide in this example, we know the analytical result which is the lowest cutoff frequency. However, we still do this step to demonstrate how to determine the lowest frequency that will propagate for cases that are not analytic. In the second step, the current density “rings up” to a maximum value, then rings down to 0. Because we are exciting modes at resonant frequencies of the cavity, the E- and B-fields continue to oscillate after the excitation is turned off. We wish to determine the resonant modes using Eigen mode analysis using data saved in Step 3 when the externally driven source is turned off and the cavity is “ringing” at its natural frequencies. In step 4, extractModesViaOperator.py is used to compute the excitation frequencies in the cavity at a given mode. Finally, in step 5, you will change the value of “mode”, which is defined under “Constants” to compute the dominant frequencies which are excited in the cavity at a given wavelength. We assume the maximum wavelength which can be resolved in a traditional periodic simulation is 0.2 m and denote this as lambdaMax. We then define the parameter \(k_x=\frac{mode}{12}\frac{2\pi}{lambdaMax}\) and run 25 simulations with mode =0,1,2,…,24. Finally, we set the phase shift to \(k_x \times L_x\) to ensure the correct phase shift is applied for the phase shifting periodic BC’s. In this way, we are able to compare the simulation with waveguide theory without explicitly changing the length of the simulation domain in the x -direction.
The Ping run is used to determine the lowest propagation frequency in the waveguide. In this simulation, we can analytically compute the lowest propagation frequency at a given k based on the allowable modes in a square wave guide. We can then compare the computed lowest propagation frequency with theory. However, for arbitrarily-shaped waveguides, this step is necessary since no theory is available to compute the lowest propagation frequency. We have defined two constants in order to easily transition from the “Ping” run to the “Excitation” run in Step 2. For Step 1, perform the following steps
The run has completed when you see the output, “Engine completed successfully.” A snapshot of the simulation run completion is shown in Fig. 356.
After the run has completed, click on the Visualize tab on the left side of the visualization window. After the data has loaded, click on Add a Data View and then select History. Perform the following steps to analyze the history:
In Graph 1, to see the data, click on the “Zoom” option above the plot. Left click with your mouse on the upper left corner of the graph and drag the “zoom” box to about \(0.2 \times 10^{-9}\) s (hold the left mouse button when you drag). You should see a step function in the the current density beginning at t=0 and ending abruptly after about 20 time steps. This is the “ping” that we impose on the simulation. To determine the lowest frequency mode that we excite, click the “Fourier Amplitudes (dB)” box in Graph 2. Again, zoom in on the left most portion of the plot. You will see that the first peak occurs at a frequency of about \(1.5\times 10^9\) Hz, which is the lowest cutoff frequency in the simulation and is what we find analytically using waveguide theory. Therefore, we have confirmed that VSim reproduces linear theory. You can confidently use VSim to numerically determine the lowest cutoff frequency for non-analytically solvable shapes. The visualization window after the above steps have been performed is shown in Fig. 357
From Step 1, we know that the lowest propagation frequency is \(\sim 1.5\times 10^9\) Hz. We can now check that the lowest cutoff frequency (frequency low in SincHat) is correct. The parameter FREQ_MIN is passed in to frequency low and is indeed \(\sim 1.5\times 10^9\) Hz. We can now proceed to excite the waveguide with confidence knowing that lowest excitation frequency is correct. To excite the waveguide, perform the following steps:
The purpose of Step 3 is to continue the simulation with only the E- and B- fields excited due to the externally imposed current density from Step 2. We will also save more data which we can analyze using Eigenmode analysis for Step 4.
Also, check the “Overwrite Existing Files” box. The dump range runs only over the data saved in step 3 and we are only sampling every 5 cells in the z- and y- directions which is adequate to compute the eigen modes. Double-check your entries against what is shown in Fig. 360. After you run the analyzer, you will need to scroll up to find the computed frequencies. The screen shot shown in Fig. 360 is from a visualization window that is scrolled up so that the computed frequencies can be compared with what you ran. Figure Fig. 360 shows that there are 6 modes, but two are degenerate resulting in 5 unique modes. One indication that you are using extractModesViaOperator.py correctly is that the imaginary part of the frequency (which represents attenuation of the wave) is nearly 0 or at least much smaller than the real part. The lowest excited mode is \(\sim 1.5 \times 10^9\) Hz, which is discussed further below in the context of standard waveguide theory.
Once the Eigenmode analysis is complete in Step 4, it is necessary to record the three lowest-order modes. The pre-loaded value of mode is 0, which means we are simulating \(k_x=0\). The waveguide dispersion relation is given by \(\omega^2 = k_x^2 c^2 + \omega_{mn}^2\), where \(\omega_{mn}^2 = c^2\pi^2\left( (m/a)^2 + (n/b)^2 \right)\), and where a and b are the y and z dimensions, respectively and m and n are integers. In this simulation, we analyzed the \((m,n)\) = (1,0),(0,1) and (1,1) modes. Furthermore, the frequency range that is excited lies between \(f_l = 1.5\times 10^9\) Hz (which is the lowest allowable propagation frequency) and \(f_h = 4.5\times 10^9\) Hz. Given these parameters, we expect from waveguide theory for the three lowest cutoffs to be \(\sim 1.5\times 10^9, 3\times 10^9, 3.35 \times 10^9\) Hz, which is what is found from extractModesViaOperator.py. Repeating these steps for modes 1 to 24 yields the disperion relation shown in Fig. 361. The overlap between the simulation results and theoretical values is evident in Fig. 361.
To demonstrate that the simulation results converge to the theoretical value, we have performed a series of simulations in which \(DX=DY=DZ\) are varied. The values chosen are DX = 0.205, 0.41, 0.50 and 0.615 cm. We then computed the lowest propagation frequency using extractModesViaOperator.py and plotted this frequency versus \(DX^2\). Using Richardson extrapolation, we then compute the lowest propagation frequency for \(DX^2=0\), which provides a better comparison with the theoretical frequency than a simulation with finite \(DX^2\). The field calculation error scales approximately with \(DX^2\) so a plot of frequency versus \(DX^2\) should be a line. The linear correlation between frequency and \(DX^2\) is shown in Fig. 362. The extrapolated frequency at \(DX^2=0\) is \(\sim 1.4992 \times 10^9\) Hz. The theoretical value is \(\sim 1.4990 \times 10^9\). We see from Fig. 362 that the computation of the lowest propagation frequency for the DC mode converges with order \(DX^2\), which is expected since the field solve is 2nd order accurate. Furthermore, using Richardson extrapolation, we see that the difference between theory and simulation, with \(DX^2=0\), is \(0.02\) %.
After performing the above actions, continue as follows:
The first step will be to ensure that we are driving the current density as expected and that the E- and B- fields are “ringing” as a result of driving the current density. Follow these steps to perform this check:
Your plots should like similar to Fig. 363. The current density is driven for a short time period. However, because we are driving resonant modes, the current density excites the transverse electric field and parallel magnetic fied. You can also plot eMid_0, bMid_1, and bMid_2 to compare with Fig. 363. We have driven a TE mode since eMid_0 is nearly 0.
We next wish to examine the spectral characteristics of the current density, which is driven between FREQ_MIN and FREQ_MAX. Therefore, the Fourier Transform of \(J_y\) or \(J_z\) should be greatest in this frequency range. Returning to the History visualization window, under Graphs 2, 3, and 4, change the plotted quantity to none, so that only Graph 1 shows a plot. Now check the “Fourier Amplitudes (dB)” box in the upper left corner. Finally, check the “Zoom” box on the right side of the visualization window and highlight from 0 to \(10^{10}\) which will expand the lower frequency part of the plot. After you have zoomed in on the plot, re-check the “Navigate” box. The result of these steps should lead to a plot that looks similar to Fig. 364. The driving frequencies lie between FREQ_MIN and FREQ_MAX as expected. The rate at which the Fourier signal dampens below FREQ_MIN and above FREQ_MAX depends on the Gaussian envelop and the paramater called OMEGA_SIGMA.
The result of varying mode from 0 to 24 is shown in Fig. 361. One experiment you can perform is to reproduce Fig. 361 by running 25 simulations with mode varying from 0 to 24. Each simulation takes just a few minutes so the 25 simulations takes about one hour. For each simulation record the three lowest frequencies that are excited using extractModesViaOperator.py.
Another experiment would be to change the dimensions of the waveguide. The Constants a and b are used to determine the lowest frequency that will propagate in the waveguide. Therefore, changing a and b will automatically compute FREQ_CUTOFF_TE. You will then need to change BGNY, ENDY, BGNZ, and ENDZ accordingly. Finally, you will need to modify the dimensions and position of the primitives constructed under Geometries which are used to construct the waveguide.
A third experiment would be to modify FREQ_MIN and and FREQ_MAX and compute the dispersion curve for these new values. No mode will propagate below FREQ_CUTOFF_TE so do not set FREQ_MIN below FREQ_CUTOFF_TE.
Lastly, you can try to excite a TM mode instead of a TE mode.