Changes
EM.Ferma
,/* Variety of Physical Objects in EM.Ferma */
[[Image:Splash-static.jpg|right|720px]]<strong><font color="#2603c4" size="4">Electrostatic, Magnetostatic & Thermal Solvers For DC And Low Frequency Simulations</font></strong><table><tr><td>[[image:Cube-icon.png | link=Getting_Started_with_EM.Cube]] [[image:cad-ico.png | link=Building_Geometrical_Constructions_in_CubeCAD]] [[image:fdtd-ico.png | link=EM.FermaTempo]] is [[image:prop-ico.png | link=EM.CUBE's 3D electrostatic and quasiTerrano]] [[image:planar-static solverico. png | link=EM.Picasso]] [[image:metal-ico.png | link=EM.Libera]] [[image:po-ico.png | link=EM.Illumina]]</td><tr></table>[[Image:Tutorial_icon.png|30px]] '''[[EM.Cube#EM.Ferma_Documentation | EM.Ferma Tutorial Gateway]]'''
== Methods Of Electrostatics & Quasistatics = EM.Ferma in a Nutshell ===
<mathtable> \mathbf{B} = \frac{\mu_0}{4\pi}\int_C \frac{I d\mathbf{l} \times \mathbf{\hat r}}{<tr><td>[[Image:Magnet lines1.png|\mathbf{r}thumb|^2}left|400px| Vector plot of magnetic field distribution in a cylindrical permanent magnet.]]</td></tr></mathtable>
== Sources in = EM.Ferma as the Static Module of EM.Cube ===
=== Mesh generation === <ul> <li> Fixed-size brick cells</li></ul> === 3D Electrostatic & Magnetostatic Simulation === <ul> <li> Finite difference solution of Laplace and Poisson equations for the electric scalar potential with Dirichlet and Neumann domain boundary conditions </li> <li> Finite difference solution of Laplace and Poisson equations for the magnetic vector potential with Dirichlet domain boundary conditions </li> <li> Calculation of electric scalar potential and electric field</li> <li> Calculation of magnetic vector potential and magnetic field</li> <li> Calculation of electric flux over user defined flux boxes and capacitance</li> <li> Calculation of magnetic flux over user defined flux surfaces and inductance</li> <li> Calculation of electric and magnetic energies, Ohmic power loss and resistance</li> <li> Parametric sweep with variable object properties or source parameters</li></ul> === 2D Quasi-Static Simulation === <ul> <li> 2D Finite difference solution of cross section of transmission line structures</li> <li> 3D domain solution as well as 2D solution of a longitudinally infinite version of the structure defined on a 2D plane </li> <li> Calculation of electric potential and electric field distribution</li> <li> Parametric sweep of transmission line's geometric and material parameters</li> <li> Optimization of transmission line's parameters for impedance design</li></ul> === Steady-State Thermal Simulation === <ul> <li> Finite difference solution of Laplace and Poisson equations for the temperature with Dirichlet and Neumann domain boundary conditions </li> <li> Calculation of temperature and heat flux density</li> <li> Calculation of thermal energy density on field sensor planes</li> <li> Calculation of thermal flux over user defined flux boxes</li> <li> Calculation of thermal energy</li></ul> === Data Generation & Visualization === <ul> <li> Electric and magnetic field intensity and vector plots on planes</li> <li> Electric and magnetic potential intensity plots on planes</li> <li> Temperature and heat flux intensity and vector plots on planes</li> <li> Electric and magnetic energy density, dissipated power density and thermal energy density plots on planes</li> <li> Animation of field and potential plots after parametric sweeps</li> <li> Graphs of characteristic impedance and effective permittivity of transmission line structures vs. sweep variables</li> <li> Custom output parameters defined as mathematical expressions of standard outputs</li></ul> == Building the Physical Structure in EM.Ferma == === Variety of Physical Objects in EM.Ferma === The simplest static problems involve a charge source in the free space that produces an electric field, or a current source in the free space that produces a magnetic field. In such cases, the only applicable boundary conditions are defined at the boundary of the computational domain. As soon as you introduce a dielectric object next to a charge source or a magnetic (permeable) material next to a current source, you have to deal with a complex boundary value problem. In other words, you need to solve the electric or magnetic Poisson equation subject to the domain boundary conditions as well as material interface boundary conditions. The simplest thermal problem involves one or more thermal plates held at fixed temperatures. Once you introduce material blocks, you have to enforce conductive and convective boundary conditions at the interface between different materials and air. EM.Ferma uses the Finite Difference (FD) technique to find a numerical solution of your static boundary value problem. [[EM.Ferma]] offers the following types of physical objects: {| borderclass="0wikitable"|+'''Provinces of the Netherlands'''
|-
|-
| style="width:30px;" | [[File:pec_group_icon.png]]
| style="width:200px;" | [[Glossary of EM.Cube's Materials, Sources, Devices & Other Physical Object Types#Fixed-Potential PEC |Fixed-Potential Perfect Electric Conductor (PEC)]]
| style="width:300px;" | Modeling perfect metals with a fixed voltage
| style="width:100px;" | Solid and surface objects
| style="width:250px;" | Can be considered an electric source if the fixed voltage is nonzero
|-
| style="width:30px;" | [[File:diel_group_icon.png]]
| style="width:200px;" | [[Glossary of EM.Cube's Materials, Sources, Devices & Other Physical Object Types#Dielectric Material |Dielectric/Magnetic Material]]
| style="width:300px;" | Modeling any homogeneous or inhomogeneous material
| style="width:100px;" | Solid objects
| style="width:250px;" | non-source material
|-
| style="width:30px;" | [[File:aniso_group_icon.png]]
| style="width:200px;" | [[Glossary of EM.Cube's Materials, Sources, Devices & Other Physical Object Types#Volume Charge |Volume Charge]]
| style="width:300px;" | Modeling volume charge sources with a fixed charge density or an expression in the global coordinates (x,y,z)
| style="width:100px;" | Solid objects
| style="width:250px;" | Acts as an electric source
|-
| style="width:30px;" | [[File:voxel_group_icon.png]]
| style="width:200px;" | [[Glossary of EM.Cube's Materials, Sources, Devices & Other Physical Object Types#Volume Current |Volume Current]]
| style="width:300px;" | Modeling volume current sources with a fixed volume current density vector or expressions in the global coordinates (x,y,z)
| style="width:100px;" | Solid objects
| style="width:250px;" | Acts as a magnetic source
|-
| style="width:30px;" | [[File:pmc_group_icon.png]]
| style="width:200px;" | [[Glossary of EM.Cube's Materials, Sources, Devices & Other Physical Object Types#Permanent Magnet |Permanent Magnet]]
| style="width:300px;" | Modeling permanent magnet sources with a fixed magnetization vector or expressions in the global coordinates (x,y,z)
| style="width:100px;" | Solid objects
| style="width:250px;" | Acts as a magnetic source
|-
| style="width:30px;" | [[File:thin_group_icon.png]]
| style="width:200px;" | [[Glossary of EM.Cube's Materials, Sources, Devices & Other Physical Object Types#Wire Current |Wire Current]]
| style="width:300px;" | Modeling wire current sources
| style="width:100px;" | Line and polyline objects
| style="width:250px;" | Acts as a magnetic source
|-
| style="width:30px;" | [[File:pec_group_icon.png]]
| style="width:200px;" | [[Glossary of EM.Cube's Materials, Sources, Devices & Other Physical Object Types#Fixed-Temperature PTC |Fixed-Temperature Perfect Thermal Conductor (PTC)]]
| style="width:300px;" | Modeling isothermal surfaces with a fixed temperature
| style="width:100px;" | Solid and surface objects
| style="width:250px;" | Can be considered a thermal source if the fixed temperature is different than the ambient temperature (shares the same navigation tree node as PEC object)
|-
| style="width:30px;" | [[File:diel_group_icon.png]]
| style="width:200px;" | [[Glossary of EM.Cube's Materials, Sources, Devices & Other Physical Object Types#Dielectric Material |Insulator Material]]
| style="width:300px;" | Modeling any homogeneous or inhomogeneous material
| style="width:100px;" | Solid objects
| style="width:250px;" | non-source material (shares the same navigation tree node as dielectric material)
|-
| style="width:30px;" | [[File:aniso_group_icon.png]]
| style="width:200px;" | [[Glossary of EM.Cube's Materials, Sources, Devices & Other Physical Object Types#Volume Heat Source |Volume Heat Source]]
| style="width:300px;" | Modeling volume heat sources with a fixed heat density or an expression in the global coordinates (x,y,z)
| style="width:100px;" | Solid objects
| style="width:250px;" | Acts as a thermal source (shares the same navigation tree node as volume charge)
|-
| style="width:30px;" | [[File:Virt_group_icon.png]]
| style="width:200px;" | [[Glossary of EM.Cube's Materials, Sources, Devices & Other Physical Object Types#Virtual_Object_Group | Virtual Object]]
| style="width:300px;" | Used for representing non-physical items
| style="width:100px;" | All types of objects
| style="width:250px;" | None
|}
Click on each category to learn more details about it in the [[Glossary of EM.Cube's Materials, Sources, Devices & Other Physical Object Types]]. == = Grouping Objects by Material or Source Type === Your physical structure in EM.Ferma is typically made up of some kind of source object either in the free space or in the presence of one or more material objects. EM.Ferma's electrostatic and magnetostatic or thermal simulation engines then discretize the entire computational domain including these source and material objects and solve the Laplace or Poisson equations to find the electric or magnetic fields or temperature everywhere in the computational domain. All the geometric objects in the project workspace are organized together into object groups which share the same properties including color and electric or magnetic parameters. It is recommended that you first create object groups, and then draw new objects under the active group. To create a new object group, right-click on its category name in the "Physical Structure" section of the navigation tree and select one of the "Insert New Group..." items from the contextual menu. However, if you start a new EM.Ferma project from scratch, and start drawing a new object without having previously defined any object groups, a new default "Fixed-Potential PEC" object group with a zero voltage is created and added to the navigation tree to hold your new geometric object. It is important to note that there is a one-to-one correspondence between electrostatic and thermal simulation entities: {| class="wikitable"|-! scope="col"| Electrostatic Item! scope="col"| Corresponding Thermal Item|-| style="width:200px;" | Electric Scalar Potential| style="width:200px;" | Temperature|-| style="width:200px;" | Electric Field| style="width:200px;" | Heat Flux Density|-| style="width:200px;" | Perfect Electric Conductor| style="width:200px;" | Perfect Thermal Conductor|-| style="width:200px;" | Dielectric Material| style="width:200px;" | Insulator Material|-| style="width:200px;" | Volume Charge| style="width:200px;" | Volume Heat Source|} {{Note|Electrostatic and thermal solvers share the same material categories on the navigation tree. This means that PEC objects are treated as PTC objects, dielectric objects are treated as insulator objects and volume charges are treated as volume heat sources when the thermal solver is enabled.}} Once a new object group node has been created in the navigation tree, it becomes and remains the "Active" object group, which is always listed in bold letters. When you draw a new geometric object such as a box or a sphere, its name is added under the currently active object group. There is only one object group that is active at any time. Any group can be made active by right-clicking on its name in the navigation tree and selecting the '''Activate''' item of the contextual menu. [[Image:Info_icon.png|30px]] Click here to learn more about '''[[Building Geometrical Constructions in CubeCAD#Transferring Objects Among Different Groups or Modules | Moving Objects among Different Groups]]'''. <table><tr><td> [[Image:STAT MAN1.png|thumb|left|480px|EM.Ferma's navigation tree.]] </td></tr></table> === A Note on Material and Source Types in EM.Ferma === In [[EM.Cube]]'s other modules, material types are categorized under the "Physical Structure" section of the navigation tree, and sources are organized under a separate "Sources" section. In those modules, all the geometric objects you draw in your project workspace typically represent material bodies. All of [[EM.Cube]] modules except for EM.Ferma require at least one excitation source to be selected from the "Sources" section of the navigation tree before you can run a simulation. In EM.Ferma, materials and sources are all lumped together and listed under the "Physical Structure" section of the navigation tree. In other words, there is no separate "Sources" section. For example, you can define default zero-potential perfect electric conductors (PEC) in your project to model metal objects. You can also define fixed-potential PEC objects with a nonzero voltage, which can effectively act as a voltage source for your boundary value problem. In this case, you will solve the Lapalce equation subject to the specified nonzero potential boundary values. Both types of PEC objects are defined from the same PEC node of the navigation tree by assigning different voltage values. Charge and current sources are also defined as geometric objects, and you have to draw them in the project workspace just like other material objects. == EM.Ferma's Computational Domain == ===The Domain Box=== In EM.Ferma, the Poisson or Laplace equations are solved subject to boundary conditions using the Finite Difference technique. As a result, you need to specify a finite computational domain and then specify the domain boundary conditions. EM.Ferma's computational domain defines where the domain boundary condition will be specified. A default domain box is always placed in the project workspace as soon as you draw your first object. The domain can be seen as a blue cubic wireframe that surrounds all of the CAD objects in the project workspace. To modify the domain settings, click the Domain button of the Simulate Toolbar or right-click on "3D Static Domain" entry in the Navigation Tree and select "Domain Settings..." from the contextual menu. In the Domain Settings Dialog, the computational domain can be defined in two different ways: Default and Custom. The default type places an enclosing box with a specified offset from the largest bounding box of your project's CAD objects. The default offset value is 20 project units, but you can change this value arbitrarily. The custom type defines a fixed domain box by specifying the coordinates of its two opposite corners labeled Min and Max in the world coordinate system. <table><tr> <td> [[Image:Qsource5.png|thumb|left|480px|EM.Ferma's Domain Settings dialog.]] </td></tr></table> ===Domain Boundary Conditions === *EM.Ferma allows you to specify the electric potential boundary conditions on the domain box. Two options are available. The Dirichlet boundary condition is the default option and is specified as a fixed potential value on the surface of the domain walls. By default, this value is 0 Volts. The Neumann boundary condition specifies the normal derivative of the electric scalar potential on the surface of the domain walls. This is equivalent to a constant normal electric field component on the domain walls and its value is specified in V/m. *The magnetostatic simulation engine always assumes Dirichlet domain boundary conditions and sets the values of the magnetic vector potential to zero on all the domain walls. *EM.Ferma provides two options for thermal boundary conditions on the domain box. The Dirichlet boundary condition is the default option and is specified as a fixed temperature value on the surface of the domain walls. By default, this value is 0°C. The Neumann boundary condition specifies the normal derivative of the temperature on the surface of the domain walls. This is equivalent to a constant heat flux passing through the domain walls and its value is specified in W/m<sup>2</sup>. A zero heat flux means a perfectly insulated domain box and is known as the adiabatic boundary condition. To modify the boundary conditions, right-click on "Boundary Conditions" in the navigation tree, and select "Boundary Conditions..." from the contextual menu to open the Boundary Conditions Dialog. When you switch from the electrostatic-magnetostatic solver to the thermal solver in EM.Ferma's Run Simulation dialog, it automatically checks the box labeled '''Treat as a Thermal Structure''' in the Boundary Conditions dialog. Conversely, if you check this box in the Boundary Conditions dialog, the solver type is set to the thermal solver in the Simulation Run dialog. In the "Global Thermal Properties" section of the Boundary Conditions dialog, you can set the values of the ambient temperature in °C, thermal conductivity of the environment in W/(m.K) and the convective coefficient in W/(m<sup>2</sup>.K). You can also disable the enforcement of the convective boundary condition on the surface of solid insulator objects. <table><tr> <td> [[Image:fermbc.png|thumb|left|480px|EM.Ferma's Boundary Conditions dialog.]] </td></tr></table> == EM.Ferma's Simulation Data & Observables == At the end of an electrostatic simulation, the electric field vector and electric scalar potential values are computed at all the mesh grid points of the entire computational domain. At the end of an magnetostatic simulation, the magnetic field vector and magnetic vector potential values are computed at all the grid nodes. At the end of a thermal simulation, the temperature and heat flux vector are computed at all the mesh grid points of the entire computational domain. Besides the electric and magnetic fields and temperature, EM.Ferma can compute a number of field integral quantities such as voltage, current, flux, energy, etc. The field components, potential values and field integrals are written into output data files and can be visualized on the screen or graphed in Data Manager only if you define a field sensor or a field integral observable. In the absence of any observable defined in the navigation tree, the static simulation will be carried out and completed, but no output simulation data will be generated. EM.Ferma offers the following types of output simulation data: {| class="wikitable"|-! scope="col"| Icon! scope="col"| Simulation Data Type! scope="col"| Observable Type! scope="col"| Applications|-| style="width:30px;" | [[File:fieldsensor_icon.png]]| style="width:150px;" | Near-Field Distribution Maps| style="width:150px;" | [[Glossary of EM.Cube's Simulation Observables & Graph Types#Near-Field_Sensor_Observable |Near-Field Sensor]] | style="width:450px;" | Computing electric and magnetic field components, electric scalar potential and magnitude of magnetic vector potential on a planar cross section of the computational domain |-| style="width:30px;" | [[File:fieldsensor_icon.png]]| style="width:150px;" | Electric and Magnetic Energy and Dissipated Power Density Maps | style="width:150px;" | [[Glossary of EM.Cube's Simulation Observables & Graph Types#Near-Field_Sensor_Observable |Near-Field Sensor]] | style="width:450px;" | Computing electric and magnetic energy densities and dissipated power density on a planar cross section of the computational domain |-| style="width:30px;" | [[File:fieldsensor_icon.png]]| style="width:150px;" | Temperature and Heat Flux Distribution Maps| style="width:150px;" | [[Glossary of EM.Cube's Simulation Observables & Graph Types#Near-Field_Sensor_Observable |Near-Field Sensor]] | style="width:450px;" | Computing temperature and heat flux components on a planar cross section of the computational domain |-| style="width:30px;" | [[File:fieldsensor_icon.png]]| style="width:150px;" | Thermal Energy Density Maps | style="width:150px;" | [[Glossary of EM.Cube's Simulation Observables & Graph Types#Near-Field_Sensor_Observable |Near-Field Sensor]] | style="width:450px;" | Computing thermal energy density on a planar cross section of the computational domain |-| style="width:30px;" | [[File:field_integ_icon.png]]| style="width:150px;" | Field Integral Quantities| style="width:150px;" | [[Glossary of EM.Cube's Simulation Observables & Graph Types#Static_Field_Integral_Observable | Static Field Integral]] | style="width:450px;" | Computing line, surface and volume integrals of the electric and magnetic fields and heat flux |} Click on each category to learn more details about it in the [[Glossary of EM.Cube's Simulation Observables & Graph Types]]. <table><tr> <td> [[Image:Ferma L1 Fig15.png|thumb|left|640px|Electric field distribution of a spherical charge on a horizontal field sensor plane.]] </td></tr> <tr> <td> [[Image:Ferma L1 Fig16.png|thumb|left|640px|Electric scalar potential distribution of a spherical charge on a horizontal field sensor plane.]] </td></tr></table> The table below list the different types of field integrals and their definitions: {| class="wikitable"|-! scope="col"| Field Integral! scope="col"| Definition! scope="col"| Output Data File|-! scope="row"| Voltage| <math> V = - \int_C \mathbf{E(r)} . \mathbf{dl} </math>| voltage.DAT|-! scope="row"| Current| <math> I = \oint_{C_o} \mathbf{H(r)} . \mathbf{dl} </math>| current.DAT|-! scope="row"| Conduction Current| <math> I_{cond} = \int\int_S \mathbf{J(r)} . \mathbf{ds} = \int\int_S \sigma \mathbf{E(r)} . \mathbf{ds} </math>| conduction_current.DAT|-! scope="row"| Electric Flux| <math> \Phi_E = \int\int_{S_o} \mathbf{D(r)} . \mathbf{ds} = \int\int_{S_o} \epsilon \mathbf{E(r)} . \mathbf{ds} </math>| flux_E.DAT|-! scope="row"| Magnetic Flux| <math> \Phi_H = \int\int_S \mathbf{B(r)} . \mathbf{ds} = \int\int_S \mu \mathbf{H(r)} . \mathbf{ds} </math>| flux_H.DAT|-! scope="row"| Electric Energy| <math> W_E = \frac{1}{2} \int \int \int_V \epsilon \vert \mathbf{E(r)} \vert ^2 dv </math>| energy_E.DAT|-! scope="row"| Magnetic Energy| <math> W_H = \frac{1}{2} \int\int\int_V \mu \vert \mathbf{H(r)} \vert ^2 dv </math>| energy_H.DAT|-! scope="row"| Ohmic Power Loss| <math> P_{ohmic} = \int\int\int_V \sigma \vert \mathbf{E(r)} \vert ^2 dv </math>| ohmic.DAT|-! scope="row"| Capacitance| <math> C = \Phi_E/V = \int\int_{S_o} \epsilon \mathbf{E(r)} . \mathbf{ds} / \int_C \mathbf{E(r)} . \mathbf{dl} </math>| capacitance.DAT|-! scope="row"| Capacitance (Alternative)| <math> C = 2W_E/V^2 = 2 \int \int \int_V \epsilon \vert \mathbf{E(r)} \vert ^2 dv / \left( \int_C \mathbf{E(r)} . \mathbf{dl} \right)^2</math>| capacitance.DAT|-! scope="row"| Self-Inductance| <math> L = \Phi_H/I = \int\int_S \mu \mathbf{H(r)} . \mathbf{ds} / \oint_{C_o} \mathbf{H(r)} . \mathbf{dl} </math>| inductance.DAT|-! scope="row"| Self-Inductance (Alternative)| <math> L = 2W_M/I^2 = 2 \int \int \int_V \mu \vert \mathbf{H(r)} \vert ^2 dv / \left( \oint_{C_o} \mathbf{H(r)} . \mathbf{dl} \right)^2</math>| inductance.DAT|-! scope="row"| Mutual Inductance| <math> M = \Phi_H^{\prime}/I = \int\int_{S^{\prime}} \mu \mathbf{H(r)} . \mathbf{ds} / \oint_{C_o} \mathbf{H(r)} . \mathbf{dl} </math>| mutual_inductance.DAT|-! scope="row"| Resistance| <math> R = V/I_{cond} = - \int_C \mathbf{E(r)} . \mathbf{dl} / \int\int_S \sigma \mathbf{E(r)} . \mathbf{ds} </math>| resistance.DAT|-! scope="row"| Resistance (Alternative 1)| <math> R = V^2/P_{ohmic} = \left( \int_C \mathbf{E(r)} . \mathbf{dl} \right)^2 / \int\int\int_V \sigma \vert \mathbf{E(r)} \vert ^2 dv </math>| resistance.DAT|-! scope="row"| Resistance (Alternative 2)| <math> R = P_{ohmic}/I_{cond}^2 = \int\int\int_V \sigma \vert \mathbf{E(r)} \vert ^2 dv / \left( \int\int_S \sigma \mathbf{E(r)} . \mathbf{ds} \right)^2</math>| resistance.DAT|-! scope="row"| Thermal Flux| <math> \Phi_T = \int\int_{S_o} \mathbf{q(r)} . \mathbf{ds} </math>| flux_T.DAT|-! scope="row"| Thermal Energy| <math> W_T = Q = \int \int \int_V \rho_V c_p \left( T\mathbf{(r)} - T_{env} \right) dv </math>| energy_T.DAT|} <table><tr> <td> [[Image:Qsource13.png|thumb|left|480px|Defining the capacitance observable in the field integral dialog.]]</td></tr> <tr> <tr> <td> [[Image:Qsource11.png|thumb|left|480px|The electric flux box for calculation of charge around a capacitor.]] </td></tr> <tr> <td> [[Image:Qsource12.png|thumb|left|480px|A line defining the voltage path for calculation of voltage between capacitor plates.]] </td></tr></table> == Discretizing the Physical Structure in EM.Ferma == ===The Static Mesh=== The Finite Difference technique discretizes the computational domain using a 3D rectangular grid. EM.Ferma generates a fixed-cell mesh. This means that the extents of the mesh cells along the principal axes are fixed: Δx, Δy, Δz. By default, the mesh cell size is set to one unit project along all the three directions (with Δx = Δy = Δz). To modify the cell size, click the Mesh Settings button of the Simulate Toolbar or right-click on "Static Mesh" in the Navigation Tree, and select "Mesh Settings..." from the contextual menu to open the Mesh Settings Dialog. {{Note|To obtain accurate results, it is highly recommended to use a square mesh as much as possible.}} [[Image:Info_icon.png|30px]] Click here to learn more about '''[[Preparing_Physical_Structures_for_Electromagnetic_Simulation#Working_with_EM.Cube.27s_Mesh_Generators | Working with Mesh Generator]]'''. [[Image:Info_icon.png|30px]] Click here to learn more about the properties of '''[[Glossary_of_EM.Cube%27s_Simulation-Related_Operations#Fixed-Cell_Brick_Mesh | EM.Ferma's Fixed-Cell Brick Mesh Generator]]'''. <table><tr> <td> [[Image:Qsource4.png|thumb|350px|EM.Ferma's Mesh Settings dialog.]] </td></tr></table> <table><tr> <td> [[Image:Qsource2.png|thumb|360px|Geometry of a spherical charge source and the enclosing domain box.]] </td><td> [[Image:Qsource3.png|thumb|360px|Fixed-cel mesh of the spherical charge object.]] </td></tr></table> == Running Static Simulations in EM.Ferma == === EM.Ferma's Simulation Modes === [[EM.Ferma]] currently offers three different simulation modes as follows: {| class="wikitable"|-! scope="col"| Simulation Mode! scope="col"| Usage! scope="col"| Number of Engine Runs! scope="col"| Frequency ! scope="col"| Restrictions|-| style="width:120px;" | [[#Running an Electrostatic or Magnetostatic Analysis | Analysis]]| style="width:270px;" | Simulates the physical structure "As Is"| style="width:100px;" | Single run| style="width:200px;" | N/A| style="width:150px;" | None|-| style="width:120px;" | [[Parametric_Modeling_%26_Simulation_Modes_in_EM.Cube#Running_Parametric_Sweep_Simulations_in_EM.Cube | Parametric Sweep]]| style="width:270px;" | Varies the value(s) of one or more project variables| style="width:100px;" | Multiple runs| style="width:200px;" | N/A| style="width:150px;" | None|-| style="width:120px;" | [[Parametric_Modeling_%26_Simulation_Modes_in_EM.Cube#Performing_Optimization_in_EM.Cube | Optimization]]| style="width:270px;" | Optimizes the value(s) of one or more project variables to achieve a design goal | style="width:100px;" | Multiple runs | style="width:200px;" | N/A| style="width:150px;" | None|} === Running an Electrostatic, Magnetostatic or Thermal Analysis === [[EM.Ferma]] has three independent but functionally similar static simulation engines: Electrostatic, Magnetostatic and Thermal. The electrostatic engine solves the electric form of Poisson's equation for electric scalar potential subject to electric field boundary conditions, in the presence of electric sources (volume charges and fixed-potential PEC blocks) and dielectric material media. The magnetostatic engine solves the magnetic form of Poisson's equation for magnetic vector potential subject to magnetic field boundary conditions, in the presence of magnetic sources (wire and volume currents and permanent magnetic blocks) and magnetic material media. The thermal engine solves the thermal form of Poisson's equation for steady-state temperature subject to thermal boundary conditions, in the presence of heat sources (volume sources and fixed-temperature PTC blocks) and insulator material media. To run a static simulation, first you have to open the Run Dialog. This is done by clicking the "Run" button of the Simulate Toolbar, or by selecting the "Run" item of the Simulate Menu, or simply using the keyboard shortcut "Ctrl+R". There are two available options for the simulation engine: '''Electrostatic-Magnetostatic Solver''' and '''Steady-State Thermal Solver'''. Clicking the Run button of this dialog starts a static analysis. A separate window pops up which reports the progress of the current simulation. <table><tr> <td> [[Image:Ferma L1 Fig11.png|thumb|left|600px|EM.Ferma's Simulation Run dialog.]] </td></tr></table> In EM.Ferma you don't have to choose between the electrostatic or magnetostatic simulation engines. The program looks at the types of sources and material objects present in your project workspace and then it determines whether an electrostatic analysis or a magnetostatic analysis or possibly both should be performed. When there are only electric sources present, you will get nonzero electric fields and zero magnetic fields. When there are only magnetic sources present, you will get nonzero magnetic fields and zero electric fields. On the other hand, since the electrostatic and thermal solvers share the same navigation resources, you can run only one of the two engines at a time. By default, the electrostatic solver is enabled. An "Analysis" is the simplest simulation mode of EM.Ferma. It is a single-shot finite difference solution of your static problem. The physical structure of your project workspace is first discretized using a fixed-cell mesh and the Poisson equation is solved numerically everywhere in the computational domain. The field and potential values at each mesh node are computed, and the specified observables are written into data files. The other available simulation modes, parametric sweep and optimization, involve multiple runs of the static solvers. ===Static Simulation Engine Settings===
<table><tr> <td> [[Image:Qsource7.png|thumb|left|480px|EM.Ferma's computational domain defines where the boundary condition will be specified. It can be seen in figure 1 as a green cubic wireframe that surrounds all of the CAD objects in the model. To modify the domain boundary, find the "3D Static Domain" entry in the navigation tree, right-click on it, and select "Domain Engine Settings...". The domain dialog will appear. In the domain dialog, the domain boundary can be specified in terms of either a custom, fixed location, or as custom offsets from CAD objects in the scene.]]</td></tr></table>
=== Boundary Condition =The 2D Quasi-Static Simulation Mode==
EM.Ferma allows 's electrostatic simulation engine features a 2D solution mode where your physical model is treated as a longitudinally infinite structure in the user direction normal to either specify the potential specified "2D Solution Plane". A 2D solution plane is defined based on the boundary (Dirichlet boundary condition), or specify the normal derivative on the boundary (Neumann boundary condition) via a specified field strength"Field Sensor" definition that already exists in your project. To modify the boundary conditionexplore EM.Ferma's 2D mode, find right-click on '''2D Solution Planes''' in the "Boundary ConditionsComputational Domain" on section of the navigation tree, and select "Boundary Conditions'''2D Domain Settings..."''' from the contextual menu. The user will be prompted with In the 2D Static Domain dialog seen , check the checkbox labeled "Reduce the 3D Domain to a 2D Solution Plane". The first field sensor observable in figurethe navigation tree is used for the definition of the 2D solution plane.