Add a Dependent Variable Field node (

) under
Definitions >
Equation Contributions in a model component to declare a scalar or vector dependent variable field on a selection. You can also add the same type of node to a physics interface as an auxiliary equation contribution. The only difference is how the node is treated in study step settings: a node under
Definitions can be controlled individually; a node inside a physics interface is treated as part of the interface.
The basic field name is the same as the node’s
Name. The field name is the one that appears on
Field nodes in the solver sequence, and which must be used as field arguments to, for example the
var(<expr>,<field1>,<field2>,...) operator.
For a scalar field, the single field variable name coincides with the field name. A vector field instead defines a number of
component variables. The component names can be specified for vector variables defined on a single frame. For multiple frames, the component variable names are auto-generated. Component names are created by appending a frame coordinate name to the field name. Also partial derivative variable names are created in the same way.
The Settings window contains the following sections:
Select the Geometric entity level of the selection where a dependent variable field is to be defined. When adding the node from
Definitions >
Equation Contributions the default level is the
Domain level. When the node is added inside a physics interface, the domain level is set depending on whether it was added as a domain, boundary, edge or point condition. It is still possible to change the domain level.
If the component where the dependent variable field is added contains attached extra dimensions, optionally select a valid attached dimension from the Extra dimension attachment list and specify a selection in the attached extra dimension. This will also filter the base selection, which will be applicable only where the extra dimension has been attached.
First select the Field type. By default, dependent variable fields are
Scalar, which also includes scalar densities. To instead create a vector field, choose
In-plane vector field,
Out-of-plane vector field, or
Three-component vector field depending on the desired number of components.
For a vector field, select a Component frame with respect to which component variables will be defined. When a single frame is selected, also enter variable names for all
Components. Default names will have been auto-generated based on the base field name and the coordinate variables for the default
Spatial frame. You can also select
All frames, covariant or
All frames, contravariant to define separate component variables on the mesh, geometry, material, and spatial frames. The component names are in this case auto-generated based on the field name and the coordinate variable names in each frame. Note that vector shape functions are intrinsically covariant and therefore remove the contravariant option.
Using a density shape function to define a scalar field also requires a Component frame setting. In this case, the base field name is used as variable name for the single density component as long as a single component frame is selected. When selecting
All frames, covariant, the density component name for each frame is created by appending all three coordinate variable names to the field base name. For example, a density field
V will typically have the single component
Vxyz in spatial frame and
VXYZ in material frame.
Specify an Initial value expression for each component of the field. When time derivatives are defined by a second-order time-dependent solver, an
Initial time derivative expression must also be given.
Click the Select Dependent Variable Quantity button (

) to open the
Physical Quantity dialog to browse to find a physical quantity to use. You can also type a search string in the text field at the top of the dialog and then click the
Filter button (

) to filter the list of physical quantities. For example, type
potential and click the
Filter button to only list physical quantities that represent some kind of potential.
Alternatively, click the Define Dependent Variable Unit button (

) to edit the unit directly in the
Unit column, typing a unit to define the dependent variable quantity. The
Quantity column then shows
Custom unit.
First select a Shape function type. Which options are available depends on the geometry dimension, the geometric entity level of the current selection, and whether there is an extra dimension attached to the selection. The default is
Lagrange shape functions.
Choose a fixed Element order from the list of orders allowed for the selected shape function and selection, or choose
User defined to show an
Order field where you can enter a parameter expression. The default order is
Quadratic when allowed, otherwise the lowest allowed order. A user-defined order expression must always evaluate to an integer corresponding to one of the allowed orders. The purpose of the
User defined option is only to make it easier to control the order programmatically, for example from a
Parametric Sweep study step.
Shape functions can in addition to the field variable components also define variables representing partial derivatives with respect to position. For most scalar shape functions, you can choose from Define derivative variables on frame to define such derivatives with respect to a single frame, or for all frames. Vector shape functions in general only define partial derivatives with respect to the frame to which its components refer. For example a vector field using
Curl shape functions and named components in the spatial frame will always define partial derivatives as well as its special curl variable with respect to the spatial frame. When components are auto-generated for all frames, derivative names will be generated only with respect to the same frame as each component. That is, auto-generated variable names will never use mixed-frame indices.
|
Define derivative variables on frame only controls whether variables are declared for the partial derivatives. Such variables can be used in equations and expressions as a shorthand for the more general differentiation operator syntax d(<var>,<coord>). The operator syntax is, however, always valid for coordinates in any frame whether corresponding variables have been declared or not. The derivative may in that case be expanded internally using the chain rule, which may be less computationally efficient.
|
|
Note the behavior of the divergence variable defined by Divergence shape functions. This variable is not a true scalar, but a covariant 3-index tensor component that transforms like a scalar density. It therefore has different values in different frames. Its variable name is auto-generated by appending all three coordinate variable names to the field name. For example the divergence of a field D with components Dx, Dy, Dz in spatial frame is called Dxyz.
|
By default, Time derivatives are defined
From solver. Time derivative variables will then be computed as the time derivative of a time-dependent solution or zero if the solution is not time-dependent. Choose
Frequency domain to define time derivatives using a time-harmonic assumption with the specified
Frequency expression. For example, the time derivative of a DOF named
u will be
ut = 2πifu where
f is the specified frequency. Choose
Off to turn time derivative variables off. The time derivative variable name, if it exists, will still be interpreted as a time derivative. This allows manually redefining the time derivatives of global DOFs using, for example, a global
Variables node.
The equations and solution vector in COMSOL Multiphysics automatically become complex-valued as soon as a non-zero imaginary part is found in some equation. This normally makes all dependent variables complex-valued. Enabling Split complex variables in real and imaginary parts in a
Compile Equations solver node reformulates the equations internally in terms of separate real and imaginary degrees of freedom. It is then possible to select for each field whether it allows a nonzero imaginary part.
Set the Value type when using splitting of complex variables to decide how degrees of freedom should be declared when
Split complex variables in real and imaginary parts has been enabled. The default setting,
Complex, will lead to the declaration of both real and imaginary degrees of freedom. The specified DOF names will therefore be complex variables. Select
Real to only declare real DOFs, guaranteeing that the DOF names are real-valued variables.