Damped Cantilever Beam PDF
Damped Cantilever Beam PDF
Damped Cantilever Beam PDF
User's Guide
R2019b
How to Contact MathWorks
Phone: 508-647-7000
Getting Started
1
Partial Differential Equation Toolbox Product Description . . . 1-2
Key Features . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-2
v
Geometry Function for a Circle . . . . . . . . . . . . . . . . . . . . . . . 2-14
Arc Length Calculations for a Geometry Function . . . . . . . . . 2-16
Geometry Function Example with Subdomains and a Hole . . 2-29
Nested Function for Geometry with Additional Parameters . . 2-32
vi Contents
View, Edit, and Delete PDE Coefficients . . . . . . . . . . . . . . . . 2-109
View Coefficients . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-109
Delete Existing Coefficients . . . . . . . . . . . . . . . . . . . . . . . . 2-111
Change a Coefficient Assignment . . . . . . . . . . . . . . . . . . . . 2-112
vii
Mesh Data . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-171
Solving PDEs
3
von Mises Effective Stress and Displacements: PDE Modeler
App . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-3
viii Contents
Thermal Deflection of Bimetallic Beam . . . . . . . . . . . . . . . . . 3-139
DC Conduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-173
ix
Poisson's Equation with Point Source and Adaptive Mesh
Refinement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-227
x Contents
Surface Plot . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-325
2-D Slices Through 3-D Geometry . . . . . . . . . . . . . . . . . . . . 3-328
Contour Slices Through 3-D Solution . . . . . . . . . . . . . . . . . 3-333
Plots of Gradients and Streamlines . . . . . . . . . . . . . . . . . . . 3-340
xi
Functions — Alphabetical List
5
xii Contents
1
Getting Started
Partial Differential Equation Toolbox provides functions for solving structural mechanics,
heat transfer, and general partial differential equations (PDEs) using finite element
analysis.
You can perform linear static analysis to compute deformation, stress, and strain. For
modeling structural dynamics and vibration, the toolbox provides a direct time integration
solver. You can analyze a component’s structural characteristics by performing modal
analysis to find natural frequencies and mode shapes. You can model conduction-
dominant heat transfer problems to calculate temperature distributions, heat fluxes, and
heat flow rates through surfaces. You can also solve standard problems such as diffusion,
electrostatics, and magnetostatics, as well as custom PDEs.
Partial Differential Equation Toolbox lets you import 2D and 3D geometries from STL or
mesh data. You can automatically generate meshes with triangular and tetrahedral
elements. You can solve PDEs by using the finite element method, and postprocess results
to explore and analyze them.
Key Features
• Structural analysis, including linear static, dynamic, and modal analysis
• Heat transfer analysis for conduction-dominant problems
• General linear and nonlinear PDEs for stationary, time-dependent, and eigenvalue
problems
• 2D and 3D geometry import from STL files and mesh data
• Automatic meshing using triangular and tetrahedral elements with linear or quadratic
basis functions
• User-defined functions for specifying PDE coefficients, boundary conditions, and initial
conditions
• Plotting and animating results, as well as derived and interpolated values
1-2
Equations You Can Solve Using PDE Toolbox
∂2 u ∂u
m +d − ∇ · c ∇u + au = f
∂t 2 ∂t
− ∇ · c ∇u + au = λdu
or
2
− ∇ · c ∇u + au = λ mu
For scalar PDEs, there are two choices of boundary conditions for each edge or face:
where h and r can be functions of space (x, y, and, in 3-D case, z), the solution u, and
time. Often, you take h = 1, and set r to the appropriate value.
• Generalized Neumann boundary conditions — On the edge or face the solution u
satisfies the equation
n · c ∇u + qu = g
n is the outward unit normal. q and g are functions defined on ∂Ω, and can be
functions of x, y, and, in 3-D case, z, the solution u, and, for time-dependent equations,
time.
∂2 u ∂u
m +d − ∇ · c ⊗ ∇u + au = f
∂t 2 ∂t
− ∇ · c ⊗ ∇u + au = λdu
or
2
− ∇ · c ⊗ ∇u + au = λ mu
1-3
1 Getting Started
The coefficients m, d, c, a, and f can be functions of location (x, y, and, in 3-D, z), and,
except for eigenvalue problems, they also can be functions of the solution u or its
gradient. For eigenvalue problems, the coefficients cannot depend on the solution u or its
gradient.
For scalar equations, all the coefficients except c are scalar. The coefficient c represents a
2-by-2 matrix in 2-D geometry, or a 3-by-3 matrix in 3-D geometry. For systems of N
equations, the coefficients m, d, and a are N-by-N matrices, f is an N-by-1 vector, and c is
a 2N-by-2N tensor (2-D geometry) or a 3N-by-3N tensor (3-D geometry). For the meaning
of c ⊗ u, see “c Coefficient for specifyCoefficients” on page 2-82.
When both m and d are 0, the PDE is stationary. When either m or d are nonzero, the
problem is time-dependent. When any coefficient depends on the solution u or its
gradient, the problem is called nonlinear.
For systems of PDEs, there are generalized versions of the Dirichlet and Neumann
boundary conditions:
For 3-D systems, the notation n · c ⊗ ∇u means the N-by-1 vector with (i,1)-
component
1-4
See Also
N
∂ ∂ ∂
∑ sin φ cos θ ci, j, 1, 1
∂x
+ sin φ cos θ ci, j, 1, 2
∂y
+ sin φ cos θ ci, j, 1, 3 u
∂z j
j=1
N
∂ ∂ ∂
+ ∑ sin φ sin θ ci, j, 2, 1
∂x
+ sin φ sin θ ci, j, 2, 2
∂y
+ sin φ sin θ ci, j, 2, 3 u
∂z j
j=1
N
∂ ∂ ∂
+ ∑ cos θ ci, j, 3, 1
∂x
+ cos θ ci, j, 3, 2
∂y
+ cos θ ci, j, 3, 3 u
∂z j
j=1
For each edge or face segment, there are a total of N boundary conditions.
See Also
Related Examples
• “Solve Problems Using PDEModel Objects” on page 2-3
• “f Coefficient for specifyCoefficients” on page 2-79
• “c Coefficient for specifyCoefficients” on page 2-82
• “m, d, or a Coefficient for specifyCoefficients” on page 2-104
1-5
1 Getting Started
You can specify the coefficients at any time before solving the PDE because the
coefficients are independent of the geometry and the boundaries. If the PDE
coefficients are material-dependent, specify them by double-clicking each particular
region.
6 Generate a triangular mesh by selecting Initialize Mesh from the Mesh menu.
Using the same menu, you can also refine mesh, display node and triangle labels, and
control mesh parameters, letting you generate a mesh that is fine enough to
adequately resolve the important features in the geometry, but is coarse enough to
run in a reasonable amount of time and memory. See “Specify Mesh Parameters in
the PDE Modeler App” on page 4-29.
7 Solve the PDE by clicking the = button or by selecting Solve PDE from the Solve
menu. To use a solver with non-default parameters, select Parameters from the
Solve menu to. The resulting dialog box lets you:
1-6
Solve 2-D PDEs Using the PDE Modeler App
• Invoke and control the nonlinear and adaptive solvers for elliptic problems.
• Specify the initial values, and the times for which to generate the output for
parabolic and hyperbolic problems.
• Specify the interval in which to search for eigenvalues for eigenvalue problems.
See “Adjust Solve Parameters in the PDE Modeler App” on page 4-31.
8 When you solve the PDE, the app automatically plots the solution using the default
settings. To customize the plot or plot other physical properties calculated using the
solution, select Parameters from the Plot menu. See “Plot the Solution in the PDE
Modeler App” on page 4-38.
Tips
After solving the problem, you can:
• Export the solution or the mesh or both to the MATLAB workspace for further analysis.
• Visualize other properties of the solution.
• Change the PDE and recompute the solution.
• Change the mesh and recompute the solution. If you select Initialize Mesh, the mesh
is initialized; if you select Refine Mesh, the current mesh is refined. From the Mesh
menu, you can also jiggle the mesh and undo previous mesh changes. You also can use
the adaptive mesh refiner and solver, adaptmesh. This option tries to find a mesh that
fits the solution.
• Change the boundary conditions. To return to the mode where you can select
boundaries, use the ∂Ω button or the Boundary Mode option from the Boundary
menu.
• Change the geometry. You can switch to the draw mode again by selecting Draw
Mode from the Draw menu or by clicking one of the Draw Mode icons to add another
shape.
The following are the shortcuts that you can use to skip one or more steps. In general, the
PDE Modeler app adds the necessary steps automatically.
• If you do not create a geometry, the PDE Modeler app uses an L-shaped geometry with
the default boundary conditions.
• If you initialize the mesh while in the draw mode, the PDE Modeler app first
decomposes the geometry using the current set formula and assigns the default
boundary condition to the outer boundaries. After that, it generate the mesh.
1-7
1 Getting Started
• If you refine the mesh before initializing it, the PDE Modeler app first initializes the
mesh.
• If you solve the PDE without generating a mesh, the PDE Modeler app initializes a
mesh before solving the PDE.
• If you select a plot type and choose to plot the solution, the PDE Modeler app checks if
the solution to the current PDE is available. If not, the PDE Modeler app first solves
the current PDE. The app displays the solution using the selected plot options.
• If do not specify the coefficients and use the default Generic Scalar application mode,
the PDE Modeler app solves the default PDE, which is Poisson's equation:
–Δu = 10.
This corresponds to the generic elliptic PDE with c = 1, a = 0, and f = 10. The default
PDE settings depend on the application mode.
See Also
Related Examples
• “Poisson’s Equation with Complex 2-D Geometry: PDE Modeler App” on page 1-9
• “Poisson's Equation on Unit Disk” on page 3-205
• “Current Density Between Two Metallic Conductors: PDE Modeler App” on page 3-
182
• “Minimal Surface Problem” on page 3-220
1-8
Poisson’s Equation with Complex 2-D Geometry: PDE Modeler App
To solve this problem in the PDE Modeler app, follow these steps:
1 Open the PDE Modeler app by using the pdeModeler command.
2 Display grid lines. To do this, select Options > Grid Spacing and clear the Auto
checkbox for the x-axis linear spacing. Enter X-axis linear spacing as
-1.5:0.25:1.5. Then select Options > Grid.
3 Align new shapes to the grid lines by selecting Options > Snap.
4 Draw two circles: one with the radius 0.4 and the center at (-0.5,0) and another with
the radius 0.2 and the center at (0.5,0.2). To draw a circle, first click the
button. Then right-click the origin and drag to draw a circle. Right-clicking constrains
the shape you draw so that it is a circle rather than an ellipse.
5 Draw two rectangles: one with corners (-1,0.2), (1,0.2), (1,-0.2), and (-1,-0.2) and
another with corners (0.5,1), (1,1), (1,-0.6), and (0.5,-0.6). To draw a rectangle, first
click the button. Then click any corner and drag to draw the rectangle.
6 Model the geometry by entering (R1+C1+R2)-C2 in the Set formula field.
7 Save the model to a file by selecting FileSave As.
8 Remove the subdomain borders. To do this, switch to the boundary mode by selecting
Boundary > Boundary Mode. Then select Boundary > Remove All Subdomain
Borders.
9 Specify the boundary conditions for all circle arcs. Using Shift+click, select these
borders. Then select Boundary > Specify Boundary Conditions and specify the
Neumann boundary condition with g = -5 and q = 0. This boundary condition means
that the solution has a slope of –5 in the normal direction for these boundary
segments.
10 For all other boundaries, keep the default Dirichlet boundary condition: h = 1, r =
0.
11 Specify the coefficients by selecting PDE > PDE Specification or clicking the PDE
button on the toolbar. Specify c = 1, a = 0, and f = 10.
1-9
1 Getting Started
12 Initialize the mesh by selecting Mesh > Initialize Mesh. Refine the mesh by
selecting Mesh > Refine Mesh.
13 Solve the PDE by selecting Solve > Solve PDE or clicking the = button on the
toolbar. The toolbox assembles the PDE problem, solves it, and plots the solution.
1-10
Poisson’s Equation with Complex 2-D Geometry: PDE Modeler App
1-11
1 Getting Started
1-12
Finite Element Method Basics
− ∇ ⋅ c ∇u + au = f on domain Ω
Suppose that this equation is a subject to the Dirichlet boundary condition u = r on ∂ΩD
and Neumann boundary conditions on ∂ΩN. Here, ∂Ω = ∂ΩD ∪ ∂ΩN is the boundary of Ω.
The first step in FEM is to convert the original differential (strong) form of the PDE into
an integral (weak) form by multiplying with test function v and integrating over the
domain Ω.
Ω
∫ − ∇ · c ∇u + au − f v dΩ = 0 ∀v
The test functions are chosen from a collection of functions (functional space) that vanish
on the Dirichlet portion of the boundary, v = 0 on ∂ΩD. Above equation can be thought of
as weighted averaging of the residue using all possible weighting functions v. The
collection of functions that are admissible solutions, u, of the weak form of PDE are
chosen so that they satisfy the Dirichlet BC, u = r on ∂ΩD.
Ω
∫ c ∇u ∇v + auv dΩ − ∫ n ·
∂ΩN
c ∇u v d ∂ΩN + ∫n ·
∂ΩD
c ∇u v d ∂ΩD = ∫ f v dΩ
Ω
∀v
Use the Neumann boundary condition to substitute for second term on the left side of the
equation. Also, note that v = 0 on ∂ΩD nullifies the third term. The resulting equation is:
1-13
1 Getting Started
∫ c ∇u ∇v + auv dΩ + ∫ quv d ∂Ω
Ω ∂ΩN
N = ∫ gv d ∂Ω
∂ΩN
N + ∫ f v dΩ
Ω
∀v
Note that all manipulations up to this stage are performed on continuum Ω, the global
domain of the problem. Therefore, the collection of admissible functions and trial
functions span infinite-dimensional functional spaces. Next step is to discretize the weak
e e
form by subdividing Ω into smaller subdomains or elements Ω , where Ω = ∪ Ω . This
step is equivalent to projection of the weak form of PDEs onto a finite-dimensional
subspace. Using the notations uh and vh to represent the finite-dimensional equivalent of
e
admissible and trial functions defined on Ω , you can write the discretized weak form of
the PDE as:
∫ c ∇u ∇v
e
h h + auhvh
e
dΩ + ∫ qu v
e
e
h hd ∂ΩN = ∫ gv
e
e
hd ∂ΩN +
e
∫ f v dΩh
e
∀vh
Ω ∂ΩN ∂ΩN Ω
Next, let ϕi, with i = 1, 2, ... , Np, be the piecewise polynomial basis functions for the
subspace containing the collections uh and vh, then any particular uh can be expressed as
a linear combination of basis functions:
Np
uh = ∑ Uiϕi
1
Here Ui are yet undetermined scalar coefficients. Substituting uh into to the discretized
weak form of PDE and using each vh = φi as test functions and performing integration
over element yields a system of Np equations in terms of Np unknowns Ui.
Note that finite element method approximates a solution by minimizing the associated
error function. The minimizing process automatically finds the linear combination of basis
functions which is closest to the solution u.
FEM yields a system KU = F where the matrix K and the right side F contain integrals in
terms of the test functions ϕi, ϕj, and the coefficients c, a, f, q, and g defining the problem.
The solution vector U contains the expansion coefficients of uh, which are also the values
of uh at each node xk (k = 1,2 for a 2-D problem or k = 1,2,3 for a 3-D problem) since
uh(xk) = Ui.
FEM techniques are also used to solve more general problems, such as:
1-14
Finite Element Method Basics
∂u
d − ∇ ⋅ c ∇u + au = f
∂t
can be approximated by
N
uh(x, t) = ∑ Ui(t)ϕi(x)
i=1
dU
M + KU = F
dt
− ∇ ⋅ c ∇u + au = λdu
for the unknowns u and λ, where λ is a complex number. Using the FEM discretization,
you solve the algebraic eigenvalue problem KU = λMU to find uh as an approximation
to u. To solve eigenvalue problems, use solvepdeeig.
• Nonlinear problems. If the coefficients c, a, f, q, or g are functions of u or ∇u, the PDE
is called nonlinear and FEM yields a nonlinear system K(U)U = F(U).
1-15
1 Getting Started
4 Solves the resulting system of algebraic equations or ODEs using linear solvers or
numerical integration, respectively. The toolbox internally calls appropriate MATLAB
solvers for this task.
References
[1] Cook, Robert D., David S. Malkus, and Michael E. Plesha. Concepts and Applications of
Finite Element Analysis. 3rd edition. New York, NY: John Wiley & Sons, 1989.
[2] Gilbert Strang and George Fix. An Analysis of the Finite Element Method. 2nd edition.
Wellesley, MA: Wellesley-Cambridge Press, 2008.
See Also
assembleFEMatrices | solvepde | solvepdeeig
1-16
2
2-2
Solve Problems Using PDEModel Objects
model = createpde();
If N is the number of equations in your system, use createpde with input argument
N.
model = createpde(N);
3 Import or create the geometry. For details, see “Geometry and Mesh”.
To see labels of a 3-D model, you might need to rotate the model, or make it
transparent, or zoom in on it. See “STL File Import” on page 2-41.
5 Create the boundary conditions. For details, see “Specify Boundary Conditions” on
page 2-124.
f = [1;2];
a = 0;
c = [1;3;5];
specifyCoefficients(model,'m',0,'d',0,'c',c,'a',a,'f',f);
2-3
2 Setting Up Your PDE
generateMesh(model);
9 Call the appropriate solver. For all problems except for eigenvalue problems, call
solvepde.
result = solvepdeeig(model);
10 Examine the solution. See “Plot 2-D Solutions and Their Gradients” on page 3-314
and “Plot 3-D Solutions and Their Gradients” on page 3-325.
See Also
applyBoundaryCondition | createpde | generateMesh | geometryFromEdges |
importGeometry | pdegplot | pdeplot | pdeplot3D
Related Examples
• “Plot 3-D Solutions and Their Gradients” on page 3-325
2-4
2-D Geometry Creation at Command Line
1 A matrix whose columns describe the basic shapes. When you export geometry from
the PDE Modeler app, this matrix has the default name gd (geometry description).
See “Create Basic Shapes” on page 2-5.
2 A matrix whose columns contain names for the basic shapes. Pad the columns with
zeros or 32 (blanks) so that every column has the same length. See “Create Names
for the Basic Shapes” on page 2-7.
3 A set of characters describing the unions, intersections, and set differences of the
basic shapes that make the geometry. See “Set Formula” on page 2-8.
Circle
Row Value
1 1 (indicates a circle)
2 x-coordinate of circle center
3 y-coordinate of circle center
4 Radius (strictly positive)
2-5
2 Setting Up Your PDE
Polygon
Row Value
1 2 (indicates a polygon)
2 Number of line segments n
3 through 3+n-1 x-coordinate of edge starting points
3+n through 2*n+2 y-coordinate of edge starting points
Note Your polygon cannot contain any self-intersections. To check whether your polygon
satisfies this restriction, use the csgchk function.
Rectangle
Row Value
1 3 (indicates a rectangle)
2 4 (number of line segments)
3 through 6 x-coordinate of edge starting points
7 through 10 y-coordinate of edge starting points
The encoding of a rectangle is the same as that of a polygon, except that the first row is 3
instead of 2.
Ellipse
Row Value
1 4 (indicates an ellipse)
2 x-coordinate of ellipse center
3 y-coordinate of ellipse center
4 First semiaxis length (strictly positive)
5 Second semiaxis length (strictly positive)
6 Angle in radians from x axis to first semiaxis
For example, specify a matrix that has a rectangle with a circular end cap and another
circular excision. First, create a rectangle and two adjoining circles.
2-6
2-D Geometry Creation at Command Line
rect1 = [3
4
-1
1
1
-1
0
0
-0.5
-0.5];
C1 = [1
1
-0.25
0.25];
C2 = [1
-1
-0.25
0.25];
Append extra zeros to the circles so they have the same number of rows as the rectangle.
C1 = [C1;zeros(length(rect1) - length(C1),1)];
C2 = [C2;zeros(length(rect1) - length(C2),1)];
gd = [rect1,C1,C2];
One easy way to create the names is by specifying a character array whose rows contain
the names, and then taking the transpose. Use the char function to create the array.
char pads the rows as needed so all have the same length. Continuing the example, give
names for the three shapes.
ns = char('rect1','C1','C2');
ns = ns';
2-7
2 Setting Up Your PDE
Set Formula
Obtain the final geometry by writing a set of characters that describes the unions and
intersections of basic shapes. Use + for union, * for intersection, - for set difference, and
parentheses for grouping. + and * have the same grouping precedence. - has higher
grouping precedence.
Continuing the example, specify the union of the rectangle and C1, and subtract C2.
sf = '(rect1+C1)-C2';
[dl,bt] = decsg(gd,sf,ns);
pdegplot(dl,'EdgeLabels','on','FaceLabels','on')
xlim([-1.5,1.5])
axis equal
2-8
2-D Geometry Creation at Command Line
2-9
2 Setting Up Your PDE
2-10
2-D Geometry Creation at Command Line
2-11
2 Setting Up Your PDE
Required Syntax
A geometry function describes the curves that bound the geometry regions. A curve is a
parametrized function (x(t),y(t)). The variable t ranges over a fixed interval. For best
results, t must be proportional to the arc length plus a constant.
You must specify at least two curves for each geometric region. For example, the
'circleg' geometry function, which is available in Partial Differential Equation Toolbox,
uses four curves to describe a circle. Curves can intersect only at the beginning or end of
parameter intervals.
2-12
Parametrized Function for 2-D Geometry Creation
• The arrows by curves 1 and 2 show region 1 to the left and region 0 to the right.
• The arrows by curves 3 and 4 show region 0 to the left and region 1 to the right.
• The arrows by curves 5 and 6 show region 0 to the left and region 1 to the right.
• The arrows by curves 7 and 8 show region 1 to the left and region 0 to the right.
2-13
2 Setting Up Your PDE
x = cos t ,
y = sin t ,
0 ≤ t ≤ 2π .
A geometry function must have at least two segments. To satisfy this requirement, break
up the circle into four segments.
2-14
Parametrized Function for 2-D Geometry Creation
• 0 ≤ t ≤ π/2
• π/2 ≤ t ≤ π
• π ≤ t ≤ 3π/2
• 3π/2 ≤ t ≤ 2π
Now that you have a parametrization, write the geometry function. Save this function file
as circlefunction.m on your MATLAB® path. This geometry is simple to create
because the parametrization does not change depending on the segment number.
Plot the geometry displaying the edge numbers and the face label.
pdegplot(@circlefunction,'EdgeLabels','on','FaceLabels','on')
axis equal
2-15
2 Setting Up Your PDE
ezpolar('2*(1+cos(Phi))')
2-16
Parametrized Function for 2-D Geometry Creation
The following are the four ways to parametrize the cardioid as a function of the arc
length:
• Use the pdearcl function with a polygonal approximation to the geometry. This
approach is general, accurate enough, and computationally fast.
• Use the integral and fzero functions to compute the arc length. This approach is
more computationally costly, but can be accurate without requiring you to choose an
arbitrary polygon.
• Use an analytic calculation of the arc length. This approach is the best when it applies,
but there are many cases where it does not apply.
2-17
2 Setting Up Your PDE
• Use a parametrization that is not proportional to the arc length plus a constant. This
approach is the simplest, but can yield a distorted mesh that does not give the most
accurate solution to your PDE problem.
Polygonal Approximation
The finite element method uses a triangular mesh to approximate the solution to a PDE
numerically. You can avoid loss in accuracy by taking a sufficiently fine polygonal
approximation to the geometry. The pdearcl function maps between parametrization and
arc length in a form well suited to a geometry function. Write the following geometry
function for the cardioid.
function [x,y] = cardioid1(bs,s)
% CARDIOID1 Geometry file defining the geometry of a cardioid.
if nargin == 0
x = 4; % four segments in boundary
return
end
if nargin == 1
dl = [0 pi/2 pi 3*pi/2
pi/2 pi 3*pi/2 2*pi
1 1 1 1
0 0 0 0];
x = dl(:,bs);
return
end
x = zeros(size(s));
y = zeros(size(s));
if numel(bs) == 1 % bs might need scalar expansion
bs = bs*ones(size(s)); % expand bs
end
2-18
Parametrized Function for 2-D Geometry Creation
y(:) = r.*sin(th);
end
pdegplot('cardioid1','EdgeLabels','on')
axis equal
The built-in cardg function gives a slightly different version of this technique.
2-19
2 Setting Up Your PDE
You can write an integral for the arc length of a curve. If the parametrization is in terms
of x u and y u , then the arc length s t is
2 dy 2
∫
t dx
st = + du .
0 du du
For a given value s0, you can find t as the root of the equation s t = s0. The fzero
function solves this type of nonlinear equation.
if nargin == 0
x = 4; % four segments in boundary
return
end
if nargin == 1
dl = [0 pi/2 pi 3*pi/2
pi/2 pi 3*pi/2 2*pi
1 1 1 1
0 0 0 0];
x = dl(:,bs);
return
end
x = zeros(size(s));
y = zeros(size(s));
if numel(bs) == 1 % bs might need scalar expansion
bs = bs*ones(size(s)); % expand bs
end
2-20
Parametrized Function for 2-D Geometry Creation
end
cbs = find(bs >= 3); % lower half of cardioid
s(cbs) = 2*pi - s(cbs);
for ii = cbs(:)'
theta = fzero(@(rr)fun(rr)-s(ii)*sscale/pi,[0,pi]);
r = 2*(1 + cos(theta));
x(ii) = r*cos(theta);
y(ii) = -r*sin(theta);
end
end
pdegplot('cardioid2','EdgeLabels','on')
axis equal
2-21
2 Setting Up Your PDE
The geometry looks identical to the polygonal approximation. This integral version takes
much longer to calculate than the polygonal version.
You also can find an analytic expression for the arc length as a function of the
parametrization. Then you can give the parametrization in terms of arc length. For
example, find an analytic expression for the arc length by using Symbolic Math Toolbox™.
syms t real
r = 2*(1+cos(t));
x = r*cos(t);
y = r*sin(t);
2-22
Parametrized Function for 2-D Geometry Creation
arcl = simplify(sqrt(diff(x)^2+diff(y)^2));
s = int(arcl,t,0,t,'IgnoreAnalyticConstraints',true)
s =
t
8 sin
2
In terms of the arc length s, the parameter t is t = 2*asin(s/8), where s ranges from
0 to 8, corresponding to t ranging from 0 to π. For s between 8 and 16, by symmetry of
the cardioid, t = pi + 2*asin((16-s)/8). Furthermore, you can express x and y in
terms of s by these analytic calculations.
syms s real
th = 2*asin(s/8);
r = 2*(1 + cos(th));
r = expand(r)
r =
s2
4−
16
x = r*cos(th);
x = simplify(expand(x))
x =
s4 3 s2
− +4
512 16
y = r*sin(th);
y = simplify(expand(y))
y =
3/2
s 64 − s2
512
Now that you have analytic expressions for x and y in terms of the arc length s, write the
geometry function.
function [x,y] = cardioid3(bs,s)
% CARDIOID3 Geometry file defining the geometry of a cardioid.
if nargin == 0
x = 4; % four segments in boundary
return
end
2-23
2 Setting Up Your PDE
if nargin == 1
dl = [0 4 8 12
4 8 12 16
1 1 1 1
0 0 0 0];
x = dl(:,bs);
return
end
x = zeros(size(s));
y = zeros(size(s));
if numel(bs) == 1 % bs might need scalar expansion
bs = bs*ones(size(s)); % expand bs
end
pdegplot('cardioid3','EdgeLabels','on')
axis equal
2-24
Parametrized Function for 2-D Geometry Creation
This analytic geometry looks slightly smoother than the previous versions. However, the
difference is inconsequential in terms of calculations.
You also can write a geometry function where the parameter is not proportional to the arc
length. This approach can yield a distorted mesh.
if nargin == 0
x = 4; % four segments in boundary
2-25
2 Setting Up Your PDE
return
end
if nargin == 1
dl = [0 pi/2 pi 3*pi/2
pi/2 pi 3*pi/2 2*pi
1 1 1 1
0 0 0 0];
x = dl(:,bs);
return
end
pdegplot('cardioid4','EdgeLabels','on')
axis equal
2-26
Parametrized Function for 2-D Geometry Creation
The labels are not evenly spaced on the edges because the parameter is not proportional
to the arc length.
Examine the default mesh for each of the four methods of creating a geometry.
subplot(2,2,1)
model = createpde;
geometryFromEdges(model,@cardioid1);
generateMesh(model);
pdeplot(model)
title('Polygons')
axis equal
subplot(2,2,2)
2-27
2 Setting Up Your PDE
model = createpde;
geometryFromEdges(model,@cardioid2);
generateMesh(model);
pdeplot(model)
title('Integral')
axis equal
subplot(2,2,3)
model = createpde;
geometryFromEdges(model,@cardioid3);
generateMesh(model);
pdeplot(model)
title('Analytic')
axis equal
subplot(2,2,4)
model = createpde;
geometryFromEdges(model,@cardioid4);
generateMesh(model);
pdeplot(model)
title('Distorted')
axis equal
2-28
Parametrized Function for 2-D Geometry Creation
The distorted mesh looks a bit less regular than the other meshes. It has some very
narrow triangles near the cusp of the cardioid. Nevertheless, all of the meshes appear to
be usable.
2-29
2 Setting Up Your PDE
has a circular hole centered at (1,-1) and of radius 1/2. The following is the code of the
geometry function.
2-30
Parametrized Function for 2-D Geometry Creation
x(cbs) = s(cbs);
y(cbs) = zeros(size(cbs));
cbs = find(bs > 5); % Inner circle radius 0.25 center (1,-1)
x(cbs) = 1 + 0.25*cos(s(cbs));
y(cbs) = -1 + 0.25*sin(s(cbs));
end
pdegplot(@cardg3,'EdgeLabels','on','FaceLabels','on')
axis equal
2-31
2 Setting Up Your PDE
When a 2-D geometry function requires additional parameters, you cannot use a standard
anonymous function approach because geometry functions return a varying number of
arguments. Instead, you can use global variables or nested functions. In most cases, the
recommended approach is to use nested functions.
The example solves a Poisson's equation with zero Dirichlet boundary conditions on all
boundaries. The geometry is a cardioid with an elliptic hole that has a center at (1,-1) and
variable semiaxes. To set up and solve the PDE model with this geometry, use a nested
function. Here, the parent function accepts the lengths of the semiaxes, rr and ss, as
input parameters. The reason to nest cardioidWithEllipseGeom within
cardioidWithEllipseModel is that nested functions share the workspace of their
parent functions. Therefore, the cardioidWithEllipseGeom function can access the
values of rr and ss that you pass to cardioidWithEllipseModel.
function cardioidWithEllipseModel(rr,ss)
applyBoundaryCondition(model,'dirichlet','Edge',1:8,'u',0);
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',1);
generateMesh(model);
u = solvepde(model);
figure
pdeplot(model,'XYData',u.NodalSolution)
axis equal
else
display('Semiaxes values must be positive numbers.')
end
if nargin == 0
x = 8; % eight segments in boundary
2-32
Parametrized Function for 2-D Geometry Creation
return
end
if nargin == 1
% Cardioid
dlc = [ 0 4 8 12
4 8 12 16
1 1 1 1
0 0 0 0];
% Ellipse
dle = [0 pi/2 pi 3*pi/2
pi/2 pi 3*pi/2 2*pi
0 0 0 0
1 1 1 1];
% Combine the edge matrices
dl = [dlc,dle];
x = dl(:,bs);
return
end
x = zeros(size(s));
y = zeros(size(s));
if numel(bs) == 1 % Does bs need scalar expansion?
bs = bs*ones(size(s)); % Expand bs
end
end
end
When calling cardioidWithEllipseModel, ensure that the semiaxes values are small
enough, so that the elliptic hole appears entirely within the outer cardioid. Otherwise, the
geometry becomes invalid.
2-33
2 Setting Up Your PDE
For example, call the function for the ellipse with the major semiaxis rr = 0.5 and the
minor semiaxis ss = 0.25. This function call returns the following geometry and the
solution.
cardioidWithEllipseModel(0.5,0.25)
2-34
Parametrized Function for 2-D Geometry Creation
2-35
2 Setting Up Your PDE
t = pi/12:pi/12:2*pi;
pgon = polyshape({[-0.5 -0.5 0.5 0.5], 0.25*cos(t)}, ...
{[0.5 -0.5 -0.5 0.5], 0.25*sin(t)})
pgon =
polyshape with properties:
plot(pgon)
axis equal
2-36
Geometry from polyshape
tr = triangulation(pgon);
model = createpde;
With the triangulation data as a mesh, use the geometryFromMesh function to create a
geometry. Plot the geometry.
tnodes = tr.Points';
telements = tr.ConnectivityList';
2-37
2 Setting Up Your PDE
geometryFromMesh(model,tnodes,telements);
pdegplot(model)
figure
pdemesh(model)
2-38
Geometry from polyshape
Because the triangulation data resulted in a low-quality mesh, generate a new finer mesh
for further analysis.
generateMesh(model)
ans =
FEMesh with properties:
2-39
2 Setting Up Your PDE
GeometricOrder: 'quadratic'
figure
pdemesh(model)
2-40
STL File Import
View the geometry examples included with Partial Differential Equation Toolbox™.
model = createpde;
importGeometry(model,'Torus.stl');
pdegplot(model,'FaceLabels','on')
2-41
2 Setting Up Your PDE
model = createpde;
importGeometry(model,'Block.stl');
pdegplot(model,'FaceLabels','on')
model = createpde;
importGeometry(model,'Plate10x10x1.stl');
pdegplot(model,'FaceLabels','on')
2-42
STL File Import
model = createpde;
importGeometry(model,'Tetrahedron.stl');
pdegplot(model,'FaceLabels','on')
2-43
2 Setting Up Your PDE
model = createpde;
importGeometry(model,'BracketWithHole.stl');
pdegplot(model,'FaceLabels','on')
2-44
STL File Import
model = createpde;
importGeometry(model,'BracketTwoHoles.stl');
pdegplot(model,'FaceLabels','on')
2-45
2 Setting Up Your PDE
To see hidden portions of the geometry, rotate the figure using Rotate 3D button or
the view function. You can rotate the angle bracket to obtain the following view.
pdegplot(model,'FaceLabels','on')
view([-24 -19])
2-46
STL File Import
model = createpde;
importGeometry(model,'ForearmLink.stl');
pdegplot(model,'FaceLabels','on');
2-47
2 Setting Up Your PDE
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
2-48
STL File Import
When you import a planar STL geometry, the toolbox converts it to a 2-D geometry by
mapping it to the X-Y plane.
model = createpde;
importGeometry(model,'PlateHolePlanar.stl');
pdegplot(model,'EdgeLabels','on')
2-49
2 Setting Up Your PDE
2-50
Geometry from Triangulated Mesh
The tetmesh file that ships with your software contains a 3-D mesh. Load the data into
your Workspace.
load tetmesh
size(tet)
ans = 1×2
4969 4
size(X)
ans = 1×2
1456 3
nodes = X';
elements = tet';
model = createpde();
geometryFromMesh(model,nodes,elements);
model.Mesh
2-51
2 Setting Up Your PDE
ans =
FEMesh with properties:
2-52
Geometry from Triangulated Mesh
load MultidomainMesh2D
model = createpde;
geometryFromMesh(model,nodes,elements,ElementIdToRegionId);
pdegplot(model,'FaceLabels','on')
2-53
2 Setting Up Your PDE
2-54
Geometry from alphaShape
Create a unit disk. Remove all the mesh grid points that fall inside the unit disk, and
include the unit disk points.
t = (pi/24:pi/24:2*pi)';
x = cos(t);
y = sin(t);
circShp = alphaShape(x,y,2);
in = inShape(circShp,xg,yg);
xg = [xg(~in); cos(t)];
yg = [yg(~in); sin(t)];
Create 3-D copies of the remaining mesh grid points, with the z-coordinates ranging from
0 through 1. Combine the points into an alphaShape object.
zg = ones(numel(xg),1);
xg = repmat(xg,5,1);
yg = repmat(yg,5,1);
zg = zg*(0:.25:1);
zg = zg(:);
shp = alphaShape(xg,yg,zg);
[elements,nodes] = boundaryFacets(shp);
nodes = nodes';
elements = elements';
2-55
2 Setting Up Your PDE
model = createpde();
geometryFromMesh(model,nodes,elements);
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
generateMesh(model);
2-56
Cuboids, Cylinders, and Spheres
All cells in a geometry must be of the same type: either cuboids, or cylinders, or spheres.
These functions do not combine cells of different types in one geometry.
Single Sphere
Create a geometry that consists of a single sphere and include this geometry in a PDE
model.
Use the multisphere function to create a single sphere. The resulting geometry consists
of one cell.
gm = multisphere(5)
gm =
DiscreteGeometry with properties:
NumCells: 1
NumFaces: 1
NumEdges: 0
NumVertices: 0
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
2-57
2 Setting Up Your PDE
model.Geometry = gm
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
pdegplot(model,'CellLabels','on')
2-58
Cuboids, Cylinders, and Spheres
Create the geometry by using the multicuboid function. The resulting geometry
consists of three cells.
gm =
DiscreteGeometry with properties:
2-59
2 Setting Up Your PDE
NumCells: 3
NumFaces: 18
NumEdges: 36
NumVertices: 24
model = createpde
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
model.Geometry = gm
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
pdegplot(model,'CellLabels','on','FaceAlpha',0.5)
2-60
Cuboids, Cylinders, and Spheres
Stacked Cylinders
Create a geometry that consists of three stacked cylinders and include this geometry in a
PDE model.
Create the geometry by using the multicylinder function with the ZOffset argument.
The resulting geometry consists of four cells stacked on top of each other.
gm =
DiscreteGeometry with properties:
2-61
2 Setting Up Your PDE
NumCells: 4
NumFaces: 9
NumEdges: 5
NumVertices: 5
model = createpde
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
model.Geometry = gm
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
pdegplot(model,'CellLabels','on','FaceAlpha',0.5)
2-62
Cuboids, Cylinders, and Spheres
Hollow Cylinder
Create a hollow cylinder and include it as a geometry in a PDE model.
Create a hollow cylinder by using the multicylinder function with the Void argument.
The resulting geometry consists of one cell.
gm = multicylinder([9 10],10,'Void',[true,false])
gm =
DiscreteGeometry with properties:
NumCells: 1
2-63
2 Setting Up Your PDE
NumFaces: 4
NumEdges: 4
NumVertices: 4
model = createpde
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
model.Geometry = gm
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
pdegplot(model,'CellLabels','on','FaceAlpha',0.5)
2-64
Cuboids, Cylinders, and Spheres
2-65
2 Setting Up Your PDE
Sphere in Cube
This example shows how to create a nested multidomain geometry consisting of a unit
sphere and a cube. The first part of the example creates a cube with a spherical cavity by
using alphaShape. The second part creates a solid sphere using tetrahedral elements,
and then combines all tetrahedral elements to obtain a solid sphere embedded in a cube.
First, create a geometry consisting of a cube with a spherical cavity. This geometry has
one cell.
Extract the grid points located outside of the unit spherical region.
[x1,y1,z1] = sphere(24);
Psphere = [x1(:) y1(:) z1(:)];
Psphere = unique(Psphere,'rows');
Combine the coordinates of the rectangular grid (without the points inside the sphere)
and the surface coordinates of the unit sphere.
Pcombined = [Pcavitycube;Psphere];
Create an alphaShape object representing the cube with the spherical cavity.
figure
plot(shpCubeWithSphericalCavity,'FaceAlpha',0.4)
title('alphaShape: Cube with Spherical Cavity')
2-66
Sphere in Cube
Recover the triangulation that defines the domain of the alphaShape object.
[tri,loc] = alphaTriangulation(shpCubeWithSphericalCavity);
modelCube = createpde;
Create a geometry from the mesh and import the geometry and the mesh into the model.
[gCube,mshCube] = geometryFromMesh(modelCube,loc',tri');
2-67
2 Setting Up Your PDE
figure
pdegplot(modelCube,'FaceAlpha',0.5,'CellLabels','on')
title('PDEModel: Cube with Spherical Cavity')
Create tetrahedral elements to form a solid sphere by using the spherical shell and
adding a new node at the center. First, obtain the spherical shell by extracting facets of
the spherical boundary.
sphereFacets = boundaryFacets(mshCube,'Face',3);
sphereNodes = findNodes(mshCube,'region','Face',3);
2-68
Sphere in Cube
newNodeID = size(mshCube.Nodes,2) + 1;
Construct the tetrahedral elements by using each of the three nodes on the spherical
boundary facets and the new node at the origin.
Create a model that combines the cube with the spherical cavity and a sphere.
model = createpde;
Create a vector that maps all mshCube elements to cell 1, and all elements of the solid
sphere to cell 2.
Add a new node at the center [0;0;0] to the nodes of the cube with the cavity.
combinedNodes = [mshCube.Nodes,[0;0;0]];
combinedElements = [mshCube.Elements,sphereTets];
[g,msh] = geometryFromMesh(model,combinedNodes,combinedElements,e2c);
figure
pdegplot(model,'FaceAlpha',0.5,'CellLabels','on')
title('Solid Sphere in Cube')
2-69
2 Setting Up Your PDE
2-70
Multidomain Geometry Reconstructed from Mesh
modelSingleDomain = createpde;
importGeometry(modelSingleDomain,'Block.stl');
msh = generateMesh(modelSingleDomain);
figure
pdemesh(modelSingleDomain)
2-71
2 Setting Up Your PDE
Find the x-coordinates of the geometric centers of all elements of the mesh. First, create
an array of the same size as elements that contains the x-coordinates of the nodes
forming the mesh elements. Each column of this vector contains the x-coordinates of 10
nodes that form an element.
elemXCoords = reshape(nodes(1,elements),10,[]);
Compute the mean of each column of this array to get a vector of the x-coordinates of the
element geometric centers.
2-72
Multidomain Geometry Reconstructed from Mesh
elemXCoordsGeometricCenter = mean(elemXCoords);
Assume that all elements have the same region ID and create a matrix
ElementIdToRegionId.
ElementIdToRegionId = ones(1,size(elements,2));
Find IDs of all elements for which the x-coordinate of the geometric center exceeds 30.
For the elements with centers located beyond x = 30, change the region IDs to 2.
ElementIdToRegionId(idx) = 2;
modelTwoDomain = createpde;
Using geometryFromMesh, import the mesh. Assign the elements to two cells based on
their IDs.
geometryFromMesh(modelTwoDomain,nodes,elements,ElementIdToRegionId)
ans =
DiscreteGeometry with properties:
NumCells: 2
NumFaces: 108
NumEdges: 205
NumVertices: 100
pdegplot(modelTwoDomain,'CellLabels','on','FaceAlpha',0.5)
2-73
2 Setting Up Your PDE
Highlight the elements from cell 1 in red and the elements from cell 2 in green.
elementIDsCell1 = findElements(modelTwoDomain.Mesh,'region','Cell',1);
elementIDsCell2 = findElements(modelTwoDomain.Mesh,'region','Cell',2);
figure
pdemesh(modelTwoDomain.Mesh.Nodes, ...
modelTwoDomain.Mesh.Elements(:,elementIDsCell1), ...
'FaceColor','red')
hold on
pdemesh(modelTwoDomain.Mesh.Nodes, ...
modelTwoDomain.Mesh.Elements(:,elementIDsCell2), ...
'FaceColor','green')
2-74
Multidomain Geometry Reconstructed from Mesh
2-75
2 Setting Up Your PDE
− ∇ ⋅ c ∇u + au = f
or variants that have derivatives with respect to time, or that have eigenvalues, or are
systems of equations. These equations are in divergence form, where the differential
operator begins ∇ ·. The coefficients a, c, and f are functions of position (x, y, z) and
possibly of the solution u.
However, you can have equations in a form with all the derivatives explicitly expanded,
such as
∂2 u ∂2 u 1 + y 2 ∂2 u
1 + x2 − 3xy + =0
∂x2 ∂x ∂y 2 ∂y2
In order to transform this expanded equation into toolbox format, you can try to match
the coefficients of the equation in divergence form to the expanded form. In divergence
form, if
c1 c3
c=
c2 c4
then
2-76
Put Equations in Divergence Form
Matching coefficients in the uxx and uyy terms in − ∇ ⋅ c ∇u to the equation, you get
c1 = − 1 + x2
c4 = − 1 + y2 /2
Then looking at the coefficients of ux and uy, which should be zero, you get
− ∇ ⋅ c ∇u = 0
n · c ∇u + qu = g
So when you derive a divergence form of the c coefficient, keep in mind that this
coefficient appears elsewhere.
For example, consider the 2-D Poisson equation –uxx – uyy = f. Obviously, you can take
c = 1. But there are other c matrices that lead to the same equation: any that have
c(2) + c(3) = 0.
c1 c3 ux
∇ · c ∇u = ∇ ·
c2 c4 uy
∂ ∂
= c u + c3uy + c u + c4uy
∂x 1 x ∂y 2 x
= c1uxx + c4uyy + c2 + c3 uxy
2-77
2 Setting Up Your PDE
n · c ∇u = 2
the boundary condition depends on which version of c you use. In this case, make sure
that you take a version of c that is compatible with both the equation and the boundary
condition.
− ∇ ⋅ c ∇u + au = f
∂2 u cos(x + y) ∂2 u 1 ∂2 u
+ + =0
∂x2 4 ∂x ∂y 2 ∂y2
By simple coefficient matching, you see that the coefficients c1 and c4 are –1 and –1/2
respectively. However, there are no c2 and c3 that satisfy the remaining equations,
−cos(x + y)
c2 + c3 =
4
∂c1 ∂c2 ∂c2
+ = =0
∂x ∂y ∂y
∂c3 ∂c4 ∂c3
+ = =0
∂x ∂y ∂x
See Also
Related Examples
• “Equations You Can Solve Using PDE Toolbox” on page 1-3
• “Solve Problems Using PDEModel Objects” on page 2-3
2-78
f Coefficient for specifyCoefficients
∂2 u ∂u
m +d − ∇ · c ∇u + au = f
∂t 2 ∂t
or in similar equations. The question is how to write the coefficient f for inclusion in the
PDE model via specifyCoefficients.
N is the number of equations, see “Equations You Can Solve Using PDE Toolbox” on page
1-3. Give f as either of the following:
• location.x
• location.y
• location.z
• location.subdomain
The fields x, y, and z represent the x-, y-, and z- coordinates of points for which
your function calculates coefficient values. The subdomain field represents the
subdomain numbers, which currently apply only to 2-D models. The location fields
are row vectors.
2-79
2 Setting Up Your PDE
• state.u
• state.ux
• state.uy
• state.uz
• state.time
The state.u field represents the current value of the solution u. The state.ux,
state.uy, and state.uz fields are estimates of the solution’s partial derivatives
(∂u/∂x, ∂u/∂y, and ∂u/∂z) at the corresponding points of the location structure. The
solution and gradient estimates are N-by-Nr matrices. The state.time field is a
scalar representing time for time-dependent models.
function f = fcoeffunction(location,state)
N = 3; % Number of equations
nr = length(location.x); % Number of columns
f = zeros(N,nr); % Allocate f
x − y + u(1)
f = 1 + tanh( ∂u(1)/ ∂x) + tanh( ∂u(3)/ ∂y)
(5 + u(3)) x2 + y2
See Also
Related Examples
• “m, d, or a Coefficient for specifyCoefficients” on page 2-104
2-80
See Also
2-81
2 Setting Up Your PDE
In this section...
“Overview of the c Coefficient” on page 2-82
“Definition of the c Tensor Elements” on page 2-83
“Some c Vectors Can Be Short” on page 2-86
“Functional Form” on page 2-100
∂2 u ∂u
m +d − ∇ · c ∇u + au = f
∂t 2 ∂t
The topic applies to the recommended workflow for including coefficients in your model
using specifyCoefficients.
For 2-D systems, c is a tensor with 4N2 elements. For 3-D systems, c is a tensor with 9N2
elements. For a definition of the tensor elements, see “Definition of the c Tensor
Elements” on page 2-83. N is the number of equations, see “Equations You Can Solve
Using PDE Toolbox” on page 1-3.
To write the coefficient c for inclusion in the PDE model via specifyCoefficients,
give c as either of the following:
ccoeffunction(location,state)
• N1 is the length of the vector representing the c coefficient. There are several
possible values of N1, detailed in “Some c Vectors Can Be Short” on page 2-86.
For 2-D geometry, 1 ≤ N1 ≤ 4N2, and for 3-D geometry, 1 ≤ N1 ≤ 9N2.
2-82
c Coefficient for specifyCoefficients
• Nr is the number of points in the location that the solver passes. Nr is equal to the
length of the location.x or any other location field. The function should
evaluate c at these points.
For 3-D systems, the notation ∇ ⋅ (c ⊗ ∇u) represents an N-by-1 matrix with an (i,1)-
component
N
∂ ∂ ∂ ∂ ∂ ∂
∑ c
∂x i, j, 1, 1 ∂x
+ c
∂x i, j, 1, 2 ∂y
+ c u
∂x i, j, 1, 3 ∂z j
j=1
N
∂ ∂ ∂ ∂ ∂ ∂
+ ∑ c
∂y i, j, 2, 1 ∂x
+ c
∂y i, j, 2, 2 ∂y
+ c u
∂y i, j, 2, 3 ∂z j
j=1
N
∂ ∂ ∂ ∂ ∂ ∂
+ ∑ c
∂z i, j, 3, 1 ∂x
+ c
∂z i, j, 3, 2 ∂y
+ c u
∂z i, j, 3, 3 ∂z j
j=1
All representations of the c coefficient begin with a “flattening” of the tensor to a matrix.
For 2-D systems, the N-by-N-by-2-by-2 tensor flattens to a 2N-by-2N matrix, where the
matrix is logically an N-by-N matrix of 2-by-2 blocks.
⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮
c(N, 1, 1, 1) c(N, 1, 1, 2) c(N, 2, 1, 1) c(N, 2, 1, 2) ⋯ c(N, N, 1, 1) c(N, N, 1, 2)
c(N, 1, 2, 1) c(N, 1, 2, 2) c(N, 2, 2, 1) c(N, 2, 2, 2) ⋯ c(N, N, 2, 1) c(N, N, 2, 2)
For 3-D systems, the N-by-N-by-3-by-3 tensor flattens to a 3N-by-3N matrix, where the
matrix is logically an N-by-N matrix of 3-by-3 blocks.
2-83
2 Setting Up Your PDE
These matrices further get flattened into a column vector. First the N-by-N matrices
of 2-by-2 and 3-by-3 blocks are transformed into "vectors" of 2-by-2 and 3-by-3 blocks.
Then the blocks are turned into vectors in the usual column-wise way.
The coefficient vector c relates to the tensor c as follows. For 2-D systems,
2-84
c Coefficient for specifyCoefficients
⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮
2
c(4N − 3) c(4N − 1) c(8N − 3) c(8N − 1) ⋯ c(4N − 3) c(4N2 − 1)
c(4N − 2) c(4N) c(8N − 2) c(8N) ⋯ c(4N2 − 2) c(4N2)
2-85
2 Setting Up Your PDE
c(10) c(13) c(16) c(9N + 10) c(9N + 13) c(9N + 16) ⋯ c(9N(N − 1) + 10) c(9N(N
c(11) c(14) c(17) c(9N + 11) c(9N + 14) c(9N + 17) ⋯ c(9N(N − 1) + 11) c(9N(N
c(12) c(15) c(18) c(9N + 12) c(9N + 15) c(9N + 18) ⋯ c(9N(N − 1) + 12) c(9N(N
⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋱ ⋮
c(9N − 8) c(9N − 5) c(9N − 2) c(18N − 8) c(18N − 5) c(18N − 2) ⋯ c(9N2 − 8) c(9N
2
c(9N − 7) c(9N − 4) c(9N − 1) c(18N − 7) c(18N − 4) c(18N − 1) ⋯ c(9N − 7) c(9N
c(9N − 6) c(9N − 3) c(9N) c(18N − 6) c(18N − 3) c(18N) ⋯ c(9N2 − 6) c(9N
2-86
c Coefficient for specifyCoefficients
2-D Systems
The software interprets a scalar c as a diagonal matrix, with c(i,i,1,1) and c(i,i,2,2) equal
to the scalar, and all other entries 0.
c 0 0 0 ⋯ 0 0
0 c 0 0 ⋯ 0 0
0 0 c 0 ⋯ 0 0
0 0 0 c ⋯ 0 0
⋮⋮ ⋮⋮ ⋱ ⋮⋮
0 0 0 0 ⋯ c 0
0 0 0 0 ⋯ 0 c
The software interprets a two-element column vector c as a diagonal matrix, with c(i,i,1,1)
and c(i,i,2,2) as the two entries, and all other entries 0.
2-87
2 Setting Up Your PDE
c(1) 0 0 0 ⋯ 0 0
0 c(2) 0 0 ⋯ 0 0
0 0 c(1) 0 ⋯ 0 0
0 0 0 c(2) ⋯ 0 0
⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮
0 0 0 0 ⋯ c(1) 0
0 0 0 0 ⋯ 0 c(2)
c(1) c(2) 0 0 ⋯ 0 0
c(2) c(3) 0 0 ⋯ 0 0
0 0 c(1) c(2) ⋯ 0 0
0 0 c(2) c(3) ⋯ 0 0
⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮
0 0 0 0 ⋯ c(1) c(2)
0 0 0 0 ⋯ c(2) c(3)
c(1) c(3) 0 0 ⋯ 0 0
c(2) c(4) 0 0 ⋯ 0 0
0 0 c(1) c(3) ⋯ 0 0
0 0 c(2) c(4) ⋯ 0 0
⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮
0 0 0 0 ⋯ c(1) c(3)
0 0 0 0 ⋯ c(2) c(4)
2-88
c Coefficient for specifyCoefficients
c(1) 0 0 0 ⋯ 0 0
0 c(1) 0 0 ⋯ 0 0
0 0 c(2) 0 ⋯ 0 0
0 0 0 c(2) ⋯ 0 0
⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮
0 0 0 0 ⋯ c(N) 0
0 0 0 0 ⋯ 0 c(N)
Caution If N = 2, 3, or 4, the 2-, 3-, or 4-element column vector form takes precedence
over the N-element form. For example, if N = 3, and you have a c matrix of the form
c1 0 0 0 0 0
0 c1 0 0 0 0
0 0 c2 0 0 0
0 0 0 c2 0 0
0 0 0 0 c3 0
0 0 0 0 0 c3
you cannot use the N-element form of c. Instead, you must use the 2N-element form. If
you give c as the vector [c1;c2;c3], the software interprets c as a 3-element form:
c1 c2 0 0 0 0
c2 c3 0 0 0 0
0 0 c1 c2 0 0
0 0 c2 c3 0 0
0 0 0 0 c1 c2
0 0 0 0 c2 c3
2-89
2 Setting Up Your PDE
c(1) 0 0 0 ⋯ 0 0
0 c(2) 0 0 ⋯ 0 0
0 0 c(3) 0 ⋯ 0 0
0 0 0 c(4) ⋯ 0 0
⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮
0 0 0 0 ⋯ c(2N − 1) 0
0 0 0 0 ⋯ 0 c(2N)
Caution If N = 2, the 4-element form takes precedence over the 2N-element form. For
example, if your c matrix is
c1 0 0 0
0 c2 0 0
0 0 c3 0
0 0 0 c4
you cannot give c as [c1;c2;c3;c4], because the software interprets this vector as the
4-element form
c1 c3 0 0
c2 c4 0 0
0 0 c1 c3
0 0 c2 c4
2-90
c Coefficient for specifyCoefficients
c(1) c(2) 0 0 ⋯ 0 0
c(2) c(3) 0 0 ⋯ 0 0
0 0 c(4) c(5) ⋯ 0 0
0 0 c(5) c(6) ⋯ 0 0
⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮
0 0 0 0 ⋯ c(3N − 2) c(3N − 1)
0 0 0 0 ⋯ c(3N − 1) c(3N)
c(1) c(3) 0 0 ⋯ 0 0
c(2) c(4) 0 0 ⋯ 0 0
0 0 c(5) c(7) ⋯ 0 0
0 0 c(6) c(8) ⋯ 0 0
⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮
0 0 0 0 ⋯ c(4N − 3) c(4N − 1)
0 0 0 0 ⋯ c(4N − 2) c(4N)
⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮
• • • • ⋯ c(N(2N + 1) − 2) c(N(2N + 1) − 1)
• • • • ⋯ • c(N(2N + 1))
2-91
2 Setting Up Your PDE
⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮
c(4N − 3) c(4N − 1) c(8N − 3) c(8N − 1) ⋯ c(4N2 − 3) c(4N2 − 1)
c(4N − 2) c(4N) c(8N − 2) c(8N) ⋯ c(4N2 − 2) c(4N2)
3-D Systems
The software interprets a scalar c as a diagonal matrix, with c(i,i,1,1), c(i,i,2,2), and
c(i,i,3,3) equal to the scalar, and all other entries 0.
2-92
c Coefficient for specifyCoefficients
c 0 0 0 0 0 ⋯ 0 0 0
0 c 0 0 0 0 ⋯ 0 0 0
0 0 c 0 0 0 ⋯ 0 0 0
0 0 0 c 0 0 ⋯ 0 0 0
0 0 0 0 c 0 ⋯ 0 0 0
0 0 0 0 0 c ⋯ 0 0 0
⋮⋮ ⋮ ⋮⋮ ⋮⋱ ⋮⋮ ⋮
0 0 0 0 0 0 ⋯ c 0 0
0 0 0 0 0 0 ⋯ 0 c 0
0 0 0 0 0 0 ⋯ 0 0 c
c(1) 0 0 0 0 0 ⋯ 0 0 0
0 c(2) 0 0 0 0 ⋯ 0 0 0
0 0 c(3) 0 0 0 ⋯ 0 0 0
0 0 0 c(1) 0 0 ⋯ 0 0 0
0 0 0 0 c(2) 0 ⋯ 0 0 0
0 0 0 0 0 c(3) ⋯ 0 0 0
⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮ ⋮
0 0 0 0 0 0 ⋯ c(1) 0 0
0 0 0 0 0 0 ⋯ 0 c(2) 0
0 0 0 0 0 0 ⋯ 0 0 c(3)
c(i,i,1,1) = c(1)
c(i,i,2,2) = c(3)
c(i,i,1,2) = c(i,i,2,1) = c(2)
c(i,i,1,3) = c(i,i,3,1) = c(4)
2-93
2 Setting Up Your PDE
2-94
c Coefficient for specifyCoefficients
c(1) 0 0 0 0 0 ⋯ 0 0 0
0 c(1) 0 0 0 0 ⋯ 0 0 0
0 0 c(1) 0 0 0 ⋯ 0 0 0
0 0 0 c(2) 0 0 ⋯ 0 0 0
0 0 0 0 c(2) 0 ⋯ 0 0 0
0 0 0 0 0 c(2) ⋯ 0 0 0
⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮ ⋮
0 0 0 0 0 0 ⋯ c(N) 0 0
0 0 0 0 0 0 ⋯ 0 c(N) 0
0 0 0 0 0 0 ⋯ 0 0 c(N)
Caution If N = 3, 6, or 9, the 3-, 6-, or 9-element column vector form takes precedence
over the N-element form. For example, if N = 3, and you have a c matrix of the form
c(1) 0 0 0 0 0 0 0 0
0 c(1) 0 0 0 0 0 0 0
0 0 c(1) 0 0 0 0 0 0
0 0 0 c(2) 0 0 0 0 0
0 0 0 0 c(2) 0 0 0 0
0 0 0 0 0 c(2) 0 0 0
0 0 0 0 0 0 c(3) 0 0
0 0 0 0 0 0 0 c(3) 0
0 0 0 0 0 0 0 0 c(3)
you cannot use the N-element form of c. If you give c as the vector [c1;c2;c3], the
software interprets c as a 3-element form:
2-95
2 Setting Up Your PDE
c(1) 0 0 0 0 0 0 0 0
0 c(2) 0 0 0 0 0 0 0
0 0 c(3) 0 0 0 0 0 0
0 0 0 c(1) 0 0 0 0 0
0 0 0 0 c(2) 0 0 0 0
0 0 0 0 0 c(3) 0 0 0
0 0 0 0 0 0 c(1) 0 0
0 0 0 0 0 0 0 c(2) 0
0 0 0 0 0 0 0 0 c(3)
c(1) 0 0 0 0 0 ⋯ 0 0 0
0 c(2) 0 0 0 0 ⋯ 0 0 0
0 0 c(3) 0 0 0 ⋯ 0 0 0
0 0 0 c(4) 0 0 ⋯ 0 0 0
0 0 0 0 c(5) 0 ⋯ 0 0 0
0 0 0 0 0 c(6) ⋯ 0 0 0
⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮ ⋮
0 0 0 0 0 0 ⋯ c(3N − 2) 0 0
0 0 0 0 0 0 ⋯ 0 c(3N − 1) 0
0 0 0 0 0 0 ⋯ 0 0 c(3N)
Caution If N = 3, the 9-element form takes precedence over the 3N-element form. For
example, if your c matrix is
2-96
c Coefficient for specifyCoefficients
c(1) 0 0 0 0 0 0 0 0
0 c(2) 0 0 0 0 0 0 0
0 0 c(3) 0 0 0 0 0 0
0 0 0 c(4) 0 0 0 0 0
0 0 0 0 c(5) 0 0 0 0
0 0 0 0 0 c(6) 0 0 0
0 0 0 0 0 0 c(7) 0 0
0 0 0 0 0 0 0 c(8) 0
0 0 0 0 0 0 0 0 c(9)
2-97
2 Setting Up Your PDE
2-98
c Coefficient for specifyCoefficients
c(1) c(2) c(4) c(7) c(10) c(13) ⋯ c(3(N − 1)(3(N − 1) + 1)/2 + 1 c(3(N − 1)(3(N − 1) + 1)/2 +
• c(3) c(5) c(8) c(11) c(14) ⋯ c(3(N − 1)(3(N − 1) + 1)/2 + 2 c(3(N − 1)(3(N − 1) + 1)/2 +
• • c(6) c(9) c(12) c(15) ⋯ c(3(N − 1)(3(N − 1) + 1)/2 + 3 c(3(N − 1)(3(N − 1) + 1)/2 +
2-99
2 Setting Up Your PDE
c(10) c(13) c(16) c(9N + 10) c(9N + 13) c(9N + 16) ⋯ c(9N(N − 1) + 10) c(9N(N
c(11) c(14) c(17) c(9N + 11) c(9N + 14) c(9N + 17) ⋯ c(9N(N − 1) + 11) c(9N(N
c(12) c(15) c(18) c(9N + 12) c(9N + 15) c(9N + 18) ⋯ c(9N(N − 1) + 12) c(9N(N
⋮ ⋮ ⋮ ⋮ ⋮ ⋮ ⋱ ⋮
c(9N − 8) c(9N − 5) c(9N − 2) c(18N − 8) c(18N − 5) c(18N − 2) ⋯ c(9N2 − 8) c(9N
2
c(9N − 7) c(9N − 4) c(9N − 1) c(18N − 7) c(18N − 4) c(18N − 1) ⋯ c(9N − 7) c(9N
c(9N − 6) c(9N − 3) c(9N) c(18N − 6) c(18N − 3) c(18N) ⋯ c(9N2 − 6) c(9N
Functional Form
If your c coefficient is not constant, represent it as a function of the form
ccoeffunction(location,state)
2-100
c Coefficient for specifyCoefficients
• N1 is the number of coefficients you pass to the solver. There are several possible
values of N1, detailed in “Some c Vectors Can Be Short” on page 2-86. For 2-D
geometry, 1 ≤ N1 ≤ 4N2, and for 3-D geometry, 1 ≤ N1 ≤ 9N2.
• Nr is the number of points in the location that the solver passes. Nr is equal to the
length of the location.x or any other location field. The function should evaluate
c at these points.
specifyCoefficients(model,'c',@ccoeffunction,...)
• location.x
• location.y
• location.z
• location.subdomain
The fields x, y, and z represent the x-, y-, and z- coordinates of points for which your
function calculates coefficient values. The subdomain field represents the subdomain
numbers, which currently apply only to 2-D models. The location fields are row
vectors.
• state is a structure with these fields:
• state.u
• state.ux
• state.uy
• state.uz
• state.time
The state.u field represents the current value of the solution u. The state.ux,
state.uy, and state.uz fields are estimates of the solution’s partial derivatives
(∂u/∂x, ∂u/∂y, and ∂u/∂z) at the corresponding points of the location structure. The
solution and gradient estimates are N-by-Nr matrices. The state.time field is a
scalar representing time for time-dependent models.
For example, suppose N = 3, and you have 2-D geometry. Suppose your c matrix is of the
form
2-101
2 Setting Up Your PDE
1 2
2 8
u(2)
1 + x2 + y2 2 2
1 + u(1) + u(3)
c=
u(2)
2 2
1 + x2 + y2
1 + u(1) + u(3)
s1(x, y) −1
−1 s1(x, y)
c(1) c(2) 0 0 ⋯ 0 0
c(2) c(3) 0 0 ⋯ 0 0
0 0 c(4) c(5) ⋯ 0 0
0 0 c(5) c(6) ⋯ 0 0
⋮ ⋮ ⋮ ⋮ ⋱ ⋮ ⋮
0 0 0 0 ⋯ c(3N − 2) c(3N − 1)
0 0 0 0 ⋯ c(3N − 1) c(3N)
n1 = 9;
nr = numel(location.x);
cmatrix = zeros(n1,nr);
cmatrix(1,:) = ones(1,nr);
cmatrix(2,:) = 2*ones(1,nr);
cmatrix(3,:) = 8*ones(1,nr);
cmatrix(4,:) = 1+location.x.^2 + location.y.^2;
cmatrix(5,:) = state.u(2,:)./(1 + state.u(1,:).^2 + state.u(3,:).^2);
cmatrix(6,:) = cmatrix(4,:);
cmatrix(7,:) = 5*location.subdomain;
2-102
See Also
cmatrix(8,:) = -ones(1,nr);
cmatrix(9,:) = cmatrix(7,:);
To include this function as your c coefficient, pass the function handle @ccoeffunction:
specifyCoefficients(model,'c',@ccoeffunction,...
See Also
Related Examples
• “Solve Problems Using PDEModel Objects” on page 2-3
• “f Coefficient for specifyCoefficients” on page 2-79
• “m, d, or a Coefficient for specifyCoefficients” on page 2-104
• “Deflection of Piezoelectric Actuator” on page 3-12
2-103
2 Setting Up Your PDE
Coefficients m, d, or a
This section describes how to write the m, d, or a coefficients in the system of equations
∂2 u ∂u
m +d − ∇ · c ⊗ ∇u + au = f
∂t 2 ∂t
− ∇ · c ⊗ ∇u + au = λdu
or
2
− ∇ · c ⊗ ∇u + au = λ mu
The topic applies to the recommended workflow for including coefficients in your model
using specifyCoefficients.
If there are N equations in the system, then these coefficients represent N-by-N matrices.
For constant (numeric) coefficient matrices, represent each coefficient using a column
vector with N2 components. This column vector represents, for example, m(:).
Note The d coefficient takes a special matrix form when m is nonzero. See “d Coefficient
When m is Nonzero” on page 5-953.
2-104
m, d, or a Coefficient for specifyCoefficients
Short m, d, or a vectors
Sometimes, your m, d, or a matrices are diagonal or symmetric. In these cases, you can
represent m, d, or a using a smaller vector than one with N2 components. The following
sections give the possibilities.
Scalar m, d, or a
a 0 ⋯ 0
0 a ⋯ 0
⋮⋮ ⋱⋮
0 0 ⋯ a
d(1) 0 ⋯ 0
0 d(2) ⋯ 0
⋮ ⋮ ⋱ ⋮
0 0 ⋯ d(N)
2-105
2 Setting Up Your PDE
Nonconstant m, d, or a
Note If both m and d are nonzero, then d must be a constant scalar or vector, not a
function.
dcoeffunction(location,state)
• N1 is the length of the vector representing the coefficient. There are several possible
values of N1, detailed in “Short m, d, or a vectors” on page 2-105. 1 ≤ N1 ≤ N2.
• Nr is the number of points in the location that the solver passes. Nr is equal to the
length of the location.x or any other location field. The function should evaluate
m, d, or a at these points.
specifyCoefficients(model,'d',@dcoeffunction,...)
• location.x
2-106
m, d, or a Coefficient for specifyCoefficients
• location.y
• location.z
• location.subdomain
The fields x, y, and z represent the x-, y-, and z- coordinates of points for which your
function calculates coefficient values. The subdomain field represents the subdomain
numbers, which currently apply only to 2-D models. The location fields are row
vectors.
• state is a structure with these fields:
• state.u
• state.ux
• state.uy
• state.uz
• state.time
The state.u field represents the current value of the solution u. The state.ux,
state.uy, and state.uz fields are estimates of the solution’s partial derivatives
(∂u/∂x, ∂u/∂y, and ∂u/∂z) at the corresponding points of the location structure. The
solution and gradient estimates are N-by-Nr matrices. The state.time field is a
scalar representing time for time-dependent models.
For example, suppose N = 3, and you have 2-D geometry. Suppose your d matrix is of the
form
1 s1(x, y) x2 + y2
d = s1(x, y) 4 −1
x2 + y2 −1 9
2-107
2 Setting Up Your PDE
n1 = 6;
nr = numel(location.x);
dmatrix = zeros(n1,nr);
dmatrix(1,:) = ones(1,nr);
dmatrix(2,:) = 5*location.subdomain;
dmatrix(3,:) = 4*ones(1,nr);
dmatrix(4,:) = sqrt(location.x.^2 + location.y.^2);
dmatrix(5,:) = -ones(1,nr);
dmatrix(6,:) = 9*ones(1,nr);
To include this function as your d coefficient, pass the function handle @dcoeffunction:
specifyCoefficients(model,'d',@dcoeffunction,...
See Also
Related Examples
• “f Coefficient for specifyCoefficients” on page 2-79
• “c Coefficient for specifyCoefficients” on page 2-82
• “Solve Problems Using PDEModel Objects” on page 2-3
• “Deflection of Piezoelectric Actuator” on page 3-12
2-108
View, Edit, and Delete PDE Coefficients
View Coefficients
A PDE model stores coefficients in its EquationCoefficients property. Suppose model
is the name of your model. Obtain the coefficients:
coeffs = model.EquationCoefficients;
To see the active coefficient assignment for a region, call the findCoefficients
function. For example, create a model and view the geometry.
model = createpde();
geometryFromEdges(model,@lshapeg);
pdegplot(model,'FaceLabels','on')
ylim([-1.1,1.1])
axis equal
2-109
2 Setting Up Your PDE
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',2);
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',3,'Face',2);
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',4,'Face',3);
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',1,'f',3,'Face',2);
2-110
View, Edit, and Delete PDE Coefficients
coeffs = model.EquationCoefficients;
findCoefficients(coeffs,'Face',2)
ans =
CoefficientAssignment with properties:
RegionType: 'face'
RegionID: 2
m: 0
d: 0
c: 1
a: 1
f: 3
findCoefficients(coeffs,'Face',1)
ans =
CoefficientAssignment with properties:
RegionType: 'face'
RegionID: [1 2 3]
m: 0
d: 0
c: 1
a: 0
f: 2
The active coefficient assignment for region 1 includes all three regions, though this
assignment is no longer active for regions 2 and 3.
delete(model.EquationCoefficients)
2-111
2 Setting Up Your PDE
coefv = model.EquationCoefficients.CoefficientAssignments;
delete(coefv(2))
Tip You do not need to delete coefficients; you can override them by calling
specifyCoefficients again. However, deleting unused assignments can make your
model smaller.
coefh1 = specifyCoefficients(model,'m',m,'d',d,'c',c,'a',a,'f',f);
• Obtain the handle using findCoefficients. For example,
coeffs = model.EquationCoefficients;
coefh1 = findCoefficients(coeffs,'face',2);
You can change any property of the coefficient handle. For example,
coefh1.RegionID = [1,3];
coefh1.a = 2;
coefh1.c = @ccoeffun;
Note Editing an existing assignment in this way does not change its priority. For
example, if the active coefficient in region 3 was assigned after coefh1, then editing
coefh1 to include region 3 does not make coefh1 the active coefficient in region 3.
2-112
Set Initial Conditions
• For time-dependent problems, the initial condition is the solution u at the initial time,
and also the initial time-derivative if the m coefficient is nonzero. Set the initial
condition in the model using setInitialConditions.
• For nonlinear stationary problems, the initial condition is a guess or approximation of
the solution u at the initial iteration of the nonlinear solver. Set the initial condition in
the model using setInitialConditions.
If you do not specify the initial condition for a stationary problem, solvepde uses the
zero function for the initial iteration.
If N = 3, and the initial condition is 15 for the first equation, 0 for the second equation,
and –3 for the third equation, use the following commands.
u0 = [15,0,-3];
setInitialConditions(model,u0);
If the m coefficient is nonzero, give an initial condition for the time derivative as well. Set
this initial derivative in the same form as the first initial condition. For example, if the
initial derivative of the solution is [4,3,0], use the following commands.
u0 = [15,0,-3];
ut0 = [4,3,0];
setInitialConditions(model,u0,ut0);
2-113
2 Setting Up Your PDE
function u0 = initfun(location)
∂2 u 3+x
2
− ∇ · ∇u =
∂t 4 − x−y
4 + x2 + y2
u(0) =
0
∂u 0
(0) =
∂t sin(xy)
3+x
This problem has m = 1, c = 1, and f = . Because m is nonzero, give both an
4−x−y
initial value of u and an initial value of the derivative of u.
Write the following function files. Save them to a location on your MATLAB path.
M = length(location.x);
uinit = zeros(2,M);
uinit(1,:) = 4 + location.x.^2 + location.y.^2;
M = length(location.x);
utinit = zeros(2,M);
utinit(2,:) = sin(location.x.*location.y);
u0 = @u0fun;
ut0 = @ut0fun;
setInitialConditions(model,u0,ut0);
2-114
See Also
results = solvepde(model,t0:tstep:t1);
If later you need to solve this PDE problem for times from t1 to t2, you can use results
to set initial conditions. If you do not explicitly specify the time step,
setInitialConditions uses results corresponding to the last solution time, t1.
setInitialConditions(model,results)
To use results for a particular solution time instead of the last one, specify the solution
time index as a third parameter of setInitialConditions. For example, to use the
solution at time t0 + 10*tstep, specify 11 as the third parameter.
setInitialConditions(model,results,11)
See Also
Related Examples
• “Solve Problems Using PDEModel Objects” on page 2-3
• “Wave Equation on Square Domain”
• “Inhomogeneous Heat Equation on Square Domain”
• “Heat Distribution in Circular Cylindrical Rod”
• “Heat Transfer Problem with Temperature-Dependent Properties”
• “Dynamic Analysis of Clamped Beam”
2-115
2 Setting Up Your PDE
inits = model.InitialConditions;
To see the active initial conditions assignment for a region, call the
findInitialConditions function. For example, create a model and view the geometry.
model = createpde();
geometryFromEdges(model,@lshapeg);
pdegplot(model,'FaceLabels','on')
ylim([-1.1,1.1])
axis equal
2-116
View, Edit, and Delete Initial Conditions
Specify constant initial conditions over all the regions in the model.
setInitialConditions(model,2);
setInitialConditions(model,3,'Face',2);
setInitialConditions(model,4,'Face',3);
ics = model.InitialConditions;
findInitialConditions(ics,'Face',2)
2-117
2 Setting Up Your PDE
ans =
GeometricInitialConditions with properties:
RegionType: 'face'
RegionID: 2
InitialValue: 3
InitialDerivative: []
findInitialConditions(ics,'Face',1)
ans =
GeometricInitialConditions with properties:
RegionType: 'face'
RegionID: [1 2 3]
InitialValue: 2
InitialDerivative: []
The active initial conditions assignment for region 1 includes all three regions, though
this assignment is no longer active for regions 2 and 3.
delete(model.InitialConditions)
icv = model.InitialConditions.InitialConditionAssignments;
delete(icv(2))
2-118
View, Edit, and Delete Initial Conditions
Tip You do not need to delete initial conditions; you can override them by calling
setInitialConditions again. However, deleting unused assignments can make your
model smaller.
ics1 = setInitialConditions(model,2);
• Obtain the handle using findInitialConditions. For example,
ics = model.InitialConditions;
ics1 = findInitialConditions(ics,'Face',2);
You can change any property of the initial conditions handle. For example,
ics1.RegionID = [1,3];
ics1.InitialValue = 2;
ics1.InitialDerivative = @ut0fun;
Note Editing an existing assignment in this way does not change its priority. For
example, if the active initial conditions in region 3 was assigned after ics1, then editing
ics1 to include region 3 does not make ics1 the active initial condition in region 3.
2-119
2 Setting Up Your PDE
• Boundaries between the interior of the region and the exterior of the region
• Boundaries between subdomains - these are boundaries in the interior of the region
For example, look at a rectangular region with a circular subdomain. The red numbers
are the subdomain labels, the black numbers are the edge segment labels.
% Set formula
sf = 'R1 + C1';
% Create geometry
gd = decsg(geom,sf,ns);
% View geometry
pdegplot(gd,'EdgeLabels','on','SubdomainLabels','on')
xlim([-1.1 1.1])
axis equal
2-120
No Boundary Conditions Between Subdomains
You need not give boundary conditions on segments 5, 6, 7, and 8, because these are
subdomain boundaries, not exterior boundaries.
However, if the circle is a hole, meaning it is not part of the region, then you do give
boundary conditions on segments 5, 6, 7, and 8.
2-121
2 Setting Up Your PDE
pdegplot(g,'EdgeLabels','on')
For example, look at the edge labels for a simple annulus geometry:
2-122
Identify Boundary Labels
2-123
2 Setting Up Your PDE
Now you can specify the boundary conditions for each edge or face. If you have a system
of PDEs, you can set a different boundary condition for each component on each boundary
edge or face. If the boundary condition is a function of position, time, or the solution u,
set boundary conditions by using the syntax in “Nonconstant Boundary Conditions” on
page 2-129.
If you do not specify a boundary condition for an edge or face, the default is the Neumann
boundary condition with the zero values for 'g' and 'q'.
The Dirichlet boundary condition implies that the solution u on a particular edge or face
satisfies the equation
hu = r,
where h and r are functions defined on ∂Ω, and can be functions of space (x, y, and, in 3-
D, z), the solution u, and, for time-dependent equations, time. Often, you take h = 1, and
set r to the appropriate value. You can specify Dirichlet boundary conditions as the value
of the solution u on the boundary or as a pair of the parameters h and r.
Suppose that you have a PDE model named model, and edges or faces [e1,e2,e3],
where the solution u must equal 2. Specify this boundary condition as follows.
2-124
Specify Boundary Conditions
If the solution on edges or faces [e1,e2,e3] satisfies the equation 2u = 3, specify the
boundary condition as follows.
% For 3-D geometry:
applyBoundaryCondition(model,'dirichlet','Face',[e1,e2,e3],'r',3,'h',2);
% For 2-D geometry:
applyBoundaryCondition(model,'dirichlet','Edge',[e1,e2,e3],'r',3,'h',2);
Systems of PDEs
Suppose that you have a PDE model named model, and edge or face labels [e1,e2,e3]
where the first component of the solution u must equal 1, while the second and third
components must equal 2. Specify this boundary condition as follows.
% For 3-D geometry:
applyBoundaryCondition(model,'dirichlet','Face',[e1,e2,e3],...
'u',[1,2,2],'EquationIndex',[1,2,3]);
% For 2-D geometry:
applyBoundaryCondition(model,'dirichlet','Edge',[e1,e2,e3],...
'u',[1,2,2],'EquationIndex',[1,2,3]);
• The 'u' and 'EquationIndex' arguments must have the same length.
• If you exclude the 'EquationIndex' argument, the 'u' argument must have length
N.
• If you exclude the 'u' argument, applyBoundaryCondition sets the components in
'EquationIndex' to 0.
Suppose that you have a PDE model named model, and edge or face labels [e1,e2,e3]
where the first, second, and third components of the solution u must satisfy the equations
2u1 = 3, 4u2 = 5, and 6u3 = 7, respectively. Specify this boundary condition as follows.
H0 = [2 0 0;
0 4 0;
0 0 6];
R0 = [3;5;7];
% For 3-D geometry:
applyBoundaryCondition(model,'dirichlet', ...
2-125
2 Setting Up Your PDE
'Face',[e1,e2,e3], ...
'h',H0,'r',R0);
% For 2-D geometry:
applyBoundaryCondition(model,'dirichlet', ...
'Edge',[e1,e2,e3], ...
'h',H0,'r',R0);
• The 'r' parameter must be a numeric vector of length N. If you do not specify 'r',
applyBoundaryCondition sets the values to 0.
• The 'h' parameter can be an N-by-N numeric matrix or a vector of length N2
corresponding to the linear indexing form of the N-by-N matrix. For details about the
linear indexing form, see “Array Indexing” (MATLAB). If you do not specify 'h',
applyBoundaryCondition sets the value to the identity matrix.
Generalized Neumann boundary conditions imply that the solution u on the edge or face
satisfies the equation
n · c ∇u + qu = g
The coefficient c is the same as the coefficient of the second-order differential operator in
the PDE equation
− ∇ ⋅ c ∇u + au = f on domain Ω
n is the outward unit normal. q and g are functions defined on ∂Ω, and can be functions of
space (x, y, and, in 3-D, z), the solution u, and, for time-dependent equations, time.
Suppose that you have a PDE model named model, and edges or faces [e1,e2,e3]
where the solution u must satisfy the Neumann boundary condition with q = 2 and g =
3. Specify this boundary condition as follows.
2-126
Specify Boundary Conditions
Systems of PDEs
For 3-D systems, the notation n · c ⊗ ∇u means the N-by-1 vector with (i,1)-component
N
∂ ∂ ∂
∑ sin φ cos θ ci, j, 1, 1
∂x
+ sin φ cos θ ci, j, 1, 2
∂y
+ sin φ cos θ ci, j, 1, 3 u
∂z j
j=1
N
∂ ∂ ∂
+ ∑ sin φ sin θ ci, j, 2, 1
∂x
+ sin φ sin θ ci, j, 2, 2
∂y
+ sin φ sin θ ci, j, 2, 3 u
∂z j
j=1
N
∂ ∂ ∂
+ ∑ cos θ ci, j, 3, 1
∂x
+ cos θ ci, j, 3, 2
∂y
+ cos θ ci, j, 3, 3 u
∂z j
j=1
where the outward normal vector of the boundary n = sin(φ)cos(θ), sin(φ)sin(θ), cos(φ) .
For each edge or face segment, there are a total of N boundary conditions.
Suppose that you have a PDE model named model, and edges or faces [e1,e2,e3]
where the first component of the solution u must satisfy the Neumann boundary condition
with q = 2 and g = 3, and the second component must satisfy the Neumann boundary
condition with q = 4 and g = 5. Specify this boundary condition as follows.
Q = [2 0; 0 4];
G = [3;5];
% For 3-D geometry:
applyBoundaryCondition(model,'neumann','Face',[e1,e2,e3],'q',Q,'g',G);
% For 2-D geometry:
applyBoundaryCondition(model,'neumann','Edge',[e1,e2,e3],'q',Q,'g',G);
• The 'g' parameter must be a numeric vector of length N. If you do not specify 'g',
applyBoundaryCondition sets the values to 0.
• The 'q' parameter can be an N-by-N numeric matrix or a vector of length N2
corresponding to the linear indexing form of the N-by-N matrix. For details about the
2-127
2 Setting Up Your PDE
linear indexing form, see “Array Indexing” (MATLAB). If you do not specify 'q',
applyBoundaryCondition sets the values to 0.
Suppose that you have a PDE model named model, and edge or face labels [e1,e2,e3]
where the first component of the solution u must equal 11, the second component must
equal 22, and the third component must satisfy the Neumann boundary condition with q
= 3 and g = 4. Express this boundary condition as follows.
Q = [0 0 0; 0 0 0; 0 0 3];
G = [0;0;4];
% For 3-D geometry:
applyBoundaryCondition(model,'mixed','Face',[e1,e2,e3],...
'u',[11,22],'EquationIndex',[1,2],...
'q',Q,'g',G);
% For 2-D geometry:
applyBoundaryCondition(model,'mixed',...
'Edge',[e1,e2,e3],'u',[11,22],...
'EquationIndex',[1,2],'q',Q,'g',G);
Suppose that you have a PDE model named model, and edges or faces [e1,e2,e3]
where the first component of the solution u must satisfy the Dirichlet boundary condition
2u1 = 3, the second component must satisfy the Neumann boundary condition with q = 4
and g = 5, and the third component must satisfy the Neumann boundary condition with
q = 6 and g = 7. Express this boundary condition as follows.
h = [2 0 0; 0 0 0; 0 0 0];
r = [3;0;0];
Q = [0 0 0; 0 4 0; 0 0 6];
G = [0;5;7];
% For 3-D geometry:
applyBoundaryCondition(model,'mixed', ...
'Face',[e1,e2,e3], ...
'h',h,'r',r,'q',Q,'g',G);
% For 2-D geometry:
applyBoundaryCondition(model,'mixed', ...
2-128
Specify Boundary Conditions
'Edge',[e1,e2,e3], ...
'h',h,'r',r,'q',Q,'g',G);
applyBoundaryCondition(model,'dirichlet', ...
'Edge',1, ...
'r',@myrfun);
applyBoundaryCondition(model,'neumann', ...
'Face',2, ...
'g',@mygfun,'q',@myqfun);
applyBoundaryCondition(model,'mixed', ...
'Edge',[3,4], ...
'u',@myufun, ...
'EquationIndex',[2,3]);
Partial Differential Equation Toolbox solvers pass the location and state data to your
function.
• location — A structure containing the following fields. If you pass a name-value pair
to applyBoundaryCondition with Vectorized set to 'on', then location can
contain several evaluation points. If you do not set Vectorized or use
Vectorized,'off', then solvers pass just one evaluation point in each call.
Furthermore, if there are Neumann conditions, then solvers pass the following data in
the location structure.
2-129
2 Setting Up Your PDE
Your function returns bcMatrix. This matrix has the following form, depending on the
boundary condition type.
• 'u' — N1-by-M matrix, where each column corresponds to one evaluation point, and
M is the number of evaluation points. N1 is the length of the 'EquationIndex'
argument. If there is no 'EquationIndex' argument, then N1 = N.
• 'r' or 'g' — N-by-M matrix, where each column corresponds to one evaluation point,
and M is the number of evaluation points.
• 'h' or 'q' — N2-by-M matrix, where each column corresponds to one evaluation point
via linear indexing of the underlying N-by-N matrix, and M is the number of evaluation
points. Alternatively, an N-by-N-by-M array, where each evaluation point is an N-by-N
matrix. For details about linear indexing, see “Array Indexing” (MATLAB).
2-130
Solve PDEs with Constant Boundary Conditions
Geometry
All the specifications use the same 2-D geometry, which is a rectangle with a circular hole.
% Set formula
sf = 'R1 - C1';
% Create geometry
g = decsg(geom,sf,ns);
2-131
2 Setting Up Your PDE
Scalar Problem
Suppose that edge 3 has Dirichlet conditions with value 32, edge 1 has Dirichlet
conditions with value 72, and all other edges have Neumann boundary conditions with q
= 0, g = -1.
applyBoundaryCondition(model,'dirichlet','edge',3,'u',32);
applyBoundaryCondition(model,'dirichlet','edge',1,'u',72);
applyBoundaryCondition(model,'neumann','edge',[2,4:8],'g',-1);
2-132
Solve PDEs with Constant Boundary Conditions
Solve an elliptic PDE with these boundary conditions with c = 1, a = 0, and f = 10.
Because the shorter rectangular side has length 0.8, to ensure that the mesh is not too
coarse choose a maximum mesh size Hmax = 0.1.
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',10);
generateMesh(model,'Hmax',0.1);
results = solvepde(model);
u = results.NodalSolution;
pdeplot(model,'XYData',u,'ZData',u)
view(-23,8)
System of PDEs
2-133
2 Setting Up Your PDE
model = createpde(2);
geometryFromEdges(model,g);
applyBoundaryCondition(model,'dirichlet','edge',3,'u',[32,72]);
applyBoundaryCondition(model,'dirichlet','edge',1,'u',[72,32]);
applyBoundaryCondition(model,'mixed','edge',4,'u',52,'EquationIndex',1,'g',[0,-1]);
Q2 = [1,2;3,4];
G2 = [5,-6];
applyBoundaryCondition(model,'neumann','edge',2,'q',Q2,'g',G2);
% The next step is optional, because it sets 'g' to its default value
applyBoundaryCondition(model,'neumann','edge',5:8,'g',[0,0]);
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f', [10;-10]);
generateMesh(model,'Hmax',0.1);
results = solvepde(model);
u = results.NodalSolution;
pdeplot(model,'XYData',u(:,2),'ZData',u(:,2))
2-134
See Also
See Also
More About
• “Specify Boundary Conditions” on page 2-124
• “Solve PDEs with Nonconstant Boundary Conditions” on page 2-136
2-135
2 Setting Up Your PDE
Geometry
All the specifications use the same geometry, which is a rectangle with a circular hole.
% Set formula
sf = 'R1-C1';
% Create geometry
g = decsg(geom,sf,ns);
2-136
Solve PDEs with Nonconstant Boundary Conditions
Scalar Problem
applyBoundaryCondition(model,'dirichlet','Edge',3,'u',32);
applyBoundaryCondition(model,'dirichlet','Edge',1,'u',72);
applyBoundaryCondition(model,'neumann','Edge',5:8,'g',-1); % q = 0 by default
2-137
2 Setting Up Your PDE
Edges 2 and 4 need functions that perform the linear interpolation. Each edge can use the
same function that returns the value u x, y = 52 + 20x.
Include the function for edges 2 and 4. To help speed the solver, allow a vectorized
evaluation.
applyBoundaryCondition(model,'dirichlet','Edge',[2,4],...
'u',myufunction,...
'Vectorized','on');
Solve an elliptic PDE with these boundary conditions, using the parameters c = 1, a =
0, and | f = 10|. Because the shorter rectangular side has length 0.8, to ensure that the
mesh is not too coarse choose a maximum mesh size Hmax = 0.1.
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',10);
generateMesh(model,'Hmax',0.1);
results = solvepde(model);
u = results.NodalSolution;
pdeplot(model,'XYData',u)
2-138
Solve PDEs with Nonconstant Boundary Conditions
System of PDEs
2-139
2 Setting Up Your PDE
applyBoundaryCondition(model,'dirichlet','Edge',3,'u',[32,72]);
applyBoundaryCondition(model,'dirichlet','Edge',1,'u',[72,32]);
applyBoundaryCondition(model,'neumann','Edge',5:8,'g',[-10,-10]);
The first component of edges 2 and 4 satisfies the equation u1 x = 52 + 20x + 10sin πx3 .
Write a function file myufun.m that incorporates these equations in the syntax described
in “Nonconstant Boundary Conditions” on page 2-129.
applyBoundaryCondition(model,'dirichlet','Edge',[2,4],...
'u',@myufun,...
'Vectorized','on');
Solve an elliptic PDE with these boundary conditions, with the parameters c = 1, a = 0,
and f = (10,-10). Because the shorter rectangular side has length 0.8, to ensure that
the mesh is not too coarse choose a maximum mesh size Hmax = 0.1.
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',[10;-10]);
generateMesh(model,'Hmax',0.1);
results = solvepde(model);
u = results.NodalSolution;
subplot(1,2,1)
pdeplot(model,'XYData',u(:,1),'ZData',u(:,1),'ColorBar','off')
view(-9,24)
subplot(1,2,2)
pdeplot(model,'XYData',u(:,2),'ZData',u(:,2),'ColorBar','off')
view(-9,24)
2-140
Solve PDEs with Nonconstant Boundary Conditions
2-141
2 Setting Up Your PDE
BCs = model.BoundaryConditions;
To see the active boundary condition assignment for a region, call the
findBoundaryConditions function.
model = createpde(3);
importGeometry(model,'Block.stl');
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
2-142
View, Edit, and Delete Boundary Conditions
Set zero Dirichlet conditions for all equations and all regions in the model.
applyBoundaryCondition(model,'dirichlet','Face',1:6,'u',[0,0,0]);
On face 3, set the Neumann boundary condition for equation 1 and Dirichlet boundary
condition for equations 2 and 3.
2-143
2 Setting Up Your PDE
View the boundary condition assignment for face 3. The result shows that the active
boundary condition is the last assignment.
BCs = model.BoundaryConditions;
findBoundaryConditions(BCs,'Face',3)
ans =
BoundaryCondition with properties:
BCType: 'mixed'
RegionType: 'Face'
RegionID: 3
r: [3x1 double]
h: [3x3 double]
g: [3x1 double]
q: [3x3 double]
u: []
EquationIndex: []
Vectorized: 'off'
findBoundaryConditions(BCs,'Face',1)
ans =
BoundaryCondition with properties:
BCType: 'dirichlet'
RegionType: 'Face'
RegionID: [1 2 3 4 5 6]
r: []
h: []
g: []
q: []
u: [0 0 0]
EquationIndex: []
Vectorized: 'off'
The active boundary conditions assignment for face 1 includes all six faces, though this
assignment is no longer active for face 3.
2-144
View, Edit, and Delete Boundary Conditions
To remove specific boundary conditions assignments from pdem, delete them from the
pdem.BoundaryConditions.BoundaryConditionAssignments vector. For example,
BCv = pdem.BoundaryConditions.BoundaryConditionAssignments;
delete(BCv(2))
Tip You do not need to delete boundary conditions; you can override them by calling
applyBoundaryCondition again. However, removing unused assignments can make
your model more concise.
bc1 =
BCType: 'dirichlet'
RegionType: 'Face'
RegionID: [1 2 3 4 5 6]
r: []
h: []
g: []
q: []
2-145
2 Setting Up Your PDE
u: [0 0 0]
EquationIndex: []
Vectorized: 'off'
You can change any property of the boundary conditions handle. For example,
bc1.BCType = 'neumann';
bc1.u = [];
bc1.g = [0 0 0];
bc1.q = [0 0 0];
bc1
bc1 =
BCType: 'neumann'
RegionType: 'Face'
RegionID: [1 2 3 4 5 6]
r: []
h: []
g: [0 0 0]
q: [0 0 0]
u: []
EquationIndex: []
Vectorized: 'off'
Note Editing an existing assignment in this way does not change its priority. For
example, if the active boundary condition was assigned after bc1, then editing bc1 does
not make bc1 the active boundary condition.
See Also
Related Examples
• “Specify Boundary Conditions” on page 2-124
2-146
Generate Mesh
Generate Mesh
The generateMesh function creates a triangular mesh for a 2-D geometry and a
tetrahedral mesh for a 3-D geometry. By default, the mesh generator uses internal
algorithms to choose suitable sizing parameters for a particular geometry. You also can
use additional arguments to specify the following parameters explicitly:
• Target maximum mesh edge length, which is an approximate upper bound on the mesh
edge lengths. Note that occasionally, some elements can have edges longer than this
parameter.
• Target minimum mesh edge length, which is an approximate lower bound on the mesh
edge lengths. Note that occasionally, some elements can have edges shorter than this
parameter.
• Mesh growth rate, which is the rate at which the mesh size increases away from the
small parts of the geometry. The value must be between 1 and 2. This ratio
corresponds to the edge length of two successive elements. The default value is 1.5,
that is, the mesh size increases by 50%.
• Quadratic or linear geometric order. A quadratic element has nodes at its corners and
edge centers, while a linear element has nodes only at its corners.
model = createpde;
importGeometry(model,'PlateSquareHolePlanar.stl');
pdegplot(model)
2-147
2 Setting Up Your PDE
Generate a default mesh. For this geometry, the default target maximum and minimum
mesh edge lengths are 8.9443 and 4.4721, respectively.
mesh_default = generateMesh(model)
mesh_default =
FEMesh with properties:
2-148
Generate Mesh
GeometricOrder: 'quadratic'
For comparison, create a mesh with the target maximum element edge length of 20.
mesh_Hmax = generateMesh(model,'Hmax',20)
mesh_Hmax =
FEMesh with properties:
2-149
2 Setting Up Your PDE
figure
pdemesh(mesh_Hmax)
Now create a mesh with the target minimum element edge length of 0.5.
mesh_Hmin = generateMesh(model,'Hmin',0.5)
2-150
Generate Mesh
mesh_Hmin =
FEMesh with properties:
figure
pdemesh(mesh_Hmin)
2-151
2 Setting Up Your PDE
Create a mesh, specifying both the maximum and minimum element edge lengths instead
of using the default values.
mesh_HminHmax = generateMesh(model,'Hmax',20,'Hmin',0.5)
mesh_HminHmax =
FEMesh with properties:
figure
pdemesh(mesh_HminHmax)
2-152
Generate Mesh
Create a mesh with the same maximum and minimum element edge lengths, but with the
growth rate of 1.9 instead of the default value of 1.5.
mesh_Hgrad = generateMesh(model,'Hmax',20,'Hmin',0.5,'Hgrad',1.9)
mesh_Hgrad =
FEMesh with properties:
2-153
2 Setting Up Your PDE
GeometricOrder: 'quadratic'
figure
pdemesh(mesh_Hgrad)
You also can choose the geometric order of the mesh. The toolbox can generate meshes
made up of quadratic or linear elements. By default, it uses quadratic meshes, which have
nodes at both the edge centers and corner nodes.
mesh_quadratic = generateMesh(model,'Hmax',50);
figure
pdemesh(mesh_quadratic,'NodeLabels','on')
2-154
Generate Mesh
hold on
plot(mesh_quadratic.Nodes(1,:),mesh_quadratic.Nodes(2,:),'ok','MarkerFaceColor','g')
To save memory or solve a 2-D problem using a legacy solver, override the default
quadratic geometric order. Legacy PDE solvers require linear triangular meshes for 2-D
geometries.
mesh_linear = generateMesh(model,'Hmax',50,'GeometricOrder','linear');
figure
pdemesh(mesh_linear,'NodeLabels','on')
hold on
plot(mesh_linear.Nodes(1,:),mesh_linear.Nodes(2,:),'ok','MarkerFaceColor','g')
2-155
2 Setting Up Your PDE
2-156
Find Mesh Elements and Nodes by Location
2-157
2 Setting Up Your PDE
thermalProperties(thermalmodel,'ThermalConductivity',1);
∘
Apply a constant temperature of 20 C to the left edge and a constant temperature of
∘
−10 Cto the right edge. All other edges are insulated by default.
thermalBC(thermalmodel,'Edge',4,'Temperature',20);
thermalBC(thermalmodel,'Edge',1,'Temperature',-10);
Generate a mesh and solve the problem. For this example, use a linear mesh to better see
the nodes on the mesh plots. Additional nodes on a quadratic mesh make it difficult to see
the plots in this example clearly.
mesh = generateMesh(thermalmodel,'GeometricOrder','linear');
thermalresults = solve(thermalmodel);
The solver finds the temperatures and temperature gradients at all nodal locations. Plot
the temperatures.
pdeplot(thermalmodel,'XYData',thermalresults.Temperature)
axis equal
2-158
Find Mesh Elements and Nodes by Location
Suppose you need to analyze the results around the center hole more closely. First, find
the nodes and elements located next to the hole by using the findNodes and
findElements functions. For example, find nodes and elements located within the radius
of 2.5 from the center [5 10].
Nr = findNodes(mesh,'radius',[5 10],2.5);
Er = findElements(mesh,'radius',[5 10],2.5);
Highlight the nodes within this radius on the mesh plot using a green marker.
figure
pdemesh(thermalmodel)
hold on
plot(mesh.Nodes(1,Nr),mesh.Nodes(2,Nr),'or','MarkerFaceColor','g')
2-159
2 Setting Up Your PDE
Find the minimal and maximal temperatures within the specified radius.
[Temps_disk] = thermalresults.Temperature(Nr);
[T_min,index_min] = min(Temps_disk);
[T_max,index_max] = max(Temps_disk);
T_min
T_min = -2.1698
T_max
T_max = 12.2420
Find the IDs of the nodes corresponding to the minimal and maximal temperatures. Plot
these nodes on the mesh plot.
2-160
Find Mesh Elements and Nodes by Location
nodeIDmin = Nr(index_min);
nodeIDmax = Nr(index_max);
figure
pdemesh(thermalmodel)
hold on
plot(mesh.Nodes(1,nodeIDmin),mesh.Nodes(2,nodeIDmin),'or','MarkerFaceColor','b')
plot(mesh.Nodes(1,nodeIDmax),mesh.Nodes(2,nodeIDmax),'or','MarkerFaceColor','r')
Now highlight the elements within the specified radius on the mesh plot using a green
marker.
figure
pdemesh(thermalmodel)
2-161
2 Setting Up Your PDE
hold on
pdemesh(mesh.Nodes,mesh.Elements(:,Er),'EdgeColor','green')
figure
pdeplot(mesh.Nodes,mesh.Elements(:,Er),'XYData',thermalresults.Temperature)
2-162
Find Mesh Elements and Nodes by Location
2-163
2 Setting Up Your PDE
Typically, PDE solvers work best with meshes made up of elements that have an
equilateral shape. Such meshes are ideal. In reality, creating an ideal mesh for most 2-D
and 3-D geometries is impossible because geometries have tiny or narrow regions and
sharp angles. For such regions, a mesh generator creates meshes with some elements
that are much smaller than the rest of mesh elements or have drastically different side
lengths.
Checking if the mesh is of good quality before running an analysis is a good practice,
especially for simulations that take a long time. The toolbox provides the meshQuality
function for this task.
meshQuality evaluates the shape quality of mesh elements and returns numbers from 0
to 1 for each mesh element. The value 1 corresponds to the optimal shape of the element.
By default, the meshQuality function combines several criteria when evaluating the
shape quality. In addition to the default metric, you can use the aspect-ratio metric,
which is based solely on the ratio of the minimum dimension of an element to its
maximum dimension.
model = createpde;
importGeometry(model,'Torus.stl');
pdegplot(model)
camlight right
2-164
Assess Quality of Mesh Elements
2-165
2 Setting Up Your PDE
hold on
pdemesh(mesh.Nodes,mesh.Elements(:,elemIDs),'FaceColor','blue','EdgeColor','blue')
Determine how much of the total mesh volume belongs to elements with quality values
less than 0.3. Return the result as a percentage.
mv03_percent = volume(mesh,elemIDs)/volume(mesh)*100
mv03_percent = 0.0198
Evaluate the shape quality of the mesh elements by using the ratio of minimal to maximal
dimension for each element.
Q = meshQuality(mesh,'aspect-ratio');
2-166
Assess Quality of Mesh Elements
figure
pdemesh(mesh,'FaceAlpha',0.5)
hold on
pdemesh(mesh.Nodes,mesh.Elements(:,elemIDs),'FaceColor','blue','EdgeColor','blue')
2-167
2 Setting Up Your PDE
Note New features might not be compatible with the legacy workflow. For description of
the mesh data in the recommended workflow, see “Mesh Data” on page 2-171.
• p (points, the mesh nodes) is a 2-by-Np matrix of nodes, where Np is the number of
nodes in the mesh. Each column p(:,k) consists of the x-coordinate of point k in
p(1,k) and the y-coordinate of point k in p(2,k).
• e (edges) is a 7-by-Ne matrix of edges, where Ne is the number of edges in the mesh.
The mesh edges in e and the edges of the geometry have a one-to-one
correspondence. The e matrix represents the discrete edges of the geometry in the
same manner as the t matrix represents the discrete faces. Each column in the e
matrix represents one edge.
2-168
Mesh Data as [p,e,t] Triples
• p (points, the mesh nodes) is a 3-by-Np matrix of nodes, where Np is the number of
nodes in the mesh. Each column p(:,k) consists of the x-coordinate of point k in
p(1,k), the y-coordinate of point k in p(2,k), and the z-coordinate of point k in
p(3,k).
• e is an object that associates the mesh faces with the geometry boundaries. Partial
Differential Equation Toolbox functions use this association when converting the
boundary conditions, which you set on geometry boundaries, to the mesh boundary
faces.
• t (tetrahedra) is either an 11-by-Nt matrix of tetrahedra or a 5-by-Nt matrix of
tetrahedra, depending on whether you call generateMesh with the GeometricOrder
name-value pair set to 'quadratic' or 'linear', respectively. Nt is the number of
tetrahedra in the mesh. Each column of t contains the indices of the points in p that
form the tetrahedron. The exception is the last element in the column, which is the
subdomain number. Tetrahedron points are ordered as shown.
2-169
2 Setting Up Your PDE
2-170
Mesh Data
Mesh Data
Partial Differential Equation Toolbox uses meshes with triangular elements for 2-D
geometries and meshes with tetrahedral elements for 3-D geometries. In both cases, it
uses the quadratic geometric order by default, and provides the option to switch to the
linear quadratic geometric order. A mesh always consists of elements of the same order.
The toolbox does not support mixed meshes.
The triangles in 2-D meshes are specified by three nodes for linear elements or six nodes
for quadratic elements. A triangle representing a linear element has nodes at the corners.
A triangle representing a quadratic element has nodes at its corners and edge centers.
The tetrahedra in 3-D meshes are specified by four nodes for linear elements or 10 nodes
for quadratic elements. A tetrahedron representing a linear element has nodes at the
corners. A tetrahedron representing a quadratic element has nodes at its corners and
edge centers.
2-171
2 Setting Up Your PDE
The model container object stores the parameters of the PDE model. The toolbox offers
several types of model container objects, each for a particular application area. For
example, for linear elasticity problems, the model container is a StructuralModel
object, and for heat transfer problems, the model container is a ThermalModel object.
For general PDE problems, the toolbox uses the PDEModel object.
The Mesh property of the model container object stores mesh data. The Mesh property
contains a FEMesh object. FEMesh include information on the nodes and elements of the
mesh, mesh growth rate, and target minimum and maximum element size. The properties
also indicate whether the mesh is linear or quadratic. You can specify these mesh
parameters when creating a mesh.
To generate a mesh for your PDE model, use the generateMesh function.
By default, generateMesh uses the quadratic geometric order, which typically produces
more accurate results than the linear geometric order. To switch to the linear geometric
order, call the mesh generator and set the GeometricOrder name-value pair to
'linear'.
2-172
3
Solving PDEs
• “von Mises Effective Stress and Displacements: PDE Modeler App” on page 3-3
• “Clamped, Square Isotropic Plate with Uniform Pressure Load” on page 3-7
• “Deflection of Piezoelectric Actuator” on page 3-12
• “Dynamics of Damped Cantilever Beam” on page 3-25
• “Dynamic Analysis of Clamped Beam” on page 3-38
• “Reduced-Order Modeling Technique for Beam with Point Load” on page 3-48
• “Modal and Frequency Response Analysis for Single Part of Kinova® Gen3 Robotic
Arm” on page 3-57
• “Thermal Stress Analysis of Jet Engine Turbine Blade” on page 3-70
• “Finite Element Analysis of Electrostatically Actuated MEMS Device” on page 3-81
• “Deflection Analysis of Bracket” on page 3-98
• “Vibration of Square Plate” on page 3-108
• “Structural Dynamics of Tuning Fork” on page 3-113
• “Modal Superposition Method for Structural Dynamics Problem” on page 3-124
• “Stress Concentration in Plate with Circular Hole” on page 3-129
• “Thermal Deflection of Bimetallic Beam” on page 3-139
• “Electrostatic Potential in Air-Filled Frame: PDE Modeler App” on page 3-147
• “Linear Elasticity Equations” on page 3-150
• “Magnetic Field in Two-Pole Electric Motor: PDE Modeler App” on page 3-157
• “Scattering Problem” on page 3-163
• “Electrostatics and Magnetostatics” on page 3-169
• “AC Power Electromagnetics Equations” on page 3-171
• “DC Conduction” on page 3-173
• “Skin Effect in Copper Wire with Circular Cross Section: PDE Modeler App”
on page 3-174
• “Current Density Between Two Metallic Conductors: PDE Modeler App” on page 3-182
3 Solving PDEs
• “Heat Transfer Between Two Squares Made of Different Materials: PDE Modeler App”
on page 3-185
• “Nonlinear Heat Transfer in Thin Plate” on page 3-189
• “Poisson's Equation on Unit Disk: PDE Modeler App” on page 3-199
• “Poisson's Equation on Unit Disk” on page 3-205
• “Scattering Problem: PDE Modeler App” on page 3-215
• “Minimal Surface Problem” on page 3-220
• “Minimal Surface Problem: PDE Modeler App” on page 3-225
• “Poisson's Equation with Point Source and Adaptive Mesh Refinement” on page 3-227
• “Heat Transfer in Block with Cavity: PDE Modeler App” on page 3-233
• “Heat Transfer in Block with Cavity” on page 3-238
• “Heat Transfer Problem with Temperature-Dependent Properties” on page 3-242
• “Heat Conduction in Multidomain Geometry with Nonuniform Heat Flux”
on page 3-252
• “Inhomogeneous Heat Equation on Square Domain” on page 3-260
• “Heat Distribution in Circular Cylindrical Rod” on page 3-265
• “Heat Distribution in Circular Cylindrical Rod: PDE Modeler App” on page 3-275
• “Wave Equation on Square Domain” on page 3-279
• “Wave Equation on Square Domain: PDE Modeler App” on page 3-284
• “Eigenvalues and Eigenmodes of L-Shaped Membrane” on page 3-287
• “Eigenvalues and Eigenmodes of L-Shaped Membrane: PDE Modeler App”
on page 3-293
• “L-Shaped Membrane with Rounded Corner: PDE Modeler App” on page 3-296
• “Eigenvalues and Eigenmodes of Square” on page 3-299
• “Eigenvalues and Eigenmodes of Square: PDE Modeler App” on page 3-306
• “Vibration of Circular Membrane” on page 3-309
• “Plot 2-D Solutions and Their Gradients” on page 3-314
• “Plot 3-D Solutions and Their Gradients” on page 3-325
• “Dimensions of Solutions, Gradients, and Fluxes” on page 3-347
3-2
von Mises Effective Stress and Displacements: PDE Modeler App
Consider a steel plate that is clamped along a right-angle inset at the lower-left corner,
and pulled along a rounded cut at the upper-right corner. All other sides are free. The
steel plate has the following properties:
The curved boundary is subjected to an outward normal load of 500 N/m. To specify a
surface traction, divide the load by the thickness (0.001 m). Thus, the surface traction is
0.5 MN/m2. The force unit in this example is MN.
To solve this problem in the PDE Modeler app, follow these steps:
1 Draw a polygon with corners (0 1), (2/3,1), (1,2/3), (1,0), (1/3,0), (1/3,1/3), (0,1/3) and
a circle with the center (2/3, 2/3) and radius 1/3.
3-3
3 Solving PDEs
6 Display the edge labels by selecting Boundary > Show Edge Labels.
7 Specify the boundary conditions. To do this, select Boundary > Specify Boundary
Conditions.
3-4
von Mises Effective Stress and Displacements: PDE Modeler App
• For the two clamped boundaries at the inset in the lower left (edges 4 and 5),
specify the Dirichlet boundary condition with zero displacements: h11 = 1, h12
= 0, h21 = 0, h22 = 1, r1 = 0, r2 = 0. Use Shift+click to select several
boundaries.
• For the rounded cut (edge 7), specify the Neumann boundary condition: g1 =
0.5*nx, g2 = 0.5*ny, q11 = q12 = q21 = q22 = 0.
8 Specify the coefficients by selecting PDE > PDE Specification or clicking the PDE
button on the toolbar. Specify E = 196E3 and nu = 0.31. The material is
homogeneous, so the same values E and nu apply to the entire 2-D domain. Because
there are no volume forces, specify Kx = Ky = 0. The elliptic type of PDE for plane
stress does not use density, so you can specify any value. For example, specify pho =
0.
9 Initialize the mesh by selecting Mesh > Initialize Mesh. Refine the mesh by
selecting Mesh > Refine Mesh.
10 Refining the mesh in areas where the gradient of the solution (the stress) is large. To
do this, select Solve > Parameters. In the resulting dialog box, select Adaptive
mode. Use the default adaptation options: the Worst triangles triangle selection
method with the Worst triangle fraction set to 0.5.
11 Solve the PDE by selecting Solve > Solve PDE or clicking the = button on the
toolbar.
12 Plot the von Mises effective stress using color. Plot the displacement vector field (u,v)
using a deformed mesh. To do this:
3-5
3 Solving PDEs
By selecting other options from the Color drop-down menu, you can visualize different
strain and stress properties, such as the x- and y-direction strains and stresses, the shear
stress, and the principal stresses and strains. You also can plot combinations of scalar and
vector properties by using color, height, vector field arrows, and displacements in a 3-D
plot to represent different properties.
3-6
Clamped, Square Isotropic Plate with Uniform Pressure Load
The partial differential equation for a thin, isotropic plate with a pressure loading is
∇2 (D ∇2 w) = − p
3
Eh
D=
12(1 − ν2)
and E is the modulus of elasticity, ν is Poisson's ratio, and h is the plate thickness. The
transverse deflection of the plate is w and p is the pressure load.
The boundary conditions for the clamped boundaries are w = 0 and w′ = 0 where w′ is the
derivative of w in a direction normal to the boundary.
The Partial Differential Equation Toolbox™ cannot directly solve the fourth order plate
equation shown above but this can be converted to the following two second order partial
differential equations.
∇2 w = v
D ∇2 v = − p
where v is a new dependent variable. However, it is not obvious how to specify boundary
conditions for this second order system. We cannot directly specify boundary conditions
for both w and w′. Instead, we directly prescribe w′ to be zero and use the following
technique to define v′ in such a way to insure that w also equals zero on the boundary.
Stiff "springs" that apply a transverse shear force to the plate edge are distributed along
the boundary. The shear force along the boundary due to these springs can be written
n ⋅ D ∇v = − kw where n is the normal to the boundary and k is the stiffness of the
springs. The value of k must be large enough that w is approximately zero at all points on
the boundary but not so large that numerical errors result because the stiffness matrix is
3-7
3 Solving PDEs
In the Partial Differential Equation Toolbox™ definition for an elliptic system, the w and v
dependent variables are u(1) and u(2). The two second order partial differential equations
can be rewritten as
− ∇2 u1 + u2 = 0
−D ∇2 u2 = p
which is the form supported by the toolbox. The input corresponding to this formulation is
shown in the sections below.
numberOfPDE = 2;
model = createpde(numberOfPDE);
Problem Parameters
Geometry Creation
For a single square, the geometry and mesh are easily defined as shown below.
geometryFromEdges(model,g);
Plot the geometry and display the edge labels for use in the boundary condition definition.
3-8
Clamped, Square Isotropic Plate with Uniform Pressure Load
figure;
pdegplot(model,'EdgeLabels','on');
ylim([-1,11])
axis equal
title 'Geometry With Edge Labels Displayed';
Coefficient Definition
The documentation on PDE coefficients shows the required formats for the a and c
matrices. The most convenient form for c in this example is nc = 3N from the table where
N is the number of differential equations. In this example N = 2. The c tensor, in the form
of an N × N matrix of 2 × 2 submatrices is shown below.
3-9
3 Solving PDEs
c(1) c(2) ⋅ ⋅
⋅ c(3) ⋅ ⋅
⋅ ⋅ c(4) c(5)
⋅ ⋅ ⋅ c(6)
The six-row by one-column c matrix is defined below. The entries in the full 2 × 2 a matrix
and the 2 × 1 f vector follow directly from the definition of the two-equation system shown
above.
c = [1 0 1 D 0 D]';
a = [0 0 1 0]';
f = [0 pres]';
specifyCoefficients(model,'m',0,'d',0,'c',c,'a',a,'f',f);
Boundary Conditions
bOuter = applyBoundaryCondition(model,'neumann','Edge',(1:4),...
'g',[0 0],'q',[0 0; k 0]);
Mesh generation
The solution is calculated using the solvepde function and the transverse deflection is
plotted using the pdeplot function. For comparison, the transverse deflection at the
plate center is also calculated using an analytical solution to this problem.
res = solvepde(model);
u = res.NodalSolution;
numNodes = size(model.Mesh.Nodes,2);
figure
pdeplot(model,'XYData',u(1:numNodes),'Contour','on');
title 'Transverse Deflection'
3-10
Clamped, Square Isotropic Plate with Uniform Pressure Load
numNodes = size(model.Mesh.Nodes,2);
fprintf('Transverse deflection at plate center(PDE Toolbox) = %12.4e\n',...
min(u(1:numNodes,1)));
wMax = -.0138*pres*len^4/(E*thick^3);
fprintf('Transverse deflection at plate center(analytical) = %12.4e\n', wMax);
3-11
3 Solving PDEs
−∇ ⋅ σ = f
where σ is the stress tensor and f is the body force vector. The electrostatic behavior of
the solid is described by Gauss' Law
∇⋅D=ρ
where D is the electric displacement and ρ is the distributed, free charge. These two PDE
systems can be combined into the following single system
σ f
−∇ ⋅ =
D −ρ
In 2D, σ has the components σ11, σ22, and σ12 = σ21 and D has the components D1 and D2.
The constitutive equations for the material define the stress tensor and electric
displacement vector in terms of the strain tensor and electric field. For a 2D, orthotropic,
piezoelectric material under plane stress conditions these are commonly written as
3-12
Deflection of Piezoelectric Actuator
where Ci j are the elastic coefficients, ℰ i are the electrical permittivities, and ei j are the
piezoelectric stress coefficients. The piezoelectric stress coefficients are written to
conform to conventional notation in piezoelectric materials where the z-direction (3-
direction) is aligned with the "poled" direction of the material. For the 2D analysis, we
want the poled direction to be aligned with the y-axis.
Finally, the strain vector can be written in terms of the x-displacement, u, and y-
displacement, v as
∂u
ϵ11 ∂x
∂v
ϵ22 =
∂y
γ12
∂u ∂v
+
∂y ∂x
∂ϕ
E1 ∂x
= −
E2 ∂ϕ
∂y
See reference 2, for example, for a more complete description of the piezoelectric
equations.
The strain-displacement equations and electric field equations above can be substituted
into the constitutive equations to yield a system of equations for the stresses and
electrical displacements in terms of displacement and electrical potential derivatives. If
the resulting equations are substituted into the PDE system equations, we have a system
of equations that involve the divergence of the displacement and electrical potential
derivatives. Arranging these equations to match the form required by PDE Toolbox will be
the topic for the next section.
The PDE Toolbox requires a system of elliptic equations to be expressed in the form
− ∇ ⋅ c ⊗ ∇u + au = f
or in tensor form
3-13
3 Solving PDEs
∂ ∂u j
− c + ai ju j = f i
∂xk i jkl ∂xl
u
u= v
ϕ
∂u
∂x
∂u
∂y
∂v
∂x
∇u =
∂v
∂y
∂ϕ
∂x
∂ϕ
∂y
The documentation for the function assempde shows that it is convenient to view the
tensor ci jkl as an N × N matrix of 2 × 2 submatrices. The most convenient form for the c
input argument for this symmetric, N = 3 system has 21 rows in c and is described in
detail in the PDE Toolbox documentation. It is repeated here for convenience.
3-14
Deflection of Piezoelectric Actuator
For the purposes of mapping terms from constitutive equations to the form required by
PDE Toolbox it is useful to write the c tensor and solution gradient in the following form
∂u
∂x
c1111 c1112 c1211 c1212 c1311 c1312 ∂u
∂y
⋅ c1122 c1221 c1222 c1321 c1322
∂v
⋅ ⋅ c2211 c2212 c2311 c2312 ∂x
⋅ ⋅ ⋅ c2222 c2321 c2322 ∂v
⋅ ⋅ ⋅ ⋅ c3311 c3312 ∂y
∂ϕ
⋅ ⋅ ⋅ ⋅ ⋅ c3322 ∂x
∂ϕ
∂y
From this equation the traditional constitutive coefficients can be mapped to the form
required for the PDE Toolbox c matrix. Note the minus sign in the equations for electric
field. This minus must be incorporated into the c matrix to match the PDE Toolbox
convention. This is shown explicitly below.
∂u
∂x
C11 ⋅ ⋅ C12 e11 e31 ∂u
∂y
⋅ G12 G12 ⋅ e14 e34
∂v
⋅ ⋅ G12 ⋅ e14 e34 ∂x
⋅ ⋅ ⋅ C22 e13 e33 ∂v
⋅ ⋅ ⋅ ⋅ −ℰ 1 ⋅ ∂y
∂ϕ
⋅ ⋅ ⋅ ⋅ ⋅ −ℰ 2 ∂x
∂ϕ
∂y
Now that we have defined the equations for a 2D piezoelectric material, we are ready to
apply these to a specific model. The model is a two-layer cantilever beam that has been
extensively studied (e.g. refs 1 and 2). It is defined as a "bimorph" because although both
3-15
3 Solving PDEs
layers are made of the same Polyvinylidene Fluoride (PVDF) material, in the top layer the
polarization direction points down (minus y direction) and in the bottom layer, it points
up. A schematic of the cantilever beam is shown in the figure below.
This figure is not to scale; the actual thickness/length ratio is 100 so the beam is very
slender. When a voltage is applied between the lower and upper surfaces of the beam, it
deflects in the y-direction; one layer shortens and the other layer lengthens. Devices of
this type can be designed to provide the required motion or force for different
applications.
The first step in solving a PDE problem is to create a PDE Model. This is a container that
holds the number of equations, geometry, mesh, and boundary conditions for your PDE.
The equations of linear elasticity have three components, so the number of equations in
this model is three.
N = 3;
model = createpde(N);
3-16
Deflection of Piezoelectric Actuator
Geometry Creation
The simple two-layer geometry of the beam can be created by defining the sum of two
rectangles.
The two lines below contain the columns of the geometry description matrix (GDM) for
the two rectangular layers. The GDM is the first input argument to decsg and describes
the basic geometric entities in the model.
topLayer = [3 4 0 L L 0 0 0 H2 H2];
bottomLayer = [3 4 0 L L 0 -H2 -H2 0 0];
gdm = [topLayer; bottomLayer]';
g = decsg(gdm, 'R1+R2', ['R1'; 'R2']');
geometryFromEdges(model,g);
figure;
pdegplot(model, 'EdgeLabels', 'on', 'FaceLabels', 'on');
xlabel('X-coordinate, meters')
ylabel('Y-coordinate, meters')
axis([-.1*L, 1.1*L, -4*H2, 4*H2])
axis square
3-17
3 Solving PDEs
The material in both layers of the beam is Polyvinylidene Fluoride (PVDF), a thermoplastic
polymer with piezoelectric behavior.
relPermittivity = 12;
3-18
Deflection of Piezoelectric Actuator
The piezoelectric strain coefficients for PVDF are given above but the constitutive
relations in the finite element formulation require the piezoelectric stress coefficients.
These are calculated on the next line (for details see, for example, reference 2).
pzeE = c2d*pzeD;
D_const_stress = [relPermittivity 0; 0 relPermittivity]*permittivityFreeSpace;
f = [0 0 0]';
specifyCoefficients(model, 'm', 0,'d', 0,'c', ctop, 'a', 0, 'f', f,'Face',2);
specifyCoefficients(model, 'm', 0,'d', 0,'c', cbot, 'a', 0, 'f', f,'Face',1);
For this example, the top geometry edge (edge 1) has the voltage prescribed as 100 volts.
The bottom geometry edge (edge 2) has the voltage prescribed as 0 volts (i.e. grounded).
The left geometry edge (edges 6 and 7) have the u and v displacements equal zero (i.e.
clamped). The stress and charge are zero on the right geometry edge (i.e. q = 0).
V = 100;
3-19
3 Solving PDEs
Set the x and y displacements (solution components 1 and 2) on the left end (geometry
edges 6 and 7) to zero.
clampLeft = applyBoundaryCondition(model,'mixed','Edge',6:7,...
'u',[0 0],...
'EquationIndex',1:2);
Mesh Generation
We need a relatively fine mesh to accurately model the bending of the beam.
hmax = 5e-04;
msh = generateMesh(model,'Hmax',hmax,...
'GeometricOrder','quadratic',...
'MesherVersion','R2013a');
Extract the NodalSolution property from the result, this has the x-deflection in column
1, the y-deflection in column 2, and the electrical potential in column 3. Find the
minimum y-deflection, and plot the solution components.
rs = result.NodalSolution;
feTipDeflection = min(rs(:,2));
fprintf('Finite element tip deflection is: %12.4e\n', feTipDeflection);
3-20
Deflection of Piezoelectric Actuator
ylabel('Y-Coordinate, meters')
axis square
end
3-21
3 Solving PDEs
3-22
Deflection of Piezoelectric Actuator
Analytical Solution
A simple, approximate, analytical solution was obtained for this problem in reference 1.
tipDeflection = -3*d31*V*L^2/(8*H2^2);
fprintf('Analytical tip deflection is: %12.4e\n', tipDeflection);
Summary
The color contour plots of x-deflection and y-deflection show the standard behavior of the
classical cantilever beam solution. The linear distribution of voltage through the thickness
of the beam is as expected. There is good agreement between the PDE Toolbox finite
element solution and the analytical solution from reference 1.
3-23
3 Solving PDEs
Although this example shows a very specific coupled elasticity-electrostatic model, the
general approach here can be used for many other systems of coupled PDEs. The key to
applying PDE Toolbox to these types of coupled systems is the systematic, multi-step
coefficient mapping procedure described above.
References
3-24
Dynamics of Damped Cantilever Beam
The beam is modeled with a plane stress elasticity formulation. The damping model is
basic viscous damping distributed uniformly through the volume of the beam. Several
transient analyses are performed where the beam is deformed into an initial shape and
then released at time, t = 0. Analyses with and without damping are considered. Two
initial displacement shapes are considered. In the first, the beam is deformed into a shape
corresponding to the lowest vibration mode. In the second, the beam is deformed by
applying an external load at the tip of the beam. No additional loading is applied in this
example so, in the damped cases, the displacement of the beam decays as a function of
time due to the damping.
The transient analyses are performed using the PDE Toolbox hyperbolic function. One
form of this function allows a transient analysis to be performed with the stiffness, mass,
and damping matrices and load vectors as input. Typically these matrices and vectors are
calculated using other PDE Toolbox functions. That approach will be demonstrated in this
example.
D = αM + βK
α βωi
ξ= +
2ωi 2
In this example, we will define ξ = 0 . 03 (three percent of critical damping) and β equal
zero so that α can be calculated as α = 2 × . 03ωi
This example specifies values of parameters using the imperial system of units. You can
replace them with values specified in the metric system. If you do so, ensure that you
specify all values throughout the example using the same system.
3-25
3 Solving PDEs
Beam Parameters
Specify the beam dimensions. It is 5 inches long and 0.1 inches thick.
width = 5;
height = 0.1;
E = 3.0e7;
nu = 0.3;
rho = 0.3/386;
G = E/(2.*(1+nu));
mu = 2.0*G*nu/(1-nu);
From beam theory, there is a simple expression for the lowest vibration frequency of the
cantilever beam.
I = height^3/12;
A = height;
eigValAnalytical = 1.8751^4*E*I/(rho*A*width^4);
freqAnalytical = sqrt(eigValAnalytical)/(2*pi);
Problem Setup
numberOfPDE = 2;
model = createpde(numberOfPDE);
gdm = [3;4;0;width;width;0;0;0;height;height];
g = decsg(gdm,'S1',('S1')');
Plot the geometry and display the edge labels for use in the boundary condition definition.
figure;
pdegplot(g,'EdgeLabels','on');
axis equal
title 'Geometry With Edge Labels Displayed'
3-26
Dynamics of Damped Cantilever Beam
geometryFromEdges(model,g);
c = [2*G+mu;0;G;0;G;mu;0;G;0;2*G+mu];
f = [0;0];
a = 0;
m = rho;
specifyCoefficients(model,'m',m,'d',0,'c',c,'a',a,'f',f);
Specify the following boundary condition to clamp (displacements equal zero) the left
beam-edge.
3-27
3 Solving PDEs
applyBoundaryCondition(model,'dirichlet','Edge',4,'u',[0 0]);
Define a maximum element size (5 elements through the beam thickness) and generate a
mesh.
hmax = height/5;
msh=generateMesh(model,'Hmax',hmax,'MesherVersion','R2013a');
eigenVec = res.Eigenvectors;
eigenVal = res.Eigenvalues;
freqNumerical = sqrt(eigenVal(1))./(2*pi);
longestPeriod = 1/freqNumerical;
Plot the deformed shape of the beam with the displacements scaled by an arbitrary factor.
scaleFactor = 20;
figure;
[p,e,t] = meshToPet(msh);
pdeplot(p+scaleFactor*eigenVec',e,t,'XYData',real(eigenVec(:,2)));
title('Lowest Frequency Vibration Mode');
axis equal
xlabel('Inches');
ylabel('Inches');
3-28
Dynamics of Damped Cantilever Beam
drawnow
In the first two transient analyses, we define an initial displacement. in the shape of the
lowest vibration mode. By doing this, we convert the PDE to a single ODE with time as
the independent variable. The solution to this ODE is the same as that of the classical
spring-mass-damper system with a frequency equal the frequency of this vibration mode.
3-29
3 Solving PDEs
Thus we are able to compare the numerical solution with the analytical solution to this
well-known problem.
For convenience, we will scale the eigenvector shape so that y-displacement at the tip
is .1 inches. This makes the transient history plots simpler.
uEigenTip = eigenVec(2,2);
u0TipDisp = .1;
u0 = u0TipDisp/uEigenTip*eigenVec;
tlist = 0:longestPeriod/100:3*longestPeriod;
R = createPDEResults(model, u0(:));
ice = icEvaluator(R);
The displacement at the tip is a sinusoidal function of time with amplitude equal to the
initial y-displacement. This agrees with the solution to the simple spring-mass system.
3-30
Dynamics of Damped Cantilever Beam
Now solve the system with damping equal to 3% of critical for this lowest vibration
frequency.
fem = assembleFEMatrices(model);
zeta = .03;
omega = 2*pi*freqNumerical;
alpha = 2*zeta*omega;
dampmat = alpha*fem.M;
specifyCoefficients(model,'m',m,'d',dampmat,'c',c,'a',a,'f',f);
tres = solvepde(model,tlist);
This figure shows the y-displacement at the tip as a function of time. Superimposed on
this plot is a second curve which shows the envelope of the maximum amplitude as a
3-31
3 Solving PDEs
function of time, calculated from the solution to the single degree-of-freedom ODE. As
expected, the PDE solution agrees well with the analytical solution.
It would be very unusual for a structure to be loaded such that the displacement is equal
to a multiple of one of its vibration modes. In this more realistic example, we solve the
3-32
Dynamics of Damped Cantilever Beam
transient equations with the initial displacement shape calculated from the static solution
of the cantilever beam with a vertical load at the tip.
Perform a static analysis with vertical tip load equal one. Follow the model building steps
as before.
P = 1.0;
pdeTipLoad = createpde(2);
pg = geometryFromEdges(pdeTipLoad,g);
specifyCoefficients(pdeTipLoad,'m',0,'d',0,'c',c,'a',a,'f',f);
tipLoad = applyBoundaryCondition(pdeTipLoad,'neumann','Edge',2,'g',[0 P/height]);
clampedEdge = applyBoundaryCondition(pdeTipLoad,'dirichlet','Edge',4,'u',[0,0]);
msh=generateMesh(pdeTipLoad,'Hmax',hmax,'MesherVersion','R2013a');
statres = solvepde(pdeTipLoad);
To make comparison with the eigenvector case clearer, we will also scale this static
solution so that the maximum y-displacement at the tip equals .1 inches.
u = statres.NodalSolution;
uEigenTip = u(2,2);
u0TipDisp = 0.1;
u0 = u0TipDisp/uEigenTip*u;
Calculate the undamped solution with the initial displacement from the static analysis.
R = createPDEResults(model, u0(:));
ice = icEvaluator(R);
setInitialConditions(model, @ice.computeIC, 0);
tres = solvepde(model,tlist);
The displacement is no longer a pure sinusoidal wave. The static solution that we are
using as the initial conditions is similar to the lowest eigenvector but higher-frequency
modes are also contributing to the transient solution.
3-33
3 Solving PDEs
Calculate the damped solution with the initial displacement from the static analysis. The
damping matrix is the same as that used in the eigenvector case, above.
specifyCoefficients(model, 'm', m, 'd', dampmat, 'c', c, 'a', a, 'f', f);
tres = solvepde(model,tlist);
Plot the tip displacement from this solution as a function of time. Again we superimpose a
curve of the damped amplitude as a function of time obtained from an analytical solution
to the single degree-of-freedom ODE. Because the initial condition differs from the lowest
eigenvector, this analytical solution only approximates the amplitude of the PDE solution.
titl = 'Initial Displacements from Static Solution, Damped Solution';
cantileverBeamTransientPlot(tres,titl);
hold on;
3-34
Dynamics of Damped Cantilever Beam
plot(tlist,u0TipDisp*exp(-zeta*omega*tlist),'Color','r');
legend('PDE','ODE Amplitude Decay','Location','southeast');
Utility function for creating the plots of tip y-displacement as a function of time.
type cantileverBeamTransientPlot.m
3-35
3 Solving PDEs
tlist = tdres.SolutionTimes;
uu = tdres.NodalSolution;
utip = uu(2,2,:);
figure; plot(tlist, utip(:)); grid on;
title(titl); xlabel('Time, seconds');
ylabel('Y-displacement at beam tip, inches');
drawnow;
end
The evaluation function returns the value of the IC at any point within the mesh. A results
object represents the values and the interpolation function that it provided is used to
compute the ICs.
type icEvaluator.m
classdef icEvaluator
% icEvaluator Evaluates Initial Conditions data at requested locations
% ICE = icEvaluator(R) Creates an initial conditions evaluator from a
% results object. The evaluator provides a function that can be called at
% specific locations within the geometry. This class customized to represent
% a stationary solution.
%
% icEvaluator methods:
% computeIC - Computes ICs at locations within the geometric domain
%
methods
function obj = icEvaluator(R)
obj.Results = R;
end
function ic = computeIC(obj,locations)
is2d = size(obj.Results.Mesh.Nodes, 1) == 2;
if is2d
querypts = [locations.x; locations.y];
else
3-36
Dynamics of Damped Cantilever Beam
3-37
3 Solving PDEs
The pressure load is suddenly applied at time equal zero and the magnitude is high
enough to produce deflections on the same order as the beam thickness.
This example specifies values of parameters using the imperial system of units. You can
replace them with values specified in the metric system. If you do so, ensure that you
specify all values throughout the example using the same system.
Equations
This section describes the equations of geometrically nonlinear elasticity. One approach
to handling the large deflections is to consider the elasticity equations in the deformed
position. However, PDE Toolbox formulates the equations based on the original geometry.
This motivates using a Lagrangian formulation of nonlinear elasticity where stresses,
strains, and coordinates refer to the original geometry.
ρü − ∇ ⋅ (F ⋅ S) = f
∂ ∂ui
ρüi − + δik Sk j = f i
∂x j ∂xk
Although large deflections are accounted for in this formulation, it is assumed that the
strains remain small so that linear elastic constitutive relations apply. Also, the material is
assumed to be isotropic. For the 2D plane stress case, the constitutive relations may be
written in matrix form:
3-38
Dynamic Analysis of Clamped Beam
E
C11 = C22 =
1 − ν2
Eν
C12 =
1 − ν2
E
G12 =
2(1 + ν)
Readers who are interested in more details about the Lagrangian formulation for
nonlinear elasticity can consult, for example, reference 1.
The equations presented above completely define the geometrically nonlinear plane stress
problem. The work required to convert them to a form acceptable to PDE Toolbox is
considerably simplified by using the MATLAB Symbolic Math Toolbox. Symbolic Math
Toolbox can perform the necessary algebraic manipulations and output a MATLAB
function defining the c-coefficient that can be passed to PDE Toolbox functions. This
function, cCoefficientLagrangePlaneStress, is shown in the appendix below.
Problem Setup
Define the geometry. First, specify the length and thickness of the beam,
3-39
3 Solving PDEs
Since the beam geometry and loading are symmetric about the beam center(x =
blength/2), the model can be simplified by considering only the right-half of the beam.
l2 = blength/2;
h2 = height/2;
Create the edges of the rectangle representing the beam with these two statements.
The geometryFromEdges function creates a geometry object from the edges and stores
it within the model.
pg = geometryFromEdges(model,g);
Plot the geometry and display the edge labels. The edge labels are needed for edge
identification when applying boundary conditions.
figure
pdegplot(g,'EdgeLabels','on');
title('Geometry With Edge Labels Displayed');
3-40
Dynamic Analysis of Clamped Beam
Derive the equation coefficients using the material properties. For the linear case, the c-
coefficient matrix is constant.
3-41
3 Solving PDEs
Apply the boundary conditions. Symmetry condition is x-displacement equal zero at left
edge.
symBC = applyBoundaryCondition(model,'mixed','Edge',4,'u',0,'EquationIndex',1);
sigma = 2e2;
presBC = applyBoundaryCondition(model,'neumann','Edge',3,'g',[0 sigma]);
setInitialConditions(model,0,0);
Generate a mesh with approximately eight elements through the thickness of the beam.
generateMesh(model,'Hmax',height/8,'MesherVersion','R2013a');
Linear Solution
Set up the analysis timespan. Here, tfinal is the final time in the analysis.
tfinal = 3e-3;
tlist = linspace(0,tfinal,100);
result = solvepde(model,tlist);
Interpolate the solution at the geometry center for the y-component (component 2) at all
times.
xc = 1.25;
yc = 0;
u4Linear = interpolateSolution(result,xc,yc,2,1:length(tlist));
Nonlinear Solution
3-42
Dynamic Analysis of Clamped Beam
analysis. Small strains are assumed; i.e. E and ν are independent of the solution. PDE
Toolbox calls user-defined coefficient functions with the arguments location and state. The
function cCoefficientLagrangePlaneStress expects the arguments E, gnu, location,
state. c is defined below as an anonymous function to provide an interface between these
two function signatures. (The function cCoefficientLagrangePlaneStress can be
used with any geometric nonlinear plane stress analysis of a model made from an
isotropic material.)
result = solvepde(model,tlist);
As before, interpolate the solution at the geometry center for the y-component
(component 2) at all times.
u4NonLinear = interpolateSolution(result,xc,yc,2,1:length(tlist));
Plot Solutions
The figure below shows the y-deflection at the center of the beam as a function of time.
The nonlinear analysis computes displacements that are substantially less than the linear
analysis. This "stress stiffening" effect is also reflected in the higher oscillation frequency
from the nonlinear analysis.
figure
plot(tlist,u4Linear(:),tlist,u4NonLinear(:));
legend('Linear','Nonlinear');
title 'Deflection at Beam Center'
xlabel 'Time, seconds'
ylabel 'Deflection, inches'
grid on
3-43
3 Solving PDEs
References
type cCoefficientLagrangePlaneStress
3-44
Dynamic Analysis of Clamped Beam
% This function was generated by the Symbolic Math Toolbox version 6.0.
% 31-Jan-2014 09:50:09
ux = reshape(state.ux,2,[]);
uy = reshape(state.uy,2,[]);
dudx=ux(1,:);
dvdx=ux(2,:);
dudy=uy(1,:);
dvdy=uy(2,:);
% if(~isempty(u))
% [ux,uy] = pdegrad(p,t,u);
% dudx=ux(1,:); dudy=uy(1,:); dvdx=ux(2,:); dvdy=uy(2,:);
% else
% dudx = zeros(1, size(t,2)); dudy=dudx; dvdx=dudx; dvdy=dudx;
% end
t4 = 1/(nu^2-1);
t6 = 1/(1+nu);
t7 = E*dudy.*t4*.25;
t8 = dudx+1.0;
t9 = E*dudy.*t4.*t8*.25;
t10 = dvdy+1.0;
t11 = t7+t9-E*dvdx.*t6.*t10*.25;
t12 = dvdy.*2.0;
t13 = dudx.^2;
t14 = dudy.^2;
3-45
3 Solving PDEs
t15 = dvdy.^2;
t16 = dvdx.^2;
t17 = E*dvdx.*t4.*(1.0./2.0);
t18 = E*dudx.*dvdx.*t4*.25;
t19 = t17+t18-E*dudy.*t6*.25-E*dudy.*dvdy.*t6.*(1.0./8.0);
t20 = E*dudy.*dvdx.*nu.*t4*.25;
t21 = t20-E*t6.*(1.0./2.0)-E*dudx.*t6*.25-E*dvdy.*t6*.25-E*dudx.*dvdy.*t6.*(1.0./8.0);
t22 = dudx.*2.0;
t23 = dvdy+2.0;
t24 = nu-1.0;
t25 = E*nu.*t4;
t26 = E*dudx.*nu.*t4.*(1.0./2.0);
t27 = E*dvdy.*nu.*t4.*(1.0./2.0);
t28 = E*dudx.*dvdy.*nu.*t4*.25;
t29 = t25+t26+t27+t28-E*dudy.*dvdx.*t6.*(1.0./8.0);
t30 = E*dudy.*t4.*t23.*(1.0./8.0);
t31 = E*dudy.*dvdy.*t4.*(1.0./8.0);
t32 = t7+t30+t31-E*dvdx.*t6.*(1.0./8.0)-E*dvdx.*t4.*t8.*t24.*(1.0./8.0);
t33 = dudy.*2.0;
t34 = dvdx.*2.0;
t35 = dudx.*dudy.*2.0;
t36 = dvdx.*dvdy;
t37 = t33+t34+t35+t36;
t38 = 1.0./t24;
t39 = E*dvdx.*t23.*t38.*(1.0./8.0);
t40 = t39-E*t6.*t37.*(1.0./8.0);
out1 = [E*t4.*(dudx.*6.0+t13.*2.0+t14+t16+4.0)*.25+E*nu.*t4.*(t12+t15)*.25;
t11;
t19;
t29;
t11;
E*t4.*(t12+t13+t14.*2.0+t15+t22+2.0)*.25+E*nu.*t4.*(t16-2.0)*.25;
t21;
t32;
t19;
t21;
E*t4.*(t12+t13+t15+t16.*2.0+t22+2.0)*.25+E*nu.*t4.*(t14-2.0)*.25;
t40;
t29;
t32;
t40;
E*t4.*(dvdy.*6.0+t14+t15.*2.0+t16+4.0)*.25+E*nu.*t4.*(t13+t22)*.25];
3-46
Dynamic Analysis of Clamped Beam
end
3-47
3 Solving PDEs
modelT = createpde('structural','transient-solid');
gm = multicuboid(0.05,0.003,0.003);
modelT.Geometry = gm;
figure
pdegplot(modelT,'FaceLabels','on','FaceAlpha',0.5)
view([71 4])
3-48
Reduced-Order Modeling Technique for Beam with Point Load
figure
pdegplot(modelT,'EdgeLabels','on','FaceAlpha',0.5)
view([71 4])
3-49
3 Solving PDEs
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(modelT,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
structuralBC(modelT,'Edge',[2 8 11 12],'Constraint','fixed');
3-50
Reduced-Order Modeling Technique for Beam with Point Load
figure
pdegplot(modelT,'VertexLabels','on','FaceAlpha',0.5)
view([78 2.5])
Generate a mesh.
generateMesh(modelT);
structuralBoundaryLoad(modelT,'Vertex',loadedVertex, ...
'Force',[0;0;10],'Frequency',6000);
3-51
3 Solving PDEs
tlist = 0:0.00005:3E-3;
RT = solve(modelT,tlist);
Define superelement interfaces using the fixed and loaded boundaries. In this case, the
reduced order model retains the degrees of freedom (DoFs) on the fixed face and the
loaded vertex while condensing all other DoFs in favor of modal DoFs. For better
performance, use the set of edges bounding face 5 instead of using the entire face.
structuralSEInterface(modelT,'Edge',[2 8 11 12]);
structuralSEInterface(modelT,'Vertex',loadedVertex);
rom = reduce(modelT,'FrequencyRange',[-0.1,5e5]);
Next, use the reduced order model to simulate the transient dynamics. Use the ode15s
function directly to integrate the reduced system ODE. Working with the reduced model
requires indexing into the reduced system matrices rom.K and rom.M. First, construct
mappings of indices of K and M to loaded and fixed DoFs by using the data available in
rom.
Create a function that returns DoF IDs given node IDs and the number of nodes.
Knowing the DoF IDs for the given node IDs, use the intersect function to find the
required indices.
numNodes = size(rom.Mesh.Nodes,2);
loadedNode = findNodes(rom.Mesh,'region','Vertex',loadedVertex);
loadDoFs = getDoF(loadedNode,numNodes);
[~,loadNodeROMIds,~] = intersect(rom.RetainedDoF,loadDoFs);
3-52
Reduced-Order Modeling Technique for Beam with Point Load
In the reduced matrices rom.K and rom.M, generalized modal DoFs appear after the
retained DoFs.
Because fixed-end DoFs are not a part of the ODE system, the indices for the ODE DoFs in
reduced matrices are as follows.
odeDoFs = [loadNodeROMIds;fixedIntModeIds];
The relevant components of rom.K and rom.M for time integration are:
Kconstrained = rom.K(odeDoFs,odeDoFs);
Mconstrained = rom.M(odeDoFs,odeDoFs);
numODE = numel(odeDoFs);
Now you have a second-order system of ODEs. To use ode15s, convert this into a system
of first-order ODEs by applying linearization. Such a first-order system is twice the size of
the second-order system.
The specified concentrated force load in the full system is along the z-direction, which is
the third DoF in the ODE system. Accounting for the linearization to obtain the first-order
system gives the loaded ODE DoF.
loadODEDoF = numODE + 3;
Specify the mass matrix and the Jacobian for the ODE solver.
odeoptions = odeset;
odeoptions = odeset(odeoptions,'Jacobian',-Kode);
odeoptions = odeset(odeoptions,'Mass',Mode);
u0 = zeros(2*numODE,1);
Solve the reduced system by using ode15s and the helper function CMSODEf, which is
defined at the end of this example.
3-53
3 Solving PDEs
Compute the values of the ODE variable and the time derivatives.
[displ,vel] = deval(sol,tlist);
Plot the z-displacement at the loaded vertex and compare it to the third DoF in the
solution of the reduced ODE system.
figure
plot(tlist,RT.Displacement.uz(loadedVertex,:))
hold on
plot(tlist,displ(3,:),'r*')
title('Z-Displacement at Loaded Vertex')
legend('full model','rom')
3-54
Reduced-Order Modeling Technique for Beam with Point Load
Knowing the solution in terms of the interface DoFs and modal DoFs, you can reconstruct
the solution for the full model. The reconstructSolution function requires the
displacement, velocity, and acceleration at all DoFs in rom. Construct the complete
solution vector, including the zero values at the fixed DoFs.
u = zeros(size(rom.K,1),numel(tlist));
ut = zeros(size(rom.K,1),numel(tlist));
utt = zeros(size(rom.K,1),numel(tlist));
u(odeDoFs,:) = displ(1:numODE,:);
ut(odeDoFs,:) = vel(1:numODE,:);
utt(odeDoFs,:) = vel(numODE+1:2*numODE,:);
RTrom = reconstructSolution(rom,u,ut,utt,tlist);
For comparison, compute the displacement in the interior at the center of the beam using
the full and reconstructed solutions.
coordCenter = [0;0;0];
iDispRT = interpolateDisplacement(RT, coordCenter);
iDispRTrom = interpolateDisplacement(RTrom, coordCenter);
figure
plot(tlist,iDispRT.uz,'k')
hold on
plot(tlist,iDispRTrom.uz,'g*')
title('Z-Displacement at Geometric Center')
legend('full model','rom')
3-55
3 Solving PDEs
function f = CMSODEf(t,u,Kode,Fode,loadedVertex)
Fode(loadedVertex) = 10*sin(6000*t);
f = -Kode*u +Fode;
end
3-56
Modal and Frequency Response Analysis for Single Part of Kinova® Gen3 Robotic Arm
Robotic arms perform precise manipulations in a wide variety of applications from factory
automation to medical surgery. Typically, robotic arms consist of several links connected
in a serial chain, with a base attached to a tabletop or the ground and an end-effector
attached at the tip. These links must be structurally strong to avoid any vibrations when
the rotors are moving with a load on them.
Loads at the tips of robotic arm cause pressure on the joints of each link. The direction of
pressure depends on the direction of the load.
This example computes deformations of the shoulder link under the applied pressure by
performing a modal analysis and frequency response analysis simulation. You can find the
helper function animateSixLinkModes.m and the geometry file Gen3Shoulder.stl
under matlab/R20XXx/examples/pde/main.
Modal Analysis
Assuming that one end of the robotic arm is fixed, find the natural frequencies and mode
shapes.
3-57
3 Solving PDEs
model = createpde('structural','modal-solid');
To perform unconstrained modal analysis of a structure, you must specify the geometry,
mesh, and material properties. First, import the geometry of the shoulder part of the
robotic arm.
importGeometry(model,'Gen3Shoulder.stl');
Generate a mesh.
generateMesh(model);
pdemesh(model)
3-58
Modal and Frequency Response Analysis for Single Part of Kinova® Gen3 Robotic Arm
Specify the Young's modulus, Poisson's ratio, and mass density of the material in
consistent units. Typically, the material used for the link is carbon fiber reinforced plastic.
Assume that the material is homogeneous.
E = 1.5E11;
nu = 0.3;
rho = 2000;
structuralProperties(model,'YoungsModulus',E, ...
'PoissonsRatio',nu, ...
'MassDensity',rho);
Identify faces for applying boundary constraints and loads by plotting the geometry with
the face labels.
figure
pdegplot(model,'FaceLabels','on')
view([-1 2])
title('Shoulder Link Geometry with Face Labels')
3-59
3 Solving PDEs
The shoulder link is fixed on one end (face 3) and connected to a moving link on the other
end (face 4). Apply the fixed boundary condition on face 3.
structuralBC(model,'Face',3,'Constraint','fixed');
Solve the model for a chosen frequency range. Specify the lower frequency limit below
zero so that all modes with frequencies near zero, if any, appear in the solution.
RF = solve(model,'FrequencyRange',[-1,10000]*2*pi);
modeID = 1:numel(RF.NaturalFrequencies);
3-60
Modal and Frequency Response Analysis for Single Part of Kinova® Gen3 Robotic Arm
Express the resulting frequencies in Hz by dividing them by 2π. Display the frequencies in
a table.
tmodalResults = table(modeID.',RF.NaturalFrequencies/2/pi);
tmodalResults.Properties.VariableNames = {'Mode','Frequency'};
disp(tmodalResults);
Mode Frequency
____ _________
1 1947.2
2 2662
3 4982.3
4 5112.6
5 7819.5
6 8037.1
7 9361
The best way to visualize the mode shapes is to animate the harmonic motion at their
respective frequencies. The animateSixLinkModes function animates the first six
modes. The resulting plot shows the areas of dominant deformation under load.
figure
frames = animateSixLinkModes(RF);
3-61
3 Solving PDEs
movie(figure('units','normalized','outerposition',[0 0 1
1]),frames,5,30)
Simulate the dynamics of the shoulder under pressure loading on a face, assuming that
the attached link applies an equal and opposite amount of pressure on the halves of the
face. Analyze the frequency response and deformation of a point in the face.
3-62
Modal and Frequency Response Analysis for Single Part of Kinova® Gen3 Robotic Arm
fmodel = createpde('structural','frequency-solid');
Import the same geometry for the shoulder part that you used for the modal analysis.
importGeometry(fmodel,'Gen3Shoulder.stl');
Generate a mesh.
mesh = generateMesh(fmodel);
structuralProperties(fmodel,'YoungsModulus',E, ...
'PoissonsRatio',nu, ...
'MassDensity',rho);
The shoulder link is fixed on one end (face 3) and connected to a moving link on the other
end (face 4). Apply the fixed boundary condition on face 3.
structuralBC(fmodel,'Face',3,'Constraint','fixed');
Estimate the pressure that the moving link applies on face 4 when the arm carries a load.
This figure shows two halves of face 4 divided at the center along the y-coordinate.
3-63
3 Solving PDEs
Use the pressFcnFR function to apply the boundary load on face 4. This function applies
a push and a twist pressure signals. The push pressure component is uniform. The twist
component applies positive pressure on the left side and negative pressure on the right
side of the face. For the definition of the pressFcnFR function, see the Pressure Function
section at the bottom of this page. This function does not have an explicit dependency on
frequency. Therefore, in the frequency domain, this pressure load acts across all
frequencies of the solution.
3-64
Modal and Frequency Response Analysis for Single Part of Kinova® Gen3 Robotic Arm
structuralBoundaryLoad(fmodel,'Face',4,'Pressure',@(region,state) pressFcnFR(region, st
Define the frequency list for the solution as 0 to 3500 Hz with 200 steps.
flist = linspace(0,3500,200)*2*pi;
Solve the model using the modal frequency response solver by specifying the model
results object RF as one of the inputs.
R = solve(fmodel,flist,'ModalResults',RF)
R =
FrequencyStructuralResults with properties:
Plot the frequency response at a point on the loaded face. A point on face 4 located at
maximum negative pressure loading is (0.003; 0.0436; 0.1307). Interpolate the
displacement to this point and plot the result.
figure
plot(R.SolutionFrequencies/2/pi,abs(queryPointDisp.uy))
title('Transverse Displacement at Point on Loaded Face')
xlabel('Frequency (Hz)')
ylabel('Y-Displacement')
xlim([0.0000 3500])
3-65
3 Solving PDEs
The peak of the response occurs near 2662 Hz, which is close to the second mode of
vibration. A smaller response also occurs at first mode close to 1947 Hz.
Find the peak response frequency index by using the max function with two output
arguments. The second output argument provides the index of the peak frequency.
[M, I] = max(abs(queryPointDisp.uy))
M = 1.1256e-04
I = 152
Plot the deformation at the peak response frequency. The applied loading is such that it
predominantly excites the opening mode and the bending mode of the shoulder.
3-66
Modal and Frequency Response Analysis for Single Part of Kinova® Gen3 Robotic Arm
RD = struct();
RD.ux = R.Displacement.ux(:,I);
RD.uy = R.Displacement.uy(:,I);
RD.uz = R.Displacement.uz(:,I);
figure('units','normalized','outerposition',[0 0 1 1]);
subplot(2,2,1)
pdeplot3D(fmodel,'ColorMapData',R.Displacement.ux(:,I), ...
'Deformation',RD,'DeformationScaleFactor',1);
title('X-Displacement')
subplot(2,2,2)
pdeplot3D(fmodel,'ColorMapData',R.Displacement.uy(:,I), ...
'Deformation',RD,'DeformationScaleFactor',1);
title('Y-Displacement')
subplot(2,2,3)
pdeplot3D(fmodel,'ColorMapData',R.Displacement.uz(:,I), ...
'Deformation',RD,'DeformationScaleFactor',1);
title('Z-Displacement')
subplot(2,2,4)
pdeplot3D(fmodel,'ColorMapData',R.Displacement.Magnitude(:,I), ...
'Deformation',RD,'DeformationScaleFactor',1);
title('Magnitude')
3-67
3 Solving PDEs
Pressure Function
Define a pressure function, pressFcnFR, to calculate a push and a twist pressure signals.
The push pressure component is uniform. The twist pressure component applies positive
pressure on the left side and negative pressure on the right side of the face. The value of
the twist pressure loading increases in a parabolic distribution from the minimum at point
C to the positive peak at L and to the negative peak at R. The twist pressure factor for the
3-68
Modal and Frequency Response Analysis for Single Part of Kinova® Gen3 Robotic Arm
function p = pressFcnFR(region,~)
meanY = mean(region.y);
absMaxY = max(abs(region.y));
scaleFactor = zeros(size(region.y));
% Find IDs of the points on the left and right halves of the face
% using y-coordinate values.
leftHalfIdx = region.y <= meanY;
rightHalfIdx = region.y >= meanY;
p = 10E3 + 0.1E6*scaleFactor;
end
3-69
3 Solving PDEs
A turbine is a component of the jet engine. It is responsible for extracting energy from the
high-temperature and high-pressure gas produced in the combustion chamber and
transforming it into rotational motion to produce thrust. The turbine is a radial array of
blades typically made of nickel alloys. These alloys resist the extremely high temperatures
of the gases. At such temperatures, the material expands significantly, producing
mechanical stress in the joints and significant deformations of several millimeters. To
avoid mechanical failure and friction between the tip of the blade and the turbine casing,
the blade design must account for the stress and deformations.
1 Perform structural analysis accounting only for pressure of the surrounding gases
while ignoring thermal effects.
2 Compute the thermal stress while ignoring the pressure.
3 Combine the pressure and thermal stress.
Pressure Loading
The blade experiences high pressure from the surrounding gases. Compute the stress
caused only by this pressure.
smodel = createpde('structural','static-solid');
importGeometry(smodel,'Blade.stl');
figure
pdegplot(smodel,'FaceLabels','on','FaceAlpha',0.5)
3-70
Thermal Stress Analysis of Jet Engine Turbine Blade
msh = generateMesh(smodel,'Hmax',0.01);
Specify the Young's modulus, Poisson's ratio, and coefficient of thermal expansion for
nickel-based alloy (NIMONIC 90).
E = 227E9; % in Pa
CTE = 12.7E-6; % in 1/K
nu = 0.27;
structuralProperties(smodel,'YoungsModulus',E, ...
'PoissonsRatio',nu, ...
'CTE',CTE);
3-71
3 Solving PDEs
Specify that the face of the root that is in contact with other metal is fixed.
structuralBC(smodel,'Face',3,'Constraint','fixed');
Specify the pressure load on the pressure and suction sides of the blade. This pressure is
due to the high-pressure gas surrounding these sides of the blade.
p1 = 5e5; %in Pa
p2 = 4.5e5; %in Pa
Rs = solve(smodel);
Plot the von Mises stress and the displacement. Specify a deformation scale factor of 100
to better visualize the deformation.
figure
pdeplot3D(smodel,'ColorMapData',Rs.VonMisesStress, ...
'Deformation',Rs.Displacement, ...
'DeformationScaleFactor',100)
view([116,25]);
3-72
Thermal Stress Analysis of Jet Engine Turbine Blade
The maximum stress is around 100 Mpa, which is significantly below the elastic limit.
Thermal Stress
Determine the temperature distribution and compute the stress and deformation due to
thermal expansion only. This part of the example ignores the pressure.
Import the same geometry and use the same mesh as for the structural analysis.
importGeometry(tmodel,'Blade.stl');
tmodel.Mesh = msh;
3-73
3 Solving PDEs
Assuming that the blade is made of nickel-based alloy (NIMONIC 90), specify the thermal
conductivity.
Convective heat transfer between the surrounding fluid and the faces of the blade defines
the boundary conditions for this problem. The convection coefficient is greater where the
gas velocity is higher. Also, the gas temperature is different around different faces. The
∘
temperature of the interior cooling air is 150 C, while the temperature on the pressure
∘
and suction sides is 1000 C.
% Interior cooling
thermalBC(tmodel,'Face',[15 12 14], ...
'ConvectionCoefficient',30, ...
'AmbientTemperature',150);
% Pressure side
thermalBC(tmodel,'Face',11, ...
'ConvectionCoefficient',50, ...
'AmbientTemperature',1000);
% Suction side
thermalBC(tmodel,'Face',10, ...
'ConvectionCoefficient',40, ...
'AmbientTemperature',1000);
% Tip
thermalBC(tmodel,'Face',13, ...
'ConvectionCoefficient',20, ...
'AmbientTemperature',1000);
% Base (exposed to hot gases)
thermalBC(tmodel,'Face',1, ...
'ConvectionCoefficient',40, ...
'AmbientTemperature',800);
% Root in contact with hot gases
thermalBC(tmodel,'Face',[6 9 8 2 7], ...
'ConvectionCoefficient',15, ...
'AmbientTemperature',400);
The boundary condition for the faces of the root in contact with other metal is a thermal
contact that can be modeled as convection with a very large coefficient (around
1000 W / m2K for metal-metal contact).
3-74
Thermal Stress Analysis of Jet Engine Turbine Blade
'ConvectionCoefficient',1000, ...
'AmbientTemperature',300);
Rt = solve(tmodel);
Plot the temperature distribution. The temperature between the tip and the root ranges
∘ ∘ ∘
from around 820 C to 330 C. The exterior gas temperature is 1000 C. The interior cooling
is efficient: it significantly lowers the temperature.
figure
pdeplot3D(tmodel,'ColorMapData',Rt.Temperature)
view([130,-20]);
3-75
3 Solving PDEs
Now, create a static structural model to compute the stress and deformation due to
thermal expansion.
tsmodel = createpde('structural','static-solid');
Import the same geometry, and use the same mesh and structural properties of the
material as for the structural analysis.
importGeometry(tsmodel,'Blade.stl');
tsmodel.Mesh = msh;
structuralProperties(tsmodel,'YoungsModulus',E, ...
'PoissonsRatio',nu, ...
'CTE',CTE);
structuralBC(tsmodel,'Face',3,'Constraint','fixed');
Rts = solve(tsmodel);
Plot the von Mises stress and the displacement. Specify a deformation scale factor of 100
to better visualize the deformation. The stress concentrates in the constrained root
because it cannot freely expand, and also in the junction between the blade and the root.
figure('units','normalized','outerposition',[0 0 1 1]);
pdeplot3D(tsmodel,'ColorMapData',Rts.VonMisesStress, ...
'Deformation',Rts.Displacement, ...
'DeformationScaleFactor',100)
caxis([0, 200e6])
view([116,25]);
3-76
Thermal Stress Analysis of Jet Engine Turbine Blade
Evaluate the displacement at the tip. In the design of the cover, this displacement must be
taken into account to avoid friction between the cover and the blade.
max(Rts.Displacement.Magnitude)
ans = 0.0015
3-77
3 Solving PDEs
Compute the stress and deformations caused by the combination of thermal and pressure
effects.
Use the same model as for the thermal stress analysis. Add the pressure load on the
pressure and suction sides of the blade. This pressure is due to the high-pressure gas
surrounding these sides of the blade.
Rc = solve(tsmodel);
Plot the von Mises stress and the displacement. Specify a deformation scale factor of 100
to better visualize the deformation.
figure('units','normalized','outerposition',[0 0 1 1]);
pdeplot3D(tsmodel,'ColorMapData',Rc.VonMisesStress, ...
'Deformation',Rc.Displacement, ...
'DeformationScaleFactor',100)
caxis([0, 200e6])
view([116,25]);
3-78
Thermal Stress Analysis of Jet Engine Turbine Blade
Evaluate the maximum stress and maximum displacement. The displacement is almost the
same as for the thermal stress analysis, while the maximum stress, 854 MPa, is
significantly higher.
max(Rc.VonMisesStress)
ans = 8.5438e+08
max(Rc.Displacement.Magnitude)
3-79
3 Solving PDEs
ans = 0.0015
3-80
Finite Element Analysis of Electrostatically Actuated MEMS Device
MEMS Devices
MEMS devices typically consist of movable thin beams or electrodes with a high aspect
ratio that are suspended over a fixed electrode.
Actuation, switching, and other signal and information processing functions can use the
electrode deformation caused by the application of voltage between the movable and
fixed electrodes. FEM provides a convenient tool for characterizing the inner workings of
3-81
3 Solving PDEs
This example uses the following geometry to model a MEMS switch. The top electrode is
150 μm in length and 2 μm in thickness. The Young’s modulus E is 170 GPa, and the
Poisson ratio υ is 0.34. The bottom electrode is 50 μm in length and 2 μm in thickness,
and is located 100 μm from the leftmost end of the top electrode. The gap between the
top and bottom electrodes is 2 μm.
3-82
Finite Element Analysis of Electrostatically Actuated MEMS Device
A voltage applied between the top electrode and the ground plane induces electrostatic
charges on the surface of the conductors which, in turn, leads to electrostatic forces
acting normal to the surface of the conductors. Because the ground plane is fixed, the
electrostatic forces deform only the top electrode. When the beam deforms, the charge
redistributes on the surface of the conductors. The resultant electrostatic forces and the
deformation of the beam also change. This process continues until the system reaches a
state of equilibrium.
For simplicity, this example uses the relaxation-based algorithm rather than the Newton
method to couple the electrostatic and the mechanical domains. The example follows
these steps:
1. Solve the electrostatic FEA problem in the nondeformed geometry with the constant
potential V0 on the movable electrode.
2. Compute the load and boundary conditions for the mechanical solution by using the
calculated values of the charge density along the movable electrode. The electrostatic
pressure on the movable electrode is given by
1 2
P= D ,
2ϵ
3-83
3 Solving PDEs
where D is the magnitude of the electric flux density and ϵ is the electric permittivity
next to the movable electrode.
3. Compute the deformation of the movable electrode by solving the mechanical FEA
problem.
4. Update the charge density along the movable electrode by using the calculated
displacement of the movable electrode,
G
Ddef x ≈ D0 x ,
G − v(x)
where Ddef x is the magnitude of the electric flux density in the deformed electrode,
D0 x is the magnitude of the electric flux density in the undeformed electrode, G is the
distance between the movable and fixed electrodes in the absence of actuation, and v x is
the displacement of the movable electrode at position x along its axis.
5. Repeat steps 2–4 until the electrode deformation values in the last two iterations
converge.
Electrostatic Analysis
In the electrostatic analysis part of this example, you compute the electric potential
around the electrodes.
First, create the cantilever switch geometry by using the constructive solid geometry
(CSG) modeling approach. The geometry for electrostatic analysis consists of three
rectangles represented by a matrix. Each column of the matrix describes a basic shape.
rect_domain = [3,4,1.75e-4,1.75e-4,-1.75e-4,-1.75e-4,-1.7e-5,1.3e-5,1.3e-5,-1.7e-5]';
rect_movable = [3,4,7.5e-5,7.5e-5,-7.5e-5,-7.5e-5,2.0e-6,4.0e-6,4.0e-6,2.0e-6]';
rect_fixed = [3,4,7.5e-5,7.5e-5,2.5e-5,2.5e-5,-2.0e-6,0,0,-2.0e-6]';
gd = [rect_domain,rect_movable,rect_fixed];
Create a name for each basic shape. Specify the names as a matrix whose columns
contain the names of the corresponding columns in the basic shape matrix.
ns = char('rect_domain','rect_movable','rect_fixed');
ns = ns';
sf = 'rect_domain-(rect_movable+rect_fixed)';
3-84
Finite Element Analysis of Electrostatically Actuated MEMS Device
dl = decsg(gd,sf,ns);
model = createpde;
geometryFromEdges(model,dl);
pdegplot(model,'EdgeLabels','on','FaceLabels','on')
xlabel('x-coordinate, meters')
ylabel('y-coordinate, meters')
axis([-2e-4, 2e-4,-4e-5, 4e-5])
axis square
3-85
3 Solving PDEs
Set constant potential values of 20 V to the movable electrode and 0 V to the fixed
electrode and domain boundary.
V0 = 0;
V1 = 20;
applyBoundaryCondition(model,'dirichlet','Edge',[4,8,9,10],'u',V0);
3-86
Finite Element Analysis of Electrostatically Actuated MEMS Device
applyBoundaryCondition(model,'dirichlet','Edge',[1,2,5,6],'u',V0);
applyBoundaryCondition(model,'dirichlet','Edge',[3,7,11,12],'u',V1);
− ∇ ⋅ (ϵ ∇V) = ρ,
where ϵ is the coefficient of permittivity and ρ is the charge density. The coefficient of
permittivity does not affect the result in this example as long as the coefficient is
constant. Assuming that there is no charge in the domain, you can simplify the Poisson
equation to the Laplace equation,
ΔV = 0.
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',0);
hmax = 5e-6;
generateMesh(model,'Hmax',hmax);
pdeplot(model)
xlabel('x-coordinate, meters')
ylabel('y-coordinate, meters')
axis([-2e-4, 2e-4,-4e-5, 4e-5])
axis square
3-87
3 Solving PDEs
results = solvepde(model);
u = results.NodalSolution;
figure
pdeplot(model,'XYData',results.NodalSolution,...
'ColorMap','jet');
title('Electric Potential');
xlabel('x-coordinate, meters')
ylabel('y-coordinate, meters')
3-88
Finite Element Analysis of Electrostatically Actuated MEMS Device
Mechanical Analysis
In the mechanical analysis part of this example, you compute the deformation of the
movable electrode.
structuralmodel = createpde('structural','static-planestress');
Create the movable electrode geometry and include it in the model. Plot the geometry.
3-89
3 Solving PDEs
dl = decsg(rect_movable);
geometryFromEdges(structuralmodel,dl);
pdegplot(structuralmodel,'EdgeLabels','on')
xlabel('x-coordinate, meters')
ylabel('y-coordinate, meters')
axis([-1e-4, 1e-4,-1e-5, 1e-5])
axis square
Specify the structural properties: the Young's modulus E is 170 GPa and the Poisson ratio
ν is 0.34.
structuralProperties(structuralmodel,'YoungsModulus',170e9, ...
'PoissonsRatio',0.34);
3-90
Finite Element Analysis of Electrostatically Actuated MEMS Device
Specify the pressure as a boundary load on the edges. The pressure tends to draw the
conductor into the field regardless of the sign of the surface charge. For the definition of
the CalculateElectrostaticPressure function, see the Electrostatic Pressure
Function section at the bottom of this page.
structuralBC(structuralmodel,'Edge',3,'Constraint','fixed');
Generate a mesh.
hmax = 1e-6;
generateMesh(structuralmodel,'Hmax',hmax);
pdeplot(structuralmodel);
xlabel('x-coordinate, meters')
ylabel('y-coordinate, meters')
axis([-1e-4, 1e-4,-1e-5, 1e-5])
axis square
3-91
3 Solving PDEs
R = solve(structuralmodel);
pdeplot(structuralmodel,'XYData',R.VonMisesStress, ...
'Deformation',R.Displacement, ...
'DeformationScaleFactor',10, ...
'ColorMap','jet');
3-92
Finite Element Analysis of Electrostatically Actuated MEMS Device
Repeatedly update the charge density along the movable electrode and solve the model
until the electrode deformation values converge.
olddisp = 0;
while abs((maxdisp-olddisp)/maxdisp) > 1e-10
3-93
3 Solving PDEs
pdeplot(structuralmodel,'XYData',R.VonMisesStress, ...
'Deformation',R.Displacement, ...
'DeformationScaleFactor',10, ...
'ColorMap','jet');
3-94
Finite Element Analysis of Electrostatically Actuated MEMS Device
maxdisp = max(abs(R.Displacement.uy));
fprintf('Finite element maximal tip deflection is: %12.4e\n', maxdisp);
References
[1] Sumant, P. S., N. R. Aluru, and A. C. Cangellaris. “A Methodology for Fast Finite
Element Modeling of Electrostatically Actuated MEMS.” International Journal for
Numerical Methods in Engineering. Vol 77, Number 13, 2009, 1789-1808.
3-95
3 Solving PDEs
1 2
P= D ,
2ϵ
where D = ϵ E is the magnitude of the electric flux density, ϵ is the electric permittivity
next to the movable electrode, and E is the magnitude of the electric field. The electric
field E is the gradient of the electric potential V :
E = − ∇V.
Solve the mechanical FEA to compute the deformation of the movable electrode. Using
the calculated displacement of the movable electrode, update the charge density along
the movable electrode.
G
Ddef x ≈ D0 x ,
G − v(x)
where Ddef x is the magnitude of the electric flux density in the deformed electrode,
D0 x is the magnitude of the electric flux density in the undeformed electrode, G is the
distance between the movable and fixed electrodes in the absence of actuation, and v x is
the displacement of the movable electrode at position x along its axis. Initially, the
movable electrode is undeformed, v x = 0, and therefore, Ddef x ≈ D0 x .
3-96
Finite Element Analysis of Electrostatically Actuated MEMS Device
end
3-97
3 Solving PDEs
The first step in solving a linear elasticity problem is to create a structural analysis model.
This is a container that holds the geometry, structural material properties, body and
boundary loads, boundary constraints, and mesh.
model = createpde('structural','static-solid');
Import an STL file of a simple bracket model using the importGeometry function. This
function reconstructs the faces, edges and vertices of the model. It can merge some faces
and edges, so the numbers can differ from those of the parent CAD model.
importGeometry(model,'BracketWithHole.stl');
Plot the geometry and turn on face labels. You will need the face labels to define the
boundary conditions.
figure
pdegplot(model,'FaceLabels','on')
view(30,30);
title('Bracket with Face Labels')
3-98
Deflection Analysis of Bracket
figure
pdegplot(model,'FaceLabels','on')
view(-134,-32)
title('Bracket with Face Labels, Rear View')
3-99
3 Solving PDEs
structuralProperties(model,'Cell',1,'YoungsModulus',200e9, ...
'PoissonsRatio',0.3);
The problem has two boundary conditions: the back face (face 4) is immobile and the
front face has an applied load. All other boundary conditions, by default, are free
boundaries.
structuralBC(model,'Face',4,'Constraint','fixed');
3-100
Deflection Analysis of Bracket
Apply a distributed load in the negative z-direction to the front face (face 8).
Create a Mesh
Create a mesh that uses 10-node tetrahedral elements with quadratic interpolation
functions. This element type is significantly more accurate than the linear interpolation
(four-node) elements, particularly in elasticity analyses that involve bending.
3-101
3 Solving PDEs
result = solve(model);
minUz = min(result.Displacement.uz);
fprintf('Maximal deflection in the z-direction is %g meters.', minUz)
3-102
Deflection Analysis of Bracket
To see the solution, plot the components of the solution vector. The maximal deflections
are in the z-direction. Because the part and the loading are symmetric, the x-
displacement and z-displacement are symmetric, and the y-displacement is antisymmetric
with respect to the center line.
Here, the plotting routine uses the 'jet' colormap, which has blue as the color
representing the lowest value and red representing the highest value. The bracket
loading causes face 8 to dip down, so the maximum z-displacement appears blue.
figure
pdeplot3D(model,'ColorMapData',result.Displacement.ux)
title('x-displacement')
colormap('jet')
3-103
3 Solving PDEs
figure
pdeplot3D(model,'ColorMapData',result.Displacement.uy)
title('y-displacement')
colormap('jet')
3-104
Deflection Analysis of Bracket
figure
pdeplot3D(model,'ColorMapData',result.Displacement.uz)
title('z-displacement')
colormap('jet')
3-105
3 Solving PDEs
Plot values of the von Mises stress at nodal locations. Use the same jet colormap.
figure
pdeplot3D(model,'ColorMapData',result.VonMisesStress)
title('von Mises stress')
colormap('jet')
3-106
Deflection Analysis of Bracket
3-107
3 Solving PDEs
The dimensions and material properties of the plate are taken from a standard finite
element benchmark problem published by NAFEMS, FV52 (See Reference).
First, create a structural model container for your 3-D modal analysis problem. This is a
container that holds the geometry, properties of the material, body loads, boundary loads,
boundary constraints, and mesh.
model = createpde('structural','modal-solid');
Import an STL file of a simple plate model using the importGeometry function. This
function reconstructs the faces, edges, and vertices of the model. It can merge some faces
and edges, so the numbers can differ from those of the parent CAD model.
importGeometry(model,'Plate10x10x1.stl');
Plot the geometry and turn on face labels. You need the face labels when defining the
boundary conditions.
figure
hc = pdegplot(model,'FaceLabels','on');
hc(1).FaceAlpha = 0.5;
title('Plate with Face Labels')
3-108
Vibration of Square Plate
Define the elastic modulus of steel, Poisson's ratio, and the material density.
structuralProperties(model,'YoungsModulus',200e9, ...
'PoissonsRatio',0.3, ...
'MassDensity',8000);
In this example, the only boundary condition is the zero z-displacement on the four edge
faces. These edge faces have labels 1 through 4.
structuralBC(model,'Face',1:4,'ZDisplacement',0);
Create and plot a mesh. Specify the target minimum edge length so that there is one row
of elements per plate thickness.
3-109
3 Solving PDEs
generateMesh(model,'Hmin',1.3);
figure
pdeplot3D(model);
title('Mesh with Quadratic Tetrahedral Elements');
For comparison with the published values, load the reference frequencies in Hz.
refFreqHz = [0 0 0 45.897 109.44 109.44 167.89 193.59 206.19 206.19];
Solve the problem for the specified frequency range. Define the upper limit as slightly
larger than the highest reference frequency and the lower limit as slightly smaller than
the lowest reference frequency.
maxFreq = 1.1*refFreqHz(end)*2*pi;
result = solve(model,'FrequencyRange',[-0.1 maxFreq]);
3-110
Vibration of Square Plate
freqHz = result.NaturalFrequencies/(2*pi);
Compare the reference and computed frequencies (in Hz) for the lowest 10 modes. The
lowest three mode shapes correspond to rigid-body motion of the plate. Their frequencies
are close to zero.
tfreqHz = table(refFreqHz.',freqHz(1:10));
tfreqHz.Properties.VariableNames = {'Reference','Computed'};
disp(tfreqHz);
Reference Computed
_________ __________
0 2.3167e-05
0 3.2897e-05
0 5.6486e-05
45.897 44.871
109.44 109.74
109.44 109.77
167.89 168.59
193.59 193.74
206.19 207.51
206.19 207.52
You see good agreement between the computed and published frequencies.
Plot the third component (z-component) of the solution for the seven lowest nonzero-
frequency modes.
h = figure;
h.Position = [100,100,900,600];
numToPrint = min(length(freqHz),length(refFreqHz));
for i = 4:numToPrint
subplot(4,2,i-3);
pdeplot3D(model,'ColorMapData',result.ModeShapes.uz(:,i));
axis equal
title(sprintf(['Mode=%d, z-displacement\n', ...
'Frequency(Hz): Ref=%g FEM=%g'], ...
i,refFreqHz(i),freqHz(i)));
end
3-111
3 Solving PDEs
Reference
[1] National Agency for Finite Element Methods and Standards. The Standard NAFEMS
Benchmarks. United Kingdom: NAFEMS, October 1990.
3-112
Structural Dynamics of Tuning Fork
A tuning fork is a U-shaped beam. When struck on one of its prongs or tines, it vibrates at
its fundamental (first) frequency and produces an audible sound.
The first flexible mode of a tuning fork is characterized by symmetric vibration of the
tines: they move towards and away from each other simultaneously, balancing the forces
at the base where they intersect. The fundamental mode of vibration does not produce
any bending effect on the handle attached at the intersection of tines. The lack of bending
at the base enables easy handling of tuning fork without influencing its dynamics.
Transverse vibration of the tines causes the handle to vibrate axially at the fundamental
frequency. This axial vibration can be used to amplify the audible sound by bringing the
end of the handle in contact with a larger surface area, like a metal table top. The next
higher mode with symmetric mode shape is about 6.25 times the fundamental frequency.
Therefore, a properly excited tuning fork tends to vibrate with a dominant frequency
corresponding to fundamental frequency, producing a pure audible tone. This example
simulates these aspects of the tuning fork dynamics by performing a modal analysis and a
transient dynamics simulation.
Find natural frequencies and mode shapes for the fundamental mode of a tuning fork and
the next several modes. Show the lack of bending effect on the fork handle at the
fundamental frequency.
First, create a structural model for modal analysis of a solid tuning fork.
model = createpde('structural','modal-solid');
importGeometry(model,'TuningFork.stl');
figure
pdegplot(model)
3-113
3 Solving PDEs
Specify the Young's modulus, Poisson's ratio, and mass density to model linear elastic
material behavior. Specify all physical properties in consistent units.
E = 210E9;
nu = 0.3;
rho = 8000;
structuralProperties(model,'YoungsModulus',E, ...
'PoissonsRatio',nu, ...
'MassDensity',rho);
Generate a mesh.
generateMesh(model,'Hmax',0.001);
3-114
Structural Dynamics of Tuning Fork
Solve the model for a chosen frequency range. Specify the lower frequency limit below
zero so that all modes with frequencies near zero appear in the solution.
RF = solve(model,'FrequencyRange',[-1,4000]*2*pi);
modeID = 1:numel(RF.NaturalFrequencies);
Express the resulting frequencies in Hz by dividing them by 2π. Display the frequencies in
a table.
tmodalResults = table(modeID.',RF.NaturalFrequencies/2/pi);
tmodalResults.Properties.VariableNames = {'Mode','Frequency'};
disp(tmodalResults);
Mode Frequency
____ _________
1 0.0043502
2 0.0057641
3 0.0060113
4 0.0063511
5 0.0064692
6 0.0080954
7 460.42
8 706.34
9 1911.5
10 2105.5
11 2906.5
12 3814.7
Because there are no boundary constraints in this example, modal results include the
rigid body modes. The first six near-zero frequencies indicate the six rigid body modes of
a 3-D solid body. The first flexible mode is the seventh mode with a frequency around 460
Hz.
The best way to visualize mode shapes is to animate the harmonic motion at their
respective frequencies. The animateSixTuningForkModes function animates the six
flexible modes, which are modes 7 through 12 in the modal results RF.
frames = animateSixTuningForkModes(RF);
3-115
3 Solving PDEs
movie(figure('units','normalized','outerposition',[0 0 1
1]),frames,5,30)
In the first mode, two oscillating tines of the tuning fork balance out transverse forces at
the handle. The next mode with this effect is the fifth flexible mode with the frequency
2906.5 Hz. This frequency is about 6.25 times greater than the fundamental frequency
460 Hz.
Simulate the dynamics of a tuning fork being gently and quickly struck on one of its tines.
Analyze vibration of tines over time and axial vibration of the handle.
3-116
Structural Dynamics of Tuning Fork
tmodel = createpde('structural','transient-solid');
Import the same tuning fork geometry you used for the modal analysis.
importGeometry(tmodel,'TuningFork.stl');
Generate a mesh.
mesh = generateMesh(tmodel,'Hmax',0.005);
structuralProperties(tmodel,'YoungsModulus',E, ...
'PoissonsRatio',nu, ...
'MassDensity',rho);
Identify faces for applying boundary constraints and loads by plotting the geometry with
the face labels.
figure('units','normalized','outerposition',[0 0 1 1])
pdegplot(tmodel,'FaceLabels','on')
view(-50,15)
title 'Geometry with Face Labels'
3-117
3 Solving PDEs
Impose sufficient boundary constraints to prevent rigid body motion under applied
loading. Typically, you hold a tuning fork by hand or mount it on a table. A simplified
approximation to this boundary condition is fixing a region near the intersection of tines
and the handle (faces 21 and 22).
structuralBC(tmodel,'Face',[21,22],'Constraint','fixed');
Approximate an impulse loading on a face of a tine by applying a pressure load for a very
small fraction of the time period of the fundamental mode. By using this very short
pressure pulse, you ensure that only the fundamental mode of a tuning fork is excited. To
evaluate the time period T of the fundamental mode, use the results of modal analysis.
T = 2*pi/RF.NaturalFrequencies(7);
3-118
Structural Dynamics of Tuning Fork
structuralIC(tmodel,'Displacement',[0;0;0],'Velocity',[0;0;0]);
Solve the transient model for 50 periods of the fundamental mode. Sample the dynamics
60 times per period of the fundamental mode.
ncycle = 50;
samplingFrequency = 60/T;
tlist = linspace(0,ncycle*T,ncycle*T*samplingFrequency);
R = solve(tmodel,tlist)
R =
TransientStructuralResults with properties:
Plot the time-series of the vibration of the tine tip, which is face 12. Find nodes on the tip
face and plot the y-component of the displacement over time, using one of these nodes.
excitedTineTipNodes = findNodes(mesh,'region','Face',12);
tipDisp = R.Displacement.uy(excitedTineTipNodes(1),:);
figure
plot(R.SolutionTimes,tipDisp)
title('Transverse Displacement at Tine Tip')
xlim([0,0.1])
xlabel('Time')
ylabel('Y-Displacement')
3-119
3 Solving PDEs
Perform fast Fourier transform (FFT) on the tip displacement time-series to see that the
vibration frequency of the tuning fork is close to its fundamental frequency. A small
deviation from the fundamental frequency computed in an unconstrained modal analysis
appears because of constraints imposed in the transient analysis.
[fTip,PTip] = tuningForkFFT(tipDisp,samplingFrequency);
figure
plot(fTip,PTip)
title({'Single-sided Amplitude Spectrum', 'of Tip Vibration'})
xlabel('f (Hz)')
ylabel('|P1(f)|')
xlim([0,4000])
3-120
Structural Dynamics of Tuning Fork
Transverse vibration of tines causes the handle to vibrate axially with the same frequency.
To observe this vibration, plot the axial displacement time-series of the end face of the
handle.
baseNodes = tmodel.Mesh.findNodes('region','Face',6);
baseDisp = R.Displacement.ux(baseNodes(1),:);
figure
plot(R.SolutionTimes,baseDisp)
title('Axial Displacement at the End of Handle')
xlim([0,0.1])
ylabel('X-Displacement')
xlabel('Time')
3-121
3 Solving PDEs
Perform an FFT of the time-series of the axial vibration of the handle. This vibration
frequency is also close to its fundamental frequency.
[fBase,PBase] = tuningForkFFT(baseDisp,samplingFrequency);
figure
plot(fBase,PBase)
title({'Single-sided Amplitude Spectrum', 'of Base Vibration'})
xlabel('f (Hz)')
ylabel('|P1(f)|')
xlim([0,4000])
3-122
Structural Dynamics of Tuning Fork
3-123
3 Solving PDEs
Modal Analysis
modelM = createpde('structural','modal-solid');
Create the geometry and include it in the model. Plot the geometry and display the edge
and vertex labels.
gm = multicuboid(0.05,0.003,0.003);
modelM.Geometry=gm;
pdegplot(modelM,'EdgeLabels','on','VertexLabels','on');
view([95 5])
3-124
Modal Superposition Method for Structural Dynamics Problem
Generate a mesh.
msh = generateMesh(modelM);
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(modelM,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
Specify minimal constraints on one end of the beam to prevent rigid body modes. For
example, specify that edge 4 and vertex 7 are fixed boundaries.
structuralBC(modelM,'Edge',4,'Constraint','fixed');
structuralBC(modelM,'Vertex',7,'Constraint','fixed');
3-125
3 Solving PDEs
Solve the problem for the frequency range from 0 to 500000. The recommended approach
is to use a value that is slightly smaller than the expected lowest frequency. Thus, use -0.1
instead of 0.
Rm = solve(modelM,'FrequencyRange',[-0.1,500000]);
Transient Analysis
modelD = createpde('structural','transient-solid');
Use the same geometry and mesh as for the modal analysis.
modelD.Geometry = gm;
modelD.Mesh = msh;
Specify the same values for the Young's modulus, Poisson's ratio, and mass density of the
material.
structuralProperties(modelD,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
Specify the same minimal constraints on one end of the beam to prevent rigid body
modes.
structuralBC(modelD,'Edge',4,'Constraint','fixed');
structuralBC(modelD,'Vertex',7,'Constraint','fixed');
Apply a sinusoidal force on the corner opposite the constrained edge and vertex.
structuralBoundaryLoad(modelD,'Vertex',5,'Force',[0,0,10],'Frequency',7600);
structuralIC(modelD,'Velocity',[0;0;0],'Displacement',[0;0;0]);
modelD.SolverOptions.RelativeTolerance = 1E-5;
modelD.SolverOptions.AbsoluteTolerance = 1E-9;
3-126
Modal Superposition Method for Structural Dynamics Problem
tlist = linspace(0,0.004,120);
Rd = solve(modelD,tlist)
Rd =
TransientStructuralResults with properties:
tlist = linspace(0,0.004,120);
Rdm = solve(modelD,tlist,'ModalResults',Rm)
Rdm =
TransientStructuralResults with properties:
intrpUd = interpolateDisplacement(Rd,0,0,0.0015);
intrpUdm = interpolateDisplacement(Rdm,0,0,0.0015);
Compare the direct integration results with the results obtained by modal superposition.
plot(Rd.SolutionTimes,intrpUd.uz,'bo')
hold on
plot(Rdm.SolutionTimes,intrpUdm.uz,'rx')
grid on
legend('Direct integration', 'Modal superposition')
xlabel('Time');
ylabel('Center of beam displacement')
3-127
3 Solving PDEs
3-128
Stress Concentration in Plate with Circular Hole
A thin rectangular plate under a uniaxial tension has a uniform stress distribution.
Introducing a circular hole in the plate disturbs the uniform stress distribution near the
hole, resulting in a significantly higher than average stress. Such a thin plate, subject to
in-plane loading, can be analyzed as a 2-D plane-stress elasticity problem. In theory, if the
plate is infinite, then the stress near the hole is three times higher than the average
stress. For a rectangular plate of finite width, the stress concentration factor is a function
of the ratio of hole diameter to the plate width. This example approximates the stress
concentration factor using a plate of a finite width.
The plate must be sufficiently long, so that the applied loads and boundary conditions are
far from the circular hole. This condition ensures that a state of uniform tension prevails
in the far field and, therefore, approximates an infinitely long plate. In this example the
length of the plate is four times greater than its width. Specify the following geometric
parameters of the problem.
radius = 20.0;
width = 50.0;
totalLength = 4*width;
Define the geometry description matrix (GDM) for the rectangle and circle.
R1 = [3 4 -totalLength totalLength ...
totalLength -totalLength ...
-width -width width width]';
C1 = [1 0 0 radius 0 0 0 0 0 0]';
Define the combined GDM, name-space matrix, and set formula to construct decomposed
geometry using decsg.
gdm = [R1 C1];
ns = char('R1','C1');
g = decsg(gdm,'R1 - C1',ns');
3-129
3 Solving PDEs
geometryFromEdges(model,g);
3-130
Stress Concentration in Plate with Circular Hole
Specify the Young's modulus and Poisson's ratio to model linear elastic material behavior.
Remember to specify physical properties in consistent units.
structuralProperties(model,'YoungsModulus',200E3,'PoissonsRatio',0.25);
Restrain all rigid-body motions of the plate by specifying sufficient constraints. For static
analysis, the constraints must also resist the motion induced by applied load.
Set the x-component of displacement on the left edge (edge 3) to zero to resist the
applied load. Set the y-component of displacement at the bottom left corner (vertex 3) to
zero to restraint the rigid body motion.
3-131
3 Solving PDEs
structuralBC(model,'Edge',3,'XDisplacement',0);
structuralBC(model,'Vertex',3,'YDisplacement',0);
Apply the surface traction with a non-zero x-component on the right edge of the plate.
structuralBoundaryLoad(model,'Edge',1,'SurfaceTraction',[100;0]);
To capture the gradation in solution accurately, use a fine mesh. Generate the mesh, using
Hmax to control the mesh size.
generateMesh(model,'Hmax',radius/6);
figure
pdemesh(model)
3-132
Stress Concentration in Plate with Circular Hole
R = solve(model);
Plot the x-component of the normal stress distribution. The stress is equal to applied
tension far away from the circular boundary. The maximum value of stress occurs near
the circular boundary.
figure
pdeplot(model,'XYData',R.Stress.sxx,'ColorMap','jet')
axis equal
title 'Normal Stress Along x-Direction';
3-133
3 Solving PDEs
Interpolate Stress
To see the details of the stress variation near the circular boundary, first define a set of
points on the boundary.
thetaHole = linspace(0,2*pi,200);
xr = radius*cos(thetaHole);
yr = radius*sin(thetaHole);
CircleCoordinates = [xr;yr];
stressHole = interpolateStress(R,CircleCoordinates);
3-134
Stress Concentration in Plate with Circular Hole
Plot the normal direction stress versus angular position of the interpolation points.
figure
plot(thetaHole,stressHole.sxx)
xlabel('\theta')
ylabel('\sigma_{xx}')
title 'Normal Stress Around Circular Boundary';
The plate with a hole model has two axes of symmetry. Therefore, you can model a
quarter of the geometry. The following model solves a quadrant of the full model with
appropriate boundary conditions.
3-135
3 Solving PDEs
symModel = createpde('structural','static-planestress');
Create the geometry that represents one quadrant of the original model. You do not need
to create additional edges to constrain the model properly.
figure
pdegplot(symModel,'EdgeLabel','on');
axis equal
title 'Symmetric Quadrant with Edge Labels';
3-136
Stress Concentration in Plate with Circular Hole
structuralProperties(symModel,'YoungsModulus',200E3, ...
'PoissonsRatio',0.25);
structuralBC(symModel,'Edge',[3 4],'Constraint','symmetric');
structuralBoundaryLoad(symModel,'Edge',1,'SurfaceTraction',[100;0]);
3-137
3 Solving PDEs
generateMesh(symModel,'Hmax',radius/6);
Rsym = solve(symModel);
Plot the x-component of the normal stress distribution. The results are identical to the
first quadrant of the full model.
figure
pdeplot(symModel,'XYData',Rsym.Stress.sxx,'ColorMap','jet');
axis equal
title 'Normal Stress Along x-Direction for Symmetric Model';
3-138
Thermal Deflection of Bimetallic Beam
This example finds the deflection of a bimetallic beam using a structural finite-element
model. The example compares this deflection to the analytic solution based on beam
theory approximation.
3-139
3 Solving PDEs
Identify the cell labels of the cells for which you want to specify material properties.
First, display the cell label for the bottom cell. To see the cell label clearly, zoom onto the
left end of the beam and rotate the geometry as follows.
figure
pdegplot(structuralmodel,'CellLabels','on')
axis([-L/2 -L/3 -W/2 W/2 0 2*H])
view([0 0])
zticks([])
3-140
Thermal Deflection of Bimetallic Beam
Now, display the cell label for the top cell. To see the cell label clearly, zoom onto the right
end of the beam and rotate the geometry as follows.
figure
pdegplot(structuralmodel,'CellLabels','on')
axis([L/3 L/2 -W/2 W/2 0 2*H])
view([0 0])
zticks([])
3-141
3 Solving PDEs
Specify the Young's modulus, Poisson's ratio, and linear coefficient of thermal expansion
to model linear elastic material behavior. To maintain unit consistency, specify all physical
properties in SI units.
Ec = 137E9; % N/m^2
nuc = 0.28;
CTEc = 20.00E-6; % m/m-C
structuralProperties(structuralmodel,'Cell',1, ...
'YoungsModulus',Ec, ...
'PoissonsRatio',nuc, ...
'CTE',CTEc);
3-142
Thermal Deflection of Bimetallic Beam
Ei = 130E9; % N/m^2
nui = 0.354;
CTEi = 1.2E-6; % m/m-C
structuralProperties(structuralmodel,'Cell',2, ...
'YoungsModulus',Ei, ...
'PoissonsRatio',nui, ...
'CTE',CTEi);
For this example, assume that the left end of the beam is fixed. To impose this boundary
condition, display the face labels on the left end of the beam.
figure
pdegplot(structuralmodel,'faceLabels','on','FaceAlpha',0.25)
axis([-L/2 -L/3 -W/2 W/2 0 2*H])
view([60 10])
xticks([])
yticks([])
zticks([])
3-143
3 Solving PDEs
3-144
Thermal Deflection of Bimetallic Beam
Plot the deflected shape of the bimetallic beam with the magnitude of displacement as the
color map data.
figure
pdeplot3D(structuralmodel,'ColorMapData',R.Displacement.Magnitude, ...
'Deformation',R.Displacement, ...
'DeformationScaleFactor',2)
title('Deflection of Invar-Copper Beam')
Compute the deflection analytically, based on beam theory. The deflection of the strip is
6Δ T αc − αi L2 Ec Ei
δ= K1
, where K1 = 14 + Ei
+ Ec
, Δ T is the temperature difference, αc and αi
3-145
3 Solving PDEs
are the coefficients of thermal expansion of copper and invar, Ec and Ei are the Young's
modulus of copper and invar, and L is the length of the strip.
K1 = 14 + (Ec/Ei)+ (Ei/Ec);
deflectionAnalytical = 3*(CTEc - CTEi)*100*2*H*L^2/(H^2*K1);
Compare the analytical results and the results obtained in this example. The results are
comparable because of the large aspect ratio.
PDEToobox_Deflection = max(R.Displacement.uz);
percentError = 100*(PDEToobox_Deflection - ...
deflectionAnalytical)/PDEToobox_Deflection;
3-146
Electrostatic Potential in Air-Filled Frame: PDE Modeler App
–∇ · (ε∇V) = ρ.
The PDE Modeler app uses the relative permittivity εr = ε/ε0, where ε0 is the absolute
dielectric permittivity of a vacuum (8.854 · 10-12 farad/meter). The relative permittivity for
the air is 1.00059. Note that the coefficient of permittivity does not affect the result in
this example as long as the coefficient is constant.
Assuming that there is no charge in the domain, you can simplify the Poisson equation to
the Laplace equation,
ΔV = 0.
Here, the boundary conditions are the Dirichlet boundary conditions V = 1000 at the
inner boundary and V = 0 at the outer boundary.
To solve this problem in the PDE Modeler app, follow these steps:
3-147
3 Solving PDEs
• For the inner boundaries, use the Dirichlet boundary condition with h = 1 and r
= 1000.
• For the outer boundaries, use the Dirichlet boundary condition with h = 1 and r
= 0.
6 Specify the coefficients by selecting PDE > PDE Specification or clicking the PDE
button on the toolbar. Specify epsilon = 1 and rho = 0.
7 Initialize the mesh by selecting Mesh > Initialize Mesh.
8 Solve the PDE by selecting Solve > Solve PDE or clicking the = button on the
toolbar.
9 Plot the equipotential lines using a contour plot. To do this, select Plot >
Parameters and choose the contour plot in the resulting dialog box.
10 Improve the accuracy of the solution by refining the mesh close to the reentrant
corners where the gradients are steep. To do this, select Solve > Parameters. Select
Adaptive mode, use the Worst triangles selection method, and set the maximum
number of triangles to 500. Select Mesh > Refine Mesh.
11 Solve the PDE using the refined mesh. To display equipotential lines at every 100th
volt, select Plot > Parameters and enter 0:100:1000 in the Contour plot levels
field.
3-148
Electrostatic Potential in Air-Filled Frame: PDE Modeler App
3-149
3 Solving PDEs
In this section...
“Summary of the Equations of Linear Elasticity” on page 3-150
“3D Linear Elasticity Problem” on page 3-151
“Plane Stress” on page 3-154
“Plane Strain” on page 3-155
σ = stress
f = body force
ε = strain
u = displacement
−∇ · σ = f
1
ε= ∇u + ∇uT
2
σi j = σ ji
The Voigt notation for the constitutive equation of the linear isotropic model is
3-150
Linear Elasticity Equations
The expanded form uses all the entries in σ and ε takes symmetry into account.
σ11 ε11
1−ν 0 0 0 ν 0 0 0 ν
σ12 ε12
• 1 − 2ν 0 0 0 0 0 0 0
σ13 • • 1 − 2ν 0 0 0 0 0 0 ε13
σ21 • • • 1 − 2ν 0 0 0 0 0 ε21
E
σ22 = • • • • 1−ν 0 0 0 ν ε22
1 + ν 1 − 2ν
σ23 • • • • • 1 − 2ν 0 0 0 ε23
σ31 • • • • • • 1 − 2ν 0 0 ε31
σ32 • • • • • • • 1 − 2ν 0 ε32
• • • • • • • • 1−ν
σ33 ε33
(3-1)
− ∇ · c ⊗ ∇u = f
But the equations in the summary do not have ∇u alone, it appears together with its
transpose:
1
ε= ∇u + ∇uT
2
3-151
3 Solving PDEs
∂ux / ∂x
∂ux / ∂y
∂ux / ∂z
∂uy / ∂x
∇u = ∂uy / ∂y
∂uy / ∂z
∂uz / ∂x
∂uz / ∂y
∂uz / ∂z
1 0 0 0 0 0 0 0 0
1 1
0 0 0 0 0 0 0
2 2
1 1
0 0 0 0 0 0 0
2 2
1 1
0 0 0 0 0 0 0
2 2
ε= 0 0 0 0 1 0 0 0 0 ∇u ≡ A ∇u
1 1
0 0 0 0 0 0 0
2 2
1 1
0 0 0 0 0 0 0
2 2
1 1
0 0 0 0 0 0 0
2 2
0 0 0 0 0 0 0 0 1
where A stands for the displayed matrix. So rewriting “Equation 3-1”, and recalling that •
means an entry is symmetric, you can write the stiffness tensor as
3-152
Linear Elasticity Equations
1−ν 0 0 0 ν 0 0 0 ν
• 1 − 2ν 0 0 0 0 0 0 0
• • 1 − 2ν 0 0 0 0 0 0
• • • 1 − 2ν 0 0 0 0 0
E
σ= • • • • 1−ν 0 0 0 ν A ∇u
1 + ν 1 − 2ν
• • • • • 1 − 2ν 0 0 0
• • • • • • 1 − 2ν 0 0
• • • • • • • 1 − 2ν 0
• • • • • • • • 1−ν
1−ν 0 0 0 ν 0 0 0 ν
0 1/2 − ν 0 1/2 − ν 0 0 0 0 0
0 0 1/2 − ν 0 0 0 1/2 − ν 0 0
0 1/2 − ν 0 1/2 − ν 0 0 0 0 0
E
= ν 0 0 0 1−ν 0 0 0 ν ∇u
1 + ν 1 − 2ν
0 0 0 0 0 1/2 − ν 0 1/2 − ν 0
0 0 1/2 − ν 0 0 0 1/2 − ν 0 0
0 0 0 0 0 1/2 − ν 0 1/2 − ν 0
ν 0 0 0 ν 0 0 0 1−ν
E
μ=
2(1 + ν)
Eν
λ=
(1 + ν)(1 − 2ν)
E(1 − ν)
= 2μ + λ
(1 + ν)(1 − 2ν)
3-153
3 Solving PDEs
2μ + λ 0 0 0 λ 0 0 0 λ
0 μ 0 μ 0 0 0 0 0
0 0 μ 0 0 0 μ 0 0
0 μ 0 μ 0 0 0 0 0
σ= λ 0 0 0 2μ + λ 0 0 0 λ ∇u ≡ c ∇u
0 0 0 0 0 μ 0 μ 0
0 0 μ 0 0 0 μ 0 0
0 0 0 0 0 μ 0 μ 0
λ 0 0 0 λ 0 0 0 2μ + λ
If you are solving a 3-D linear elasticity problem by using PDEModel instead of
StructuralModel, use the elasticityC3D(E,nu) function (included in your software)
to obtain the c coefficient. This function uses the linearized, small-displacement
assumption for an isotropic material. For examples that use this function, see Vibration of
a Square Plate.
Plane Stress
Plane stress is a condition that prevails in a flat plate in the x-y plane, loaded only in its
own plane and without z-direction restraint. For plane stress, σ13 = σ23 = σ31 = σ32 = σ33
= 0. Assuming isotropic conditions, the Hooke's law for plane stress gives the following
strain-stress relation:
ε11 1 −ν 0 σ11
1
ε22 = −ν 1 0 σ22
E
2ε12 0 0 2 + 2ν σ12
σ11 1 ν 0 ε11
E ν 1 0
σ22 = ε22
1 − ν2 1−ν
σ12 0 0 2ε12
2
3-154
Linear Elasticity Equations
1 0 0 0
1 1
0 0
2 2
ε= ∇u ≡ A ∇u
1 1
0 0
2 2
0 0 0 1
E Eν
0 0
1 − ν2 1 − ν2 2μ μ + λ 2λμ
σ11 0 0
E E 2μ + λ 2μ + λ
σ12 0 0
2 1+ν 2 1+ν 0 μ μ 0
= ∇u = ∇u
σ21 E E 0 μμ 0
0 0
σ22 2 1+ν 2 1+ν 2λμ 2μ μ + λ
0 0
Eν E 2μ + λ 2μ + λ
0 0
1 − ν2 1 − ν2
Plane Strain
Plane strain is a deformation state where there are no displacements in the z-direction,
and the displacements in the x- and y-directions are functions of x and y but not z. The
stress-strain relation is only slightly different from the plane stress case, and the same set
of material parameters is used.
For plane strain, ε13 = ε23 = ε31 = ε32 = ε33 = 0. Assuming isotropic conditions, the stress-
strain relation can be written as follows:
3-155
3 Solving PDEs
1 0 0 0
1 1
0 0
2 2
ε= ∇u ≡ A ∇u
1 1
0 0
2 2
0 0 0 1
E 1−ν Eν
0 0
1 + ν 1 − 2ν 1 + ν 1 − 2ν
σ11 2μ + λ 0 0 λ
E E
σ12 0 0
2 1+ν 2 1+ν 0 μμ 0
= ∇u =
σ21 E E 0 μ μ 0
0 0
σ22 2 1+ν 2 1+ν λ 0 0 2μ + λ
Eν E 1−ν
0 0
1 + ν 1 − 2ν 1 + ν 1 − 2ν
∇u
3-156
Magnetic Field in Two-Pole Electric Motor: PDE Modeler App
• Two ferromagnetic pieces: the stator and the rotor (transformer steel)
• The air gap between the stator and the rotor
• The armature copper coil carrying the DC current
Magnetic permeability of the air and copper is close to the magnetic permeability of a
vacuum, μ0 = 4π*10-7 H/m. In this example, use the magnetic permeability μ = μ0 for both
the air gap and copper coil. For the stator and the rotor, μ is
3-157
3 Solving PDEs
μmax
μ = μ0 2
+ μmin
1 + c ∇A
where µmax = 5000, µmin = 200, and c = 0.05. The current density J is 0 everywhere except
in the coil, where it is 10 A/m2.
The geometry of the problem makes the magnetic vector potential A symmetric with
respect to y and antisymmetric with respect to x. Therefore, you can limit the domain to x
≥ 0, y ≥ 0 with the Neumann boundary condition
1
n ⋅ ∇A = 0
μ
on the x-axis and the Dirichlet boundary condition A = 0 on the y-axis. Because the field
outside the motor is negligible, you can use the Dirichlet boundary condition A = 0 on the
exterior boundary.
To solve this problem in the PDE Modeler app, follow these steps:
1 Set the x-axis limits to [-1.5 1.5] and the y-axis limits to [-1 1]. To do this, select
Options > Axes Limits and set the corresponding ranges.
2 Set the application mode to Magnetostatics.
3 Create the geometry. The geometry of this electric motor is complex. The model is a
union of five circles and two rectangles. The reduction to the first quadrant is
achieved by intersection with a square. To draw the geometry, enter the following
commands in the MATLAB Command Window:
pdecirc(0,0,1,'C1')
pdecirc(0,0,0.8,'C2')
pdecirc(0,0,0.6,'C3')
pdecirc(0,0,0.5,'C4')
pdecirc(0,0,0.4,'C5')
pderect([-0.2 0.2 0.2 0.9],'R1')
pderect([-0.1 0.1 0.2 0.9],'R2')
pderect([0 1 0 1],'SQ1')
3-158
Magnetic Field in Two-Pole Electric Motor: PDE Modeler App
3-159
3 Solving PDEs
6 Specify the boundary conditions. To do this, select the boundaries along the x-axis.
Select Boundary > Specify Boundary Conditions. In the resulting dialog box,
specify a Neumann boundary condition with g = 0 and q = 0.
All other boundaries have a Dirichlet boundary condition with h = 1 and r = 0, which
is the default boundary condition in the PDE Modeler app.
7 Specify the coefficients by selecting PDE > PDE Specification or clicking the PDE
button on the toolbar. Double-click each subdomain and specify the following
coefficients:
3-160
Magnetic Field in Two-Pole Electric Motor: PDE Modeler App
The plot shows that the magnetic flux is parallel to the equipotential lines of the
magnetostatic potential.
3-161
3 Solving PDEs
3-162
Scattering Problem
Scattering Problem
This example shows how to solve a simple scattering problem, where you compute the
waves reflected by a square object illuminated by incident waves that are coming from
the left.
For this problem, assume an infinite horizontal membrane subjected to small vertical
displacements U. The membrane is fixed at the object boundary. The medium is
homogeneous, and the phase velocity (propagation speed) of a wave, α, is constant. The
wave equation is
∂2 U
2
− α2 ▵ U = 0
∂t
The solution U is the sum of the incident wave V and the reflected wave R:
U=V+R
When the illumination is harmonic in time, you can compute the field by solving a single
steady problem. Assume that the incident wave is a plane wave traveling in the -x
direction:
The reflected wave can be decomposed into spatial and time components:
R x, y, t = r x, y e−iωt
Now you can rewrite the wave equation as the Helmholtz equation for the spatial
component of the reflected wave with the wave number k = ω/α:
2
−Δr − k r = 0
The Dirichlet boundary condition for the boundary of the object is U = 0, or in terms of
the incident and reflected waves, R = -V. For the time-harmonic solution and the incident
wave traveling in the -x direction, you can write this boundary condition as follows:
r x, y = − e−ikx
The reflected wave R travels outward from the object. The condition at the outer
computational boundary must allow waves to pass without reflection. Such conditions are
3-163
3 Solving PDEs
∂R
∂t
+ α ξ ⋅ ∇R = 0
This equation considers only the waves moving in the positive ξ-direction. Here, ξ is the
radial distance from the object. With the time-harmonic solution, this equation turns into
the generalized Neumann boundary condition
ξ ⋅ ∇r − ikr = 0
To solve the scattering problem using the programmatic workflow, first create a PDE
model with a single dependent variable.
numberOfPDE = 1;
model = createpde(numberOfPDE);
g = @scatterg;
k = 60;
c = 1;
a = -k^2;
f = 0;
geometryFromEdges(model,g);
Plot the geometry and display the edge labels for use in the boundary condition definition.
figure;
pdegplot(model,'EdgeLabels','on');
axis equal
title 'Geometry with Edge Labels Displayed';
ylim([0,1])
3-164
Scattering Problem
bOuter = applyBoundaryCondition(model,'neumann','Edge',(5:8),'g',0,'q',-60i);
innerBCFunc = @(loc,state)-exp(-1i*k*loc.x);
bInner = applyBoundaryCondition(model,'dirichlet','Edge',(1:4),'u',innerBCFunc);
specifyCoefficients(model,'m',0,'d',0,'c',c,'a',a,'f',f);
Generate a mesh.
generateMesh(model,'Hmax',0.02);
figure
3-165
3 Solving PDEs
pdemesh(model);
axis equal
Solve for the complex amplitude. The real part of vector u stores an approximation to a
real value solution of the Helmholtz equation.
result = solvepde(model);
u = result.NodalSolution;
figure
pdeplot(model,'XYData',real(u),'Mesh','off');
colormap(jet)
3-166
Scattering Problem
xlabel 'x'
ylabel 'y'
title('Real Value Solution of Helmholtz Equation')
Using the solution to the Helmholtz equation, create an animation showing the
corresponding solution to the time-dependent wave equation.
figure
m = 10;
maxu = max(abs(u));
for j = 1:m
uu = real(exp(-j*2*pi/m*sqrt(-1))*u);
pdeplot(model,'XYData',uu,'ColorBar','off','Mesh','off');
colormap(jet)
3-167
3 Solving PDEs
caxis([-maxu maxu]);
axis tight
ax = gca;
ax.DataAspectRatio = [1 1 1];
axis off
M(j) = getframe;
end
3-168
Electrostatics and Magnetostatics
–∇ · (ε∇V) = ρ,
For electrostatics problems, you can use Dirichlet boundary conditions specifying the
electrostatic potential V on the boundary or Neumann boundary conditions specifying the
surface charge n · (ε∇V) on the boundary.
Maxwell's equations for steady cases are ∇ × H = J and ∇ ⋅ B = 0. Here, B = μH, where B
is the magnetic flux density, H is the magnetic field intensity, J is the current density, and
µ is the material's magnetic permeability.
If the current flows are parallel to the z-axis, then A = 0, 0, A and J = 0, 0, J . Using the
common gauge assumption ∇ · A = 0, simplify the equation for A in terms of J to the
scalar elliptic PDE:
1 ∂A ∂A
−∇ · ∇ A = J, where J = J x, y . For the 2-D case, B = ,− ,0 .
μ ∂y ∂x
3-169
3 Solving PDEs
boundary. This is equivalent to specifying the tangential value of the magnetic field H on
the boundary.
3-170
AC Power Electromagnetics Equations
∂H
∇×E= −μ
∂t
∂E
∇×H=ε +J
∂t
Here, E is the electric field, H is the magnetic field, and J is the current density. In the
absence of a current, you can eliminate H from the first set and E from the second set
and see that both fields satisfy wave equations with the wave speed εμ:
∂2 E
ΔE − εμ =0
∂t2
∂2 H
ΔH − εμ =0
∂t2
J = σE
∂E ∂2 E
ΔE − μσ − εμ 2 = 0
∂t ∂t
For time-harmonic fields, use the complex form of the equations, replacing E with
Ece jωt
For a plane, the electric field is Ec = 0, 0, Ec , J = 0, 0, Je jωt , and the magnetic field is
−1
H = Hx, Hy, 0 = ∇ × Ec
jμσ
3-171
3 Solving PDEs
1
−∇ · ∇Ec + jωσ − ω2ε Ec = 0
μ
The PDE Modeler app uses this equation when it is in the AC Power Electromagnetics
application mode . The equation is a complex Helmholtz equation that describes the
propagation of plane electromagnetic waves in imperfect dielectrics and good conductors
(σ » ωε). A complex permittivity εc can be defined as εc = ε ⁻ jσ/ω. The conditions at
material interfaces with abrupt changes of ε and µ are the natural conditions for the
variational formulation and need no special attention.
• The Dirichlet boundary condition specifying the value of the electric field Ec on the
boundary
• The Neumann boundary condition specifying the normal derivative of Ec, which is
equivalent to specifying the tangential component of the magnetic field H:
j 1
Ht = n · ∇Ec
ω μ
The solution is the electric field E. Using the solution, you can compute the current
density J = σE and the magnetic flux density
j
B= ∇×E
ω
Using the PDE Modeler app, you can plot the electric field E, the current density J, the
magnetic field H, and the magnetic flux density B. You also can plot the resistive heating
rate
Q = Ec2 /σ
You can plot the magnetic field and the magnetic flux density as vector fields by using
arrows.
References
[1] Popovic, B. D., Introductory Engineering Electromagnetics. Reading, MA: Addison-
Wesley, 1971.
3-172
DC Conduction
DC Conduction
The direct current conduction problems, such as electrolysis and computation of
resistances of grounding plates, involve a steady current passing through a conductive
medium. The current density J is related to the electric field E as J = σ E, where σ is the
conductivity of the medium. The electric field E is the gradient of the electric potential V,
E = –∇V. Thus, the continuity equation ∇ · J = Q, where Q is the current source, yields the
elliptic Poisson's equation:
–∇ · (σ ∇V) = Q.
The toolbox supports the following boundary conditions for DC conduction problems:
3-173
3 Solving PDEs
1
−∇ · ∇Ec + jωσ − ω2ε Ec = 0
μ
Due to induction, the current density in the interior of the conductor is smaller than at
the outer surface, where it is set to JS = 1. The Dirichlet condition for the electric field is
Ec = 1/σ. In this case, the analytical solution is
J0 kr
J = JS
J0 kR
Here,
k= jωμσ,
R is the radius of the wire, r is the distance from the center line, and J0(x) is the first
Bessel function of zeroth order.
To solve this problem in the PDE Modeler app, follow these steps:
1 Draw a circle with a radius of 0.1. The circle represents a cross section of the
conductor.
pdecirc(0,0.05,0.1)
3-174
Skin Effect in Copper Wire with Circular Cross Section: PDE Modeler App
2 Set the x-axis limit to [-0.2 0.2] and the y-axis limit to [-0.1 0.2]. To do this,
select Options > Axes Limits and set the corresponding ranges. Then select
Options > Axes Equal.
3 Set the application mode to AC Power Electromagnetics.
4 Specify the Dirichlet boundary condition E = JS/σ = 1/σ for the boundary of the circle.
To do this:
3-175
3 Solving PDEs
Due to the skin effect, the current density at the surface of the conductor is much
higher than in the conductor's interior.
9 Improve the accuracy of the solution close to the surface by using adaptive mesh
refinement. To do this:
3-176
Skin Effect in Copper Wire with Circular Cross Section: PDE Modeler App
12 These plots show the real part of the solution, but the solution vector is the full
complex solution. Plot the imaginary part of the solution. To do this:
3-177
3 Solving PDEs
c Select user entry from the Property drop-down menu for both Color and
Height(3-D plot) options.
d Type imag(u) in the corresponding User entry fields.
e Select Show Mesh to observe the mesh.
f
13 Observe that the skin effect depends on the frequency of the alternating current.
When you increase or decrease the frequency, the skin "depth" increases or
decreases, respectively. At high frequencies, only a thin layer on the surface of the
wire conducts the current. At very low frequencies (approaching DC conditions),
almost the entire cross section area of the wire conducts the current.
Find the solution for the angular frequencies omega = 2*pi*1000, omega =
2*pi*50, and omega = 1E-6. Plot the real parts of the solutions in 2-D.
3-178
Skin Effect in Copper Wire with Circular Cross Section: PDE Modeler App
3-179
3 Solving PDEs
3-180
Skin Effect in Copper Wire with Circular Cross Section: PDE Modeler App
3-181
3 Solving PDEs
–∇ · (σ∇V) = 0
∂V
=0
∂n
The conductivity is σ = 1.
To solve this equation in the PDE Modeler app, follow these steps:
1 Model the geometry: draw the rectangle with corners at (-1.2,-0.6), (1.2,-0.6),
(1.2,0.6), and (-1.2,0.6), and two circles with a radius of 0.3 and centers at (-0.6,0)
and (0.6,0). The rectangle represents the blotting paper, and the circles represent the
conductors.
• For the rectangle, use the Neumann boundary condition with g = 0 and q = 0.
• For the left circle, use the Dirichlet boundary condition with h = 1 and r = 1.
• For the right circle, use the Dirichlet boundary condition with h = 1 and r = -1.
3-182
Current Density Between Two Metallic Conductors: PDE Modeler App
5 Specify the coefficients by selecting PDE > PDE Specification or clicking the PDE
button on the toolbar. Specify sigma = 1 and q = 0.
6 Initialize the mesh by selecting Mesh > Initialize Mesh.
7 Refine the mesh by selecting Mesh > Refine Mesh.
8 Improve the triangle quality by selecting Mesh > Jiggle Mesh.
9 Solve the PDE by selecting Solve > Solve PDE or clicking the = button on the
toolbar. The resulting potential is zero along the y-axis, which, for this problem, is a
vertical line of antisymmetry.
3-183
3 Solving PDEs
The current flows, as expected, from the conductor with a positive potential to the
conductor with a negative potential. The conductivity σ is isotropic, and the
equipotential lines are orthogonal to the current lines.
3-184
Heat Transfer Between Two Squares Made of Different Materials: PDE Modeler App
The 2-D geometry for this problem is a square with an embedded diamond (a square with
45 degrees rotation). PDE governing this problem is a parabolic heat equation:
∂T
ρC − ∇ ⋅ k ∇T = Q + h Text − T
∂t
where ρ is the density, C is the heat capacity, k is the coefficient of heat conduction, Q is
the heat source, h is convective heat transfer coefficient, and Text is the external
temperature.
To solve this problem in the PDE Modeler app, follow these steps:
1 Model the geometry: draw the square region with corners in (0,0), (3,0), (3,3), and
(0,3) and the diamond-shaped region with corners in (1.5,0.5), (2.5,1.5), (1.5,2.5), and
(0.5,1.5).
pderect([0 3 0 3])
pdepoly([1.5 2.5 1.5 0.5],[0.5 1.5 2.5 1.5])
2 Set the x-axis limit to [-1.5 4.5] and y-axis limit to [-0.5 3.5]. To do this, select
Options > Axes Limits and set the corresponding ranges.
3 Set the application mode to Heat Transfer.
4 The temperature is kept at 0 on all the outer boundaries, so you do not have to
change the default Dirichlet boundary condition T = 0.
5 Specify the coefficients. To do this, select PDE > PDE Mode. Then click each region
and select PDE > PDE Specification or click the PDE button on the toolbar. Since
you are solving the parabolic heat equation, select the Parabolic type of PDE for
both regions. For the square region, specify the following coefficients:
• Density, pho = 2
• Heat capacity, C = 0.1
• Coefficient of heat conduction, k = 10
3-185
3 Solving PDEs
• Heat source, Q = 0
• Convective heat transfer coefficient, h = 0
• External temperature, Text = 0
• Density, pho = 1
• Heat capacity, C = 0.1
• Coefficient of heat conduction, k = 2
• Heat source, Q = 4
• Convective heat transfer coefficient, h = 0
• External temperature, Text = 0
6 Initialize the mesh by selecting Mesh > Initialize Mesh. For a more accurate
solution, refine the mesh by selecting Mesh > Refine Mesh.
7 Set the initial value and the solution time. To do this, select Solve > Parameters.
The dynamics for this problem is very fast — the temperature reaches steady state in
about 0.1 time units. To capture the interesting part of the dynamics, set time to
logspace(-2,-1,10). This gives 10 logarithmically spaced numbers between 0.01
and 0.1. Set the initial value of the temperature u(t0) to 0.
8 Solve the equation by selecting Solve > Solve PDE or clicking the = button on the
toolbar.
9 Plot the solution. By default, the app plots the temperature distribution at the last
time. The best way to visualize the dynamic behavior of the temperature is to animate
the solution. To do this, select Plot > Parameters and select the Animation and
Height (3-D plot) options to animate a 3-D plot. Also, you can select the Plot in x-y
grid option to use a rectangular grid instead of the default triangular grid. Using a
rectangular grid instead of a triangular grid speeds up the animation process
significantly.
You can also plot isothermal lines using a contour plot and the heat flux vector field
using arrows.
3-186
Heat Transfer Between Two Squares Made of Different Materials: PDE Modeler App
c Change the colormap to hot by using the corresponding drop-down menu in the
same dialog box.
d To obtain the first plot, select the Color and Contour options.
e For the second plot, select the Color and Arrows and set their values to
temperature and heat flux, respectively.
Isothermal Lines
3-187
3 Solving PDEs
3-188
Nonlinear Heat Transfer in Thin Plate
The plate is square and the temperature is fixed along the bottom edge. No heat is
transferred from the other three edges (i.e. they are insulated). Heat is transferred from
both the top and bottom faces of the plate by convection and radiation. Because radiation
is included, the problem is nonlinear. One of the purposes of this example is to show how
to handle nonlinearities in PDE problems.
Both a steady state and a transient analysis are performed. In a steady state analysis we
are interested in the final temperature at different points in the plate after it has reached
an equilibrium state. In a transient analysis we are interested in the temperature in the
plate as a function of time. One question that can be answered by this transient analysis
is how long does it take for the plate to reach an equilibrium temperature.
The plate has planar dimensions one meter by one meter and is 1 cm thick. Because the
plate is relatively thin compared with the planar dimensions, the temperature can be
assumed constant in the thickness direction; the resulting problem is 2D.
Convection and radiation heat transfer are assumed to take place between the two faces
of the plate and a specified ambient temperature.
The amount of heat transferred from each plate face per unit area due to convection is
defined as
Qc = hc(T − Ta)
The amount of heat transferred from each plate face per unit area due to radiation is
defined as
Qr = ϵσ(T 4 − Ta4)
where ϵ is the emissivity of the face and σ is the Stefan-Boltzmann constant. Because the
heat transferred due to radiation is proportional to the fourth power of the surface
temperature, the problem is nonlinear.
3-189
3 Solving PDEs
∂T
ρCptz − ktz ∇2 T + 2Qc + 2Qr = 0
∂t
where ρ is the material density, Cp is the specific heat, tz is the plate thickness, and the
factors of two account for the heat transfer from both plate faces.
∂T
ρCptz − ktz ∇2 T + 2hcT + 2ϵσT 4 = 2hcTa + 2ϵσTa4
∂t
Problem Setup
numberOfPDE = 1;
model = createpde(numberOfPDE);
For a square, the geometry and mesh are easily defined as shown below.
width = 1;
height = 1;
Define the square by giving the 4 x-locations followed by the 4 y-locations of the corners.
Convert the DECSG geometry into a geometry object on doing so it is appended to the
PDEModel
3-190
Nonlinear Heat Transfer in Thin Plate
geometryFromEdges(model,g);
Plot the geometry and display the edge labels for use in the boundary condition definition.
figure;
pdegplot(model,'EdgeLabels','on');
axis([-.1 1.1 -.1 1.1]);
title 'Geometry With Edge Labels Displayed';
Specify the coefficients. The expressions for the coefficients required by PDE Toolbox can
easily be identified by comparing the equation above with the scalar parabolic equation in
the PDE Toolbox documentation.
c = thick*k;
3-191
3 Solving PDEs
Because of the radiation boundary condition, the "a" coefficient is a function of the
temperature, u. It is defined as a MATLAB expression so it can be evaluated for different
values of u during the analysis.
Apply the boundary conditions. Three of the plate edges are insulated. Because a
Neumann boundary condition equal zero is the default in the finite element formulation,
the boundary conditions on these edges do not need to be set explicitly. A Dirichlet
condition is set on all nodes on the bottom edge, edge 1,
applyBoundaryCondition(model,'dirichlet','Edge',1,'u',1000);
setInitialConditions(model,0);
Create the triangular mesh on the square with approximately ten elements in each
direction.
3-192
Nonlinear Heat Transfer in Thin Plate
Because the a and f coefficients are functions of temperature (due to the radiation
boundary conditions), solvepde automatically picks the nonlinear solver to obtain the
solution.
R = solvepde(model);
u = R.NodalSolution;
figure;
pdeplot(model,'XYData',u,'Contour','on','ColorMap','jet');
title 'Temperature In The Plate, Steady State Solution'
xlabel 'X-coordinate, meters'
ylabel 'Y-coordinate, meters'
axis equal
3-193
3 Solving PDEs
p = msh.Nodes;
plotAlongY(p,u,0);
title 'Temperature As a Function of the Y-Coordinate'
xlabel 'Y-coordinate, meters'
ylabel 'Temperature, degrees-Kelvin'
3-194
Nonlinear Heat Transfer in Thin Plate
Transient Solution
3-195
3 Solving PDEs
u0(1:numNodes) = 300;
Set the initial temperature on the bottom edge E1 to the value of the constant BC, 1000
K.
setInitialConditions(model,1000,'edge',1);
model.SolverOptions.RelativeTolerance = 1.0e-3;
model.SolverOptions.AbsoluteTolerance = 1.0e-4;
Solve the problem by using solvepde. The solver automatically picks the parabolic solver
to obtain the solution.
R = solvepde(model,tlist);
u = R.NodalSolution;
figure;
plot(tlist,u(3, :));
grid on
title 'Temperature Along the Top Edge of the Plate as a Function of Time'
xlabel 'Time, seconds'
ylabel 'Temperature, degrees-Kelvin'
3-196
Nonlinear Heat Transfer in Thin Plate
figure;
pdeplot(model,'XYData',u(:,end),'Contour','on','ColorMap','jet');
title(sprintf('Temperature In The Plate, Transient Solution( %d seconds)\n', ...
tlist(1,end)));
xlabel 'X-coordinate, meters'
ylabel 'Y-coordinate, meters'
axis equal;
3-197
3 Solving PDEs
Summary
The plots of temperature in the plate from the steady state and transient solution at the
ending time are very close. That is, after around 5000 seconds, the transient solution has
reached the steady state values. The temperatures from the two solutions at the top edge
of the plate agree to within one percent.
3-198
Poisson's Equation on Unit Disk: PDE Modeler App
This example uses the PDE Modeler app. For a programmatic workflow, see “Poisson's
Equation on Unit Disk” on page 3-205. Because the app and the programmatic workflow
use different meshers, they yield slightly different results.
The problem formulation is –Δu = 1 in Ω, u = 0 on ∂Ω, where Ω is the unit disk. The exact
solution is
1 − x2 − y2
u x, y =
4
To solve this problem in the PDE Modeler app, follow these steps:
button. Then right-click the origin and drag to draw a circle. Right-clicking
constrains the shape you draw so that it is a circle rather than an ellipse. If the circle
is not a perfect unit circle, double-click it. In the resulting dialog box, specify the
exact center location and radius of the circle.
5 Check that the application mode is set to Generic Scalar.
6 Specify the boundary conditions. To do this, switch to boundary mode by clicking the
3-199
3 Solving PDEs
9
Initialize the mesh by selecting Mesh > Initialize Mesh or clicking the button.
10 Solve the PDE by selecting Solve > Solve PDE or clicking the = button on the
toolbar. The toolbox assembles the PDE problem, solves it, and plots the solution.
3-200
Poisson's Equation on Unit Disk: PDE Modeler App
3-201
3 Solving PDEs
12
Refine the mesh by selecting Mesh > Refine Mesh or clicking the button.
3-202
Poisson's Equation on Unit Disk: PDE Modeler App
13 Compare the numerical solution to the exact solution for the refined mesh. Plot the
absolute error.
3-203
3 Solving PDEs
14 Export the mesh data and the solution to the MATLAB workspace by selecting Mesh
> Export Mesh and Solve > Export Solution, respectively.
3-204
Poisson's Equation on Unit Disk
The Poisson equation on a unit disk with zero Dirichlet boundary condition can be written
as −Δu = 1 in Ω, u = 0 on δΩ, where Ω is the unit disk. The exact solution is
1 − x2 − y2
u(x, y) = .
4
For most PDEs, the exact solution is not known. However, the Poisson's equation on a unit
disk has a known, exact solution that you can use to see how the error decreases as you
refine the mesh.
Problem Definition
model = createpde();
geometryFromEdges(model,@circleg);
Plot the geometry and display the edge labels for use in the boundary condition definition.
figure
pdegplot(model,'EdgeLabels','on');
axis equal
3-205
3 Solving PDEs
3-206
Poisson's Equation on Unit Disk
pdemesh(model);
axis equal
results = solvepde(model);
u = results.NodalSolution;
pdeplot(model,'XYData',u)
title('Numerical Solution');
xlabel('x')
ylabel('y')
3-207
3 Solving PDEs
Compare this result with the exact analytical solution and plot the error.
p = model.Mesh.Nodes;
exact = (1 - p(1,:).^2 - p(2,:).^2)/4;
pdeplot(model,'XYData',u - exact')
title('Error');
xlabel('x')
ylabel('y')
3-208
Poisson's Equation on Unit Disk
Solve the equation while refining the mesh in each iteration and comparing the result
with the exact solution. Each refinement halves the Hmax value. Refine the mesh until the
−7
infinity norm of the error vector is less than 5 ⋅ 10 .
hmax = 0.1;
error = [];
err = 1;
while err > 5e-7 % run until error <= 5e-7
generateMesh(model,'Hmax',hmax); % refine mesh
results = solvepde(model);
u = results.NodalSolution;
p = model.Mesh.Nodes;
3-209
3 Solving PDEs
Plot the infinity norm of the error vector for each iteration. The value of the error
decreases in each iteration.
plot(error,'rx','MarkerSize',12);
ax = gca;
ax.XTick = 1:numel(error);
title('Error History');
xlabel('Iteration');
ylabel('Norm of Error');
3-210
Poisson's Equation on Unit Disk
figure
pdemesh(model);
axis equal
3-211
3 Solving PDEs
figure
pdeplot(model,'XYData',u)
title('Numerical Solution');
xlabel('x')
ylabel('y')
3-212
Poisson's Equation on Unit Disk
Compare the result with the exact analytical solution and plot the error.
p = model.Mesh.Nodes;
exact = (1 - p(1,:).^2 - p(2,:).^2)/4;
pdeplot(model,'XYData',u - exact')
title('Error');
xlabel('x')
ylabel('y')
3-213
3 Solving PDEs
3-214
Scattering Problem: PDE Modeler App
For this problem, assume an infinite horizontal membrane subjected to small vertical
displacements U. The membrane is fixed at the object boundary. The medium is
homogeneous, and the phase velocity (propagation speed) of a wave, α, is constant. The
wave equation is
∂2 U
− α2 ΔU = 0
∂t2
The solution U is the sum of the incident wave V and the reflected wave R:
U = V + R
When the illumination is harmonic in time, you can compute the field by solving a single
steady problem. Assume that the incident wave is a plane wave traveling in the –x
direction:
The reflected wave can be decomposed into spatial and time components:
R x, y, t = r x, y e−iωt
Now you can rewrite the wave equation as the Helmholtz equation for the spatial
component of the reflected wave with the wave number k = ω/α:
–Δr – k2 r = 0
The Dirichlet boundary condition for the boundary of the object is U = 0, or in terms of
the incident and reflected waves, R = -V. For the time-harmonic solution and the incident
wave traveling in the –x direction, you can write this boundary condition as follows:
r x, y = − e−ikx
The reflected wave R travels outward from the object. The condition at the outer
computational boundary must allow waves to pass without reflection. Such conditions are
3-215
3 Solving PDEs
∂R
+ αξ · ∇R = 0
∂t
This equation considers only the waves moving in the positive ξ-direction. Here, ξ is the
radial distance from the object. With the time-harmonic solution, this equation turns into
the generalized Neumann boundary condition
ξ · ∇r = ikr
To solve the scattering problem in the PDE Modeler app, follow these steps:
1 Open the PDE Modeler app by using the pdeModeler command.
2 Set the x-axis limit to [0.1 1.5] and the y-axis limit to [0 1]. To do this, select
Options > Axes Limits and set the corresponding ranges.
3 Display grid lines. To do this:
a Select Options > Grid Spacing and clear the Auto checkboxes.
b Enter X-axis linear spacing as 0.1:0.05:1.5 and Y-axis linear spacing as
0:0.05:1.
c Select Options > Grid.
4 Align new shapes to the grid lines by selecting Options > Snap.
5 Draw a square with sides of length 0.1 and a center in [0.8 0.5]. To do this, first
click the button. Then right-click the origin and drag to draw a square. Right-
clicking constrains the shape you draw so that it is a square rather than a rectangle.
If the square is not a perfect square, double-click it. In the resulting dialog box,
specify the exact location of the bottom left corner and the side length.
6 Rotate the square by 45 degrees. To do this, select Draw > Rotate... and enter 45 in
the resulting dialog box. The rotated square represents the illuminated object.
7 Draw a circle with a radius of 0.45 and a center in [0.8 0.5]. To do this, first click
the button. Then right-click the origin and drag to draw a circle. Right-clicking
constrains the shape you draw so that it is a circle rather than an ellipse. If the circle
is not a perfect unit circle, double-click it. In the resulting dialog box, specify the
exact center location and radius of the circle.
3-216
Scattering Problem: PDE Modeler App
• For the perimeter of the circle, the boundary condition is the Neumann boundary
condition with q = -ik, where the wave number k = 60 corresponds to a
wavelength of about 0.1 units. Enter g = 0 and q = -60*i.
• For the perimeter of the square, the boundary condition is the Dirichlet boundary
condition:
r = − v x, y = − eika ⋅ x
In this problem, because the reflected wave travels in the –x direction, the
boundary condition is r = –e–ikx. Enter h = 1 and r = -exp(-i*60*x).
11 Specify the coefficients by selecting PDE > PDE Specification or clicking the PDE
button on the toolbar. The Helmholtz equation is a wave equation, but in Partial
Differential Equation Toolbox you can treat it as an elliptic equation with a = -k2.
Specify c = 1, a = -3600, and f = 0.
12 Initialize the mesh by selecting Mesh > Initialize Mesh.
For sufficient accuracy, you need about 10 finite elements per wavelength. The outer
boundary must be located a few object diameters away from the object itself. Refine
the mesh by selecting Mesh > Refine Mesh. Refine the mesh two more times to
achieve the required resolution.
13 Solve the PDE by selecting Solve > Solve PDE or clicking the = button on the
toolbar.
The solution is complex. When plotting the solution, you get a warning message.
3-217
3 Solving PDEs
14 Plot the reflected waves. Change the colormap to jet by selecting Plot >
Parameters and then selecting jet from the Colormap drop-down menu.
a Export the mesh data and the solution to the MATLAB workspace by selecting
Mesh > Export Mesh and Solve > Export Solution, respectively.
b Enter the following commands in the MATLAB Command Window.
figure
maxu = max(abs(u));
m = 10;
for j = 1:m,
uu = real(exp(-j*2*pi/10*sqrt(-1))*u);
pdeplot(p,e,t,'XYData',uu,'ColorBar','off','Mesh','off');
3-218
Scattering Problem: PDE Modeler App
colormap(jet)
caxis([-maxu maxu]);
axis tight
ax = gca;
ax.DataAspectRatio = [1 1 1];
axis off
M(:,j) = getframe;
end
movie(M);
3-219
3 Solving PDEs
1
−∇ ⋅ ∇u = 0
2
1 + ∇u
− ∇ ⋅ (c ∇u) + au = f .
Therefore, for the minimal surface problem, the coefficients are as follows:
1
c= , a = 0, f = 0.
2
1 + ∇u
Because the coefficient c is a function of the solution u, the minimal surface problem is a
nonlinear elliptic problem.
To solve the minimal surface problem using the programmatic workflow, first create a
PDE model with a single dependent variable.
numberOfPDE = 1;
model = createpde(numberOfPDE);
Create the geometry and include it in the model. The circleg function represents this
geometry.
geometryFromEdges(model,@circleg);
pdegplot(model,'EdgeLabels','on');
axis equal
title 'Geometry with Edge Labels';
3-220
Minimal Surface Problem
a = 0;
f = 0;
cCoef = @(region,state) 1./sqrt(1+state.ux.^2 + state.uy.^2);
specifyCoefficients(model,'m',0,'d',0,'c',cCoef,'a',a,'f',f);
bcMatrix = @(region,~)region.x.^2;
applyBoundaryCondition(model,'dirichlet',...
'Edge',1:model.Geometry.NumEdges,...
'u',bcMatrix);
3-221
3 Solving PDEs
Generate a mesh.
generateMesh(model,'Hmax',0.1);
figure;
pdemesh(model);
axis equal
Solve the problem by using the solvepde function. Because the problem is nonlinear,
solvepde invokes a nonlinear solver. Observe the solver progress by setting the
SolverOptions.ReportStatistics property of the model to 'on'.
model.SolverOptions.ReportStatistics = 'on';
result = solvepde(model);
3-222
Minimal Surface Problem
u = result.NodalSolution;
3-223
3 Solving PDEs
3-224
Minimal Surface Problem: PDE Modeler App
1
−∇ ⋅ ∇u = 0
2
1 + ∇u
This example uses the PDE Modeler app. For the programmatic workflow, see “Minimal
Surface Problem” on page 3-220.
− ∇ ⋅ c ∇u + au = f
Therefore, for the minimal surface problem the coefficients are as follows:
1
c= , a = 0, f = 0
2
1 + ∇u
Because the coefficient c is a function of the solution u, the minimal surface problem is a
nonlinear elliptic problem.
To solve the minimal surface problem in the PDE Modeler app, follow these steps:
pdecirc([0 0 1])
2 Check that the application mode is set to Generic Scalar.
3 Specify the boundary conditions. To do this:
a
Switch to boundary mode by clicking the button or selecting Boundary
> Boundary Mode.
b Select all boundaries by selecting Edit > Select All.
c Select Boundary > Specify Boundary Conditions.
d Specify the Dirichlet boundary condition u = x2. To do this, specify h = 1, r =
x.^2.
3-225
3 Solving PDEs
4 Specify the coefficients by selecting PDE > PDE Specification or clicking the PDE
button on the toolbar. Specify c = 1./sqrt(1+ux.^2+uy.^2), a = 0, and f = 0.
5 Initialize the mesh by selecting Mesh > Initialize Mesh.
6 Refine the mesh by selecting Mesh > Refine Mesh.
7 Choose the nonlinear solver. To do this, select Solve > Parameters and check Use
nonlinear solver. Set the tolerance parameter to 0.001.
8 Solve the PDE by selecting Solve > Solve PDE or clicking the = button on the
toolbar.
9 Plot the solution in 3-D. To do this, select PlotParameters. In the resulting dialog
box, select Height (3-D plot).
3-226
Poisson's Equation with Point Source and Adaptive Mesh Refinement
−Δu = δ(x, y)
on the unit disk with zero Dirichlet boundary conditions. The exact solution expressed in
polar coordinates is
log(r)
u(r, θ) = ,
2π
By using adaptive mesh refinement, Partial Equation Toolbox™ can accurately find the
solution everywhere away from the origin.
Create a geometry and include it in the model. For more information, see the |circleg| and
|pdegeom| pages.
g = @circleg;
geometryFromEdges(model,g);
3-227
3 Solving PDEs
figure;
pdegplot(model,'EdgeLabels','on');
axis equal
title 'Geometry With Edge Labels Displayed';
Specify the zero solution at all four outer edges of the circle.
applyBoundaryCondition(model,'dirichlet','Edge',(1:4),'u',0);
adaptmesh solves elliptic PDEs using the adaptive mesh generation. The 'tripick'
parameter lets you specify a function that returns which triangles will be refined in the
next iteration. circlepick returns triangles with computed error estimates greater a
given tolerance. The tolerance is provided to circlepick using the 'par' parameter.
3-228
Poisson's Equation with Point Source and Adaptive Mesh Refinement
[u,p,e,t] = adaptmesh(g,model,c,a,f,'tripick','circlepick','maxt',2000,'par',1e-3);
figure;
pdemesh(p,e,t);
axis equal
3-229
3 Solving PDEs
x = p(1,:)';
y = p(2,:)';
r = sqrt(x.^2+y.^2);
uu = -log(r)/2/pi;
figure;
pdeplot(p,e,t,'XYData',u-uu,'ZData',u-uu,'Mesh','off');
3-230
Poisson's Equation with Point Source and Adaptive Mesh Refinement
figure;
pdeplot(p,e,t,'XYData',u,'ZData',u,'Mesh','off');
3-231
3 Solving PDEs
3-232
Heat Transfer in Block with Cavity: PDE Modeler App
Consider a block containing a rectangular crack or cavity. The left side of the block is
heated to 100 degrees centigrade. At the right side of the block, heat flows from the block
to the surrounding air at a constant rate, for example -10 W/m2. All the other boundaries
are insulated. The temperature in the block at the starting time t0 = 0 is 0 degrees. The
goal is to model the heat distribution during the first five seconds.
The PDE governing this problem is a parabolic heat equation. Partial Differential Equation
Toolbox solves the generic parabolic PDE of the form
∂u
d − ∇ ⋅ c ∇u + au = f
∂t
∂u
d − Δu = 0
∂t
To solve this problem in the PDE Modeler app, follow these steps:
pdeModeler
2 Model the geometry: draw a rectangle with corners (-0.5,-0.8), (0.5,-0.8), (0.5,0.8),
and (-0.5,0.8) and a rectangle with corners (-0.05,-0.4), (0.05,-0.4), (0.05,0.4), and
(-0.05,0.4). Draw the first rectangle by using the pderect function.
3-233
3 Solving PDEs
4 Set the x-axis limit to [-0.6 0.6] and y-axis limit to [-1 1]. To do this, select
Options > Axes Limits and set the corresponding ranges.
5 Select Options > Snap to align any new shape to the grid lines. Then draw the
rectangle with corners (-0.05,-0.4), (0.05,-0.4), (0.05,0.4), and (-0.05,0.4)
6 Model the geometry by entering R1-R2 in the Set formula field.
7 Check that the application mode is set to Generic Scalar.
8 Specify the boundary conditions. To do this, switch to the boundary mode by
selecting Boundary > Boundary Mode. Then select Boundary > Specify
Boundary Conditions and specify the Neumann boundary condition.
• For convenience, first specify the insulating Neumann boundary condition ∂u/∂n =
0 for all boundaries. To do this, select all boundaries by using Edit > Select All
and specify g = 0, q = 0.
• Specify the Dirichlet boundary condition u = 100 for the left side of the block. To
do this, specify h = 1, r = 100.
• Specify the Neumann boundary condition ∂u/∂n = –10 for the right side of the
block. To do this, specify g = -10, q = 0.
3-234
Heat Transfer in Block with Cavity: PDE Modeler App
9 Specify the coefficients by selecting PDE > PDE Specification or clicking the PDE
button on the toolbar. Heat equation is a parabolic equation, so select the Parabolic
type of PDE. Specify c = 1, a = 0, f = 0, and d = 1.
10 Initialize the mesh by selecting Mesh > Initialize Mesh. Refine the mesh by
selecting Mesh > Refine Mesh.
11 Set the initial value to 0, the solution time to 5 seconds, and compute the solution
every 0.5 seconds. To do this, select Solve > Parameters. In the Solve Parameters
dialog box, set time to 0:0.5:5, and u(t0) to 0.
12 Solve the PDE by selecting Solve > Solve PDE or clicking the = button on the
toolbar. The app solves the heat equation at 11 different times from 0 to 5 seconds
and displays the heat distribution at the end of the time span.
13 Plot isothermal lines using a contour plot and the heat flux vector field using arrows
and change the colormap to hot. To do this:
3-235
3 Solving PDEs
14 Use an animated plot to visualize the dynamic behavior of the temperature. For this,
select Plot > Parameters and then select the Animation option.
15 The temperature in the block rises very quickly. To improve the animation and focus
on the first second, change the list of times to the MATLAB expression
logspace(-2,0.5,20). To do this, select Solve > Parameters. In the Solve
Parameters dialog box, set time to logspace(-2,0.5,20).
3-236
Heat Transfer in Block with Cavity: PDE Modeler App
16 You can explore the solution by varying the parameters of the model and plotting the
results. For example, change the heat capacity coefficient d and the heat flow at the
right boundary to see how these parameters affect the heat distribution.
3-237
3 Solving PDEs
Consider a block containing a rectangular crack or cavity. The left side of the block is
heated to 100 degrees centigrade. At the right side of the block, heat flows from the block
to the surrounding air at a constant rate, for example −10W /m2. All the other boundaries
are insulated. The temperature in the block at the starting time t0 = 0 is 0 degrees. The
goal is to model the heat distribution during the first five seconds.
thermalmodel = createpde('thermal','transient');
geometryFromEdges(thermalmodel,@crackg);
pdegplot(thermalmodel,'EdgeLabels','on');
ylim([-1,1])
axis equal
3-238
Heat Transfer in Block with Cavity
thermalProperties(thermalmodel,'ThermalConductivity',1,...
'MassDensity',1,...
'SpecificHeat',1);
Set the boundary conditions to have the solution u equal to 20 on the left edge (edge 6),
and g equal to -10 on the right edge (edge 1). The boundary condition on edge 1
corresponds to constant heat flow to the exterior. The toolbox uses the default insulating
boundary condition for all other boundaries.
thermalBC(thermalmodel,'Edge',6,'Temperature',20);
thermalBC(thermalmodel,'Edge',1,'HeatFlux',-10);
3-239
3 Solving PDEs
thermalIC(thermalmodel,0);
tlist = 0:0.5:5;
generateMesh(thermalmodel);
thermalresults = solve(thermalmodel,tlist);
T = thermalresults.Temperature;
Compute the heat flux density. Plot the solution at t = 5.0 seconds with isothermal lines
using a contour plot, and plot the heat flux vector field using arrows.
[qx,qy] = evaluateHeatFlux(thermalresults);
pdeplot(thermalmodel,'XYData',T(:,end),'Contour','on',...
'FlowData',[qx(:,end),qy(:,end)],'ColorMap','hot')
3-240
Heat Transfer in Block with Cavity
3-241
3 Solving PDEs
The partial differential equation for transient conduction heat transfer is:
∂T
ρCp − ∇ ⋅ (k ∇T) = f
∂t
where T is the temperature, ρ is the material density, Cp is the specific heat, and k is the
thermal conductivity. f is the heat generated inside the body which is zero in this
example.
thermalmodelS = createpde('thermal','steadystate');
Create a 2-D geometry by drawing one rectangle the size of the block and a second
rectangle the size of the slot.
Subtract the second rectangle from the first to create the block with a slot.
g = decsg(gdm,'R1-R2',['R1'; 'R2']');
Convert the decsg format into a geometry object. Include the geometry in the model.
geometryFromEdges(thermalmodelS,g);
Plot the geometry with edge labels displayed. The edge labels will be used below in the
function for defining boundary conditions.
figure
pdegplot(thermalmodelS,'EdgeLabels','on');
3-242
Heat Transfer Problem with Temperature-Dependent Properties
Set the temperature on the left edge to 100 degrees. On the right edge, there is a
prescribed heat flux out of the block. The top and bottom edges and the edges inside the
cavity are all insulated, that is, no heat is transferred across these edges.
thermalBC(thermalmodelS,'Edge',6,'Temperature',100);
thermalBC(thermalmodelS,'Edge',1,'HeatFlux',-10);
Specify the thermal conductivity of the material. First, consider the constant thermal
conductivity, for example, equal one. Later, consider a case where the thermal
conductivity is a function of temperature.
3-243
3 Solving PDEs
thermalProperties(thermalmodelS,'ThermalConductivity',1);
3-244
Heat Transfer Problem with Temperature-Dependent Properties
pdeplot(thermalmodelS,'XYData',T,'Contour','on','ColorMap','hot');
axis equal
title 'Temperature, Steady State Solution'
thermalmodelT = createpde('thermal','transient');
3-245
3 Solving PDEs
g = decsg(gdm,'R1-R2',['R1'; 'R2']');
geometryFromEdges(thermalmodelT,g);
Specify thermal conductivity, mass density, and specific heat of the material.
thermalProperties(thermalmodelT,'ThermalConductivity',1,...
'MassDensity',1,...
'SpecificHeat',1);
Define boundary conditions. In the transient cases, the temperature on the left edge is
zero at time=0 and ramps to 100 degrees over .5 seconds. You can find the helper
function transientBCHeatedBlock under matlab/R20XXx/examples/pde/main.
thermalBC(thermalmodelT,'Edge',6,'Temperature',@transientBCHeatedBlock);
On the right edge, there is a prescribed heat flux out of the block.
thermalBC(thermalmodelT,'Edge',1,'HeatFlux',-10);
The top and bottom edges as well as the edges inside the cavity are all insulated, that is
no heat is transferred across these edges.
msh = generateMesh(thermalmodelT,'Hmax',0.2);
figure
pdeplot(thermalmodelT);
axis equal
title 'Block With Finite Element Mesh Displayed'
3-246
Heat Transfer Problem with Temperature-Dependent Properties
Calculate the transient solution. Perform a transient analysis from zero to five seconds.
The toolbox saves the solution every .1 seconds so that plots of the results as functions of
time can be created.
tlist = 0:.1:5;
thermalIC(thermalmodelT,0);
R = solve(thermalmodelT,tlist);
T = R.Temperature;
Two plots are useful in understanding the results from this transient analysis. The first is
a plot of the temperature at the final time. The second is a plot of the temperature at a
specific point in the block, in this case near the center of the right edge, as a function of
time. To identify a node near the center of the right edge, it is convenient to define this
short utility function.
3-247
3 Solving PDEs
Call this function to get a node near the center of the right edge.
The two plots are shown side-by-side in the figure below. The temperature distribution at
this time is very similar to that obtained from the steady-state solution above. At the right
edge, for times less than about one-half second, the temperature is less than zero. This is
because heat is leaving the block faster than it is arriving from the left edge. At times
greater than about three seconds, the temperature has essentially reached steady-state.
h = figure;
h.Position = [1 1 2 1].*h.Position;
subplot(1,2,1);
axis equal
pdeplot(thermalmodelT,'XYData',T(:,end),'Contour','on','ColorMap','hot');
axis equal
title 'Temperature, Final Time, Transient Solution'
subplot(1,2,2);
axis equal
plot(tlist, T(nid,:));
grid on
title 'Temperature at Right Edge as a Function of Time';
xlabel 'Time, seconds'
ylabel 'Temperature, degrees-Celsius'
3-248
Heat Transfer Problem with Temperature-Dependent Properties
It is not uncommon for material properties to be functions of the dependent variables. For
example, assume that the thermal conductivity is a simple linear function of temperature:
k = @(~,state) 0.3+0.003*state.u;
In this case, the variable u is the temperature. For this example, assume that the density
and specific heat are not functions of temperature.
thermalProperties(thermalmodelS,'ThermalConductivity',k);
Calculate the steady-state solution. Compared with the constant-conductivity case, the
temperature on the right-hand edge is lower. This is due to the lower conductivity in
regions with lower temperature.
R = solve(thermalmodelS);
T = R.Temperature;
figure
pdeplot(thermalmodelS,'XYData',T,'Contour','on','ColorMap','hot');
axis equal
title 'Temperature, Steady State Solution'
3-249
3 Solving PDEs
thermalProperties(thermalmodelT,'ThermalConductivity',k,...
'MassDensity',1,...
'SpecificHeat',1);
Use the same timespan tlist = 0:.1:5 as for the linear case.
thermalIC(thermalmodelT,0);
R = solve(thermalmodelT,tlist);
T = R.Temperature;
3-250
Heat Transfer Problem with Temperature-Dependent Properties
Plot the temperature at the final time step and the temperature at the right edge as a
function of time. The plot of temperature at the final time step is only slightly different
from the comparable plot from the linear analysis: temperature at the right edge is
slightly lower than the linear case. The plot of temperature as a function of time is
considerably different from the linear case. Because of the lower conductivity at lower
temperatures, the heat takes longer to reach the right edge of the block. In the linear
case, the temperature is essentially constant at around three seconds but for this
nonlinear case, the temperature curve is just beginning to flatten at five seconds.
h = figure;
h.Position = [1 1 2 1].*h.Position;
subplot(1,2,1);
axis equal
pdeplot(thermalmodelT,'XYData',T(:,end),'Contour','on','ColorMap','hot');
axis equal
title 'Temperature, Final Time, Transient Solution'
subplot(1,2,2);
axis equal
plot(tlist(1:size(T,2)), T(nid,:));
grid on
title 'Temperature at Right Edge as a Function of Time (Nonlinear)';
xlabel 'Time, seconds'
ylabel 'Temperature, degrees-Celsius'
3-251
3 Solving PDEs
The physical properties and geometry of this problem are described in Singh, Jain, and
Rizwan-uddin (see Reference), which also has an analytical solution for this problem. The
inner face of the sphere has a temperature of zero at all times. The outer hemisphere with
positive y value has a nonuniform heat flux defined by
2 2 2 2
qouter = θ (π − θ) ϕ (π − ϕ)
0 ≤ θ ≤ π, 0 ≤ ϕ ≤ π .
θ and ϕ are azimuthal and elevation angles of points in the sphere. Initially, the
temperature at all points in the sphere is zero.
thermalmodel = createpde('thermal','transient');
Create a multilayered sphere using the multisphere function. Assign the resulting
geometry to the thermal model. The sphere has three layers of material with a hollow
inner core.
gm = multisphere([1,2,4,6],'Void',[true,false,false,false]);
thermalmodel.Geometry = gm;
Plot the geometry and show the cell labels and face labels. Use a FaceAlpha of 0.25 so
that labels of the interior layers are visible.
figure('Position',[10,10,800,400]);
subplot(1,2,1)
pdegplot(thermalmodel,'FaceAlpha',0.25,'CellLabel','on')
title('Geometry with Cell Labels')
subplot(1,2,2)
pdegplot(thermalmodel,'FaceAlpha',0.25,'FaceLabel','on')
title('Geometry with Face Labels')
3-252
Heat Conduction in Multidomain Geometry with Nonuniform Heat Flux
Generate a mesh for the geometry. Choose a mesh size that is coarse enough to speed the
solution, but fine enough to represent the geometry reasonably accurately.
generateMesh(thermalmodel,'Hmax',1);
Specify the thermal conductivity, mass density, and specific heat for each layer of the
sphere. The material properties are dimensionless values, not given by realistic material
properties.
thermalProperties(thermalmodel,'Cell',1,'ThermalConductivity',1, ...
'MassDensity',1, ...
'SpecificHeat',1);
thermalProperties(thermalmodel,'Cell',2,'ThermalConductivity',2, ...
'MassDensity',1, ...
'SpecificHeat',0.5);
thermalProperties(thermalmodel,'Cell',3,'ThermalConductivity',4, ...
'MassDensity',1, ...
'SpecificHeat',4/9);
Specify boundary conditions. The innermost face has a temperature of zero at all times.
thermalBC(thermalmodel,'Face',1,'Temperature',0);
3-253
3 Solving PDEs
The outer surface of the sphere has an external heat flux. Use the functional form of
thermal boundary conditions to define the heat flux.
[phi,theta,~] = cart2sph(region.x,region.y,region.z);
Qflux = zeros(size(region.x));
end
[phi,theta,r] = meshgrid(linspace(0,2*pi),linspace(-pi/2,pi/2),6);
[x,y,z] = sph2cart(phi,theta,r);
region.x = x;
region.y = y;
region.z = z;
flux = externalHeatFlux(region,[]);
figure
surf(x,y,z,flux,'LineStyle','none')
axis equal
view(130,10)
colorbar
xlabel 'x'
ylabel 'y'
zlabel 'z'
title('External Flux')
3-254
Heat Conduction in Multidomain Geometry with Nonuniform Heat Flux
thermalBC(thermalmodel,'Face',4,'HeatFlux',@externalHeatFlux,'Vectorized','on');
thermalIC(thermalmodel,0);
tlist = [0,2,5:5:50];
R = solve(thermalmodel,tlist);
3-255
3 Solving PDEs
To plot contours at several times, with the contour levels being the same for all plots,
determine the range of temperatures in the solution. The minimum temperature is zero
because it is the boundary condition on the inner face of the sphere.
Tmin = 0;
Tmax = max(R.Temperature(:,end));
h = figure;
for i = 1:numel(tlist)
pdeplot3D(thermalmodel,'ColorMapData',R.Temperature(:,i))
caxis([Tmin,Tmax])
view(130,10)
title(['Temperature at Time ' num2str(tlist(i))]);
M(i) = getframe;
end
3-256
Heat Conduction in Multidomain Geometry with Nonuniform Heat Flux
To see a movie of the contours when running this example on your computer, execute the
following line:
movie(M,2)
Visualize the temperature contours on the cross-section. First, define a rectangular grid
of points on the y − z plane where x = 0.
[YG,ZG] = meshgrid(linspace(-6,6,100),linspace(-6,6,100));
XG = zeros(size(YG));
Interpolate the temperature at the grid points. Perform interpolation for several time
steps to observe the evolution of the temperature contours.
3-257
3 Solving PDEs
tIndex = [2,3,5,7,9,11];
varNames = {'Time_index','Time_step'};
index_step = table(tIndex.',tlist(tIndex).','VariableNames',varNames);
disp(index_step);
Time_index Time_step
__________ _________
2 2
3 5
5 15
7 25
9 35
11 45
TG = interpolateTemperature(R,XG,YG,ZG,tIndex);
t = linspace(0,2*pi);
ylayer1 = cos(t); zlayer1 = sin(t);
ylayer2 = 2*cos(t); zlayer2 = 2*sin(t);
ylayer3 = 4*cos(t); zlayer3 = 4*sin(t);
ylayer4 = 6*cos(t); zlayer4 = 6*sin(t);
Plot the contours in the range Tmin to Tmax for the time steps corresponding to the time
indices tIndex.
figure('Position',[10,10,1000,550]);
for i = 1:numel(tIndex)
subplot(2,3,i)
contour(YG,ZG,reshape(TG(:,i),size(YG)),'ShowText','on')
colorbar
title(['Temperature at Time ' num2str(tlist(tIndex(i)))]);
hold on
caxis([Tmin,Tmax])
axis equal
% Plot boundaries of spherical layers for reference.
plot(ylayer1,zlayer1,'k','LineWidth',1.5)
plot(ylayer2,zlayer2,'k','LineWidth',1.5)
plot(ylayer3,zlayer3,'k','LineWidth',1.5)
plot(ylayer4,zlayer4,'k','LineWidth',1.5)
end
3-258
Heat Conduction in Multidomain Geometry with Nonuniform Heat Flux
Reference
[1] Singh, Suneet, P. K. Jain, and Rizwan-uddin. "Analytical Solution for Three-
Dimensional, Unsteady Heat Conduction in a Multilayer Sphere." ASME. J. Heat Transfer.
138(10), 2016, pp. 101301-101301-11.
3-259
3 Solving PDEs
∂u
− Δu = 1
∂t
This equation is solved on a square domain with a discontinuous initial condition and zero
temperatures on the boundaries.
Plot the geometry and display the edge labels for use in the boundary condition definition.
figure
pdegplot(thermalmodel,'EdgeLabels','on','FaceLabels','on')
3-260
Inhomogeneous Heat Equation on Square Domain
thermalBC(thermalmodel,'Edge',1:4,'Temperature',0);
The discontinuous initial value is 1 inside the circle and zero outside. Specify zero initial
temperature everywhere.
thermalIC(thermalmodel,0);
3-261
3 Solving PDEs
thermalIC(thermalmodel,1,'Face',2);
msh = generateMesh(thermalmodel);
figure;
pdemesh(thermalmodel);
axis equal
nframes = 20;
tlist = linspace(0,0.1,nframes);
3-262
Inhomogeneous Heat Equation on Square Domain
thermalmodel.SolverOptions.ReportStatistics ='on';
result = solve(thermalmodel,tlist);
99 successful steps
0 failed attempts
200 function evaluations
1 partial derivatives
20 LU decompositions
199 solutions of linear systems
T = result.Temperature;
figure
Tmax = max(max(T));
Tmin = min(min(T));
for j = 1:nframes
pdeplot(thermalmodel,'XYData',T(:,j),'ZData',T(:,j));
caxis([Tmin Tmax]);
axis([-1 1 -1 1 0 1]);
Mv(j) = getframe;
end
3-263
3 Solving PDEs
3-264
Heat Distribution in Circular Cylindrical Rod
The model geometry, material properties, and boundary conditions must all be symmetric
about a single axis for this simplification from 3-D to 2-D to be appropriate. Because of
this symmetry, a cylindrical coordinate system is the most convenient form for defining
the partial differential equation. However, Partial Differential Equation Toolbox™ expects
the equations in a Cartesian system. One of the main goals of this example is to show how
to express the PDE defined in a cylindrical system in a Cartesian form that Partial
Differential Equation Toolbox™ can handle.
This particular example shows heat transfer in a rod with a circular cross section. There
is a heat source at the left end of the rod and a fixed temperature at the right end. The
outer surface of the rod exchanges heat with the environment due to convection. In
addition, heat is generated within the rod due to radioactive decay.
We would like to calculate the temperature in the rod as a function of time. The parabolic
equation describing heat transfer is
∂u
ρC − ∇ ⋅ (k ∇u) = q,
∂t
where ρ, C, are the density, specific heat, and thermal conductivity of the material,
respectively, u is the temperature, and q is the heat generated in the rod.
∂u 1 ∂ ∂u 1 ∂ ∂u ∂ ∂u
ρC − kr − 2 k − k = q,
∂t r ∂r ∂r r ∂θ ∂θ ∂z ∂z
where r, θ, and z are the three coordinate variables of the cylindrical system. Because the
problem is axisymmetric, ∂u/ ∂θ = 0 and after multiplying by r the equation can be
rewritten
∂u ∂ ∂u ∂ ∂u
rρC − kr − kr = rq .
∂t ∂r ∂r ∂z ∂z
The equation can be converted to the form supported by PDE Toolbox if r is defined as y
and z is defined as x. Rewriting the above equation gives
3-265
3 Solving PDEs
∂u
ρCy − ∇ ⋅ (ky ∇u) = qy .
∂t
In transient problems of this type it is often useful to first compute the steady state
solution-- the solution to the time-independent, elliptic equation. If the final time in the
transient analysis is sufficiently large, the transient solution at the final time should be
close to this steady state solution. This provides a valuable check on the accuracy of the
transient analysis.
The 2-D model is a rectangular strip whose y-dimension extends from the axis of
symmetry to the outer surface and x-dimension extends over the actual length of the rod
(from -1.5 m to 1.5 m). The geometry and mesh for this rectangular section are easily
defined by specifying the x and y locations of the four corners as shown below.
g = decsg([3 4 -1.5 1.5 1.5 -1.5 0 0 .2 .2]');
3-266
Heat Distribution in Circular Cylindrical Rod
internalHeatSource(thermalModelS,qFunc);
When defining boundary conditions below, it is necessary to know the edge numbers for
the boundary edges of the geometry. A convenient way to obtain these edge numbers is to
plot the geometry using pdegplot with option edgeLabels set to 'on'.
figure
pdegplot(thermalModelS,'EdgeLabels','on');
axis equal
xlim([-2 2]);
title 'Rod Section Geometry With Edge Labels Displayed';
Define the boundary conditions. Edge 1, which is the edge at y equal zero, is along the
axis of symmetry so there is no heat transferred in the direction normal to this edge. This
3-267
3 Solving PDEs
thermalBC(thermalModelS,'Edge',2,'Temperature',100);
generateMesh(thermalModelS,'Hmax',0.1);
figure;
pdeplot(thermalModelS);
axis equal
title 'Rod Section With Triangular Element Mesh'
3-268
Heat Distribution in Circular Cylindrical Rod
result = solve(thermalModelS);
T = result.Temperature;
figure;
pdeplot(thermalModelS,'XYData',T,'Contour','on');
axis equal
title 'Steady State Temperature';
3-269
3 Solving PDEs
Transient Solution
Create a thermal model for transient analysis, include the geometry, and mesh.
thermalModelT = createpde('thermal','transient');
generateMesh(thermalModelT,'Hmax',0.1);
For a transient analysis, specify the thermal conductivity, mass density, specific heat of
the material.
3-270
Heat Distribution in Circular Cylindrical Rod
thermalProperties(thermalModelT,'ThermalConductivity',kFunc,...
'MassDensity',rho,...
'SpecificHeat',cFunc);
internalHeatSource(thermalModelT,qFunc);
thermalBC(thermalModelT,'Edge',2,'Temperature',100);
thermalBC(thermalModelT,'Edge',3,...
'ConvectionCoefficient',outerCC,...
'AmbientTemperature',100);
thermalBC(thermalModelT,'Edge',4,'HeatFlux',leftHF);
Compute the transient solution for solution times from t = 0 to t = 20000 seconds. Initial
temperature in the rod is zero.
tfinal = 20000;
tlist = 0:100:tfinal;
thermalIC(thermalModelT,0);
thermalModelT.SolverOptions.ReportStatistics = 'on';
result = solve(thermalModelT,tlist);
T = result.Temperature;
figure;
pdeplot(thermalModelT,'XYData',T(:,end),'Contour','on');
axis equal
title(sprintf('Transient Temperature at Final Time (%g seconds)',tfinal));
3-271
3 Solving PDEs
The steady state solution and the transient solution at 20000 seconds are in close
agreement. This can be seen by comparing the two figures.
The third figure below shows the temperature at the left end of the rod as a function of
time. The outer surface of the rod is exposed to the environment with a constant
temperature of 100 degrees-C. Consequently, when the surface temperature of the rod is
less than 100, the rod is being heated by the environment and when greater than 100,
cooled. When the rod temperature is less than 100 degrees, the outer surface is slightly
warmer than the inner axis but when the temperature is around 100 degrees, the outer
surface becomes cooler than the interior of the rod.
Find nodes on the left end of the rod and on the center axis and outer surface using their
coordinate values.
3-272
Heat Distribution in Circular Cylindrical Rod
p = thermalModelT.Mesh.Nodes;
nodesLeftEnd = find(p(1,:) < -1.5+eps);
nodeCenter = nodesLeftEnd(p(2,nodesLeftEnd) < eps);
nodeOuter = nodesLeftEnd(p(2,nodesLeftEnd) > 0.2-eps);
figure;
plot(tlist,T(nodeCenter,:));
hold all
plot(tlist,T(nodeOuter,:),'--');
title 'Temperature at Left End as a Function of Time'
xlabel 'Time, seconds'
ylabel 'Temperature, degrees-C'
grid on;
legend('Center Axis','Outer Surface','Location','SouthEast');
3-273
3 Solving PDEs
3-274
Heat Distribution in Circular Cylindrical Rod: PDE Modeler App
Consider a cylindrical radioactive rod. Heat is continuously added at the left end of the
rod, while the right end is kept at a constant temperature. At the outer boundary, heat is
exchanged with the surroundings by transfer. At the same time, heat is uniformly
produced in the whole rod due to radioactive processes. Assuming that the initial
temperature is zero leads to the following equation:
∂u
ρC − ∇ · k ∇u = q
∂t
Here, ρ, C, and k are the density, thermal capacity, and thermal conductivity of the
material, u is the temperature, and q is the heat generated in the rod.
∂u 1 ∂ ∂u 1 ∂ ∂u ∂ ∂u
ρC − kr − 2 k − k =q
∂t r ∂r ∂r r ∂θ ∂θ ∂z ∂z
Here r, θ, and z are the three coordinate variables of the cylindrical system. Because the
problem is axisymmetric, ∂u/ ∂θ = 0.
This is a cylindrical problem, and Partial Differential Equation Toolbox requires equations
to be in Cartesian coordinates. To transform the equation to the Cartesian coordinates,
first multiply both sides of the equation by r:
∂u ∂ ∂u ∂ ∂u
ρrC − kr − kr = qr
∂t ∂r ∂r ∂z ∂z
∂u
ρyC − ∇ · ky ∇u = qy
∂t
3-275
3 Solving PDEs
To solve this problem in the PDE Modeler app, follow these steps:
1 Model the rod as a rectangle with corners in (-1.5,0), (1.5,0), (1.5,0.2), and (-1.5,0.2).
Here, the x-axis represents the z direction, and the y-axis represents the r direction.
pderect([-1.5,1.5,0,0.2])
2 Specify the boundary conditions. To do this, double-click the boundaries to open the
Boundary Condition dialog box. The PDE Modeler app requires boundary
conditions in a particular form. Thus, Neumann boundary conditions must be in the
form n · c ∇u + qu = g, and Dirichlet boundary conditions must be in the form
hu = r. Also, because both sides of the equation are multiplied by r = y, multiply
coefficients for the boundary conditions by y.
• For the left end, use the Neumann condition n · k ∇u = HF_lef t = 5000. Specify
g = 5000*y and q = 0.
• For the right end, use the Dirichlet condition u = T_right = 100. Specify h = 1
and r = 100.
• For the outer boundary, use the Neumann condition
n · k ∇u = h_outer T _outer − u = 50 100 − u . Specify g = 50*y*100 and q =
50*y.
• The cylinder axis r = 0 is not a boundary in the original problem, but in the 2-D
treatment it has become one. Use the artificial Neumann boundary condition for
the axis, n · k ∇u = 0. Specify g = 0 and q = 0.
3 Specify the coefficients by selecting PDE > PDE Specification or click the PDE
button on the toolbar. Heat equation is a parabolic equation, so select the Parabolic
type of PDE. Because both sides of the equation are multiplied by r = y, multiply the
coefficients by y and enter the following values: c = 40*y, a = 0, f = 20000*y,
and d = 7800*500*y.
3-276
Heat Distribution in Circular Cylindrical Rod: PDE Modeler App
3-277
3 Solving PDEs
You can explore the solution by varying the parameters of the model and plotting the
results. For example, you can:
• Show the solution when u does not depend on time, that is, the steady state solution.
To do this, open the PDE Specification dialog box, and change the PDE type to
Elliptic. The resulting steady state solution is in close agreement with the transient
solution at 20000 seconds.
• Show the steady state solution without cooling on the outer boundary: the heat
transfer coefficient is zero. To do this, set the Neumann boundary condition at the
outer boundary (the top side of the rectangle) to g = 0 and q = 0. The resulting plot
shows that the temperature rises to more than 2500 on the left end of the rod.
3-278
Wave Equation on Square Domain
∂2 u
− ∇ ⋅ ∇u = 0 .
∂t2
To express this in toolbox form, note that the solvepde function solves problems of the
form
∂2 u
m − ∇ ⋅ (c ∇u) + au = f .
∂t2
c = 1;
a = 0;
f = 0;
m = 1;
Solve the problem on a square domain. The squareg function describes this geometry.
Create a model object and include the geometry. Plot the geometry and view the edge
labels.
numberOfPDE = 1;
model = createpde(numberOfPDE);
geometryFromEdges(model,@squareg);
pdegplot(model,'EdgeLabels','on');
ylim([-1.1 1.1]);
axis equal
title 'Geometry With Edge Labels Displayed';
xlabel x
ylabel y
3-279
3 Solving PDEs
specifyCoefficients(model,'m',m,'d',0,'c',c,'a',a,'f',f);
Set zero Dirichlet boundary conditions on the left (edge 4) and right (edge 2) and zero
Neumann boundary conditions on the top (edge 1) and bottom (edge 3).
applyBoundaryCondition(model,'dirichlet','Edge',[2,4],'u',0);
applyBoundaryCondition(model,'neumann','Edge',([1 3]),'g',0);
generateMesh(model);
figure
3-280
Wave Equation on Square Domain
pdemesh(model);
ylim([-1.1 1.1]);
axis equal
xlabel x
ylabel y
• πx
u(x, 0) = arctan cos .
2
• ∂u πy
= 3sin(πx)exp sin .
∂t t=0 2
3-281
3 Solving PDEs
u0 = @(location) atan(cos(pi/2*location.x));
ut0 = @(location) 3*sin(pi*location.x).*exp(sin(pi/2*location.y));
setInitialConditions(model,u0,ut0);
This choice avoids putting energy into the higher vibration modes and permits a
reasonable time step size.
n = 31;
tlist = linspace(0,5,n);
model.SolverOptions.ReportStatistics ='on';
result = solvepde(model,tlist);
u = result.NodalSolution;
Create an animation to visualize the solution for all time steps. Keep a fixed vertical scale
by first calculating the maximum and minimum values of u over all times, and scale all
plots to use those z-axis limits.
figure
umax = max(max(u));
umin = min(min(u));
for i = 1:n
pdeplot(model,'XYData',u(:,i),'ZData',u(:,i),'ZStyle','continuous',...
'Mesh','off','XYGrid','on','ColorBar','off');
axis([-1 1 -1 1 umin umax]);
caxis([umin umax]);
xlabel x
ylabel y
zlabel u
M(i) = getframe;
end
3-282
Wave Equation on Square Domain
3-283
3 Solving PDEs
∂2 u
− Δu = 0
∂t2
To solve this problem in the PDE Modeler app, follow these steps:
1 Open the PDE Modeler app by using the pdeModeler command.
2 Display grid lines by selecting Options > Grid.
3 Align new shapes to the grid lines by selecting Options > Snap.
4 Draw a square with the corners at (-1,-1), (-1,1), (1,1), and (1,-1). To do this, first click
the button. Then click one of the corners using the right mouse button and
drag to draw a square. The right mouse button constrains the shape you draw to be a
square rather than a rectangle.
button or selecting Boundary > Boundary Mode. Select the left and right
boundaries. Then select Boundary > Specify Boundary Conditions and specify the
Dirichlet boundary condition u = 0. This boundary condition is the default one (h =
1, r = 0), so you do not need to change it.
For the bottom and top boundaries, set the Neumann boundary condition ∂u/∂n = 0.
To do this, set g = 0, q = 0.
7 Specify the coefficients by selecting PDEPDE Specification or clicking the PDE
button on the toolbar. Select the Hyperbolic type of PDE, and specify c = 1, a = 0,
f = 0, and d = 1.
3-284
Wave Equation on Square Domain: PDE Modeler App
8 Initialize the mesh by selecting Mesh > Initialize Mesh. Refine the mesh by
selecting Mesh > Refine Mesh.
9 Set the solution times. To do this, select Solve > Parameters. Create linearly spaced
time vector from 0 to 5 seconds by setting the solution time to linspace(0,5,31).
10 In the same dialog box, specify initial conditions for the wave equation. For a well-
behaved solution, the initial values must match the boundary conditions. If the initial
time is t = 0, then the following initial values that satisfy the boundary conditions:
atan(cos(pi/2*x)) for u(0) and 3*sin(pi*x).*exp(sin(pi/2*y)) for ∂u/∂t,
The inverse tangent function and exponential function introduce more modes into the
solution.
11 Solve the PDE by selecting Solve > Solve PDE or clicking the = button on the
toolbar. The app solves the heat equation at times from 0 to 5 seconds and displays
the result at the end of the time span.
3-285
3 Solving PDEs
3-286
Eigenvalues and Eigenmodes of L-Shaped Membrane
Create a model and include this geometry. The geometry of the L-shaped membrane is
described in the file lshapeg.
model = createpde();
geometryFromEdges(model,@lshapeg);
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
Specify the coefficients for the problem: d = 1 and c = 1. All other coefficients are equal
to zero.
specifyCoefficients(model,'m',0,'d',1,'c',1,'a',0,'f',0);
Set the interval [0 100] as the region for the eigenvalues in the solution.
r = [0 100];
generateMesh(model,'Hmax',0.05);
results = solvepdeeig(model,r);
3-287
3 Solving PDEs
length(results.Eigenvalues)
ans = 19
Plot the first eigenmode and compare it to the MATLAB's membrane function.
3-288
Eigenvalues and Eigenmodes of L-Shaped Membrane
u = results.Eigenvectors;
pdeplot(model,'XYData',u(:,1),'ZData',u(:,1));
figure
membrane(1,20,9,9)
3-289
3 Solving PDEs
Eigenvectors can be multiplied by any scalar and remain eigenvectors. This explains the
difference in scale that you see.
membrane can produce the first 12 eigenfunctions for the L-shaped membrane. Compare
the 12th eigenmodes.
figure
pdeplot(model,'XYData',u(:,12),'ZData',u(:,12));
3-290
Eigenvalues and Eigenmodes of L-Shaped Membrane
figure
membrane(12,20,9,9)
3-291
3 Solving PDEs
3-292
Eigenvalues and Eigenmodes of L-Shaped Membrane: PDE Modeler App
–Δu = λu
on the geometry of the L-shaped membrane. The boundary condition is the Dirichlet
condition u = 0. This example uses the PDE Modeler app. For a programmatic workflow,
see “Eigenvalues and Eigenmodes of L-Shaped Membrane” on page 3-287.
To solve this problem in the PDE Modeler app, follow these steps:
1 Draw a polygon with the corners (0,0), (–1,0), (–1,–1), (1,–1), (1,1), and (0,1) by using
the pdepoly function.
pdepoly([0,-1,-1,1,1,0],[0,0,-1,-1,1,1])
2 Check that the application mode is set to Generic Scalar.
3 Use the default Dirichlet boundary condition u = 0 for all boundaries. To verify it,
switch to boundary mode by selecting Boundary > Boundary Mode. Use Edit >
Select all to select all boundaries. Select Boundary > Specify Boundary
Conditions and verify that the boundary condition is the Dirichlet condition with h =
1, r = 0.
4 Specify the coefficients by selecting PDE > PDE Specification or clicking the PDE
button on the toolbar. This is an eigenvalue problem, so select the Eigenmodes type
of PDE. The general eigenvalue PDE is described by − ∇ ⋅ c ∇u + au = λdu. Thus, for
this problem, use the default coefficients c = 1, a = 0, and d = 1.
5 Specify the maximum edge size for the mesh by selecting Mesh > Parameters. Set
the maximum edge size value to 0.05.
6 Initialize the mesh by selecting Mesh > Initialize Mesh.
7 Specify the eigenvalue range by selecting Solve > Parameters. In the resulting
dialog box, use the default eigenvalue range [0 100].
8 Solve the PDE by selecting Solve > Solve PDE or clicking the = button on the
toolbar. By default, the app plots the first eigenfunction.
3-293
3 Solving PDEs
9 Plot other eigenfunctions by selecting Plot > Parameters and then selecting the
corresponding eigenvalue from the drop-down list at the bottom of the dialog box.
For example, plot the fifth eigenfunction in the specified range.
3-294
Eigenvalues and Eigenmodes of L-Shaped Membrane: PDE Modeler App
3-295
3 Solving PDEs
–Δu = λu
on an L-shaped membrane with a rounded inner corner. The boundary condition is the
Dirichlet condition u = 0.
To solve this problem in the PDE Modeler app, follow these steps:
1 Draw an L-shaped membrane as a polygon with the corners (0,0), (–1,0), (–1,–1), (1,–
1), (1,1), and (0,1) by using the pdepoly function.
pdecirc(-0.5,0.5,0.5,'C1')
pderect([-0.5 0 0.5 0],'SQ1')
3 Model the geometry with the rounded corner by entering P1+SQ1-C1 in the Set
formula field.
4 Check that the application mode is set to Generic Scalar.
5 Remove unnecessary subdomain borders by selecting Boundary > Remove All
Subdomain Borders.
6 Use the default Dirichlet boundary condition u = 0 for all boundaries. To check the
boundary condition, switch to boundary mode by selecting Boundary > Boundary
Mode. Use Edit > Select all to select all boundaries. Select Boundary > Specify
Boundary Conditions and verify that the boundary condition is the Dirichlet
condition with h = 1, r = 0.
7 Specify the coefficients by selecting PDE > PDE Specification or clicking the PDE
button on the toolbar. This is an eigenvalue problem, so select the Eigenmodes as
the type of PDE. The general eigenvalue PDE is described by − ∇ ⋅ c ∇u + au = λdu.
Thus, for this problem, use the default coefficients c = 1, a = 0, and d = 1.
8 Specify the maximum edge size for the mesh by selecting Mesh > Parameters. Set
the maximum edge size value to 0.05.
9 Initialize the mesh by selecting Mesh > Initialize Mesh.
3-296
L-Shaped Membrane with Rounded Corner: PDE Modeler App
10 Specify the eigenvalue range by selecting Solve > Parameters. In the resulting
dialog box, use the default eigenvalue range [0 100].
11 Solve the PDE by selecting Solve > Solve PDE or clicking the = button on the
toolbar. By default, the app plots the first eigenfunction as a color plot.
3-297
3 Solving PDEs
3-298
Eigenvalues and Eigenmodes of Square
The eigenvalue PDE problem is −Δu = λu. This example finds the eigenvalues smaller
than 10 and the corresponding eigenmodes.
Create a model. Import and plot the geometry. The geometry description file for this
problem is called squareg.m.
model = createpde();
geometryFromEdges(model,@squareg);
pdegplot(model,'EdgeLabels','on')
ylim([-1.5,1.5])
axis equal
3-299
3 Solving PDEs
Specify the zero Neumann boundary condition for the upper and lower boundary.
applyBoundaryCondition(model,'neumann','Edge',[1,3],'g',0,'q',0);
∂u 3
Specify the generalized Neumann condition − u = 0 for the right boundary.
∂n 4
applyBoundaryCondition(model,'neumann','Edge',2,'g',0,'q',-3/4);
The eigenvalue PDE coefficients for this problem are c = 1, a = 0, and d = 1. You can
enter the eigenvalue range r as the vector [-Inf 10].
3-300
Eigenvalues and Eigenmodes of Square
specifyCoefficients(model,'m',0,'d',1,'c',1,'a',0,'f',0);
r = [-Inf,10];
generateMesh(model,'Hmax',0.05);
results = solvepdeeig(model,r);
3-301
3 Solving PDEs
l = results.Eigenvalues
l = 5×1
-0.4146
2.0528
4.8019
7.2693
9.4550
u = results.Eigenvectors;
pdeplot(model,'XYData',u(:,1));
3-302
Eigenvalues and Eigenmodes of Square
pdeplot(model,'XYData',u(:,length(l)));
3-303
3 Solving PDEs
u(x, y) = f (x)g(y) .
The functions f and g are eigenfunctions in the x and y directions, respectively. In the x
direction, the first eigenmode is a slowly increasing exponential function. The higher
modes include sinusoids. In the y direction, the first eigenmode is a straight line
(constant), the second is half a cosine, the third is a full cosine, the fourth is one and a
half full cosines, etc. These eigenmodes in the y direction are associated with the
eigenvalues
π2 4π2 9π2
0, , , ,...
4 4 4
3-304
Eigenvalues and Eigenmodes of Square
Look at the difference between the first and the second eigenvalue compared to π2 /4:
ans = 1.6751e-07
Likewise, the fifth eigenmode is made up of the first eigenmode in the x direction and the
third eigenmode in the y direction. As expected, l(5)-l(1) is approximately equal to π2:
ans = 6.2135e-06
You can explore higher modes by increasing the search range to include eigenvalues
greater than 10.
3-305
3 Solving PDEs
The eigenvalue PDE problem is −Δu = λu. Find the eigenvalues smaller than 10 and the
corresponding eigenmodes.
To solve this problem in the PDE Modeler app, follow these steps:
1 Draw a square with the corners (-1,-1), (-1,1), (1,1), and (1,-1) by using the pderect
function.
pderect([-1 1 -1 1])
2 Check that the application mode is set to Generic Scalar.
3 Specify the boundary conditions. To do this, switch to the boundary mode by
selecting Boundary > Boundary Mode. Double-click the boundary to specify the
boundary condition.
• Specify the Dirichlet condition u = 0 for the left boundary. To do this, specify h =
1, r = 0.
• ∂u
Specify the Neumann condition = 0 for the upper and lower boundary. To do
∂n
this, specify g = 0, q = 0.
• ∂u 3
Specify the generalized Neumann condition − u = 0 for the right boundary.
∂n 4
To do this, specify g = 0, q = -3/4.
4 Specify the coefficients by selecting PDE > PDE Specification or clicking the PDE
button on the toolbar. This is a eigenvalue problem, so select the Eigenmodes type
of PDE. The general eigenvalue PDE is described by − ∇ ⋅ c ∇u + au = λdu. Thus, for
this problem, the coefficients are c = 1, a = 0, and d = 1.
5 Specify the maximum edge size for the mesh by selecting Mesh > Parameters. Set
the maximum edge size value to 0.05.
6 Initialize the mesh by selecting Mesh > Initialize Mesh.
7 Specify the eigenvalue range by selecting Solve > Parameters. In the resulting
dialog box, enter the eigenvalue range as the MATLAB vector [-Inf 10].
3-306
Eigenvalues and Eigenmodes of Square: PDE Modeler App
8 Solve the PDE by selecting Solve > Solve PDE or clicking the = button on the
toolbar. By default, the app plots the first eigenfunction.
9 Plot other eigenfunctions by selecting Plot > Parameters and then selecting the
corresponding eigenvalue from the drop-down list at the bottom of the dialog box.
For example, plot the last eigenfunction in the specified range.
3-307
3 Solving PDEs
10 Export the eigenfunctions and eigenvalues to the MATLAB workspace by using the
Solve > Export Solution.
3-308
Vibration of Circular Membrane
The calculation of vibration modes requires the solution of the eigenvalue partial
differential equation (PDE). In this example the solution of the eigenvalue problem is
performed using both the PDE Toolbox's solvepdeeig solver and the core MATLAB's
eigs eigensolver.
The main objective of this example is to show how eigs can be used with PDE Toolbox.
Generally, the eigenvalues calculated by solvepdeeig and eigs are practically identical.
However, sometimes, it is simply more convenient to use eigs than solvepdeeig. One
example of this is when it is desired to calculate a specified number of eigenvalues in the
vicinity of a user-specified target value. solvepdeeig requires that a lower and upper
bound surrounding this target value be specified. eigs requires only that the target
eigenvalue and the desired number of eigenvalues be specified.
numberOfPDE = 1;
model = createpde(numberOfPDE);
Create a geometry object and include it in the PDE model. The geometry is a circle.
radius = 2;
g = decsg([1 0 0 radius]','C1',('C1')');
geometryFromEdges(model,g);
figure;
pdegplot(model,'EdgeLabels','on');
axis equal
title 'Geometry With Edge Labels Displayed';
3-309
3 Solving PDEs
Specify the boundary conditions: the solution is zero at all four outer edges of the circle.
bOuter = applyBoundaryCondition(model,'dirichlet','Edge',(1:4),'u',0);
Generate a mesh.
generateMesh(model,'Hmax',0.2);
3-310
Vibration of Circular Membrane
Use assembleFEMatrices to calculate the global finite element mass and stiffness
matrices with boundary conditions imposed using nullspace approach.
FEMatrices = assembleFEMatrices(model,'nullspace');
K = FEMatrices.Kc;
B = FEMatrices.B;
M = FEMatrices.M;
Find the largest eigenvalue and its index in the eigenvalues vector.
[maxEigenvaluesEigs, maxIndex] = max(eigenvaluesEigs);
Transform the eigenvectors with constrained equations removed to the full eigenvector
including constrained equations.
eigenvectorsEigs = B*eigenvectorsEigs;
Solve the eigenvalue problem by using the solvepdeeig function. Set the range for
solvepdeeig to be slightly larger than the range from eigs.
r = [min(eigenvaluesEigs)*.99 max(eigenvaluesEigs)*1.01];
result = solvepdeeig(model,r);
eigenvectorsPde = result.Eigenvectors;
eigenvaluesPde = result.Eigenvalues;
3-311
3 Solving PDEs
As you can see, both functions calculate the same eigenvalues. For any eigenvalue, the
eigenvector can be multiplied by an arbitrary scalar. The eigs and solvepdeeig
functions choose a different arbitrary scalar for normalizing their eigenvectors as shown
in the figure below.
h = figure;
h.Position = [1 1 2 1].*h.Position;
subplot(1,2,1);
axis equal
pdeplot(model,'XYData', eigenvectorsEigs(:,maxIndex),'Contour','on');
title(sprintf('eigs eigenvector, eigenvalue: %12.4e', eigenvaluesEigs(maxIndex)));
xlabel('x');
ylabel('y');
subplot(1,2,2);
axis equal
pdeplot(model,'XYData',eigenvectorsPde(:,end),'Contour','on');
title(sprintf('solvepdeeig eigenvector, eigenvalue: %12.4e',eigenvaluesPde(end)));
xlabel('x');
ylabel('y');
3-312
Vibration of Circular Membrane
3-313
3 Solving PDEs
To quickly visualize a 2-D scalar PDE solution, use the pdeplot function. This function
lets you plot the solution without explicitly interpolating the solution. For example, solve
the scalar elliptic problem − ∇u = 1 on the L-shaped membrane with zero Dirichlet
boundary conditions and plot the solution.
Create the PDE model, 2-D geometry, and mesh. Specify boundary conditions and
coefficients. Solve the PDE problem.
model = createpde;
geometryFromEdges(model,@lshapeg);
applyBoundaryCondition(model,'dirichlet','edge',1:model.Geometry.NumEdges,'u',0);
c = 1;
a = 0;
f = 1;
specifyCoefficients(model,'m',0,'d',0,'c',c,'a',a,'f',f);
generateMesh(model);
results = solvepde(model);
u = results.NodalSolution;
pdeplot(model,'XYData',u,'ZData',u,'Mesh','on')
xlabel('x')
ylabel('y')
3-314
Plot 2-D Solutions and Their Gradients
To get a smoother solution surface, specify the maximum size of the mesh triangles by
using the Hmax argument. Then solve the PDE problem using this new mesh, and plot the
solution again.
generateMesh(model,'Hmax',0.05);
results = solvepde(model);
u = results.NodalSolution;
pdeplot(model,'XYData',u,'ZData',u,'Mesh','on')
xlabel('x')
ylabel('y')
3-315
3 Solving PDEs
Alternatively, you can interpolate the solution and, if needed, its gradient in separate
steps, and then plot the results by using MATLAB™ functions, such as surf, mesh,
quiver, and so on. For example, solve the same scalar elliptic problem −Δu = 1 on the L-
shaped membrane with zero Dirichlet boundary conditions. Interpolate the solution and
its gradient, and then plot the results.
Create the PDE model, 2-D geometry, and mesh. Specify boundary conditions and
coefficients. Solve the PDE problem.
model = createpde;
geometryFromEdges(model,@lshapeg);
applyBoundaryCondition(model,'dirichlet','edge',1:model.Geometry.NumEdges,'u',0);
3-316
Plot 2-D Solutions and Their Gradients
c = 1;
a = 0;
f = 1;
specifyCoefficients(model,'m',0,'d',0,'c',c,'a',a,'f',f);
generateMesh(model,'Hmax',0.05);
results = solvepde(model);
Interpolate the solution and its gradients to a dense grid from -1 to 1 in each direction.
v = linspace(-1,1,101);
[X,Y] = meshgrid(v);
querypoints = [X(:),Y(:)]';
uintrp = interpolateSolution(results,querypoints);
uintrp = reshape(uintrp,size(X));
mesh(X,Y,uintrp)
xlabel('x')
ylabel('y')
3-317
3 Solving PDEs
Interpolate gradients of the solution to the grid from -1 to 1 in each direction. Plot the
result using quiver.
[gradx,grady] = evaluateGradient(results,querypoints);
figure
quiver(X(:),Y(:),gradx,grady)
xlabel('x')
ylabel('y')
3-318
Plot 2-D Solutions and Their Gradients
Zoom in to see more details. For example, restrict the range to [-0.2,0.2] in each
direction.
3-319
3 Solving PDEs
figure
h1 = meshc(X,Y,uintrp);
set(h1,'FaceColor','g','EdgeColor','b')
xlabel('x')
ylabel('y')
alpha(0.5)
hold on
Z = -0.05*ones(size(X));
gradz = zeros(size(gradx));
h2 = quiver3(X(:),Y(:),Z(:),gradx,grady,gradz);
3-320
Plot 2-D Solutions and Their Gradients
set(h2,'Color','r')
axis([-0.2,0.2,-0.2,0.2])
figure
mesh(X,Y,uintrp)
xlabel('x')
ylabel('y')
alpha(0.25)
hold on
z = linspace(0,0.15,101);
Z = meshgrid(z);
3-321
3 Solving PDEs
surf(X,X,Z')
figure
xq = v;
yq = v;
uintrp = interpolateSolution(results,xq,yq);
plot3(xq,yq,uintrp)
grid on
3-322
Plot 2-D Solutions and Their Gradients
xlabel('x')
ylabel('y')
Interpolate gradients of the solution along the same line and add them to the solution
plot.
[gradx,grady] = evaluateGradient(results,xq,yq);
gradx = reshape(gradx,size(xq));
grady = reshape(grady,size(yq));
hold on
quiver(xq,yq,gradx,grady)
view([-20 -45 75])
3-323
3 Solving PDEs
3-324
Plot 3-D Solutions and Their Gradients
• Surface plot — Sometimes you want to examine the solution on the surface of the
geometry. For example, in a stress or strain calculation, the most interesting data can
appear on the geometry surface. For an example, see “Surface Plot” on page 3-325.
For a colored surface plot of a scalar solution, set the pdeplot3D colormapdata to
the solution u:
pdeplot3D(model,'ColorMapData',u)
• Plot on a 2-D slice — To examine the solution on the interior of the geometry, define a
2-D grid that intersects the geometry, and interpolate the solution onto the grid. For
examples, see “2-D Slices Through 3-D Geometry” on page 3-328 and “Contour Slices
Through 3-D Solution” on page 3-333. While these two examples show planar grid
slices, you can also slice on a curved grid.
• Streamline or quiver plots — Plot the gradient of the solution as streamlines or a
quiver. See “Plots of Gradients and Streamlines” on page 3-340.
• You can use any MATLAB plotting command to create 3-D plots. See “Techniques for
Visualizing Scalar Volume Data” (MATLAB) and “Visualizing Vector Volume Data”
(MATLAB).
Surface Plot
This example shows how to obtain a surface plot of a solution with 3-D geometry and N >
1.
Import a tetrahedral geometry to a model with N = 2 equations and view its faces.
model = createpde(2);
importGeometry(model,'Tetrahedron.stl');
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
view(-40,24)
3-325
3 Solving PDEs
Create coefficients for the problem, where f = [1;10] and c is a symmetric matrix in
6N form.
f = [1;10];
a = 0;
c = [2;0;4;1;3;8;1;0;2;1;2;4];
specifyCoefficients(model,'m',0,'d',0,'c',c,'a',a,'f',f);
3-326
Plot 3-D Solutions and Their Gradients
results = solvepde(model);
u = results.NodalSolution;
pdeplot3D(model,'ColorMapData',u(:,1))
view(-175,4)
title('u(1)')
figure
pdeplot3D(model,'ColorMapData',u(:,2))
3-327
3 Solving PDEs
view(-175,4)
title('u(2)')
The problem is
∂u
− Δu = f
∂t
3-328
Plot 3-D Solutions and Their Gradients
f x, y, z = 1 + y + 10z2
Define a function for the nonlinear f coefficient in the syntax as given in “f Coefficient for
specifyCoefficients” on page 2-79.
bcMatrix = 1+10*region.z.^2+region.y;
model = createpde;
g = importGeometry(model,'Plate10x10x1.stl');
pdegplot(g,'FaceLabels','on','FaceAlpha',0.5)
3-329
3 Solving PDEs
applyBoundaryCondition(model,'dirichlet','face',1:6,'u',0);
3-330
Plot 3-D Solutions and Their Gradients
Create a grid of (x,y,z) points, where x = 5, y ranges from 0 through 10, and z ranges
from 0 through 1. Interpolate the solution to these grid points and all times.
yy = 0:0.5:10;
zz = 0:0.25:1;
[YY,ZZ] = meshgrid(yy,zz);
XX = 5*ones(size(YY));
uintrp = interpolateSolution(results,XX,YY,ZZ,1:length(tlist));
The solution matrix uintrp has 11 columns, one for each time in tlist. Take the
interpolated solution for the second column, which corresponds to time 0.02.
usol = uintrp(:,2);
The elements of usol come from interpolating the solution to the XX, YY, and ZZ
matrices, which are each 5-by-21, corresponding to z-by-y variables. Reshape usol to
the same 5-by-21 size, and make a surface plot of the solution. Also make surface plots
corresponding to times 0.06, 0.10, and 0.20.
figure
usol = reshape(usol,size(XX));
subplot(2,2,1)
surf(usol)
title('t = 0.02')
zlim([0,1.5])
xlim([1,21])
ylim([1,5])
usol = uintrp(:,4);
usol = reshape(usol,size(XX));
subplot(2,2,2)
surf(usol)
title('t = 0.06')
zlim([0,1.5])
3-331
3 Solving PDEs
xlim([1,21])
ylim([1,5])
usol = uintrp(:,6);
usol = reshape(usol,size(XX));
subplot(2,2,3)
surf(usol)
title('t = 0.10')
zlim([0,1.5])
xlim([1,21])
ylim([1,5])
usol = uintrp(:,11);
usol = reshape(usol,size(XX));
subplot(2,2,4)
surf(usol)
title('t = 0.20')
zlim([0,1.5])
xlim([1,21])
ylim([1,5])
3-332
Plot 3-D Solutions and Their Gradients
The problem is to solve Poisson's equation with zero Dirichlet boundary conditions for a
complicated geometry. Poisson's equation is
− ∇ ⋅ ∇u = f .
3-333
3 Solving PDEs
− ∇ ⋅ ∇(cu) + au = f .
So you can represent the problem by setting c = 1 and a = 0. Arbitrarily set f = 10.
c = 1;
a = 0;
f = 10;
The first step in solving any 3-D PDE problem is to create a PDE Model. This is a
container that holds the number of equations, geometry, mesh, and boundary conditions
for your PDE. Create the model, then import the 'ForearmLink.stl' file and view the
geometry.
N = 1;
model = createpde(N);
importGeometry(model,'ForearmLink.stl');
pdegplot(model,'FaceAlpha',0.5)
view(-42,24)
3-334
Plot 3-D Solutions and Their Gradients
specifyCoefficients(model,'m',0,'d',0,'c',c,'a',a,'f',f);
applyBoundaryCondition(model,'dirichlet','Face',1:model.Geometry.NumFaces,'u',0);
generateMesh(model);
result = solvepde(model);
3-335
3 Solving PDEs
Because the boundary conditions are u = 0 on all faces, the solution u is nonzero only in
the interior. To examine the interior, take a rectangular grid that covers the geometry
with a spacing of one unit in each coordinate direction.
[X,Y,Z] = meshgrid(0:135,0:35,0:61);
For plotting and analysis, create a PDEResults object from the solution. Interpolate the
result at every grid point.
V = interpolateSolution(result,X,Y,Z);
V = reshape(V,size(X));
figure
colormap jet
contourslice(X,Y,Z,V,[],[],0:5:60)
xlabel('x')
ylabel('y')
zlabel('z')
colorbar
view(-11,14)
axis equal
3-336
Plot 3-D Solutions and Their Gradients
figure
colormap jet
contourslice(X,Y,Z,V,[],1:6:31,[])
xlabel('x')
ylabel('y')
zlabel('z')
colorbar
view(-62,34)
axis equal
3-337
3 Solving PDEs
For large problems you can run out of memory when creating a fine 3-D grid.
Furthermore, it can be time-consuming to evaluate the solution on a full grid. To save
memory and time, evaluate only at the points you plot. You can also use this technique to
interpolate to tilted grids, or to other surfaces.
For example, interpolate the solution to a grid on the tilted plane 0 ≤ x ≤ 135, 0 ≤ y ≤ 35,
and z = x/10 + y/2. Plot both contours and colored surface data. Use a fine grid, with
spacing 0.2.
[X,Y] = meshgrid(0:0.2:135,0:0.2:35);
Z = X/10 + Y/2;
V = interpolateSolution(result,X,Y,Z);
3-338
Plot 3-D Solutions and Their Gradients
V = reshape(V,size(X));
figure
subplot(2,1,1)
contour(X,Y,V);
axis equal
title('Contour Plot on Tilted Plane')
xlabel('x')
ylabel('y')
colorbar
subplot(2,1,2)
surf(X,Y,V,'LineStyle','none');
axis equal
view(0,90)
title('Colored Plot on Tilted Plane')
xlabel('x')
ylabel('y')
colorbar
3-339
3 Solving PDEs
The problem is the calculation of the mean exit time of a Brownian particle from a region
that contains absorbing (escape) boundaries and reflecting boundaries. For more
information, see Narrow escape problem. The PDE is Poisson's equation with constant
coefficients. The geometry is a simple rectangular solid. The solution u(x, y, z) represents
the mean time it takes a particle starting at position (x, y, z) to exit the region.
3-340
Plot 3-D Solutions and Their Gradients
model = createpde;
importGeometry(model,'Block.stl');
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
view(-42,24)
Set faces 1, 2, and 5 to be the places where the particle can escape. On these faces, the
solution u = 0. Keep the default reflecting boundary conditions on faces 3, 4, and 6.
applyBoundaryCondition(model,'dirichlet','Face',[1,2,5],'u',0);
3-341
3 Solving PDEs
The PDE is
−Δu = − ∇ ⋅ ∇u = 2
− ∇ ⋅ c ∇u + au = f
c = 1;
a = 0;
f = 2;
specifyCoefficients(model,'m',0,'d',0,'c',c','a',a,'f',f);
generateMesh(model);
results = solvepde(model);
[X,Y,Z] = meshgrid(0:135,0:35,0:61);
V = interpolateSolution(results,X,Y,Z);
V = reshape(V,size(X));
Create a contour slice plot for five fixed values of the y-coordinate.
figure
colormap jet
contourslice(X,Y,Z,V,[],0:4:16,[])
xlabel('x')
ylabel('y')
zlabel('z')
xlim([0,100])
ylim([0,20])
3-342
Plot 3-D Solutions and Their Gradients
zlim([0,50])
axis equal
view(-50,22)
colorbar
The particle has the largest mean exit time near the point x, y, z = 100, 0, 0 .
Examine the solution in more detail by evaluating the gradient of the solution. Use a
rather coarse mesh so that you can see the details on the quiver and streamline plots.
[X,Y,Z] = meshgrid(1:9:99,1:3:20,1:6:50);
[gradx,grady,gradz] = evaluateGradient(results,X,Y,Z);
3-343
3 Solving PDEs
Plot the gradient vectors. First reshape the approximate gradients to the shape of the
mesh.
gradx = reshape(gradx,size(X));
grady = reshape(grady,size(Y));
gradz = reshape(gradz,size(Z));
figure
quiver3(X,Y,Z,gradx,grady,gradz)
axis equal
xlabel 'x'
ylabel 'y'
zlabel 'z'
title('Quiver Plot of Estimated Gradient of Solution')
3-344
Plot 3-D Solutions and Their Gradients
Plot the streamlines of the approximate gradient. Start the streamlines from a sparser set
of initial points.
hold on
[sx,sy,sz] = meshgrid([1,46],1:6:20,1:12:50);
streamline(X,Y,Z,gradx,grady,gradz,sx,sy,sz)
title('Quiver Plot with Streamlines')
hold off
The streamlines show that small values of y and z give larger mean exit times. They also
show that the x-coordinate has a significant effect on u when x is small, but when x is
3-345
3 Solving PDEs
greater than 40, the larger values have little effect on u. Similarly, when z is less than 20,
its values have little effect on u.
See Also
Related Examples
• “Solve Problems Using PDEModel Objects” on page 2-3
3-346
Dimensions of Solutions, Gradients, and Fluxes
Note solvepde does not compute components of flux of a PDE solution. To compute flux
of the solution at the mesh nodes, use evaluateCGradient.
The dimensions of the solution, its gradient, and flux of the solution depend on:
• For results returned by solvepde, this is the number of solution times (specified
as an input to solvepde).
• For results returned by solvepdeeig, this is the number of eigenvalues.
• For results returned by interpolateSolution, evaluateGradient, and
evaluateCGradient, this is the number of query times for time-dependent
problems or query modes for eigenvalue problems.
3-347
3 Solving PDEs
Node Indices
u2 u2 (t1 ) u2 (t2 ) L u2 (tNt )
M M M O M
uNp uNp (t1 ) uNp (t2 ) L uNp (tNt )
Time-Dependent or Eigenvalue
Stationary System System
s
ce
Node Iindices
11 1
di
2 N
uNp2(t2 ) uNp (t2 )N L uNp (t2 )
In
u12 (t1 ) u2 (t1 ) L u2 (t1 )
e
od
M
M M O M or
e
u1Np (t1 ) 2 N
m
Equation Number
3-348
Dimensions of Solutions, Gradients, and Fluxes
Suppose you also compute the solution, its gradient, or flux of the solution at other points
("query points") in the geometry by using interpolateSolution, evaluateGradient,
or evaluateCGradient, respectively. Here:
The tables show how to index into the solution returned by solvepde or solvepdeeig,
where:
The tables also show the dimensions of solutions, gradients, and flux of the solution at
nodal locations (returned by solvepde,solvepdeeig, and evaluateCGradient) and
the dimensions of interpolated solutions and gradients (returned by
interpolateSolution, evaluateGradient, and evaluateCGradient).
result.XGradients(iP)
result.YGradients(iP)
result.ZGradients(iP)
3-349
3 Solving PDEs
result.YGradients(iP,iN)
result.ZGradients(iP,iN)
result.XGradients(iP,iT)
result.YGradients(iP,iT)
result.ZGradients(iP,iT)
System, result.NodalSolution(iP,iN,i Np-by-N-by-Nt Nqp-by-Nq-by-Nqt
N>1 T)
result.XGradients(iP,iN,iT)
result.YGradients(iP,iN,iT)
result.ZGradients(iP,iN,iT)
3-350
See Also
See Also
EigenResults | StationaryResults | TimeDependentResults |
evaluateGradient | interpolateSolution | solvepde | solvepdeeig
3-351
4
You open the PDE Modeler app by entering pdeModeler at the command line. The main
components of the PDE Modeler app are the menus, the dialog boxes, and the toolbar.
Use Commands
• To open a blank PDE Modeler app window, type pdeModeler in the MATLAB
Command Window.
• To open the PDE Modeler app with a circle already drawn in it, type pdecirc in the
MATLAB Command Window.
• To open the PDE Modeler app with an ellipse already drawn in it, type pdeellip in
the MATLAB Command Window.
• To open the PDE Modeler app with a rectangle already drawn in it, type pderect in
the MATLAB Command Window.
• To open the PDE Modeler app with a polygon already drawn in it, type pdepoly in the
MATLAB Command Window.
You can use a sequence of drawing commands to create several basic shapes. For
example, the following commands create a circle, a rectangle, an ellipse, and a polygon:
pderect([-1.5,0,-1,0])
pdecirc(0,0,1)
pdepoly([-1,0,0,1,1,-1],[0,0,1,1,-1,-1])
pdeellip(0,0,1,0.3,pi)
4-2
2-D Geometry Creation in PDE Modeler App
Using the left mouse button, drag to create a rectangle. Using the right mouse
button (or Ctrl+click), drag to create a square.
Draw a rectangle/square starting at the center.
Using the left mouse button, drag to create a rectangle. Using the right mouse
button (or Ctrl+click), drag to create a square.
Draw an ellipse/circle starting at the perimeter.
Using the left mouse button, drag to create an ellipse. Using the right mouse
button (or Ctrl+click), drag to create a circle.
Draw an ellipse/circle starting at the center.
Using the left mouse button, drag to create an ellipse. Using the right mouse
button (or Ctrl+click), drag to create a circle.
Draw a polygon.
Using the left mouse button, drag to create polygon edges. You can close the
polygon by pressing the right mouse button. Clicking at the starting vertex also
closes the polygon.
Alternatively, you can create a basic shape by typing one of the following commands in
the MATLAB Command Window:
4-3
4 PDE Modeler App
These commands open the PDE Modeler app with the requested shape already drawn in
it. If the app is already open, these commands add the requested shape to the app
window without deleting any existing shapes.
You can use a sequence of drawing commands to create several basic shapes. For
example, these commands create a circle, a rectangle, an ellipse, and a polygon:
pderect([-1.5,0,-1,0])
pdecirc(0,0,1)
pdepoly([-1,0,0,1,1,-1],[0,0,1,1,-1,-1])
pdeellip(0,0,1,0.3,pi)
Rotate Shapes
To rotate a shape:
4-4
2-D Geometry Creation in PDE Modeler App
4 By default, the rotation center is the center-of-mass of the selected shapes. To use a
different rotation center, clear the Use center-of-mass option and enter a rotation
center (xc,yc) as a 1-by-2 vector, for example, [-0.4 0.3].
The app assigns a unique name to each shape. The names depend on the type of the
shape:
• For circles, the default names are C1, C2, C3, and so on.
• For ellipses, the default names are E1, E2, E3, and so on.
• For polygons, the default names are P1, P2, P3, and so on.
• For rectangles, the default names are R1, R2, R3, and so on.
• For squares, the default names are SQ1, SQ2, SQ3, and so on.
To change the name and parameters of a shape, first switch to the draw mode and then
double-click the shape. (Select Draw Mode from the Draw menu to switch to the draw
mode.) The resulting dialog box lets you change the name and parameters of the selected
shape. The name cannot contain spaces.
4-5
4 PDE Modeler App
Now you can combine basic shapes to create a complex geometry. To do this, use the Set
formula field located under the toolbar. Here you can specify a geometry by using the
names of basic shapes and the following operators:
For example, SQ1+C2 creates a geometry comprised of all points of the square SQ1
and all points of the circle C2.
• * is the set intersection operator.
For example, SQ1*C2 creates a geometry comprised of the points that belong to both
the square SQ1 and the circle C2.
• - is the set difference operator.
For example, SQ1-C2 creates a geometry comprised of the points of the square SQ1
that do not belong to the circle C2.
The operators + and * have the same precedence. The operator - has a higher
precedence. You can control the precedence by using parentheses. The resulting
geometrical model (called decomposed geometry) is the set of points for which the set
formula evaluates to true. By default, it is the union of all basic shapes.
4-6
2-D Geometry Creation in PDE Modeler App
To add axis grid, the snap-to-grid feature, and zoom, use the Options menu. To adjust the
grid spacing:
4-7
4 PDE Modeler App
• Specify the grid spacing for the x-axis and y-axis. For example, change the default
linear spacing -1.5:0.5:1.5 to -1:0.2:1.
You also can add extra ticks to customize the grid and aid in drawing. To separate
extra tick entries, use spaces, commas, semicolons, or brackets.
4-8
2-D Geometry Creation in PDE Modeler App
4-9
4 PDE Modeler App
4-10
2-D Geometry Creation in PDE Modeler App
4 Set the grid spacing for x-axis to -1.5:0.1:1.5 and for y-axis to -1:0.1:1. To do
this, select Options > Grid Spacing, clear the Auto checkboxes, and set the
corresponding ranges.
5 Draw a rectangle with the width 2, the height 1, and the top left corner at (–1,0.5). To
do this, first click the button. Then click the point (–1,0.5) and drag to draw a
rectangle.
To edit the parameters of the rectangle, double-click it. In the resulting dialog box,
specify the exact parameters.
6 Draw four circles with the radius 0.2 and the centers at (–0.8,–0.3), (–0.8,0.3), (0.8,–
0.3), and (0.8,0.3).To do this, first click the button. Then click the center of a
circle using the right mouse button and drag to draw a circle. The right mouse button
constrains the shape you draw to be a circle rather than an ellipse. If the circle is not
a perfect unit circle, then double-click it. In the resulting dialog box, specify the exact
center location and radius of the circle.
7 Add four squares with the side 0.2, one in each corner.
4-11
4 PDE Modeler App
8 Model the geometry with rounded corners by subtracting the small squares from the
rectangle, and then adding the circles. To do this, enter the following formula in the
Set formula field.
R1-(SQ1+SQ2+SQ3+SQ4)+C1+C2+C3+C4
9
Switch to the boundary mode by clicking the button or selecting Boundary >
Boundary Mode. The CSG model is now decomposed using the set formula, and you
get a rectangle with rounded corners.
4-12
2-D Geometry Creation in PDE Modeler App
10 Because of the intersection of the solid objects used in the initial CSG model, a
number of subdomain borders remain. They appear as gray lines. To remove these
borders, select Boundary > Remove All Subdomain Borders.
4-13
4 PDE Modeler App
4-14
Specify Boundary Conditions in the PDE Modeler App
Select Boundary Mode from the Boundary menu or click the button. Then
select a boundary or multiple boundaries for which you are specifying the conditions.
Note that no if you do not select any boundaries, then the specified conditions apply to all
boundaries.
Specify Boundary Conditions opens a dialog box where you can specify the boundary
condition for the selected boundary segments. There are three different condition types:
n · c ∇u + qu = g .
4-15
4 PDE Modeler App
The following figure shows the dialog box for the generic system PDE (Options >
Application > Generic System).
For boundary condition entries you can use the following variables in a valid MATLAB
expression:
4-16
Specify Boundary Conditions in the PDE Modeler App
• The solution u.
• The time t.
Note If the boundary condition is a function of the solution u, you must use the nonlinear
solver. If the boundary condition is a function of the time t, you must choose a parabolic
or hyperbolic PDE.
4-17
4 PDE Modeler App
• x — x-coordinate
• y — y-coordinate
• u — Solution of equation
• ux — Derivative of u in the x-direction
• uy — Derivative of u in the y-direction
• t — Time (parabolic and hyperbolic equations)
• sd — Subdomain number
For elliptic problems, when you include u, ux, or uy, you must use the nonlinear solver.
Select Solve > Parameters > Use nonlinear solver.
4-18
Specify Coefficients in PDE Modeler App
Note
• Do not use quotes or unnecessary spaces in your entries. The parser can misinterpret
a space as a vector separator, as when a MATLAB vector uses a space to separate
elements of a vector.
• Use .*, ./, and .^ for multiplication, division, and exponentiation operations. The text
expressions operate on row vectors, so the operations must make sense for row
vectors. The row vectors are the values at the triangle centroids in the mesh.
You can write MATLAB functions for coefficients as well as plain text expressions. For
example, suppose your coefficient f is given by the file fcoeff.m.
function f = fcoeff(x,y,t,sd)
The coefficient c is a 2-by-2 matrix. You can give 1-, 2-, 3-, or 4-element matrix
expressions. Separate the expressions for elements by spaces. These expressions mean:
• c 0
1-element expression:
0 c
• c(1) 0
2-element expression:
0 c(2)
4-19
4 PDE Modeler App
• c(1) c(2)
3-element expression:
c(2) c(3)
• c(1) c(3)
4-element expression:
c(2) c(4)
For example, c is a symmetric matrix with constant diagonal entries and cos(xy) as the
off-diagonal terms:
∂u 1.1 cos(xy)
−∇· ∇u = 10.
∂t cos(xy) 5.5
4-20
Specify Coefficients in PDE Modeler App
Enter character expressions for coefficients using the form in “Coefficients for Scalar
PDEs” on page 4-18, with additional options for nonlinear equations. The additional
options are:
4-21
4 PDE Modeler App
• Similarly, represent the ith components of the gradients of the solution u using
'ux(i)' and 'uy(i)' for i = 1 or 2.
Note For elliptic problems, when you include coefficients u(i), ux(i), or uy(i), you
must use the nonlinear solver. Select Solve > Parameters > Use nonlinear solver.
For higher-dimensional systems, do not use the PDE Modeler app. Represent your
problem coefficients at the command line.
You can enter scalars into the c matrix, corresponding to these equations:
If you need matrix versions of any of the cij coefficients, enter expressions separated by
spaces. You can give 1-, 2-, 3-, or 4-element matrix expressions. These mean:
• c 0
1-element expression:
0 c
• c(1) 0
2-element expression:
0 c(2)
• c(1) c(2)
3-element expression:
c(2) c(3)
• c(1) c(3)
4-element expression:
c(2) c(4)
For example, these expressions show one of each type (1-, 2-, 3-, and 4-element
expressions)
4-22
Specify Coefficients in PDE Modeler App
4 + cos(xy) 0 −1 0
−∇ · ∇u1 − ∇ · ∇u2 = 1
0 4 + cos(xy) 0 1
.1 .2 7 .6
−∇ · ∇u1 − ∇ · ∇u2 = 2
.2 .3 .5 exp(x − y)
∂u
d − ∇ ⋅ c ∇u + au = f
∂t
• d=5
4-23
4 PDE Modeler App
• a=0
• f is a linear ramp up to 10, holds at 10, then ramps back down to 0:
10t 0 ≤ t ≤ 0.1
f = 10 * 1 0.1 ≤ t ≤ 0.9
10 − 10t 0.9 ≤ t ≤ 1
• c = 1 +.x2 + y2
To solve this equation in the PDE Modeler app, follow these steps:
function f = framp(t)
if t <= 0.1
f = 10*t;
elseif t <= 0.9
f = 1;
else
f = 10-10*t;
end
f = 10*f;
2 Open the PDE Modeler app by using the pdeModeler command.
3 Display grid lines by selecting Options > Grid.
4 Align new shapes to the grid lines by selecting Options > Snap.
5 Draw a rectangle with the corners at (-1,-0.4), (-1,0.4), (1,0.4), and (1,-0.4). To do this,
first click the button. Then click one of the corners using the left mouse button
and drag to draw a rectangle.
6 Draw a circle with the radius 0.2 and the center at (0.5,0). To do this, first click the
button. Then right-click the origin and drag to draw a circle. Right-clicking
constrains the shape you draw so that it is a circle rather than an ellipse. If the circle
is not a perfect unit circle, double-click it. In the resulting dialog box, specify the
exact center location and radius of the circle.
7 Model the geometry by entering R1-C1 in the Set formula field.
4-24
Specify Coefficients in PDE Modeler App
• For the rectangle, use the Dirichlet boundary condition with h = 1 and r =
t*(x-y).
• For the circle, use the Neumann boundary condition with g = x.^2+y.^2 and q
= 1.
10 Specify the coefficients by selecting PDE > PDE Specification or clicking the PDE
button on the toolbar. Select the Parabolic type of PDE. Specify c = 1+x.^2+y.^2,
a = 0, f = framp(t), and d = 5.
4-25
4 PDE Modeler App
Note Do not include quotes or spaces when you specify your coefficients the PDE
Modeler app. The parser interprets all inputs as vectors of characters. It can
misinterpret a space as a vector separator, as when a MATLAB vector uses a space to
separate elements of a vector.
11 Initialize the mesh by selecting Mesh > Initialize Mesh.
12 Refine the mesh twice by selecting Mesh > Refine Mesh.
13 Improve the triangle quality by selecting Mesh > Jiggle Mesh.
14 Set the initial value and the solution time. To do this, select Solve > Parameters.
In the resulting dialog box, set the time to linspace(0,1,50) and the initial value
u(t0) to 0.
4-26
Specify Coefficients in PDE Modeler App
15 Solve the equation by selecting Solve > Solve PDE or clicking the = button on the
toolbar.
4-27
4 PDE Modeler App
4-28
Specify Mesh Parameters in the PDE Modeler App
4-29
4 PDE Modeler App
• Maximum edge size: Largest triangle edge length (approximately). This parameter is
optional and must be a real positive number.
• Mesh growth rate: The rate at which the mesh size increases away from small parts
of the geometry. The value must be between 1 and 2. The default value is 1.3, i.e., the
mesh size increases by 30%.
• Mesher version: Choose the geometry triangulation algorithm. R2013a is faster, and
can mesh more geometries. preR2013a gives the same mesh as previous toolbox
versions.
• Jiggle mesh: Toggles automatic jiggling of the initial mesh on/off.
• Jiggle mode: Select a jiggle mode from a pop-up menu. Available modes are on,
optimize minimum, and optimize mean. on jiggles the mesh once. Using the jiggle
mode optimize minimum, the jiggling process is repeated until the minimum
triangle quality stops increasing or until the iteration limit is reached. The same
applies for the optimize mean option, but it tries to increase the mean triangle
quality.
• Number of jiggle iterations: Iteration limit for the optimize minimum and
optimize mean modes. Default: 20.
For the mesh refinement algorithm refinemesh, the Refinement method can be
regular or longest. The default refinement method is regular, which results in a
uniform mesh. The refinement method longest always refines the longest edge on each
triangle.
To initialize a triangular mesh, select Initialize Mesh from the Mesh menu or click the
button. To refine a mesh, select Refine Mesh from the Mesh menu or click the
button.
4-30
Adjust Solve Parameters in the PDE Modeler App
the button.
4-31
4 PDE Modeler App
Elliptic Equations
By default, no specific solve parameters are used, and the elliptic PDEs are solved using
the basic elliptic solver assempde. Optionally, the adaptive mesh generator and solver
adaptmesh can be used. For the adaptive mode, the following parameters are available:
4-32
Adjust Solve Parameters in the PDE Modeler App
• Worst triangles. This method picks all triangles that are worse than a fraction of
the value of the worst triangle (default: 0.5).
• Relative tolerance. This method picks triangles using a relative tolerance
criterion (default: 1E-3).
• User-defined function. Enter the name of a user-defined triangle selection
method. See Poisson's Equation with Point Source and Adaptive Mesh Refinement
for an example of a user-defined triangle selection method.
• Function parameter. The function parameter allows fine-tuning of the triangle
selection methods. For the worst triangle method (pdeadworst), it is the fraction of
the worst value that is used to determine which triangles to refine. For the relative
tolerance method, it is a tolerance parameter that controls how well the solution fits
the PDE.
• Refinement method. Can be regular or longest. See “Specify Mesh Parameters in
the PDE Modeler App” on page 4-29.
If the problem is nonlinear, i.e., parameters in the PDE are directly dependent on the
solution u, a nonlinear solver must be used. The following parameters are used:
4-33
4 PDE Modeler App
Note The adaptive mode and the nonlinear solver can be used together.
Parabolic Equations
• Time. A MATLAB vector of times at which a solution to the parabolic PDE should be
generated. The relevant time span is dependent on the dynamics of the problem.
4-34
Adjust Solve Parameters in the PDE Modeler App
Hyperbolic Equations
• Time. A MATLAB vector of times at which a solution to the hyperbolic PDE should be
generated. The relevant time span is dependent on the dynamics of the problem.
4-35
4 PDE Modeler App
• Absolute tolerance. Absolute tolerance parameter for the ODE solver that is used for
solving the time-dependent part of the hyperbolic PDE problem.
Eigenvalue Equations
For the eigenvalue PDE, the only solve parameter is the Eigenvalue search range, a
two-element vector, defining an interval on the real axis as a search range for the
eigenvalues. The left side can be -Inf.
Nonlinear Equations
Before solving a nonlinear elliptic PDE in the PDE Modeler app, select SolveParameters.
Then select Use nonlinear solver and click OK.
4-36
Adjust Solve Parameters in the PDE Modeler App
4-37
4 PDE Modeler App
To open the Plot Selection dialog box, select Parameters from the Plot menu or click
the button.
Parameters opens a dialog box containing options controlling the plotting and
visualization.
• Plot type (far left) contains a row of six different plot types, which can be used for
visualization:
4-38
Plot the Solution in the PDE Modeler App
A color bar is added to the plots to map the colors in the plot to the magnitude of the
property that is represented using color or contour lines.
• Property contains four pop-up menus containing lists of properties that are available
for plotting using the corresponding plot type. From the first pop-up menu you control
the property that is visualized using color and/or contour lines. The second and third
pop-up menus contain vector valued properties for visualization using arrows and
deformed mesh, respectively. From the fourth pop-up menu, finally, you control which
scalar property to visualize using z-height in a 3-D plot. The lists of properties are
dependent on the current application mode. For the generic scalar mode, you can
select the following scalar properties:
4-39
4 PDE Modeler App
available in the local workspace. You enter the expression into the edit box to the
right of the Property pop-up menu in the User entry column.
The vector property pop-up menus contain the following properties in the generic
scalar case:
For the generic system case, the properties available for visualization using color, contour
lines, or z-height are u, v, abs(u,v), and a user entry. For visualization using arrows or a
deformed mesh, you can choose (u,v) or a user entry. For applications in structural
mechanics, u and v are the x- and y-displacements, respectively.
The variables available in the local workspace for a user entered expression are the same
for all scalar and system modes (the solution is always referred to as u and, in the system
case, v).
• User entry contains four edit fields where you can enter your own expression, if you
select the user entry property from the corresponding pop-up menu to the left of the
edit fields. If the user entry property is not selected, the corresponding edit field is
disabled.
• Plot style contains three pop-up menus from which you can control the plot style for
the color, arrow, and height plot types respectively. The available plot styles for color
surface plots are
4-40
Plot the Solution in the PDE Modeler App
• Flat shading. A surface plot using the selected colormap and flat shading, i.e.,
each triangular area is colored using a constant color.
A total of three properties of the solution—two scalar properties and one vector field—can
be visualized simultaneously. If the Height (3-D plot) option is turned off, the solution
plot is a 2-D plot and is plotted in the main axes of the PDE Modeler app. If the Height
(3-D plot) option is used, the solution plot is a 3-D plot in a separate figure window. If
possible, the 3-D plot uses an existing figure window. If you would like to plot in a new
figure window, simply type figure at the MATLAB command line.
• Plot in x-y grid. If you select this option, the solution is converted from the original
triangular grid to a rectangular x-y grid. This is especially useful for animations since
it speeds up the process of recording the movie frames significantly.
• Show mesh. In the surface plots, the mesh is plotted using black color if you select
this option. By default, the mesh is hidden.
• Contour plot levels. For contour plots, the number of level curves, e.g., 15 or 20 can
be entered. Alternatively, you can enter a MATLAB vector of levels. The curves of the
contour plot are then drawn at those levels. The default is 20 contour level curves.
4-41
4 PDE Modeler App
• Colormap. Using the Colormap pop-up menu, you can select from a number of
different color maps: cool, gray, bone, pink, copper, hot, jet, hsv, prism, and
parula.
• Plot solution automatically. This option is normally selected. If turned off, there will
not be a display of a plot of the solution immediately upon solving the PDE. The new
solution, however, can be plotted using this dialog box.
For the parabolic and hyperbolic PDEs, the bottom right portion of the Plot Selection
dialog box contains the Time for plot parameter.
Time for plot. A pop-up menu allows you to select which of the solutions to plot by
selecting the corresponding time. By default, the last solution is plotted.
Also, the Animation plot type is enabled. In its property field you find an Options button.
If you press it, an additional dialog box appears. It contains parameters that control the
animation:
• Animation rate (fps). For the animation, this parameter controls the speed of the
movie in frames per second (fps).
• Number of repeats. The number of times the movie is played.
• Replay movie. If you select this option, the current movie is replayed without
rerecording the movie frames. If there is no current movie, this option is disabled.
4-42
Plot the Solution in the PDE Modeler App
For eigenvalue problems, the bottom right part of the dialog box contains a pop-up menu
with all eigenvalues. The plotted solution is the eigenvector associated with the selected
eigenvalue. By default, the smallest eigenvalue is selected.
You can rotate the 3-D plots by clicking the plot and, while keeping the mouse button
down, moving the mouse. For guidance, a surrounding box appears. When you release the
mouse, the plot is redrawn using the new viewpoint. Initially, the solution is plotted using
-37.5 degrees horizontal rotation and 30 degrees elevation.
If you click the Plot button, the solution is plotted immediately using the current plot
setup. If there is no current solution available, the PDE is first solved. The new solution is
then plotted. The dialog box remains on the screen.
If you click the Done button, the dialog box is closed. The current setup is saved but no
additional plotting takes place.
If you click the Cancel button, the dialog box is closed. The setup remains unchanged
since the last plot.
4-43
4 PDE Modeler App
In plot mode, you can use the mouse to display the numerical value of the plotted
property at the position where you click. Press the left mouse button to display the
triangle number and the value of the plotted property on the information line.
The information remains on the information line until you release the mouse button.
4-44
5
adaptmesh
Adaptive 2-D mesh generation and PDE solution
Note This page describes the legacy workflow. New features might not be compatible
with the legacy workflow. In the recommended workflow, see generateMesh for mesh
generation and solvepde for PDE solution.
Syntax
[u,p,e,t] = adaptmesh(g,b,c,a,f)
[u,p,e,t] = adaptmesh(g,b,c,a,f,'PropertyName',PropertyValue)
Description
[u,p,e,t] = adaptmesh(g,b,c,a,f) and [u,p,e,t] =
adaptmesh(g,b,c,a,f,'PropertyName',PropertyValue) perform adaptive mesh
generation and PDE solution for elliptic problems with 2-D geometry. Optional arguments
are given as property name/property value pairs.
− ∇ ⋅ c ∇u + au = f
− ∇ ⋅ c ⊗ ∇u + au = f
with the problem geometry and boundary conditions given by g and b. The mesh is
described by the p, e, and t matrices.
The solution u is represented as the solution vector u. If the PDE is scalar, meaning that is
has only one equation, then u is a column vector representing the solution u at each node
in the mesh. If the PDE is a system of N > 1 equations, then u is a column vector with
N*Np elements, where Np is the number of nodes in the mesh. The first Np elements of u
represent the solution of equation 1, the next Np elements represent the solution of
equation 2, and so on.
5-2
adaptmesh
The algorithm works by solving a sequence of PDE problems using refined triangular
meshes. The first triangular mesh generation is provided as an optional argument to
adaptmesh or obtained by a call to initmesh without options. Subsequent generations
of triangular meshes are obtained by solving the PDE problem, computing an error
estimate, selecting a set of triangles based on the error estimate, and then refining the
triangles. The solution to the PDE problem is then recomputed. The loop continues until
the triangle selection method selects no further triangles, until the maximum number of
triangles is attained, or until the maximum number of triangle generations is reached.
g describes the geometry of the PDE problem. g can be a decomposed geometry matrix,
the name of a geometry file, or a function handle to a geometry file.
The adapted triangular mesh of the PDE problem is given by the mesh data p, e, and t.
For details on the mesh data representation, see “Mesh Data as [p,e,t] Triples” on page 2-
168.
The coefficients c, a, and f of the PDE problem can be given in a wide variety of ways. In
the context of adaptmesh, the coefficients can depend on u if the nonlinear solver is
enabled using the property nonlin. The coefficients cannot depend on t, the time.
5-3
5 Functions — Alphabetical List
Par is passed to the Tripick function, which is described later. Normally it is used as
tolerance of how well the solution fits the equation.
No more than Ngen successive refinements are attempted. Refinement is also stopped
when the number of triangles in the mesh exceeds Maxt.
p1, e1, and t1 are the input mesh data. This triangular mesh is used as starting mesh for
the adaptive algorithm. For details on the mesh data representation, see initmesh. If no
initial mesh is provided, the result of a call to initmesh with no options is used as the
initial mesh.
The refinement method is longest or regular. For details on the refinement method,
see refinemesh.
The MesherVersion property chooses the algorithm for mesh generation. The 'R2013a'
algorithm runs faster and can triangulate more geometries than the 'preR2013a'
algorithm. Both algorithms use Delaunay triangulation.
The adaptive algorithm can also solve nonlinear PDE problems. For nonlinear PDE
problems, the Nonlin parameter must be set to on. The nonlinear tolerance Toln,
5-4
adaptmesh
nonlinear initial value u0, nonlinear Jacobian calculation Jac, and nonlinear residual
norm Norm are passed to the nonlinear solver pdenonlin.
Examples
Solve the Laplace equation over a circle sector, with Dirichlet boundary conditions u =
cos(2/3atan2( y , x )) along the arc and u = 0 along the straight lines, and compare the
resulting solution to the exact solution. Set options so that adaptmesh refines the
triangles using the worst error criterion until it obtains a mesh with at least 500 triangles.
[u,p,e,t]=adaptmesh('cirsg','cirsb',1,0,0,'maxt',500,...
'tripick','pdeadworst','ngen',inf);
x=p(1,:); y=p(2,:);
exact=((x.^2+y.^2).^(1/3).*cos(2/3*atan2(y,x)))';
max(abs(u-exact))
ans = 0.0028
size(t,2)
ans = 629
pdemesh(p,e,t)
5-5
5 Functions — Alphabetical List
Test how many refinements you need with a uniform triangle net.
[p,e,t]=initmesh('cirsg');
[p,e,t]=refinemesh('cirsg',p,e,t);
u=assempde('cirsb',p,e,t,1,0,0);
x=p(1,:); y=p(2,:);
exact=((x.^2+y.^2).^(1/3).*cos(2/3*atan2(y,x)))';
max(abs(u-exact))
ans = 0.0121
size(t,2)
ans = 788
5-6
adaptmesh
[p,e,t]=refinemesh('cirsg',p,e,t);
u=assempde('cirsb',p,e,t,1,0,0);
x=p(1,:); y=p(2,:);
exact=((x.^2+y.^2).^(1/3).*cos(2/3*atan2(y,x)))';
max(abs(u-exact))
ans = 0.0078
size(t,2)
ans = 3152
pdemesh(p,e,t)
5-7
5 Functions — Alphabetical List
Uniform refinement with 3152 triangles produces an error of 0.0078. This error is over
three times as large as that produced by the adaptive method (0.0028) with many fewer
2
triangles (629). Typically, a problem with regular solution has an O(h ) error. However,
this solution is singular since u ≈ r 1/3 at the origin.
Diagnostics
Upon termination, one of the following messages is displayed:
• Adaption completed (This means that the Tripick function returned zero
triangles to refine.)
• Maximum number of triangles obtained
• Maximum number of refinement passes obtained
Algorithms
Mesh Refinement for Improving Solution Accuracy
Partial Differential Equation Toolbox provides the refinemesh function for global,
uniform mesh refinement for 2-D geometries. It divides each triangle into four similar
triangles by creating new corners at the midsides, adjusting for curved boundaries. You
can assess the accuracy of the numerical solution by comparing results from a sequence
of successively refined meshes. If the solution is smooth enough, more accurate results
can be obtained by extrapolation.
The solutions of equations often have geometric features such as localized strong
gradients. An example of engineering importance in elasticity is the stress concentration
occurring at reentrant corners, such as the MATLAB L-shaped membrane. In such cases,
it is more economical to refine the mesh selectively, that is, only where it is needed. The
selection that is based on estimates of errors in the computed solutions is called adaptive
mesh refinement. See adaptmesh for an example of the computational savings where
global refinement needs more than 6000 elements to compete with an adaptively refined
mesh of 500 elements.
5-8
adaptmesh
the error. The process is terminated when the maximum number of elements is exceeded,
when each triangle contributes less than a preset tolerance, or when an iteration limit is
reached. You can provide an initial mesh, or let adaptmesh call initmesh automatically.
You also choose selection and termination criteria parameters. The three components of
the algorithm are the error indicator function (which computes an estimate of the element
error contribution), the mesh refiner (which selects and subdivides elements), and the
termination criteria.
The error indicator function used in the software is an elementwise estimate of the
contribution, based on the work of C. Johnson et al. [1], [2]. For Poisson's equation –Δu = f
on Ω, the following error estimate for the FEM-solution uh holds in the L2-norm ⋅ :
∂v 2 1/2
2
Dh(v) = ∑ hτ
∂nτ
τ ∈ E1
The braced quantity is the jump in normal derivative of v across the edge τ, hτ is the
length of the edge τ, and the sum runs over Ei, the set of all interior edges of the
triangulation. The coefficients α and β are independent of the triangulation. This bound is
turned into an elementwise error indicator function E(K) for the element K by summing
the contributions from its edges.
The general form of the error indicator function for the elliptic equation
–∇ · (c∇u) + au = f (5-1)
5-9
5 Functions — Alphabetical List
is
1/2
1 2 2
2 τ ∈∑∂K τ τ
E K = α h f − au K +β h n · c ∇uh
where nτ is the unit normal of the edge τ and the braced term is the jump in flux across
the element edge. The L2 norm is computed over the element K. The pdejmps function
computes this error indicator.
When an element is refined, new nodes appear on its midsides, and if the neighbor
triangle is not refined in a similar way, it is said to have hanging nodes. The final
triangulation must have no hanging nodes, and they are removed by splitting neighbor
triangles. To avoid further deterioration of triangle quality in successive generations, the
"longest edge bisection" scheme is used by Rosenberg-Stenger [3], in which the longest
side of a triangle is always split, whenever any of the sides have hanging nodes. This
guarantees that no angle is ever smaller than half the smallest angle of the original
triangulation.
Two selection criteria can be used. One, pdeadworst, refines all elements with value of
the error indicator larger than half the worst of any element. The other, pdeadgsc,
refines all elements with an indicator value exceeding a user-defined dimensionless
tolerance. The comparison with the tolerance is properly scaled with respect to domain,
solution size, and so on.
5-10
adaptmesh
References
[1] Johnson, C. Numerical Solution of Partial Differential Equations by the Finite Element
Method. Lund, Sweden: Studentlitteratur, 1987.
[2] Johnson, C., and K. Eriksson. Adaptive Finite Element Methods for Parabolic Problems
I: A Linear Model Problem. SIAM J. Numer. Anal, 28, (1991), pp. 43–77.
[3] Rosenberg, I.G., and F. Stenger, A lower bound on the angles of triangles constructed
by bisecting the longest side. Mathematics of Computation. Vol 29, Number 10,
1975, pp 390–395.
See Also
initmesh | refinemesh
5-11
5 Functions — Alphabetical List
addVertex
Add a vertex on a geometry boundary
Syntax
VertexID = addVertex(g,'Coordinates',Coords)
Description
VertexID = addVertex(g,'Coordinates',Coords) adds a new isolated vertex at
the point with coordinates Coords to a boundary of the geometry g. To add several
vertices simultaneously, specify Coords as an N-by-2 matrix for a 2-D geometry or an N-
by-3 matrix for a 3-D geometry. Here, N is the number of new points.
If a point with the specified coordinates is slightly offset (within an internally specified
tolerance) from a geometry boundary, addVertex approximates it to a point on the
boundary. If a vertex already exists at the specified location, addVertex returns the ID of
the existing vertex instead of creating one.
Examples
Use addVertex to add a single vertex and multiple vertices on a side of a block
geometry.
5-12
addVertex
VertexID = 9
5-13
5 Functions — Alphabetical List
VertexIDs = 3×1
10
11
12
5-14
addVertex
Add a vertex at the corner of the block. Since there is already a vertex at the corner,
addVertex does not create a new vertex, but returns the ID of the existing vertex.
VertexID = 5
Input Arguments
g — Geometry
DiscreteGeometry object
5-15
5 Functions — Alphabetical List
Coordinates of a new vertex, specified as an N-by-2 or N-by-3 numeric matrix for a 2-D or
3-D geometry, respectively. Here, N is the number of new vertices.
Example: 'Coordinates',[0;0;1]
Data Types: double
Output Arguments
VertexID — Vertex ID
row vector
Vertex ID, returned as a row vector of positive numbers. Each number represents a vertex
ID. When you add a new vertex to a geometry with N vertices, the ID of the added vertex
is N + 1. If a vertex already exists at the specified location, addVertex returns the ID of
the existing vertex.
Limitations
• addVertex does not work with AnalyticGeometry objects. See AnalyticGeometry.
See Also
DiscreteGeometry Properties | generateMesh | geometryFromMesh | importGeometry
| pdegplot | structuralBC | structuralBoundaryLoad
Introduced in R2019b
5-16
AnalyticGeometry Properties
AnalyticGeometry Properties
Analytic 2-D geometry description
Description
AnalyticGeometry describes a 2-D geometry in the form of an analytic geometry object.
PDEModel, StructuralModel, and ThermalModel objects have a Geometry property,
which can be an AnalyticGeometry or DiscreteGeometry object.
Add a 2-D analytic geometry to your model by using decsg to create the geometry and
geometryFromEdges to attach it to the model.
Properties
Properties
5-17
5 Functions — Alphabetical List
See Also
DiscreteGeometry Properties | PDEModel | StructuralModel | ThermalModel | decsg
| geometryFromEdges
Topics
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2015a
5-18
applyBoundaryCondition
applyBoundaryCondition
Package: pde
Syntax
applyBoundaryCondition(model,'dirichlet',RegionType,RegionID,
Name,Value)
applyBoundaryCondition(model,'neumann',RegionType,RegionID,
Name,Value)
applyBoundaryCondition(model,'mixed',RegionType,RegionID,Name,Value)
bc = applyBoundaryCondition( ___ )
Description
applyBoundaryCondition(model,'dirichlet',RegionType,RegionID,
Name,Value) adds a Dirichlet boundary condition to model. The boundary condition
applies to boundary regions of type RegionType with ID numbers in RegionID, and with
arguments r, h, u, EquationIndex specified in the Name,Value pairs. For Dirichlet
boundary conditions, specify either both arguments r and h, or the argument u. When
specifying u, you can also use EquationIndex.
applyBoundaryCondition(model,'neumann',RegionType,RegionID,
Name,Value) adds a Neumann boundary condition to model. The boundary condition
applies to boundary regions of type RegionType with ID numbers in RegionID, and with
values g and q specified in the Name,Value pairs.
applyBoundaryCondition(model,'mixed',RegionType,RegionID,Name,Value)
adds an individual boundary condition for each equation in a system of PDEs. The
boundary condition applies to boundary regions of type RegionType with ID numbers in
RegionID, and with values specified in the Name,Value pairs. For mixed boundary
conditions, you can use Name,Value pairs from both Dirichlet and Neumann boundary
conditions as needed.
5-19
5 Functions — Alphabetical List
Examples
model = createpde(1);
R1 = [3,4,-1,1,1,-1,-.4,-.4,.4,.4]';
g = decsg(R1);
geometryFromEdges(model,g);
pdegplot(model,'EdgeLabels','on')
xlim([-1.2,1.2])
axis equal
5-20
applyBoundaryCondition
applyBoundaryCondition(model,'dirichlet','Edge',1,'u',0);
applyBoundaryCondition(model,'dirichlet','Edge',2:4,'r',1,'h',1);
5-21
5 Functions — Alphabetical List
model = createpde(2);
R1 = [3,4,-1,1,1,-1,-.4,-.4,.4,.4]';
g = decsg(R1);
geometryFromEdges(model,g);
5-22
applyBoundaryCondition
Apply both types of boundary conditions to a scalar problem. First, create a PDE model
and import a simple block geometry.
model = createpde;
importGeometry(model,'Block.stl');
Set zero Dirichlet conditions on the narrow faces, which are labeled 1 through 4.
5-23
5 Functions — Alphabetical List
applyBoundaryCondition(model,'dirichlet','Face',1:4,'u',0);
Solve an elliptic PDE with these boundary conditions, and plot the result.
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',0);
generateMesh(model);
results = solvepde(model);
u = results.NodalSolution;
pdeplot3D(model,'ColorMapData',u)
5-24
applyBoundaryCondition
model = createpde(3);
importGeometry(model,'Block.stl');
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
5-25
5 Functions — Alphabetical List
applyBoundaryCondition(model,'dirichlet','Face',1:2,'u',[0,0,0]);
applyBoundaryCondition(model,'neumann','Face',4:5,'g',[1;1;1]);
applyBoundaryCondition(model,'neumann','Face',6,'g',[-1;-1;-1]);
For face 3, apply generalized Neumann boundary condition for the first equation and
Dirichlet boundary conditions for the second and third equations.
Solve an elliptic PDE with these boundary conditions, and plot the result.
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',[0;0;0]);
generateMesh(model);
results = solvepde(model);
u = results.NodalSolution;
pdeplot3D(model,'ColorMapData',u(:,1))
5-26
applyBoundaryCondition
Input Arguments
model — PDE model
PDEModel object
5-27
5 Functions — Alphabetical List
Geometric region type, specified as 'Face' for 3-D geometry or 'Edge' for 2-D
geometry.
Example: applyBoundaryCondition(model,'dirichlet','Face',3,'u',0)
Data Types: char | string
Geometric region ID, specified as a vector of positive integers. Find the region IDs using
pdegplot with the 'FaceLabels' (3-D) or 'EdgeLabels' (2-D) value set to 'on'.
Example: applyBoundaryCondition(model,'dirichlet','Face',3:6,'u',0)
Data Types: double
Dirichlet condition h*u = r, specified as an N-by-N matrix, a vector with N^2 elements,
or a function handle. N is the number of PDEs in the system. For the syntax of the
function handle form of h, see “Nonconstant Boundary Conditions” on page 2-129.
Example: 'h',[2,1;1,2]
Data Types: double | function_handle
Complex Number Support: Yes
5-28
applyBoundaryCondition
u — Dirichlet conditions
zeros(N,1) (default) | vector of up to N elements | function handle
For the syntax of the function handle form of u, see “Nonconstant Boundary Conditions”
on page 2-129.
Example: applyBoundaryCondition(model,'dirichlet','Face',
[2,4,11],'u',0)
Data Types: double
Complex Number Support: Yes
5-29
5 Functions — Alphabetical List
Index of the known u components, specified as a vector of integers with entries from 1 to
N. EquationIndex and u must have the same length.
Vectorized function evaluation, specified as 'on' or 'off'. This evaluation applies when
you pass a function handle as an argument. To save time in function handle evaluation,
specify 'on', assuming that your function handle computes in a vectorized fashion. See
“Vectorization” (MATLAB). For details of this evaluation, see “Nonconstant Boundary
Conditions” on page 2-129.
Example: applyBoundaryCondition(model,'dirichlet','Face',
[2,4,11],'u',@ucalculator,'Vectorized','on')
Data Types: char | string
Output Arguments
bc — Boundary condition
BoundaryCondition object
Tips
• When there are multiple boundary condition assignments to the same geometric
region, the toolbox uses the last applied setting.
• To avoid assigning boundary conditions to a wrong region, ensure that you are using
the correct geometric region IDs by plotting and visually inspecting the geometry.
5-30
applyBoundaryCondition
• If you do not specify a boundary condition for an edge or face, the default is the
Neumann boundary condition with the zero values for 'g' and 'q'.
See Also
BoundaryCondition | PDEModel | findBoundaryConditions
Topics
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2015a
5-31
5 Functions — Alphabetical List
area
Package: pde
Syntax
A = area(mesh)
[A,AE] = area(mesh)
A = area(mesh,elements)
Description
A = area(mesh) returns the area A of the entire mesh.
[A,AE] = area(mesh) also returns a row vector AE containing areas of each individual
element of the mesh.
Examples
Include the geometry of the built-in function lshapeg. Plot the geometry.
geometryFromEdges(model,@lshapeg);
pdegplot(model,'FaceLabels','on')
5-32
area
mesh = generateMesh(model);
figure
pdemesh(model)
5-33
5 Functions — Alphabetical List
ma = area(mesh)
ma = 3.0000
5-34
area
model = createpde;
Include the geometry of the built-in function lshapeg. Plot the geometry.
geometryFromEdges(model,@lshapeg);
pdegplot(model,'FaceLabels','on')
mesh = generateMesh(model);
figure
pdemesh(model)
5-35
5 Functions — Alphabetical List
Compute the area of the entire mesh and the area of each individual element of the mesh.
Display the areas of the first 5 elements.
[ma,mi] = area(mesh);
mi(1:5)
ans = 1×5
5-36
area
Find the combined area of the elements associated with a particular face of a 2-D mesh.
model = createpde;
Include the geometry of the built-in function lshapeg. Plot the geometry.
geometryFromEdges(model,@lshapeg);
pdegplot(model,'FaceLabels','on')
5-37
5 Functions — Alphabetical List
mesh = generateMesh(model);
figure
pdemesh(model)
Find the elements associated with face 1 and compute the total area of these elements.
Ef1 = findElements(mesh,'region','Face',1);
maf1 = area(mesh,Ef1)
maf1 = 1.0000
Find how much of the total mesh area belongs to these elements. Return the result as a
percentage.
maf1_percent = maf1/area(mesh)*100
5-38
area
maf1_percent = 33.3333
Input Arguments
mesh — Mesh object
Mesh property of a PDEModel object | output of generateMesh
Mesh object, specified as the Mesh property of a PDEModel object or as the output of
generateMesh.
Example: model.Mesh
Output Arguments
A — Area
positive number
Area of the entire mesh or the combined area of the specified elements of the mesh,
returned as a positive number.
See Also
FEMesh Properties | findElements | findNodes | meshQuality | volume
Topics
“Finite Element Method Basics” on page 1-13
5-39
5 Functions — Alphabetical List
Introduced in R2018a
5-40
assema
assema
(Not recommended) Assemble area integral contributions
Syntax
[K,M,F] = assema(model,c,a,f)
[K,M,F] = assema(p,t,c,a,f)
Description
[K,M,F] = assema(model,c,a,f) assembles the stiffness matrix K, the mass matrix
M, and the load vector F using the mesh contained in model, and the PDE coefficients c,
a, and f.
[K,M,F] = assema(p,t,c,a,f) assembles the matrices from the mesh data in p and
t.
Examples
− ∇ ⋅ ∇u = 1 .
− ∇ ⋅ (c ∇u) + au = f .
5-41
5 Functions — Alphabetical List
c = 1;
a = 0;
f = 1;
Create a PDE model container. Import the ForearmLink.stl file into the model and
examine the geometry.
model = createpde;
importGeometry(model,'ForearmLink.stl');
pdegplot(model,'FaceAlpha',0.5)
generateMesh(model);
5-42
assema
Create the finite element matrices from the mesh and the coefficients.
[K,M,F] = assema(model,c,a,f);
Assemble finite element matrices for the 2-D L-shaped region, using the [p,e,t] mesh
representation.
Define the geometry using the lshapeg function included your software.
g = @lshapeg;
c = 1;
a = 0;
f = 1;
[p,e,t] = initmesh(g);
[K,M,F] = assema(p,t,c,a,f);
The returned matrix M has all zeros. The K matrix is quite sparse.
5-43
5 Functions — Alphabetical List
Input Arguments
model — PDE model
PDEModel object
c — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. c represents the c coefficient in the scalar
PDE
− ∇ ⋅ c ∇u + au = f
− ∇ ⋅ c ⊗ ∇u + au = f
Example: 'cosh(x+y.^2)'
Data Types: double | char | string | function_handle
Complex Number Support: Yes
a — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. a represents the a coefficient in the scalar
PDE
− ∇ ⋅ c ∇u + au = f
− ∇ ⋅ c ⊗ ∇u + au = f
5-44
assema
Example: 2*eye(3)
Data Types: double | char | string | function_handle
Complex Number Support: Yes
f — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. f represents the f coefficient in the scalar
PDE
− ∇ ⋅ c ∇u + au = f
− ∇ ⋅ c ⊗ ∇u + au = f
Example: char('sin(x)';'cos(y)';'tan(z)')
Data Types: double | char | string | function_handle
Complex Number Support: Yes
p — Mesh points
matrix
Mesh points, specified as a 2-by-Np matrix of points, where Np is the number of points in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
t — Mesh triangles
matrix
5-45
5 Functions — Alphabetical List
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
Output Arguments
K — Stiffness matrix
sparse matrix
Stiffness matrix, returned as a sparse matrix. See “Elliptic Equations” on page 5-79.
M — Mass matrix
sparse matrix
Mass matrix. returned as a sparse matrix. See “Elliptic Equations” on page 5-79.
F — Load vector
vector
See Also
assembleFEMatrices
5-46
assemb
assemb
(Not recommended) Assemble boundary condition contributions
Syntax
[Q,G,H,R] = assemb(model)
[Q,G,H,R] = assemb(b,p,e)
[Q,G,H,R] = assemb( ___ ,[],sdl)
Description
[Q,G,H,R] = assemb(model) assembles the matrices Q and H, and the vectors G and
R. Q should be added to the system matrix and contains contributions from mixed
boundary conditions.
[Q,G,H,R] = assemb( ___ ,[],sdl), for any of the previous input arguments,
restricts the finite element matrices to those that include the subdomain specified by the
subdomain labels in sdl. The empty argument is required in this syntax for historic and
compatibility reasons.
Examples
5-47
5 Functions — Alphabetical List
− ∇ ⋅ ∇u = 1 .
− ∇ ⋅ (c ∇u) + au = f .
c = 1;
a = 0;
f = 1;
Create a PDE model container. Import the ForearmLink.stl file into the model and
examine the geometry.
model = createpde;
importGeometry(model,'Block.stl');
h = pdegplot(model,'FaceLabels','on');
h(1).FaceAlpha = 0.5;
5-48
assemb
Set zero Dirichlet boundary conditions on the narrow faces (numbered 1 through 4).
applyBoundaryCondition(model,'Face',1:4,'u',0);
applyBoundaryCondition(model,'Face',6,'g',-1);
applyBoundaryCondition(model,'Face',5,'g',1);
generateMesh(model);
5-49
5 Functions — Alphabetical List
[Q,G,H,R] = assemb(model);
Assemble boundary condition matrices for the 2-D L-shaped region with Dirichlet
boundary conditions, using the [p,e,t] mesh representation.
Define the geometry and boundary conditions using functions included in your software.
g = @lshapeg;
b = @lshapeb;
[p,e,t] = initmesh(g);
[Q,G,H,R] = assemb(b,p,e);
Only one of the resulting matrices is nonzero, namely H. The H matrix is quite sparse.
Input Arguments
model — PDE model
PDEModel object
5-50
assemb
b — Boundary conditions
boundary matrix | boundary file
Boundary conditions, specified as a boundary matrix or boundary file. Pass a boundary file
as a function handle or as a file name. A boundary matrix is generally an export from the
PDE Modeler app.
Example: b = 'circleb1', b = "circleb1", or b = @circleb1
Data Types: double | char | string | function_handle
p — Mesh points
matrix
Mesh points, specified as a 2-by-Np matrix of points, where Np is the number of points in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
e — Mesh edges
matrix
Mesh edges, specified as a 7-by-Ne matrix of edges, where Ne is the number of edges in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
Subdomain labels, specified as a vector of positive integers. For 2-D geometry only. View
the subdomain labels in your geometry using the command
5-51
5 Functions — Alphabetical List
pdegplot(g,'SubdomainLabels','on')
Output Arguments
Q — Neumann boundary condition matrix
sparse matrix
Neumann boundary condition vector, returned as a sparse vector. See “Elliptic Equations”
on page 5-79.
H — Dirichlet matrix
sparse matrix
R — Dirichlet vector
sparse vector
5-52
assemb
Algorithms
As explained in “Elliptic Equations” on page 5-79, the finite element matrices and
vectors correspond to the reduced linear system and are the following.
For more information on the reduced linear system form of the finite element matrices,
see the assempde “More About” on page 5-79 section, and the linear algebra approach
detailed in “Systems of PDEs” on page 5-87.
See Also
assembleFEMatrices
5-53
5 Functions — Alphabetical List
assembleFEMatrices
Assemble finite element matrices
Syntax
FEM = assembleFEMatrices(model)
FEM = assembleFEMatrices(model,bcmethod)
Description
FEM = assembleFEMatrices(model) returns a structural array containing finite
element matrices. Model attributes, such as coefficients, material properties, boundary
conditions, and so on, must not depend on time or solution.
Examples
Create a PDE model for the Poisson equation on an L-shaped membrane with zero
Dirichlet boundary conditions.
model = createpde(1);
geometryFromEdges(model,@lshapeg);
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',1);
applyBoundaryCondition(model,'edge',1:model.Geometry.NumEdges,'u',0);
Generate a mesh and obtain the default finite element matrices for the problem and
mesh.
generateMesh(model,'Hmax',0.2);
FEM = assembleFEMatrices(model)
5-54
assembleFEMatrices
Create a PDE model for the Poisson equation on an L-shaped membrane with zero
Dirichlet boundary conditions.
model = createpde(1);
geometryFromEdges(model,@lshapeg);
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',1);
applyBoundaryCondition(model,'edge',1:model.Geometry.NumEdges,'u',0);
Generate a mesh and obtain the nullspace finite element matrices for the problem and
mesh.
generateMesh(model,'Hmax',0.2);
FEM = assembleFEMatrices(model,'nullspace')
Compare this result to the solution given by solvepde. The two solutions are identical.
u1 = solvepde(model);
norm(u - u1.NodalSolution)
5-55
5 Functions — Alphabetical List
ans = 0
Create a transient thermal model and include the geometry of the built-in function
squareg.
thermalmodel = createpde('thermal','transient');
geometryFromEdges(thermalmodel,@squareg);
pdegplot(thermalmodel,'EdgeLabels','on')
xlim([-1.1 1.1])
ylim([-1.1 1.1])
5-56
assembleFEMatrices
Specify the thermal conductivity, mass density, and specific heat of the material.
thermalProperties(thermalmodel,'ThermalConductivity',0.2, ...
'MassDensity',2.7*10^(-6), ...
'SpecificHeat',920);
5-57
5 Functions — Alphabetical List
Input Arguments
model — Model object
PDEModel object | ThermalModel object | StructuralModel object
Output Arguments
FEM — Finite element matrices
structural array
Finite element matrices, returned as a structural array. The fields in the structural array
depend on bcmethod as follows:
5-58
assembleFEMatrices
Tips
• The mass matrix M is nonzero when the model is time-dependent. By using this matrix,
you can solve a model with Rayleigh damping. For an example, see “Dynamics of
Damped Cantilever Beam”.
• For a thermal model, the m and a coefficients are zeros. The thermal conductivity maps
to the c coefficient. The product of the mass density and the specific heat maps to the
d coefficient. The internal heat source maps to the f coefficient.
• For a structural model, the a coefficient is zero. The Young's modulus and Poisson's
ratio map to the c coefficient. The mass density maps to the m coefficient. The body
loads map to the f coefficient. When you specify the damping model by using the
Rayleigh damping parameters Alpha and Beta, the discretized damping matrix C is
computed by using the mass matrix M and the stiffness matrix K as C = Alpha*M
+Beta*K.
Algorithms
The full finite element matrices and vectors are as follows:
• K is the stiffness matrix, the integral of the c coefficient against the basis functions.
• M is the mass matrix, the integral of the m or d coefficient against the basis functions.
• A is the integral of the a coefficient against the basis functions.
• F is the integral of the f coefficient against the basis functions.
• Q is the integral of the q boundary condition against the basis functions.
• G is the integral of the g boundary condition against the basis functions.
• The H and R matrices come directly from the Dirichlet conditions and the mesh.
Given these matrices, the 'nullspace' technique generates the combined finite element
matrices [Kc,Fc,B,ud] as follows. The combined stiffness matrix is for the reduced linear
5-59
5 Functions — Alphabetical List
u = B*(Kc\Fc) + ud.
See Also
PDEModel | StructuralModel | ThermalModel | solve | solvepde
Topics
“Finite Element Method Basics” on page 1-13
Introduced in R2016a
5-60
assempde
assempde
(Not recommended) Assemble finite element matrices and solve elliptic PDE
Syntax
u = assempde(model,c,a,f)
u = assempde(b,p,e,t,c,a,f)
u = assempde(K,M,F,Q,G,H,R)
[Ks,Fs] = assempde(K,M,F,Q,G,H,R)
[Kc,Fc,B,ud] = assempde(K,M,F,Q,G,H,R)
Description
u = assempde(model,c,a,f) solves the PDE
− ∇ ⋅ c ∇u + au = f
with geometry, boundary conditions, and finite element mesh in model, and coefficients c,
a, and f. If the PDE is a system of equations (model.PDESystemSize > 1), then
assempde solves the system of equations
− ∇ ⋅ c ⊗ ∇u + au = f
[Kc,Fc,B,ud] = assempde( ___ ), for any of the previous input syntaxes, assembles
finite element matrices using the reduced linear system form, which eliminates any
5-61
5 Functions — Alphabetical List
Dirichlet boundary conditions from the system of linear equations. You can calculate the
solution u at node points by the command u = B*(Kc\Fc) + ud. See “Reduced Linear
System” on page 5-79.
[Ks,Fs] = assempde( ___ ) assembles finite element matrices that represent any
Dirichlet boundary conditions using a stiff-spring approximation. You can calculate the
solution u at node points by the command u = Ks\Fs. See “Stiff-Spring Approximation”
on page 5-79.
Examples
model = createpde;
geometryFromEdges(model,@lshapeg);
5-62
assempde
applyBoundaryCondition(model,'Edge',1:model.Geometry.NumEdges,'u',0);
generateMesh(model,'GeometricOrder','linear');
c = 1;
a = 0;
f = 5;
u = assempde(model,c,a,f);
pdeplot(model,'XYData',u)
5-63
5 Functions — Alphabetical List
Create a PDE model container, import a 3-D geometry description, and view the geometry.
model = createpde;
importGeometry(model,'Block.stl');
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
5-64
assempde
Set zero Dirichlet conditions on faces 1 through 4 (the edges). Set Neumann conditions
with g = -1 on face 6 and g = 1 on face 5.
applyBoundaryCondition(model,'Face',1:4,'u',0);
applyBoundaryCondition(model,'Face',6,'g',-1);
applyBoundaryCondition(model,'Face',5,'g',1);
c = 1;
a = 0;
f = 0.1;
5-65
5 Functions — Alphabetical List
generateMesh(model);
u = assempde(model,c,a,f);
5-66
assempde
g = @circleg;
b = @circleb1;
[p,e,t] = initmesh(g);
c = 1;
a = 0;
f = 'sin(x)';
u = assempde(b,p,e,t,c,a,f);
pdeplot(p,e,t,'XYData',u)
5-67
5 Functions — Alphabetical List
Obtain the finite-element matrices that represent the problem using a reduced linear
algebra representation of Dirichlet boundary conditions.
model = createpde;
importGeometry(model,'Block.stl');
5-68
assempde
applyBoundaryCondition(model,'dirichlet','Face',1:model.Geometry.NumFaces,'u',0);
generateMesh(model);
c = 1;
a = 0;
f = 'log(1+x+y./(1+z))';
[K,F,B,ud] = assempde(model,c,a,f);
You can obtain the solution u of the PDE at mesh nodes by executing the command
u = B*(K\F) + ud;
Generally, this solution is slightly more accurate than the stiff-spring solution, as
calculated in the next example.
model = createpde;
importGeometry(model,'Block.stl');
applyBoundaryCondition(model,'Face',1:model.Geometry.NumFaces,'u',0);
generateMesh(model);
5-69
5 Functions — Alphabetical List
c = 1;
a = 0;
f = 'log(1+x+y./(1+z))';
[Ks,Fs] = assempde(model,c,a,f);
You can obtain the solution u of the PDE at mesh nodes by executing the command
u = Ks\Fs;
Generally, this solution is slightly less accurate than the reduced linear algebra solution,
as calculated in the previous example.
Obtain the full collection of finite element matrices for an elliptic problem.
Import geometry and set up an elliptic problem with Dirichlet boundary conditions. The
Torus.stl geometry has only one face, so you need set only one boundary condition.
model = createpde();
importGeometry(model,'Torus.stl');
applyBoundaryCondition(model,'face',1,'u',0);
c = 1;
a = 0;
f = 1;
generateMesh(model);
Most of the resulting matrices are quite sparse. G, M, Q, and R are all zero sparse
matrices.
howsparse = @(x)nnz(x)/numel(x);
disp(['Maximum fraction of nonzero entries in K or H is ',...
num2str(max(howsparse(K),howsparse(H)))])
5-70
assempde
Input Arguments
model — PDE model
PDEModel object
c — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. c represents the c coefficient in the scalar
PDE
− ∇ ⋅ c ∇u + au = f
− ∇ ⋅ c ⊗ ∇u + au = f
Example: 'cosh(x+y.^2)'
Data Types: double | char | string | function_handle
Complex Number Support: Yes
a — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. a represents the a coefficient in the scalar
PDE
− ∇ ⋅ c ∇u + au = f
− ∇ ⋅ c ⊗ ∇u + au = f
5-71
5 Functions — Alphabetical List
Example: 2*eye(3)
Data Types: double | char | string | function_handle
Complex Number Support: Yes
f — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. f represents the f coefficient in the scalar
PDE
− ∇ ⋅ c ∇u + au = f
− ∇ ⋅ c ⊗ ∇u + au = f
Example: char('sin(x)';'cos(y)';'tan(z)')
Data Types: double | char | string | function_handle
Complex Number Support: Yes
b — Boundary conditions
boundary matrix | boundary file
Boundary conditions, specified as a boundary matrix or boundary file. Pass a boundary file
as a function handle or as a file name. A boundary matrix is generally an export from the
PDE Modeler app.
Example: b = 'circleb1', b = "circleb1", or b = @circleb1
Data Types: double | char | string | function_handle
p — Mesh points
matrix
Mesh points, specified as a 2-by-Np matrix of points, where Np is the number of points in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
5-72
assempde
e — Mesh edges
matrix
Mesh edges, specified as a 7-by-Ne matrix of edges, where Ne is the number of edges in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
t — Mesh triangles
matrix
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
K — Stiffness matrix
sparse matrix | full matrix
Stiffness matrix, specified as a sparse matrix or full matrix. Generally, you obtain K from a
previous call to assema or assempde. For the meaning of stiffness matrix, see “Elliptic
Equations” on page 5-79.
Example: [K,M,F,Q,G,H,R] = assempde(model,c,a,f)
Data Types: double
Complex Number Support: Yes
M — Mass matrix
sparse matrix | full matrix
5-73
5 Functions — Alphabetical List
Mass matrix, specified as a sparse matrix or full matrix. Generally, you obtain M from a
previous call to assema or assempde. For the meaning of mass matrix, see “Elliptic
Equations” on page 5-79.
Example: [K,M,F,Q,G,H,R] = assempde(model,c,a,f)
Data Types: double
Complex Number Support: Yes
Neumann boundary condition vector, specified as a sparse vector or full vector. Generally,
you obtain G from a previous call to assemb or assempde. For the meaning of this vector,
see “Elliptic Equations” on page 5-79.
Example: [K,M,F,Q,G,H,R] = assempde(model,c,a,f)
Data Types: double
Complex Number Support: Yes
5-74
assempde
Dirichlet boundary condition matrix, specified as a sparse matrix or full matrix. Generally,
you obtain H from a previous call to assemb or assempde. For the meaning of this matrix,
see “Algorithms” on page 5-79.
Example: [K,M,F,Q,G,H,R] = assempde(model,c,a,f)
Data Types: double
Complex Number Support: Yes
Dirichlet boundary condition vector, specified as a sparse vector or full vector. Generally,
you obtain R from a previous call to assemb or assempde. For the meaning of this vector,
see “Algorithms” on page 5-79.
Example: [K,M,F,Q,G,H,R] = assempde(model,c,a,f)
Data Types: double
Complex Number Support: Yes
Subdomain labels, specified as a vector of positive integers. For 2-D geometry only. View
the subdomain labels in your geometry using the command
pdegplot(g,'SubdomainLabels','on')
Output Arguments
u — PDE solution
vector
5-75
5 Functions — Alphabetical List
• If the PDE is scalar, meaning only one equation, then u is a column vector
representing the solution u at each node in the mesh. u(i) is the solution at the ith
column of model.Mesh.Nodes or the ith column of p.
• If the PDE is a system of N > 1 equations, then u is a column vector with N*Np
elements, where Np is the number of nodes in the mesh. The first Np elements of u
represent the solution of equation 1, then next Np elements represent the solution of
equation 2, etc.
To plot the solution, use pdeplot for 2-D geometry, or see “Plot 3-D Solutions and Their
Gradients” on page 3-325.
Kc — Stiffness matrix
sparse matrix
Stiffness matrix, returned as a sparse matrix. See “Elliptic Equations” on page 5-79.
u1 = Kc\Fc returns the solution on the non-Dirichlet points. To obtain the solution u at
the nodes of the mesh,
u = B*(Kc\Fc) + ud
Generally, Kc, Fc, B, and ud make a slower but more accurate solution than Ks and Fs.
Fc — Load vector
vector
u = B*(Kc\Fc) + ud
Generally, Kc, Fc, B, and ud make a slower but more accurate solution than Ks and Fs.
B — Dirichlet nullspace
sparse matrix
u = B*(Kc\Fc) + ud
Generally, Kc, Fc, B, and ud make a slower but more accurate solution than Ks and Fs.
5-76
assempde
ud — Dirichlet vector
vector
u = B*(Kc\Fc) + ud
Generally, Kc, Fc, B, and ud make a slower but more accurate solution than Ks and Fs.
Finite element matrix for stiff-spring approximation, returned as a sparse matrix. See
“Algorithms” on page 5-79.
u = Ks\Fs.
Generally, Ks and Fs make a quicker but less accurate solution than Kc, Fc, B, and ud.
u = Ks\Fs.
Generally, Ks and Fs make a quicker but less accurate solution than Kc, Fc, B, and ud.
K — Stiffness matrix
sparse matrix
Stiffness matrix, returned as a sparse matrix. See “Elliptic Equations” on page 5-79.
K represents the stiffness matrix alone, unlike Kc or Ks, which are stiffness matrices
combined with other terms to enable immediate solution of a PDE.
5-77
5 Functions — Alphabetical List
M — Mass matrix
sparse matrix
Mass matrix. returned as a sparse matrix. See “Elliptic Equations” on page 5-79.
F — Load vector
vector
F represents the load vector alone, unlike Fc or Fs, which are load vectors combined with
other terms to enable immediate solution of a PDE.
Neumann boundary condition vector, returned as a sparse vector. See “Elliptic Equations”
on page 5-79.
H — Dirichlet matrix
sparse matrix
R — Dirichlet vector
sparse vector
5-78
assempde
More About
See “Systems of PDEs” on page 5-87 for details on the approach used to eliminate
Dirichlet conditions.
Stiff-Spring Approximation
This form of the finite element matrices converts Dirichlet boundary conditions to
Neumann boundary conditions using a stiff-spring approximation. Using this
approximation, assempde returns a matrix Ks and a vector Fs that represent the
combined finite element matrices. The approximate solution u is u = Ks\Fs.
See “Elliptic Equations” on page 5-79. For details of the stiff-spring approximation, see
“Systems of PDEs” on page 5-87.
Algorithms
Elliptic Equations
Partial Differential Equation Toolbox solves equations of the form
∂2 u ∂u
m +d − ∇ · c ∇u + au = f
∂t 2 ∂t
5-79
5 Functions — Alphabetical List
− ∇ ⋅ c ∇u + au = f
which the documentation calls an elliptic equation, whether or not the equation is elliptic
in the mathematical sense. The equation holds in Ω, where Ω is a bounded domain in two
or three dimensions. c, a, f, and the unknown solution u are complex functions defined on
Ω. c can also be a 2-by-2 matrix function on Ω. The boundary conditions specify a
combination of u and its normal derivative on the boundary:
Our nomenclature deviates slightly from the tradition for potential theory, where a
Neumann condition usually refers to the case q = 0 and our Neumann would be called a
mixed condition. In some contexts, the generalized Neumann boundary conditions is also
referred to as the Robin boundary conditions. In variational calculus, Dirichlet conditions
are also called essential boundary conditions and restrict the trial space. Neumann
conditions are also called natural conditions and arise as necessary conditions for a
solution. The variational form of the Partial Differential Equation Toolbox equation with
Neumann conditions is given below.
5-80
assempde
environment at your disposal to solve the linear system and further process the
solution.
More elaborate applications make use of the Finite Element Method (FEM) specific
information returned by the different functions of the software. Therefore we quickly
summarize the theory and technique of FEM solvers to enable advanced applications to
make full use of the computed quantities.
FEM can be summarized in the following sentence: Project the weak form of the
differential equation onto a finite-dimensional function space. The rest of this section
deals with explaining the preceding statement.
We start with the weak form of the differential equation. Without restricting the
generality, we assume generalized Neumann conditions on the whole boundary, since
Dirichlet conditions can be approximated by generalized Neumann conditions. In the
simple case of a unit matrix h, setting g = qr and then letting q → ∞ yields the Dirichlet
condition because division with a very large q cancels the normal derivative terms. The
actual implementation is different, since the preceding procedure may create
conditioning problems. The mixed boundary condition of the system case requires a more
complicated treatment, described in “Systems of PDEs” on page 5-87.
Assume that u is a solution of the differential equation. Multiply the equation with an
arbitrary test function v and integrate on Ω:
Ω
∫ − ∇ · c ∇u v + auv dx = ∫ f v dx
Ω
Ω
∫ c ∇u · ∇v + auv dx − ∫n ·
∂Ω
c ∇u v ds = ∫ f v dx
Ω
Ω
∫ c ∇u · ∇v + auv dx − ∫ −qu + g v ds = ∫ f v dx
∂Ω Ω
Ω
∫ c ∇u · ∇v + auv − f v dx − ∫ −qu + g v ds = 0 ∀v
∂Ω
5-81
5 Functions — Alphabetical List
This equation is called the variational, or weak, form of the differential equation.
Obviously, any solution of the differential equation is also a solution of the variational
problem. The reverse is true under some restrictions on the domain and on the coefficient
functions. The solution of the variational problem is also called the weak solution of the
differential equation.
The solution u and the test functions v belong to some function space V. The next step is
to choose an Np-dimensional subspace V Np ⊂ V. Project the weak form of the differential
equation onto a finite-dimensional function space simply means requesting u and v to lie
in V Np rather than V. The solution of the finite dimensional problem turns out to be the
element of V Np that lies closest to the weak solution when measured in the energy norm.
Convergence is guaranteed if the space V Np tends to V as Np→∞. Since the differential
operator is linear, we demand that the variational equation is satisfied for Np test-
functions Φi ∊V Np that form a basis, i.e.,
∫
Ω
c ∇u · ∇ϕi + auϕi − f ϕi dx − ∫ −qu + g ϕ ds = 0, i = 1, ..., N
∂Ω
i p
Np
u(x) = ∑ U jϕ j(x)
j=1
Np
Ki, j = ∫ c ∇ϕ
Ω
j ⋅ ∇ϕi dx (stiffness matrix)
Mi, j = ∫aϕ ϕ dx
Ω
j i (mass matrix)
5-82
assempde
Qi, j = ∫ qϕ ϕ ds
∂Ω
j i
Fi = ∫ f ϕ dx
Ω
i
Gi = ∫ gϕ ds
∂Ω
i
(K + M + Q)U = F + G. (5-2)
K, M, and Q are Np-by-Np matrices, and F and G are Np-vectors. K, M, and F are produced
by assema, while Q, G are produced by assemb. When it is not necessary to distinguish
K, M, and Q or F and G, we collapse the notations to KU = F, which form the output of
assempde.
When the problem is self-adjoint and elliptic in the usual mathematical sense, the matrix
K + M + Q becomes symmetric and positive definite. Many common problems have these
characteristics, most notably those that can also be formulated as minimization problems.
For the case of a scalar equation, K, M, and Q are obviously symmetric. If c(x) ≥ δ > 0,
a(x) ≥ 0 and q(x) ≥ 0 with q(x) > 0 on some part of ∂Ω, then, if U ≠ 0.
UT K + M + Q U = ∫ cu
Ω
2
+ au2 dx + ∫ qu
∂Ω
2 ds > 0, if U ≠ 0
UT(K + M + Q)U is the energy norm. There are many choices of the test-function spaces.
The software uses continuous functions that are linear on each element of a 2-D mesh,
and are linear or quadratic on elements of a 3-D mesh. Piecewise linearity guarantees
that the integrals defining the stiffness matrix K exist. Projection onto V Np is nothing
more than linear interpolation, and the evaluation of the solution inside an element is
done just in terms of the nodal values. If the mesh is uniformly refined, V Np approximates
the set of smooth functions on Ω.
A suitable basis for V Np in 2-D is the set of “tent” or “hat” functions ϕi. These are linear
on each element and take the value 0 at all nodes xj except for xi. For the definition of
basis functions for 3-D geometry, see “Finite Element Basis for 3-D” on page 5-91.
Requesting ϕi(xi) = 1 yields the very pleasant property
5-83
5 Functions — Alphabetical List
Np
u xi = ∑ U jϕ j xi = Ui
j=1
That is, by solving the FEM system we obtain the nodal values of the approximate
solution. The basis function ϕi vanishes on all the elements that do not contain the node
xi. The immediate consequence is that the integrals appearing in Ki,j, Mi,j, Qi,j, Fi and Gi
only need to be computed on the elements that contain the node xi. Secondly, it means
that Ki,j andMi,j are zero unless xi and xj are vertices of the same element and thus K and
M are very sparse matrices. Their sparse structure depends on the ordering of the indices
of the mesh points.
The integrals in the FEM matrices are computed by adding the contributions from each
element to the corresponding entries (i.e., only if the corresponding mesh point is a
vertex of the element). This process is commonly called assembling, hence the name of
the function assempde.
The assembling routines scan the elements of the mesh. For each element they compute
the so-called local matrices and add their components to the correct positions in the
sparse matrices or vectors.
The discussion now specializes to triangular meshes in 2-D. The local 3-by-3 matrices
contain the integrals evaluated only on the current triangle. The coefficients are assumed
constant on the triangle and they are evaluated only in the triangle barycenter. The
integrals are computed using the midpoint rule. This approximation is optimal since it has
the same order of accuracy as the piecewise linear interpolation.
Consider a triangle given by the nodes P1, P2, and P3 as in the following figure.
5-84
assempde
Note The local 3-by-3 matrices contain the integrals evaluated only on the current
triangle. The coefficients are assumed constant on the triangle and they are evaluated
only in the triangle barycenter.
area ΔP1P2P3
mi, j = ∫
ΔP1P2P3
a Pc ϕi x ϕ j x dx = a Pc
12
1 + δi, j
P1 + P2 + P3
Pc =
3
5-85
5 Functions — Alphabetical List
area ΔP1P2P3
f i = f Pc
3
For the local stiffness matrix we have to evaluate the gradients of the basis functions that
do not vanish on P1P2P3. Since the basis functions are linear on the triangle P1P2P3, the
gradients are constants. Denote the basis functions ϕ1, ϕ2, and ϕ3 such that ϕ(Pi) = 1. If P2
– P3 = [x1,y1]T then we have that
1 y1
∇ϕ1 =
2 area ΔP1P2P3 −x1
1 y1
ki, j = y j, − x j c Pc
4 area ΔP1P2P3 −x1
If two vertices of the triangle lie on the boundary ∂Ω, they contribute to the line integrals
associated to the boundary conditions. If the two boundary points are P1 and P2, then we
have
P1 − P2
Qi, j = q Pb 1 + δi, j , i, j = 1, 2
6
and
P1 − P2
Gi = g Pb , i = 1, 2
2
For each triangle the vertices Pm of the local triangle correspond to the indices im of the
mesh points. The contributions of the individual triangle are added to the matrices such
that, e.g.,
This is done by the function assempde. The gradients and the areas of the triangles are
computed by the function pdetrg.
5-86
assempde
The Dirichlet boundary conditions are treated in a slightly different manner. They are
eliminated from the linear system by a procedure that yields a symmetric, reduced
system. The function assempde can return matrices K, F, B, and ud such that the solution
is u = Bv + ud where Kv = F. u is an Np-vector, and if the rank of the Dirichlet conditions
is rD, then v has Np – rD components.
1 Generate the finite element matrices [K,M,F,Q,G,H,R]. This step is equivalent to calling
assema to generate the matrices K, M, and F, and also calling assemb to generate the
matrices Q, G, H, and R.
2 Generate the combined finite element matrices [Kc,Fc,B,ud]. The combined stiffness
matrix is for the reduced linear system, Kc = K + M + Q. The corresponding
combined load vector is Fc = F + G. The B matrix spans the null space of the
columns of H (the Dirichlet condition matrix representing hu = r). The R vector
represents the Dirichlet conditions in Hu = R. The ud vector represents boundary
condition solutions for the Dirichlet conditions.
3 Calculate the solution u via
u = B*(Kc\Fc) + ud.
assempde uses one of two algorithms for assembling a problem into combined finite
element matrix form. A reduced linear system form leads to immediate solution via linear
algebra. You choose the algorithm by the number of outputs. For the reduced linear
system form, request four outputs:
[Kc,Fc,B,ud] = assempde(_)
[Ks,Fs] = assempde(_)
For details, see “Reduced Linear System” on page 5-79 and “Stiff-Spring Approximation”
on page 5-79.
Systems of PDEs
Partial Differential Equation Toolbox software can also handle systems of N partial
differential equations over the domain Ω. We have the elliptic system
5-87
5 Functions — Alphabetical List
− ∇ ⋅ c ⊗ ∇u + au = f
∂u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t
∂2 u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t2
− ∇ ⋅ c ⊗ ∇u + au = λdu
For 2-D systems, the notation ∇ ⋅ (c ⊗ ∇u) represents an N-by-1 matrix with an (i,1)-
component
N
∂ ∂ ∂ ∂ ∂ ∂ ∂ ∂
∑ c
∂x i, j, 1, 1 ∂x
+ c
∂x i, j, 1, 2 ∂y
+ c
∂y i, j, 2, 1 ∂x
+ c u
∂y i, j, 2, 2 ∂y j
j=1
For 3-D systems, the notation ∇ ⋅ (c ⊗ ∇u) represents an N-by-1 matrix with an (i,1)-
component
N
∂ ∂ ∂ ∂ ∂ ∂
∑ c
∂x i, j, 1, 1 ∂x
+ c
∂x i, j, 1, 2 ∂y
+ c u
∂x i, j, 1, 3 ∂z j
j=1
N
∂ ∂ ∂ ∂ ∂ ∂
+ ∑ c
∂y i, j, 2, 1 ∂x
+ c
∂y i, j, 2, 2 ∂y
+ c u
∂y i, j, 2, 3 ∂z j
j=1
N
∂ ∂ ∂ ∂ ∂ ∂
+ ∑ c
∂z i, j, 3, 1 ∂x
+ c
∂z i, j, 3, 2 ∂y
+ c u
∂z i, j, 3, 3 ∂z j
j=1
The symbols a and d denote N-by-N matrices, and f denotes a column vector of length N.
The elements cijkl, aij, dij, and fi of c, a, d, and f are stored row-wise in the MATLAB
matrices c, a, d, and f. The case of identity, diagonal, and symmetric matrices are
handled as special cases. For the tensor cijkl this applies both to the indices i and j, and to
the indices k and l.
5-88
assempde
Partial Differential Equation Toolbox software does not check the ellipticity of the
problem, and it is quite possible to define a system that is not elliptic in the mathematical
sense. The preceding procedure that describes the scalar case is applied to each
component of the system, yielding a symmetric positive definite system of equations
whenever the differential system possesses these characteristics.
The boundary conditions now in general are mixed, i.e., for each point on the boundary a
combination of Dirichlet and generalized Neumann conditions,
hu = r
n · c ⊗ ∇u + qu = g + h′μ
For 2-D systems, the notation n · c ⊗ ∇u represents an N-by-1 matrix with (i,1)-
component
N
∂ ∂ ∂ ∂
∑ cos(α)ci, j, 1, 1
∂x
+ cos(α)ci, j, 1, 2
∂y
+ sin(α)ci, j, 2, 1
∂x
+ sin(α)ci, j, 2, 2 u
∂y j
j=1
For 3-D systems, the notation n · c ⊗ ∇u represents an N-by-1 matrix with (i,1)-
component
N
∂ ∂ ∂
∑ cos(α)ci, j, 1, 1
∂x
+ cos(α)ci, j, 1, 2
∂y
+ cos(α)ci, j, 1, 3 u
∂z j
j=1
N
∂ ∂ ∂
+ ∑ cos(β)ci, j, 2, 1
∂x
+ cos(β)ci, j, 2, 2
∂y
+ cos(β)ci, j, 2, 3 u
∂z j
j=1
N
∂ ∂ ∂
+ ∑ cos(γ)ci, j, 3, 1
∂x
+ cos(γ)ci, j, 3, 2
∂y
+ cos(γ)ci, j, 3, 3 u
∂z j
j=1
There are M Dirichlet conditions and the h-matrix is M-by-N, M ≥ 0. The generalized
Neumann condition contains a source h′μ, where the Lagrange multipliers μ are
computed such that the Dirichlet conditions become satisfied. In a structural mechanics
problem, this term is exactly the reaction force necessary to satisfy the kinematic
constraints described by the Dirichlet conditions.
5-89
5 Functions — Alphabetical List
The rest of this section details the treatment of the Dirichlet conditions and may be
skipped on a first reading.
hu = r
L(h′hu − h′r)
When this number is increased, hu = r will be more accurately satisfied, but the potential
ill-conditioning of the modified equations will become more serious.
The second method is also applicable to general mixed conditions with nondiagonal h,
and is free of the ill-conditioning, but is more involved computationally. Assume that there
are Np nodes in the mesh. Then the number of unknowns is NpN = Nu. When Dirichlet
boundary conditions fix some of the unknowns, the linear system can be correspondingly
reduced. This is easily done by removing rows and columns when u values are given, but
here we must treat the case when some linear combinations of the components of u are
given, hu = r. These are collected into HU = R where H is an M-by-Nu matrix and R is an
M-vector.
KU +H´ µ = F
HU = R.
The constraints can be solved for M of the U-variables, the remaining called V, an Nu – M
vector. The null space of H is spanned by the columns of B, and U = BV + ud makes U
satisfy the Dirichlet conditions. A permutation to block-diagonal form exploits the sparsity
of H to speed up the following computation to find B in a numerically stable way. µ can be
eliminated by pre-multiplying by B´ since, by the construction, HB = 0 or B´H´ = 0. The
reduced system becomes
B´ KBV = B´ F – B´Kud
5-90
assempde
p4
p1
p2 p3
r s
ϕ1 = 1 − r − s − t
ϕ2 = r
ϕ3 = s
ϕ4 = t
For a quadratic tetrahedron, there are additional nodes at the edge midpoints.
5-91
5 Functions — Alphabetical List
p4
p8
p9 p1 p10
p5 p7
p2 p3
p6
r s
As in the 2-D case, a 3-D basis function ϕi takes the value 0 at all nodes j, except for node
i, where it takes the value 1.
See Also
assembleFEMatrices | solvepde
5-92
assempde
5-93
5 Functions — Alphabetical List
BodyLoadAssignment Properties
Body load assignments
Description
A BodyLoadAssignment object contains a description of the body loads for a structural
analysis model. A StructuralModel container has a vector of BodyLoadAssignment
objects in its BodyLoads.BodyLoadAssignments property.
To create body load assignments for your structural analysis model, use the
structuralBodyLoad function.
Properties
Properties of BodyLoadAssignment
Region type, returned as 'Face' for a 2-D region or 'Cell' for a 3-D region.
Data Types: char | string
RegionID — Region ID
vector of positive integers
Acceleration due to gravity, returned as a numeric vector. This property must be specified
in units consistent with the geometry and material properties units.
5-94
BodyLoadAssignment Properties
Example:
structuralBodyLoad(structuralmodel,'GravitationalAcceleration',
[0,0,-9.8])
Data Types: double
See Also
findBodyLoad | structuralBodyLoad
Introduced in R2017b
5-95
5 Functions — Alphabetical List
BoundaryCondition Properties
Boundary condition for PDE model
Description
A BoundaryCondition object specifies the type of PDE boundary condition on a set of
geometry boundaries. A PDEModel object contains a vector of BoundaryCondition
objects in its BoundaryConditions property.
Properties
Properties
Geometric region type, returned as 'Face' for 3-D geometry or 'Edge' for 2-D
geometry.
Example: applyBoundaryCondition(model,'dirichlet','Face',3,'u',0)
Data Types: char | string
5-96
BoundaryCondition Properties
Geometric region ID, returned as a vector of positive integers. Find the region IDs by
using pdegplot with the 'FaceLabels' (3-D) or 'EdgeLabels' (2-D) value set to
'on'.
Example: applyBoundaryCondition(model,'dirichlet','Face',3:6,'u',0)
Data Types: double
Dirichlet condition h*u = r, returned as an N-by-N matrix, a vector with N^2 elements,
or a function handle. N is the number of PDEs in the system. For the syntax of the
function handle form of h, see “Nonconstant Boundary Conditions” on page 2-129.
Example: 'h',[2,1;1,2]
Data Types: double | function_handle
Complex Number Support: Yes
5-97
5 Functions — Alphabetical List
u — Dirichlet conditions
zeros(N,1) (default) | vector of up to N elements | function handle
For the syntax of the function handle form of u, see “Nonconstant Boundary Conditions”
on page 2-129.
Example: applyBoundaryCondition(model,'dirichlet','Face',
[2,4,11],'u',0)
Data Types: double
Complex Number Support: Yes
Index of the known u components, returned as a vector of integers with entries from 1 to
N. EquationIndex and u must have the same length.
Example: applyBoundaryCondition(model,'mixed','Face',[2,4,11],'u',
[3,-1],'EquationIndex',[2,3])
Data Types: double
5-98
BoundaryCondition Properties
Vectorized function evaluation, returned as 'on' or 'off'. This evaluation applies when
you pass a function handle as an argument. To save time in function handle evaluation,
specify 'on', assuming that your function handle computes in a vectorized fashion. See
“Vectorization” (MATLAB). For details of this evaluation, see “Nonconstant Boundary
Conditions” on page 2-129.
Example: applyBoundaryCondition(model,'dirichlet','Face',
[2,4,11],'u',@ucalculator,'Vectorized','on')
Data Types: char
See Also
PDEModel | applyBoundaryCondition | findBoundaryConditions
Topics
“Specify Boundary Conditions” on page 2-124
“View, Edit, and Delete Boundary Conditions” on page 2-142
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2015a
5-99
5 Functions — Alphabetical List
CoefficientAssignment Properties
Coefficient assignments
Description
A CoefficientAssignment object contains a description of the PDE coefficients. A
PDEModel container has a vector of CoefficientAssignment objects in its
EquationCoefficients.CoefficientAssignments property.
∂2 u ∂u
m +d − ∇ · c ∇u + au = f
∂t 2 ∂t
− ∇ · c ∇u + au = λdu
or
2
− ∇ · c ∇u + au = λ mu
Properties
Properties
Region type, returned as 'face' for a 2-D region, or 'cell' for a 3-D region.
Data Types: char | string
RegionID — Region ID
vector of positive integers
5-100
CoefficientAssignment Properties
Solution multiplier coefficient, returned as a scalar, column vector, or function handle. For
details of the a coefficient specification, see “m, d, or a Coefficient for specifyCoefficients”
on page 2-104.
Data Types: double | function_handle
5-101
5 Functions — Alphabetical List
f — Source coefficient
scalar | column vector | function handle
Source coefficient, returned as a scalar, column vector, or function handle. For details of
the f coefficient specification, see “f Coefficient for specifyCoefficients” on page 2-79.
Data Types: double | function_handle
Complex Number Support: Yes
See Also
findCoefficients | specifyCoefficients
Topics
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2016a
5-102
createpde
createpde
Create model
Syntax
structuralmodel = createpde('structural',StructuralAnalysisType)
thermalmodel = createpde('thermal',ThermalAnalysisType)
model = createpde(N)
Description
structuralmodel = createpde('structural',StructuralAnalysisType)
returns a structural analysis model for the specified analysis type. This model lets you
solve small-strain linear elasticity problems.
Examples
model = createpde(3)
model =
PDEModel with properties:
PDESystemSize: 3
5-103
5 Functions — Alphabetical List
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
thermalmodel =
ThermalModel with properties:
AnalysisType: 'steadystate'
Geometry: []
MaterialProperties: []
5-104
createpde
HeatSources: []
StefanBoltzmannConstant: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
thermalmodel = createpde('thermal','transient')
thermalmodel =
ThermalModel with properties:
AnalysisType: 'transient'
Geometry: []
MaterialProperties: []
HeatSources: []
StefanBoltzmannConstant: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
staticStructural = createpde('structural','static-solid')
staticStructural =
StructuralModel with properties:
AnalysisType: 'static-solid'
Geometry: []
MaterialProperties: []
BodyLoads: []
BoundaryConditions: []
ReferenceTemperature: []
SuperelementInterfaces: []
5-105
5 Functions — Alphabetical List
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
transientStructural =
StructuralModel with properties:
AnalysisType: 'transient-planestress'
Geometry: []
MaterialProperties: []
BodyLoads: []
BoundaryConditions: []
DampingModels: []
InitialConditions: []
SuperelementInterfaces: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
Create a modal analysis structural model for solving a plane-strain (2-D) problem.
modalStructural = createpde('structural','modal-planestrain')
modalStructural =
StructuralModel with properties:
AnalysisType: 'modal-planestrain'
Geometry: []
MaterialProperties: []
BoundaryConditions: []
SuperelementInterfaces: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
Create a frequency response analysis structural model for solving a solid (3-D) problem.
frStructural = createpde('structural','frequency-solid')
frStructural =
StructuralModel with properties:
5-106
createpde
AnalysisType: 'frequency-solid'
Geometry: []
MaterialProperties: []
BodyLoads: []
BoundaryConditions: []
DampingModels: []
SuperelementInterfaces: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
Input Arguments
N — Number of equations
1 (default) | positive integer
Number of equations, specified as a positive integer. You do not need to specify N for a
model where N = 1.
Example: model = createpde
Example: model = createpde(3);
Data Types: double
5-107
5 Functions — Alphabetical List
5-108
createpde
Output Arguments
model — PDE model
PDEModel object
See Also
PDEModel | StructuralModel | ThermalModel
Topics
“Solve Problems Using PDEModel Objects” on page 2-3
“Equations You Can Solve Using PDE Toolbox” on page 1-3
Introduced in R2015a
5-109
5 Functions — Alphabetical List
createPDEResults
Create solution object
Note This page describes the legacy workflow. New features might not be compatible
with the legacy workflow. For the corresponding step in the recommended workflow, see
solvepde and solvepdeeig.
The original (R2015b) version of createPDEResults had only one syntax, and created a
PDEResults object. Beginning with R2016a, you generally do not need to use
createPDEResults, because the solvepde and solvepdeeig functions return solution
objects. Furthermore, createPDEResults returns an object of a newer type than
PDEResults. If you open an existing PDEResults object, it is converted to a
StationaryResults object.
If you use one of the older solvers such as adaptmesh, then you can use
createPDEResults to obtain a solution object. Stationary and time-dependent solution
objects have gradients available, whereas PDEResults did not include gradients.
Syntax
results = createPDEResults(model,u)
results = createPDEResults(model,u,'stationary')
results = createPDEResults(model,u,utimes,'time-dependent')
results = createPDEResults(model,eigenvectors,eigenvalues,'eigen')
Description
results = createPDEResults(model,u) creates a StationaryResults solution
object from model and its solution u.
5-110
createPDEResults
results = createPDEResults(model,eigenvectors,eigenvalues,'eigen')
creates an EigenResults solution object from model, its eigenvector solution
eigenvectors, and its eigenvalues eigenvalues.
Examples
Create a PDE model for a system of three equations. Import the geometry of a bracket
and plot the face labels.
model = createpde(3);
importGeometry(model,'BracketWithHole.stl');
figure
pdegplot(model,'FaceLabels','on')
view(30,30)
title('Bracket with Face Labels')
5-111
5 Functions — Alphabetical List
figure
pdegplot(model,'FaceLabels','on')
view(-134,-32)
title('Bracket with Face Labels, Rear View')
5-112
createPDEResults
Set boundary conditions: face 3 is immobile, and there is a force in the negative z
direction on face 6.
applyBoundaryCondition(model,'dirichlet','face',4,'u',[0,0,0]);
applyBoundaryCondition(model,'neumann','face',8,'g',[0,0,-1e4]);
5-113
5 Functions — Alphabetical List
generateMesh(model,'Hmax',1e-2);
u = assempde(model,c,a,f);
results = createPDEResults(model,u)
results =
StationaryResults with properties:
pdeplot3D(model,'ColorMapData',results.NodalSolution(:,3))
5-114
createPDEResults
model = createpde();
importGeometry(model,'Tetrahedron.stl');
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
view(45,45)
5-115
5 Functions — Alphabetical List
Set the temperature on face 2 to 100. Leave the other boundary conditions at their
default values (insulating).
applyBoundaryCondition(model,'dirichlet','face',2,'u',100);
d = 1;
c = 1;
a = 0;
f = 0;
u0 = 0;
Create a mesh and solve the PDE for times from 0 through 200 in steps of 10.
5-116
createPDEResults
tlist = 0:10:200;
generateMesh(model);
u = parabolic(u0,tlist,model,c,a,f,d);
results = createPDEResults(model,u,tlist,'time-dependent');
pdeplot3D(model,'ColorMapData',results.NodalSolution(:,11))
5-117
5 Functions — Alphabetical List
Create the geometry and mesh for the L-shaped membrane. Apply Dirichlet boundary
conditions to all edges.
model = createpde;
geometryFromEdges(model,@lshapeg);
generateMesh(model,'Hmax',0.05,'GeometricOrder','linear');
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
5-118
createPDEResults
Solve the eigenvalue problem for coefficients c = 1, a = 0, and d = 1. Obtain solutions for
eigenvalues from 0 through 100.
c = 1;
a = 0;
d = 1;
r = [0,100];
[eigenvectors,eigenvalues] = pdeeig(model,c,a,d,r);
results = createPDEResults(model,eigenvectors,eigenvalues,'eigen')
results =
EigenResults with properties:
pdeplot(model,'XYData',results.Eigenvectors(:,10))
5-119
5 Functions — Alphabetical List
Input Arguments
model — PDE model
PDEModel object
u — PDE solution
vector | matrix
5-120
createPDEResults
Times for a PDE solution, specified as a monotone vector. These times should be the same
as the tlist times that you specified for the solution by the hyperbolic or parabolic
solvers.
Example: utimes = 0:0.2:5;
Output Arguments
results — PDE solution
StationaryResults object (default) | TimeDependentResults object |
EigenResults object
5-121
5 Functions — Alphabetical List
Tips
• Dimensions of the returned solutions and gradients are the same as those returned by
solvepde and solvepdeeig. For details, see “Dimensions of Solutions, Gradients,
and Fluxes” on page 3-347.
Algorithms
The procedure for evaluating gradients at nodal locations is as follows:
1 Calculate the gradients at the Gauss points located inside each element.
2 Extrapolate the gradients at the nodal locations.
3 Average the value of the gradient from all elements that meet at the nodal point. This
step is needed because of the inter-element discontinuity of gradients. The elements
that connect at the same nodal point give different extrapolated values of the
gradient for the point. createPDEResults performs area-weighted averaging for 2-
D meshes and volume-weighted averaging for 3-D meshes.
See Also
EigenResults | StationaryResults | TimeDependentResults |
evaluateGradient | interpolateSolution
5-122
createPDEResults
Topics
“Linear Elasticity Equations” on page 3-150
Introduced in R2015b
5-123
5 Functions — Alphabetical List
csgchk
Check validity of Geometry Description matrix
Syntax
gstat = csgchk(gd,xlim,ylim)
gstat = csgchk(gd)
Description
gstat = csgchk(gd,xlim,ylim) checks if the solid objects in the Geometry
Description matrix gd are valid, given optional real numbers xlim and ylim as current
length of the x- and y-axis, and using a special format for polygons. For a polygon, the last
vertex coordinate can be equal to the first one, to indicate a closed polygon. If xlim and
ylim are specified and if the first and the last vertices are not equal, the polygon is
considered as closed if these vertices are within a certain “closing distance.” These
optional input arguments are meant to be used only when calling csgchk from the PDE
Modeler app.
gstat = csgchk(gd) is identical to the preceding call, except for using the same
format of gd that is used by decsg. This call is recommended when using csgchk as a
command-line function.
gstat is a row vector of integers that indicates the validity status of the corresponding
solid objects, i.e., columns, in gd.
For a circle solid, gstat = 0 indicates that the circle has a positive radius, 1 indicates a
nonpositive radius, and 2 indicates that the circle is not unique.
For a polygon, gstat = 0 indicates that the polygon is closed and does not intersect
itself, i.e., it has a well-defined, unique interior region. 1 indicates an open and non-self-
intersecting polygon, 2 indicates a closed and self-intersecting polygon, and 3 indicates
an open and self-intersecting polygon.
5-124
csgchk
For an ellipse solid, gstat = 0 indicates that the ellipse has positive semiaxes, 1
indicates that at least one of the semiaxes is nonpositive, and 2 indicates that the ellipse
is not unique.
If gstat consists of zero entries only, then gd is valid and can be used as input argument
by decsg.
See Also
decsg
5-125
5 Functions — Alphabetical List
csgdel
Delete borders between minimal regions
Syntax
[dl1,bt1] = csgdel(dl,bt,bl)
[dl1,bt1] = csgdel(dl,bt)
Description
[dl1,bt1] = csgdel(dl,bt,bl) deletes the border segments in the list bl. If the
consistency of the Decomposed Geometry matrix is not preserved by deleting the
elements in the list bl, additional border segments are deleted. Boundary segments
cannot be deleted.
For an explanation of the concepts or border segments, boundary segments, and minimal
regions, see decsg.
dl and dl1 are Decomposed Geometry matrices. For a description of the Decomposed
Geometry matrix, see decsg. The format of the Boolean tables bt and bt1 is also
described in the entry on decsg.
See Also
csgchk | decsg
5-126
decsg
decsg
Decompose constructive solid 2-D geometry into minimal regions
Syntax
dl = decsg(gd,sf,ns)
dl = decsg(gd)
[dl,bt] = decsg( ___ )
Description
dl = decsg(gd,sf,ns) decomposes the geometry description matrix gd into the
geometry matrix dl and returns the minimal regions that satisfy the set formula sf. The
name-space matrix ns is a text matrix that relates the columns in gd to variable names in
sf.
Typically, you draw a geometry in the PDE Modeler app, then export it to the MATLAB
Command Window by selecting Export Geometry Description, Set Formula, Labels
from the Draw menu in the app. The resulting geometry description matrix gd represents
the CSG model. decsg analyzes the model and constructs a set of disjointed minimal
regions bounded by boundary segments and border segments. This set of minimal regions
constitutes the decomposed geometry and allows other Partial Differential Equation
Toolbox functions to work with the geometry.
Alternatively, you can use the decsg function when creating a geometry without using the
app. See “2-D Geometry Creation at Command Line” on page 2-5 for details.
To return all minimal regions (sf corresponds to the union of all shapes in gd), use the
shorter syntax dl = decsg(gd).
[dl,bt] = decsg( ___ ) returns a Boolean table (matrix) that relates the original
shapes to the minimal regions. A column in bt corresponds to the column with the same
index in gd. A row in bt corresponds to the index of a minimal region. You can use bt to
remove boundaries between subdomains.
5-127
5 Functions — Alphabetical List
Examples
Create a 2-D geometry in the PDE Modeler app, then export it to the MATLAB workspace
and decompose it to minimal regions by using decsg.
Start the PDE Modeler app and draw a unit circle and a unit square.
pdecirc(0,0,1)
pderect([0 1 0 1])
Export the geometry description matrix, set formula, and name-space matrix to the
MATLAB workspace by selecting the Export Geometry Description option from the
Draw menu.
Decompose the exported geometry into minimal regions. The result is one minimal region
with five edge segments: three circle edge segments and two line edge segments.
dl = decsg(gd,sf,ns)
dl =
2.0000 2.0000 1.0000 1.0000 1.0000
0 0 -1.0000 0.0000 0.0000
1.0000 0 0.0000 1.0000 -1.0000
0 1.0000 -0.0000 -1.0000 1.0000
0 0 -1.0000 0 -0.0000
0 0 1.0000 1.0000 1.0000
1.0000 1.0000 0 0 0
0 0 0 0 0
0 0 0 0 0
0 0 1.0000 1.0000 1.0000
View the geometry. Display the edge labels and the subdomain labels.
pdegplot(dl,'EdgeLabels','on','SubdomainLabels','on')
axis equal
5-128
decsg
For comparison, decompose the same geometry without specifying the set formula sf and
the name-space matrix ns. This syntax returns the union of all shapes in the geometry gd.
dl_all = decsg(gd)
dl_all =
2.0000 2.0000 2.0000 2.0000 1.0000 1.0000 1.0000 1.0000
0 1.0000 1.0000 0 -1.0000 0.0000 1.0000 0.0000
1.0000 1.0000 0 0 0.0000 1.0000 0.0000 -1.0000
0 0 1.0000 1.0000 -0.0000 -1.0000 0 1.0000
0 1.0000 1.0000 0 -1.0000 0 1.0000 -0.0000
3.0000 2.0000 2.0000 3.0000 1.0000 1.0000 3.0000 1.0000
1.0000 0 0 1.0000 0 0 2.0000 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 1.0000 1.0000 1.0000 1.0000
5-129
5 Functions — Alphabetical List
pdegplot(dl_all,'EdgeLabels','on','SubdomainLabels','on')
axis equal
Start the PDE Modeler app and draw a unit circle and a unit square.
pdecirc(0,0,1)
pderect([0 1 0 1])
Export the Geometry Description matrix, set formula, and Name Space matrix to the
MATLAB workspace by selecting the Export Geometry Description option from the
Draw menu.
5-130
decsg
Decompose the exported geometry into minimal regions. Because the geometry is a union
of all regions, C1+SQ1, you can omit the arguments specifying the set formula and name-
space matrix when using decsg.
[dl,bt] = decsg(gd)
dl =
2.0000 2.0000 2.0000 2.0000 1.0000 1.0000 1.0000 1.0000
0 1.0000 1.0000 0 -1.0000 0.0000 1.0000 0.0000
1.0000 1.0000 0 0 0.0000 1.0000 0.0000 -1.0000
0 0 1.0000 1.0000 -0.0000 -1.0000 0 1.0000
0 1.0000 1.0000 0 -1.0000 0 1.0000 -0.0000
3.0000 2.0000 2.0000 3.0000 1.0000 1.0000 3.0000 1.0000
1.0000 0 0 1.0000 0 0 2.0000 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 1.0000 1.0000 1.0000 1.0000
bt =
1 0
0 1
1 1
View the geometry. Display the edge labels and the subdomain labels.
pdegplot(dl,'EdgeLabels','on','SubdomainLabels','on')
axis equal
5-131
5 Functions — Alphabetical List
[dl2,bt2] = csgdel(dl,bt);
figure
pdegplot(dl2,'EdgeLabels','on','SubdomainLabels','on')
axis equal
5-132
decsg
Input Arguments
gd — Geometry description matrix
matrix of double-precision numbers
• For a circle, the first row contains 1. The second and third rows contain the x- and y-
coordinates of the center. The fourth row contains the radius of the circle.
• For a polygon, the first row contains 2. The second row contains n, which is the
number of line segments in the boundary of the polygon. The next n rows contain the
5-133
5 Functions — Alphabetical List
x-coordinates of the starting points of the edges, and the n rows after that contain the
y-coordinates of the starting points of the edges.
• For a rectangle, the first row contains 3, and the second row contains 4. The next four
rows contain the x-coordinates of the starting points of the edges, and the four rows
after that contain the y-coordinates of the starting points of the edges.
• For an ellipse, the first row contains 4. The second and third rows contain the x- and y-
coordinates of the center. The fourth and fifth rows contain the semiaxes of the ellipse.
The sixth row contains the rotational angle of the ellipse, measured in radians.
All shapes in a geometry description matrix have the same number of rows. Rows that are
not required for a particular shape are filled with zeros.
When you export geometry from the PDE Modeler app by selecting Export Geometry
Description, Set Formula, Labels from the Draw menu in the app, you can use any
variable name for the exported geometry description matrix in the MATLAB workspace.
The default name is gd.
Data Types: double
sf — Set formula
character vector | string scalar
Set formula, specified as a character vector or a string including the names of shapes,
such as C1, SQ2, E3, and the operators +, *, and - corresponding to the set operations
union, intersection, and set difference, respectively. The operators + and * have the same
precedence. The operator - has a higher precedence. You can control the precedence by
using parentheses.
When you export geometry from the PDE Modeler app by selecting Export Geometry
Description, Set Formula, Labels from the Draw menu in the app, you can use any
variable name for the formula in the MATLAB workspace. The default name is sf.
Example: '(SQ1+C1)-C2'
Data Types: char | string
ns — Name-space matrix
matrix of double-precision numbers
5-134
decsg
column assigns a name to the corresponding geometric object in gd, so you can refer to a
specific object in gd in the set formula sf.
When you export geometry from the PDE Modeler app by selecting Export Geometry
Description, Set Formula, Labels from the Draw menu in the app, you can use any
variable name for the name-space matrix in the MATLAB workspace. The default name is
ns.
Data Types: double
Output Arguments
dl — Decomposed geometry matrix
matrix of double-precision numbers
• For circle edge segments, the first row is 1. The eighth and ninth rows contain the
coordinates of the center of the circle. The 10th row contains the radius.
• For line edge segments, the first row is 2.
• For ellipse edge segments, the first row is 4. The eighth and ninth rows contain the
coordinates of the center of the ellipse. The 10th and 11th rows contain the semiaxes
of the ellipse. The 12th row contains the rotational angle of the ellipse.
All shapes in a decomposed geometry matrix have the same number of rows. Rows that
are not required for a particular shape are filled with zeros.
5-135
5 Functions — Alphabetical List
Boolean table relating the original shapes to the minimal regions, returned as a matrix of
1s and 0s.
Data Types: double
5-136
decsg
Limitations
• In rare cases decsg can error or create an invalid geometry because of the limitations
of its algorithm. Such issues can occur when two or more edges of a geometry
partially overlap, almost coincide, or are almost tangent.
Tips
• decsg does not check the input CSG model for correctness. It assumes that no circles
or ellipses are identical or degenerated and that no lines have zero length. Polygons
must not be self-intersecting. Use the function csgchk to check the CSG model.
• decsg returns NaN if it cannot evaluate the set formula sf.
See Also
PDE Modeler | csgchk | csgdel | geometryFromEdges | pdecirc | pdeellip |
pdepoly | pderect | wgeom
Topics
“2-D Geometry Creation at Command Line” on page 2-5
5-137
5 Functions — Alphabetical List
DiscreteGeometry Properties
Discrete 2-D or 3-D geometry description
Description
DiscreteGeometry describes a 2-D or 3-D geometry in the form of a discrete geometry
object. PDEModel, StructuralModel, and ThermalModel objects have a Geometry
property, which can be an AnalyticGeometry or DiscreteGeometry object.
Create a discrete geometry for your model by using one of the following approaches:
• Use importGeometry to import a 2-D or 3-D geometry from an STL file and attach it
to the model.
• Use geometryFromMesh to reconstruct a 2-D or 3-D geometry from mesh and attach
it to the model.
• Use multicuboid, multicylinder, or multisphere to create a 3-D geometry.
Then assign the resulting geometry to the Geometry property of the model. For
example, create a PDE model and add the following geometry formed by three spheres
to the model.
model = createpde;
gm = multisphere([1,2,3]);
model.Geometry = gm;
Properties
Properties
5-138
DiscreteGeometry Properties
See Also
AnalyticGeometry Properties | PDEModel | StructuralModel | ThermalModel |
geometryFromMesh | importGeometry | multicuboid | multicylinder |
multisphere
Topics
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2015a
5-139
5 Functions — Alphabetical List
dst, idst
(Not recommended) Discrete sine transform
Syntax
y = dst(x)
y = dst(x,n)
x = idst(y)
x = idst(y,n)
Description
The dst function implements the following equation:
N
kn
y(k) = ∑ x(n)sin π
N+1
, k = 1, ..., N
n=1
y = dst(x) computes the discrete sine transform of the columns of x. For best
performance speed, the number of rows in x should be 2m – 1, for some integer m.
x = idst(y) calculates the inverse discrete sine transform of the columns of y. For best
performance speed, the number of rows in y should be 2m – 1, for some integer m.
5-140
dst, idst
5-141
5 Functions — Alphabetical List
EigenResults
PDE eigenvalue solution and derived quantities
Description
An EigenResults object contains the solution of a PDE eigenvalue problem in a form
convenient for plotting and postprocessing.
Creation
There are several ways to create an EigenResults object:
• Solve an eigenvalue problem using the solvepdeeig function. This function returns a
PDE eigenvalue solution as an EigenResults object. This is the recommended
approach.
• Solve an eigenvalue problem using the pdeeig function. Then use the
createPDEResults function to obtain an EigenResults object from a PDE
eigenvalue solution returned by pdeeig. Note that pdeeig is a legacy function. It is
not recommended for solving eigenvalue problems.
Properties
Mesh — Finite element mesh
FEMesh object
5-142
EigenResults
Solution eigenvectors, returned as a matrix or 3-D array. The solution is a matrix for
scalar eigenvalue problems, and a 3-D array for eigenvalue systems. For details, see
“Dimensions of Solutions, Gradients, and Fluxes” on page 3-347.
Data Types: double
Solution eigenvalues, returned as a vector. The vector is in order by the real part of the
eigenvalues from smallest to largest.
Data Types: double
Object Functions
interpolateSolution Interpolate PDE solution to arbitrary points
Examples
Create the geometry for the L-shaped membrane. Apply zero Dirichlet boundary
conditions to all edges.
model = createpde;
geometryFromEdges(model,@lshapeg);
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
specifyCoefficients(model,'m',0,'d',1,'c',1,'a',0,'f',0);
Create the mesh and solve the eigenvalue problem for eigenvalues from 0 through 100.
generateMesh(model,'Hmax',0.05);
ev = [0,100];
results = solvepdeeig(model,ev)
5-143
5 Functions — Alphabetical List
5-144
EigenResults
results =
EigenResults with properties:
pdeplot(model,'XYData',results.Eigenvectors(:,10))
5-145
5 Functions — Alphabetical List
See Also
StationaryResults | TimeDependentResults | solvepdeeig
Topics
“Eigenvalues and Eigenmodes of L-Shaped Membrane” on page 3-287
“Eigenvalues and Eigenmodes of Square” on page 3-299
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2016a
5-146
evaluate
evaluate
Package: pde
Note This function supports the legacy workflow. Using the [p,e,t] representation of
FEMesh data is not recommended. Use interpolateSolution and
evaluateGradient to interpolate a PDE solution and its gradient to arbitrary points
without switching to a [p,e,t] representation.
Syntax
uOut = evaluate(F,pOut)
uOut = evaluate(F,x,y)
uOut = evaluate(F,x,y,z)
Description
uOut = evaluate(F,pOut) returns the interpolated values from the interpolant F at
the points pOut.
Note If a query point is outside the mesh, evaluate returns NaN for that point.
uOut = evaluate(F,x,y) returns the interpolated values from the interpolant F at the
points [x(k),y(k)], for k from 1 through numel(x). This syntax applies to 2-D
geometry.
5-147
5 Functions — Alphabetical List
Examples
This example shows how to interpolate a solution to a scalar problem using a pOut matrix
of values.
Solve the equation −Δu = 1 on the unit disk with zero Dirichlet conditions.
F = pdeInterpolant(p,t,u);
Generate a random set of coordinates in the unit square. Evaluate the interpolated
solution at the random points.
numNaN = 9
uOut contains some NaN entries because some points in pOut are outside of the unit disk.
Interpolate to x, y values
This example shows how to interpolate a solution to a scalar problem using x, y values.
Solve the equation −Δu = 1 on the unit disk with zero Dirichlet conditions.
5-148
evaluate
Evaluate the interpolated solution at grid points in the unit square with spacing 0.2.
[x,y] = meshgrid(0:0.2:1);
uOut = evaluate(F,x,y);
numNaN = sum(isnan(uOut))
numNaN = 12
uOut contains some NaN entries because some points in the unit square are outside of the
unit disk.
Solve the system of equations −Δu = f with Dirichlet boundary conditions on the unit
disk, where
T
xy
f = sin(x) + cos(y), cosh(xy), .
1 + x2 + y2
5-149
5 Functions — Alphabetical List
a = 0;
f = char('sin(x) + cos(y)','cosh(x.*y)','x.*y./(1+x.^2+y.^2)');
u = assempde(problem,p,e,t,c,a,f); % solve the PDE
s = linspace(0,2*pi);
x = 0.5 + 0.4*cos(s);
y = 0.4*sin(s);
uOut = evaluate(F,x,y);
npts = length(x);
plot3(x,y,uOut(1:npts),'b')
hold on
plot3(x,y,uOut(npts+1:2*npts),'k')
plot3(x,y,uOut(2*npts+1:end),'r')
hold off
view(35,35)
5-150
evaluate
∂u
− Δu = 1
∂t
on the unit disk with zero Dirichlet conditions and zero initial conditions. Solve at five
times from 0 to 1.
5-151
5 Functions — Alphabetical List
52 successful steps
0 failed attempts
106 function evaluations
1 partial derivatives
13 LU decompositions
105 solutions of linear systems
F = pdeInterpolant(p,t,u);
x = 0.1;
y = -0.1;
uOut = evaluate(F,x,y)
uOut = 1×5
Interpolate to a Grid
5-152
evaluate
Use the built-in geometry functions to create an L-shaped region with zero Dirichlet
boundary conditions. Solve an elliptic PDE with coefficients c = 1, a = 0, f = 1, with zero
Dirichlet boundary conditions.
Create an Interpolant
F = pdeInterpolant(p,t,u);
xgrid = -1:0.1:1;
ygrid = -1:0.2:1;
[X,Y] = meshgrid(xgrid,ygrid);
The resulting grid has some points that are outside the L-shaped region.
uout = evaluate(F,X,Y);
The interpolated solution uout is a column vector. You can reshape it to match the size of
X or Y. This gives a matrix, like the output of the tri2grid function.
Z = reshape(uout,size(X));
Input Arguments
F — Interpolant
output of pdeInterpolant
5-153
5 Functions — Alphabetical List
Query points, specified as a matrix with two or three rows. The first row represents the x
component of the query points, the second row represents the y component, and, for 3-D
geometry, the third row represents the z component. evaluate computes the interpolant
at each column of pOut. In other words, evaluate interpolates at the points pOut(:,k).
Example: pOut = [-1.5,0,1;
1,1,2.2]
Data Types: double
evaluate transforms query point components to the linear index representation, such as
x(:).
Example: x = -1:0.2:3
Data Types: double
evaluate transforms query point components to the linear index representation, such as
y(:).
Example: y = -1:0.2:3
Data Types: double
5-154
evaluate
evaluate transforms query point components to the linear index representation, such as
z(:).
Example: z = -1:0.2:3
Data Types: double
Output Arguments
uOut — Interpolated values
array
Interpolated values, returned as an array. uOut has the same number of columns as the
data u used in creating F. If u depends on time, uOut contains a column for each time
step. For time-independent u, uOut has one column.
The number of rows in uOut is the number of equations in the PDE system, N, times the
number of query points, pOut. The first pOut rows correspond to equation 1, the next
pOut rows correspond to equation 2, and so on.
If a query point is outside the mesh, evaluate returns NaN for that point.
More About
Element
An element is a basic unit in the finite-element method.
For 3-D problems, an element is a tetrahedron with either four or ten points. A four-point
(linear) tetrahedron has nodes only at its corners. A ten-point (quadratic) tetrahedron has
nodes at its corners and at the center point of each edge.
5-155
5 Functions — Alphabetical List
Algorithms
For each point where a solution is requested (pOut), there are two steps in the
interpolation process. First, the element containing the point must be located and second,
interpolation within that element must be performed using the element shape functions
and the values of the solution at the element’s node points.
See Also
pdeInterpolant
Topics
“Mesh Data” on page 2-171
Introduced in R2014b
5-156
evaluateCGradient
evaluateCGradient
Package: pde
Syntax
[cgradx,cgrady] = evaluateCGradient(results,xq,yq)
[cgradx,cgrady,cgradz] = evaluateCGradient(results,xq,yq,zq)
[ ___ ] = evaluateCGradient(results,querypoints)
[cgradx,cgrady] = evaluateCGradient(results)
[cgradx,cgrady,cgradz] = evaluateCGradient(results)
Description
[cgradx,cgrady] = evaluateCGradient(results,xq,yq) returns the flux of PDE
solution for the stationary equation at the 2-D points specified in xq and yq. The flux of
the solution is the tensor product of c-coefficient and gradients of the PDE solution,
c ⊗ ∇u.
[ ___ ] = evaluateCGradient( ___ ,iU) returns the flux of the solution of the PDE
system for equation indices (components) iU. When evaluating flux for a system of PDEs,
specify iU after the input arguments in any of the previous syntaxes.
5-157
5 Functions — Alphabetical List
The first dimension of cgradx, cgrady, and, in the 3-D case, cgradz corresponds to
query points. The second dimension corresponds to equation indices iU.
[ ___ ] = evaluateCGradient( ___ ,iT) returns the flux of PDE solution for the time-
dependent equation or system of time-dependent equations at times iT. When evaluating
flux for a time-dependent PDE, specify iT after the input arguments in any of the previous
syntaxes. For a system of time-dependent PDEs, specify both equation indices
(components) iU and time indices iT.
The first dimension of cgradx, cgrady, and, in the 3-D case, cgradz corresponds to
query points. For a single time-dependent PDE, the second dimension corresponds to
time-steps iT. For a system of time-dependent PDEs, the second dimension corresponds
to equation indices iU, and the third dimension corresponds to time-steps iT.
Examples
Solve the problem −Δu = 1 on the L-shaped membrane with zero Dirichlet boundary
conditions. Evaluate the tensor product of c-coefficient and gradients of the solution to a
scalar elliptic problem at nodal and arbitrary locations. Plot the results.
5-158
evaluateCGradient
model = createpde;
geometryFromEdges(model,@lshapeg);
pdegplot(model,'FaceLabels','on')
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
specifyCoefficients(model,'m',0,'d',0,'c',10,'a',0,'f',1,'Face',1);
specifyCoefficients(model,'m',0,'d',0,'c',5,'a',0,'f',1,'Face',2);
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',1,'Face',3);
5-159
5 Functions — Alphabetical List
generateMesh(model,'Hmax',0.05);
results = solvepde(model);
u = results.NodalSolution;
[cgradx,cgrady] = evaluateCGradient(results);
figure
pdeplot(model,'XYData',u,'Contour','on','FlowData',[cgradx,cgrady])
Compute the flux of the solution on the grid from -1 to 1 in each direction using the query
points matrix.
5-160
evaluateCGradient
v = linspace(-1,1,37);
[X,Y] = meshgrid(v);
querypoints = [X(:),Y(:)]';
[cgradxq,cgradyq] = evaluateCGradient(results,querypoints);
Alternatively, you can specify the query points as X,Y instead of specifying them as a
matrix.
[cgradxq,cgradyq] = evaluateCGradient(results,X,Y);
figure
quiver(X(:),Y(:),cgradxq,cgradyq)
xlabel('x')
ylabel('y')
5-161
5 Functions — Alphabetical List
N = 3;
model = createpde(N);
importGeometry(model,'SquareBeam.STL');
pdegplot(model,'FaceLabels','on')
5-162
evaluateCGradient
E = 2.1e11;
nu = 0.3;
c = elasticityC3D(E, nu);
a = 0;
f = [0;0;0];
specifyCoefficients(model,'m',0,'d',0,'c',c,'a',a','f',f);
applyBoundaryCondition(model,'dirichlet','Face',6,'u',[0 0 0]);
applyBoundaryCondition(model,'neumann','Face',5,'g',[0,0,-3e3]);
5-163
5 Functions — Alphabetical List
generateMesh(model,'Hmax',25,'GeometricOrder','quadratic');
results = solvepde(model);
Compute stress, that is, the product of c-coefficient and gradients of displacement.
[sig_xx,sig_yy,sig_zz] = evaluateCGradient(results);
Plot normal component of stress along x-direction. The top portion of the beam
experiences tension, and the bottom portion experiences compression.
figure
pdeplot3D(model,'ColorMapData',sig_xx(:,1))
Define a line across the beam from the bottom to the top at mid-span and mid-width.
Compute stresses along the line.
5-164
evaluateCGradient
[sig_xx,sig_xy,sig_xz] = evaluateCGradient(results,xg,yg,zg,1);
figure
plot(sig_xx,zg)
grid on
xlabel('\sigma_{xx}')
ylabel('z')
5-165
5 Functions — Alphabetical List
Compute stresses in an idealized 3-D mechanical part under an applied load. First, create
a PDE model for this problem.
N = 3;
model = createpde(N);
importGeometry(model,'BracketWithHole.stl');
figure
pdegplot(model,'FaceLabels','on')
view(30,30)
title('Bracket with Face Labels')
5-166
evaluateCGradient
figure
pdegplot(model,'FaceLabels','on')
view(-134,-32)
title('Bracket with Face Labels, Rear View')
5-167
5 Functions — Alphabetical List
applyBoundaryCondition(model,'dirichlet','Face',4,'u',[0,0,0]);
distributedLoad = 1e4; % Applied load in Pascals
applyBoundaryCondition(model,'neumann','Face',8,'g',[0,0,-distributedLoad]);
5-168
evaluateCGradient
result = solvepde(model);
Create a grid. For this grid, compute the stress tensor, which is the product of c-
coefficient and gradients of displacement.
v = linspace(0,0.2,21);
[xq,yq,zq] = meshgrid(v);
[cgradx,cgrady,cgradz] = evaluateCGradient(result);
sxx = cgradx(:,1);
sxy = cgradx(:,2);
sxz = cgradx(:,3);
syx = cgrady(:,1);
syy = cgrady(:,2);
syz = cgrady(:,3);
szx = cgradz(:,1);
szy = cgradz(:,2);
szz = cgradz(:,3);
Plot von Mises stress. The maximum stress occurs at the weakest section. This section
has the least material to support the applied load.
pdeplot3D(model,'colormapdata',sVonMises)
5-169
5 Functions — Alphabetical List
Solve a 2-D transient heat transfer problem on a square domain and compute heat flow
across convective boundary.
numberOfPDE = 1;
model = createpde(numberOfPDE);
5-170
evaluateCGradient
g = @squareg;
geometryFromEdges(model,g);
pdegplot(model,'EdgeLabels','on')
xlim([-1.2,1.2])
ylim([-1.2,1.2])
axis equal
rho = 7800;
cp = 500;
k = 100;
Text = 25;
hext = 5000;
5-171
5 Functions — Alphabetical List
Specify the coefficients. Apply insulated boundary conditions on three edges and the free
convection boundary condition on the right edge.
specifyCoefficients(model,'m',0,'d',rho*cp,'c',k,'a',0,'f',0);
applyBoundaryCondition(model,'neumann','Edge', [1,3,4],'q',0,'g',0);
applyBoundaryCondition(model,'neumann','Edge', 2,'q',hext,'g',Text*hext);
Set the initial conditions: uniform room temperature across domain and higher
temperature on the left edge.
setInitialConditions(model,25);
setInitialConditions(model, 100, 'Edge', 4);
Generate a mesh and solve the problem using 0:1000:200000 as a vector of times.
generateMesh(model);
tlist = 0:1000:200000;
results = solvepde(model,tlist);
yg = -1:0.1:1;
xg = ones(size(yg));
[qx,qy] = evaluateCGradient(results,xg,yg,1:length(tlist));
HeatFlowX(1:length(tlist)) = -trapz(yg,qx(:,1:length(tlist)));
figure
plot(tlist,HeatFlowX)
title('Heat flow across convection boundary')
xlabel('Time')
ylabel('Heat flow')
5-172
evaluateCGradient
Solve the heat transfer problem for the following 2-D geometry consisting of a square and
a diamond made of different materials. Compute the heat flux density and plot it as a
vector field.
5-173
5 Functions — Alphabetical List
geometryFromEdges(model,dl);
pdegplot(model,'EdgeLabels','on','FaceLabels','on')
xlim([-1.5,4.5])
ylim([-0.5,3.5])
axis equal
5-174
evaluateCGradient
rho_sq = 2;
C_sq = 0.1;
k_sq = 10;
Q_sq = 0;
h_sq = 0;
rho_d = 1;
C_d = 0.1;
k_d = 2;
Q_d = 4;
h_d = 0;
Specify the coefficients for both subdomains. Apply the boundary and initial conditions.
specifyCoefficients(model,'m',0,'d',rho_sq*C_sq,'c',k_sq,'a',h_sq,'f',Q_sq,'Face',1);
specifyCoefficients(model,'m',0,'d',rho_d*C_d,'c',k_d,'a',h_d,'f',Q_d,'Face',2);
applyBoundaryCondition(model,'dirichlet','Edge',[1,2,7,8],'h',1,'r',0);
setInitialConditions(model,0);
Mesh the geometry and solve the problem. To capture the most dynamic part of heat
distribution process, solve the problem using logspace(-2,-1,10) as a vector of times.
generateMesh(model);
tlist = logspace(-2,-1,10);
results = solvepde(model,tlist);
u = results.NodalSolution;
Compute the heat flux density. Plot the solution with isothermal lines using a contour plot,
and plot the heat flux vector field using arrows. The direction of the heat flow (from
higher to lower temperatures) is opposite to the direction of c ⊗ ∇u. Therefore, use -
cgradx and -cgrady to show the heat flow.
[cgradx,cgrady] = evaluateCGradient(results);
figure
pdeplot(model,'XYData',u(:,10),'Contour','on','FlowData',[-cgradx(:,10),-cgrady(:,10)],
5-175
5 Functions — Alphabetical List
Input Arguments
results — PDE solution
StationaryResults object | TimeDependentResults object
5-176
evaluateCGradient
evaluateCGradient converts query points to column vectors xq(:), yq(:), and (if
present) zq(:). For a single stationary PDE, the result consists of column vectors of the
same size. To ensure that the dimensions of the returned x-, y-, and z-components are
consistent with the dimensions of the original query points, use reshape. For example,
use cgradx = reshape(cgradx,size(xq)).
For a time-dependent PDE or a system of PDEs, the first dimension of the resulting arrays
corresponds to spatial points specified by the column vectors xq(:), yq(:), and (if
present) zq(:).
Data Types: double
evaluateCGradient converts query points to column vectors xq(:), yq(:), and (if
present) zq(:). For a single stationary PDE, the result consists of column vectors of the
same size. To ensure that the dimensions of the returned x-, y-, and z-components are
consistent with the dimensions of the original query points, use reshape. For example,
use cgrady = reshape(cgrady,size(yq)).
For a time-dependent PDE or a system of PDEs, the first dimension of the resulting arrays
corresponds to spatial points specified by the column vectors xq(:), yq(:), and (if
present) zq(:).
Data Types: double
5-177
5 Functions — Alphabetical List
For a time-dependent PDE or a system of PDEs, the first dimension of the resulting arrays
corresponds to spatial points specified by the column vectors xq(:), yq(:), and (if
present) zq(:).
Data Types: double
Query points, specified as a real matrix with either two rows for 2-D geometry or three
rows for 3-D geometry. evaluateCGradient evaluates the tensor product of c-
coefficient and gradients of the PDE solution at the coordinate points
querypoints(:,i), so each column of querypoints contains exactly one 2-D or 3-D
query point.
Example: For 2-D geometry, querypoints = [0.5,0.5,0.75,0.75; 1,2,0,0.5]
Data Types: double
iT — Time indices
vector of positive integers
Time indices, specified as a vector of positive integers. Each entry in iT specifies a time
index.
Example: iT = 1:5:21 specifies every fifth time-step up to 21.
Data Types: double
iU — Equation indices
vector of positive integers
5-178
evaluateCGradient
Example: iU = [1,5] specifies the indices for the first and fifth equations.
Data Types: double
Output Arguments
cgradx — x-component of the flux of the PDE solution
array
x-component of the flux of the PDE solution, returned as an array. The first array
dimension represents the node index. If results is a StationaryResults object, the
second array dimension represents the equation index for a system of PDEs. If results
is a TimeDependentResults object, the second array dimension represents either the
time-step for a single PDE or the equation index for a system of PDEs. The third array
dimension represents the time-step index for a system of time-dependent PDEs. For
information about the size of cgradx, see “Dimensions of Solutions, Gradients, and
Fluxes” on page 3-347.
For query points that are outside the geometry, cgradx = NaN.
y-component of the flux of the PDE solution, returned as an array. The first array
dimension represents the node index. If results is a StationaryResults object, the
second array dimension represents the equation index for a system of PDEs. If results
is a TimeDependentResults object, the second array dimension represents either the
time-step for a single PDE or the equation index for a system of PDEs. The third array
dimension represents the time-step index for a system of time-dependent PDEs. For
information about the size of cgrady, see “Dimensions of Solutions, Gradients, and
Fluxes” on page 3-347.
For query points that are outside the geometry, cgrady = NaN.
z-component of the flux of the PDE solution, returned as an array. The first array
dimension represents the node index. If results is a StationaryResults object, the
second array dimension represents the equation index for a system of PDEs. If results
is a TimeDependentResults object, the second array dimension represents either the
5-179
5 Functions — Alphabetical List
time-step for a single PDE or the equation index for a system of PDEs. The third array
dimension represents the time-step index for a system of time-dependent PDEs. For
information about the size of cgradz, see “Dimensions of Solutions, Gradients, and
Fluxes” on page 3-347.
For query points that are outside the geometry, cgradz = NaN.
Tips
• While the results object contains the solution and its gradient (both calculated at
the nodal points of the triangular or tetrahedral mesh), it does not contain the flux of
the PDE solution. To compute the flux at the nodal locations, call
evaluateCGradient without specifying locations. By default, evaluateCGradient
uses nodal locations.
See Also
PDEModel | StationaryResults | TimeDependentResults | evaluateGradient |
interpolateSolution
Topics
“Deflection Analysis of Bracket”
“Dynamics of Damped Cantilever Beam”
“Heat Transfer Between Two Squares Made of Different Materials: PDE Modeler App” on
page 3-185
Introduced in R2016b
5-180
evaluateGradient
evaluateGradient
Package: pde
Syntax
[gradx,grady] = evaluateGradient(results,xq,yq)
[gradx,grady,gradz] = evaluateGradient(results,xq,yq,zq)
[ ___ ] = evaluateGradient(results,querypoints)
Description
[gradx,grady] = evaluateGradient(results,xq,yq) returns the interpolated
values of gradients of the PDE solution results at the 2-D points specified in xq and yq.
The first dimension of gradx, grady, and, in 3-D case, gradz corresponds to query
points. The second dimension corresponds to equation indices iU.
5-181
5 Functions — Alphabetical List
times iT. When evaluating gradient for a time-dependent PDE, specify iT after the input
arguments in any of the previous syntaxes. For a system of time-dependent equations,
specify both time indices iT and equation indices (components) iU.
The first dimension of gradx, grady, and, in 3-D case, gradz corresponds to query
points. For a single time-dependent PDE, the second dimension corresponds to time-steps
iT. For a system of time-dependent PDEs, the second dimension corresponds to equation
indices iU, and the third dimension corresponds to time-steps iT.
Examples
Evaluate gradients of the solution to a scalar elliptic problem along a line. Plot the
results.
Create the solution to the problem −Δu = 1 on the L-shaped membrane with zero
Dirichlet boundary conditions.
model = createpde;
geometryFromEdges(model,@lshapeg);
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
specifyCoefficients(model,'m',0,...
'd',0,...
'c',1,...
'a',0,...
'f',1);
generateMesh(model,'Hmax',0.05);
results = solvepde(model);
Evaluate gradients of the solution along the straight line from (x,y)=(-1,-1) to (1,1).
Plot the results as a quiver plot by using quiver.
xq = linspace(-1,1,101);
yq = xq;
[gradx,grady] = evaluateGradient(results,xq,yq);
gradx = reshape(gradx,size(xq));
grady = reshape(grady,size(yq));
quiver(xq,yq,gradx,grady)
5-182
evaluateGradient
xlabel('x')
ylabel('y')
Calculate gradients for the mean exit time of a Brownian particle from a region that
contains absorbing (escape) boundaries and reflecting boundaries. Use the Poisson's
equation with constant coefficients and 3-D rectangular block geometry to model this
problem.
5-183
5 Functions — Alphabetical List
model = createpde;
importGeometry(model,'Block.stl');
applyBoundaryCondition(model,'dirichlet','Face',[1,2,5],'u',0);
specifyCoefficients(model,'m',0,...
'd',0,...
'c',1,...
'a',0,...
'f',2);
generateMesh(model);
results = solvepde(model);
[X,Y,Z] = meshgrid(1:16:100,1:6:20,1:7:50);
[gradx,grady,gradz] = evaluateGradient(results,X,Y,Z);
Reshape the gradients to the shape of the grid and plot the gradients.
gradx = reshape(gradx,size(X));
grady = reshape(grady,size(Y));
gradz = reshape(gradz,size(Z));
quiver3(X,Y,Z,gradx,grady,gradz)
axis equal
xlabel('x')
ylabel('y')
zlabel('z')
5-184
evaluateGradient
Solve a scalar elliptic problem and interpolate gradients of the solution to a dense grid.
Use a query matrix to specify the grid.
Create the solution to the problem −Δu = 1 on the L-shaped membrane with zero
Dirichlet boundary conditions.
model = createpde;
geometryFromEdges(model,@lshapeg);
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
5-185
5 Functions — Alphabetical List
specifyCoefficients(model,'m',0,...
'd',0,...
'c',1,...
'a',0,...
'f',1);
generateMesh(model,'Hmax',0.05);
results = solvepde(model);
Interpolate gradients of the solution to the grid from -1 to 1 in each direction. Plot the
result using the quiver plotting function.
v = linspace(-1,1,101);
[X,Y] = meshgrid(v);
querypoints = [X(:),Y(:)]';
[gradx,grady] = evaluateGradient(results,querypoints);
quiver(X(:),Y(:),gradx,grady)
xlabel('x')
ylabel('y')
5-186
evaluateGradient
Zoom in on a particular part of the plot to see more details. For example, limit the plotting
range to 0.2 in each direction.
5-187
5 Functions — Alphabetical List
Evaluate gradients of the solution to a two-component elliptic system and plot the results.
model = createpde(2);
Create the 2-D geometry as a rectangle with a circular hole in its center. For details about
creating the geometry, see the example in “Solve PDEs with Constant Boundary
Conditions” on page 2-131.
5-188
evaluateGradient
R1 = [3,4,-0.3,0.3,0.3,-0.3,-0.3,-0.3,0.3,0.3]';
C1 = [1,0,0,0.1]';
C1 = [C1;zeros(length(R1)-length(C1),1)];
geom = [R1,C1];
ns = (char('R1','C1'))';
sf = 'R1 - C1';
g = decsg(geom,sf,ns);
geometryFromEdges(model,g);
pdegplot(model,'EdgeLabels','on')
axis equal
axis([-0.4,0.4,-0.4,0.4])
5-189
5 Functions — Alphabetical List
specifyCoefficients(model,'m',0,...
'd',0,...
'c',1,...
'a',0,...
'f',[2; -2]);
applyBoundaryCondition(model,'dirichlet','Edge',3,'u',[-1,1]);
applyBoundaryCondition(model,'dirichlet','Edge',1,'u',[1,-1]);
applyBoundaryCondition(model,'neumann','Edge',[2,4:8],'g',[0,0]);
generateMesh(model,'Hmax',0.1);
results = solvepde(model);
Interpolate the gradients of the solution to the grid from -0.3 to 0.3 in each direction for
each of the two components.
v = linspace(-0.3,0.3,15);
[X,Y] = meshgrid(v);
[gradx,grady] = evaluateGradient(results,X,Y,[1,2]);
figure
gradx1 = gradx(:,1);
grady1 = grady(:,1);
quiver(X(:),Y(:),gradx1,grady1)
title('Component 1')
axis equal
xlim([-0.3,0.3])
5-190
evaluateGradient
figure
gradx2 = gradx(:,2);
grady2 = grady(:,2);
quiver(X(:),Y(:),gradx2,grady2)
title('Component 2')
axis equal
xlim([-0.3,0.3])
5-191
5 Functions — Alphabetical List
Import slab geometry for a 3-D problem with three solution components. Plot the
geometry.
model = createpde(3);
importGeometry(model,'Plate10x10x1.stl');
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
5-192
evaluateGradient
Set boundary conditions such that face 2 is fixed (zero deflection in any direction) and
face 5 has a load of 1e3 in the positive z-direction. This load causes the slab to bend
upward. Set the initial condition that the solution is zero, and its derivative with respect
to time is also zero.
applyBoundaryCondition(model,'dirichlet','Face',2,'u',[0,0,0]);
applyBoundaryCondition(model,'neumann','Face',5,'g',[0,0,1e3]);
setInitialConditions(model,0,0);
Create PDE coefficients for the equations of linear elasticity. Set the material properties
to be similar to those of steel. See “Linear Elasticity Equations” on page 3-150.
E = 200e9;
nu = 0.3;
5-193
5 Functions — Alphabetical List
specifyCoefficients(model,'m',1,...
'd',0,...
'c',elasticityC3D(E,nu),...
'a',0,...
'f',[0;0;0]);
Solve the problem for times 0 through 5e-3 in steps of 1e-4. You might have to wait a
few minutes for the solution.
tlist = 0:5e-4:5e-3;
results = solvepde(model,tlist);
Evaluate the gradients of the solution at fixed x- and z-coordinates in the centers of their
ranges, 5 and 0.5 respectively. Evaluate for y from 0 through 10 in steps of 0.2. Obtain
just component 3, the z-component.
yy = 0:0.2:10;
zz = 0.5*ones(size(yy));
xx = 10*zz;
component = 3;
[gradx,grady,gradz] = evaluateGradient(results,xx,yy,zz,component,1:length(tlist));
The three projections of the gradients of the solution are 51-by-1-by-51 arrays. Use
squeeze to remove the singleton dimension. Removing the singleton dimension
transforms these arrays to 51-by-51 matrices which simplifies indexing into them.
gradx = squeeze(gradx);
grady = squeeze(grady);
gradz = squeeze(gradz);
Plot the interpolated gradient component grady along the y axis for the following six
values from the time interval tlist.
figure
t = [1:2:11];
for i = t
p(i) = plot(yy,grady(:,i),'DisplayName', strcat('t=', num2str(tlist(i))));
hold on
end
legend(p(t))
xlabel('y')
5-194
evaluateGradient
ylabel('grady')
ylim([-5e-6, 20e-6])
Input Arguments
results — PDE solution
StationaryResults object | TimeDependentResults object
5-195
5 Functions — Alphabetical List
evaluateGradient converts query points to column vectors xq(:), yq(:), and (if
present) zq(:). For a single stationary PDE, the result consists of column vectors of the
same size. To ensure that the dimensions of the gradient components are consistent with
the dimensions of the original query points, use reshape. For example, use gradx =
reshape(gradx,size(xq)).
For a time-dependent PDE or a system of PDEs, the first dimension of the resulting arrays
corresponds to spatial points specified by the column vectors xq(:), yq(:), and (if
present) zq(:).
Data Types: double
evaluateGradient converts query points to column vectors xq(:), yq(:), and (if
present) zq(:). For a single stationary PDE, the result consists of column vectors of the
same size. To ensure that the dimensions of the gradient components are consistent with
the dimensions of the original query points, use reshape. For example, use grady =
reshape(grady,size(yq)).
For a time-dependent PDE or a system of PDEs, the first dimension of the resulting arrays
corresponds to spatial points specified by the column vectors xq(:), yq(:), and (if
present) zq(:).
Data Types: double
5-196
evaluateGradient
evaluateGradient converts query points to column vectors xq(:), yq(:), and (if
present) zq(:). For a single stationary PDE, the result consists of column vectors of the
same size. To ensure that the dimensions of the gradient components are consistent with
the dimensions of the original query points, use reshape. For example, use gradz =
reshape(gradz,size(zq)).
For a time-dependent PDE or a system of PDEs, the first dimension of the resulting arrays
corresponds to spatial points specified by the column vectors xq(:), yq(:), and (if
present) zq(:).
Data Types: double
Query points, specified as a real matrix with either two rows for 2-D geometry, or three
rows for 3-D geometry. evaluateGradient evaluates the gradients of the solution at the
coordinate points querypoints(:,i), so each column of querypoints contains exactly
one 2-D or 3-D query point.
Example: For 2-D geometry, querypoints = [0.5,0.5,0.75,0.75; 1,2,0,0.5]
Data Types: double
iU — Equation indices
vector of positive integers
iT — Time indices
vector of positive integers
Time indices, specified as a vector of positive integers. Each entry in iT specifies a time
index.
Example: iT = 1:5:21 specifies every fifth time-step up to 21.
5-197
5 Functions — Alphabetical List
Output Arguments
gradx — x-component of the gradient
array
x-component of the gradient, returned as an array. For query points that are outside the
geometry, gradx = NaN. For information about the size of gradx, see “Dimensions of
Solutions, Gradients, and Fluxes” on page 3-347.
y-component of the gradient, returned as an array. For query points that are outside the
geometry, grady = NaN. For information about the size of grady, see “Dimensions of
Solutions, Gradients, and Fluxes” on page 3-347.
z-component of the gradient, returned as an array. For query points that are outside the
geometry, gradz = NaN. For information about the size of gradz, see “Dimensions of
Solutions, Gradients, and Fluxes” on page 3-347.
Tips
The results object contains the solution and its gradient calculated at the nodal points
of the triangular or tetrahedral mesh. You can access the solution and three components
of the gradient at nodal points by using dot notation.
interpolateSolution and evaluateGradient let you interpolate the solution and its
gradient to a custom grid, for example, specified by meshgrid.
See Also
PDEModel | StationaryResults | TimeDependentResults | contour |
evaluateCGradient | interpolateSolution | quiver | quiver3
5-198
evaluateGradient
Topics
“Plot 2-D Solutions and Their Gradients” on page 3-314
“Plot 3-D Solutions and Their Gradients” on page 3-325
“Dimensions of Solutions, Gradients, and Fluxes” on page 3-347
Introduced in R2016a
5-199
5 Functions — Alphabetical List
evaluateHeatFlux
Package: pde
Syntax
[qx,qy] = evaluateHeatFlux(thermalresults,xq,yq)
[qx,qy,qz] = evaluateHeatFlux(thermalresults,xq,yq,zq)
[ ___ ] = evaluateHeatFlux(thermalresults,querypoints)
[qx,qy] = evaluateHeatFlux(thermalresults)
[qx,qy,qz] = evaluateHeatFlux(thermalresults)
Description
[qx,qy] = evaluateHeatFlux(thermalresults,xq,yq) returns the heat flux for a
thermal problem at the 2-D points specified in xq and yq. This syntax is valid for both the
steady-state and transient thermal models.
[ ___ ] = evaluateHeatFlux( ___ ,iT) returns the heat flux for a thermal problem at
the times specified in iT. You can specify iT after the input arguments in any of the
previous syntaxes.
The first dimension of qx, qy, and, in the 3-D case, qz corresponds to query points. The
second dimension corresponds to time steps iT.
5-200
evaluateHeatFlux
Examples
For a 2-D steady-state thermal model, evaluate heat flux at the nodal locations and at the
points specified by x and y coordinates.
thermalmodel = createpde('thermal');
R1 = [3,4,-1,1,1,-1,1,1,-1,-1]';
g = decsg(R1,'R1',('R1')');
geometryFromEdges(thermalmodel,g);
pdegplot(thermalmodel,'EdgeLabels','on')
xlim([-1.5 1.5])
axis equal
5-201
5 Functions — Alphabetical List
Assuming that this geometry represents an iron plate, the thermal conductivity is
79 . 5 W /(mK).
thermalProperties(thermalmodel,'ThermalConductivity',79.5,'Face',1);
Apply a constant temperature of 500 K to the bottom of the plate (edge 3). Also, assume
that the top of the plate (edge 1) is insulated, and apply convection on the two sides of the
plate (edges 2 and 4).
thermalBC(thermalmodel,'Edge',3,'Temperature',500);
thermalBC(thermalmodel,'Edge',1,'HeatFlux',0);
thermalBC(thermalmodel,'Edge',[2 4], ...
'ConvectionCoefficient',25, ...
'AmbientTemperature',50);
5-202
evaluateHeatFlux
generateMesh(thermalmodel);
results = solve(thermalmodel)
results =
SteadyStateThermalResults with properties:
[qx,qy] = evaluateHeatFlux(results);
figure
pdeplot(thermalmodel,'FlowData',[qx qy])
5-203
5 Functions — Alphabetical List
Create a grid specified by x and y coordinates, and evaluate heat flux to the grid.
v = linspace(-0.5,0.5,11);
[X,Y] = meshgrid(v);
[qx,qy] = evaluateHeatFlux(results,X,Y);
Reshape the qTx and qTy vectors, and plot the resulting heat flux.
qx = reshape(qx,size(X));
qy = reshape(qy,size(Y));
figure
quiver(X,Y,qx,qy)
5-204
evaluateHeatFlux
Alternatively, you can specify the grid by using a matrix of query points.
qx = reshape(qx,size(X));
qy = reshape(qy,size(Y));
figure
quiver(X,Y,qx,qy)
5-205
5 Functions — Alphabetical List
For a 3-D steady-state thermal model, evaluate heat flux at the nodal locations and at the
points specified by x, y, and z coordinates.
thermalmodel = createpde('thermal');
5-206
evaluateHeatFlux
importGeometry(thermalmodel,'Block.stl');
pdegplot(thermalmodel,'FaceLabels','on','FaceAlpha',0.5)
title('Copper block, cm')
axis equal
Assuming that this is a copper block, the thermal conductivity of the block is
approximately 4 W /(cmK).
thermalProperties(thermalmodel,'ThermalConductivity',4);
Apply a constant temperature of 373 K to the left side of the block (face 1) and a constant
temperature of 573 K to the right side of the block (face 3).
thermalBC(thermalmodel,'Face',1,'Temperature',373);
thermalBC(thermalmodel,'Face',3,'Temperature',573);
5-207
5 Functions — Alphabetical List
thermalBC(thermalmodel,'Face',4,'HeatFlux',-20);
generateMesh(thermalmodel);
thermalresults = solve(thermalmodel)
thermalresults =
SteadyStateThermalResults with properties:
[qx,qy,qz] = evaluateHeatFlux(thermalresults);
figure
pdeplot3D(thermalmodel,'FlowData',[qx qy qz])
5-208
evaluateHeatFlux
Create a grid specified by x, y, and z coordinates, and evaluate heat flux to the grid.
[X,Y,Z] = meshgrid(1:26:100,1:6:20,1:11:50);
[qx,qy,qz] = evaluateHeatFlux(thermalresults,X,Y,Z);
Reshape the qx, qy, and qz vectors, and plot the resulting heat flux.
qx = reshape(qx,size(X));
qy = reshape(qy,size(Y));
qz = reshape(qz,size(Z));
figure
quiver3(X,Y,Z,qx,qy,qz)
5-209
5 Functions — Alphabetical List
Alternatively, you can specify the grid by using a matrix of query points.
qx = reshape(qx,size(X));
qy = reshape(qy,size(Y));
qz = reshape(qz,size(Z));
figure
quiver3(X,Y,Z,qx,qy,qz)
5-210
evaluateHeatFlux
Solve a 2-D transient heat transfer problem on a square domain, and compute heat flow
across a convective boundary.
thermalmodel = createpde('thermal','transient');
5-211
5 Functions — Alphabetical List
g = @squareg;
geometryFromEdges(thermalmodel,g);
pdegplot(thermalmodel,'EdgeLabels','on')
xlim([-1.2 1.2])
ylim([-1.2 1.2])
axis equal
Assign the following thermal properties: thermal conductivity is 100 W /(m∘C), mass
density is 7800 kg/m3, and specific heat is 500 J/(kg∘C).
thermalProperties(thermalmodel,'ThermalConductivity',100, ...
'MassDensity',7800, ...
'SpecificHeat',500);
5-212
evaluateHeatFlux
Apply insulated boundary conditions on three edges and the free convection boundary
condition on the right edge.
thermalBC(thermalmodel,'Edge',[1 3 4],'HeatFlux',0);
thermalBC(thermalmodel,'Edge',2,...
'ConvectionCoefficient',5000, ...
'AmbientTemperature',25);
Set the initial conditions: uniform room temperature across domain and higher
temperature on the top edge.
thermalIC(thermalmodel,25);
thermalIC(thermalmodel,100,'Edge',1);
Generate a mesh and solve the problem using 0:1000:200000 as a vector of times.
generateMesh(thermalmodel);
tlist = 0:1000:200000;
thermalresults = solve(thermalmodel,tlist)
thermalresults =
TransientThermalResults with properties:
Create a grid specified by x and y coordinates, and evaluate heat flux to the grid.
v = linspace(-1,1,11);
[X,Y] = meshgrid(v);
[qx,qy] = evaluateHeatFlux(thermalresults,X,Y,1:length(tlist));
Reshape qx and qy, and plot the resulting heat flux for the 25th solution step.
tlist(25)
ans = 24000
figure
5-213
5 Functions — Alphabetical List
quiver(X(:),Y(:),qx(:,25),qy(:,25));
xlim([-1,1])
axis equal
Heat Flux for Transient Thermal Model on Two Squares Made of Different
Materials
Solve the heat transfer problem for the following 2-D geometry consisting of a square and
a diamond made of different materials. Compute the heat flux, and plot it as a vector field.
5-214
evaluateHeatFlux
thermalmodel = createpde('thermal','transient');
5-215
5 Functions — Alphabetical List
For the square region, assign the following thermal properties: thermal conductivity is
10 W /(m∘C), mass density is 2 kg/m3, and specific heat is 0 . 1 J/(kg∘C).
thermalProperties(thermalmodel,'ThermalConductivity',10, ...
'MassDensity',2, ...
'SpecificHeat',0.1, ...
'Face',1);
For the diamond-shaped region, assign the following thermal properties: thermal
conductivity is 2 W /(m∘C), mass density is 1 kg/m3, and specific heat is 0 . 1 J/(kg∘C).
thermalProperties(thermalmodel,'ThermalConductivity',2, ...
'MassDensity',1, ...
5-216
evaluateHeatFlux
'SpecificHeat',0.1, ...
'Face',2);
Assume that the diamond-shaped region is a heat source with the density of 4 W /m3.
internalHeatSource(thermalmodel,4,'Face',2);
∘
Apply a constant temperature of 0 C to the sides of the square plate.
thermalBC(thermalmodel,'Temperature',0,'Edge',[1 2 7 8]);
∘
Set the initial temperature to 0 C.
thermalIC(thermalmodel,0);
generateMesh(thermalmodel);
The dynamic for this problem is very fast: the temperature reaches steady state in about
0.1 seconds. To capture the interesting part of the dynamics, set the solution time to
logspace(-2,-1,10). This gives 10 logarithmically spaced solution times between 0.01
and 0.1. Solve the equation.
tlist = logspace(-2,-1,10);
thermalresults = solve(thermalmodel,tlist);
temp = thermalresults.Temperature;
Compute the heat flux density. Plot the solution with isothermal lines using a contour plot,
and plot the heat flux vector field using arrows.
[qTx,qTy] = evaluateHeatFlux(thermalresults);
figure
pdeplot(thermalmodel,'XYData',temp(:,10),'Contour','on', ...
'FlowData',[qTx(:,10) qTy(:,10)], ...
'ColorMap','hot')
5-217
5 Functions — Alphabetical List
Input Arguments
thermalresults — Solution of thermal problem
SteadyStateThermalResults object | TransientThermalResults object
5-218
evaluateHeatFlux
evaluateHeatFlux converts query points to column vectors xq(:), yq(:), and (if
present) zq(:). It returns the heat flux in a form of a column vector of the same size. To
ensure that the dimensions of the returned solution are consistent with the dimensions of
the original query points, use reshape. For example, use qx =
reshape(qx,size(xq)).
Data Types: double
evaluateHeatFlux converts query points to column vectors xq(:), yq(:), and (if
present) zq(:). It returns the heat flux in a form of a column vector of the same size. To
ensure that the dimensions of the returned solution is consistent with the dimensions of
the original query points, use reshape. For example, use qy =
reshape(qy,size(yq)).
Data Types: double
evaluateHeatFlux converts query points to column vectors xq(:), yq(:), and (if
present) zq(:). It returns the heat flux in a form of a column vector of the same size. To
ensure that the dimensions of the returned solution is consistent with the dimensions of
5-219
5 Functions — Alphabetical List
Query points, specified as a real matrix with two rows for 2-D geometry or three rows for
3-D geometry. evaluateHeatFlux evaluates the heat flux at the coordinate points
querypoints(:,i), so each column of querypoints contains exactly one 2-D or 3-D
query point.
Example: For 2-D geometry, querypoints = [0.5 0.5 0.75 0.75; 1 2 0 0.5]
Data Types: double
iT — Time indices
vector of positive integers
Time indices, specified as a vector of positive integers. Each entry in iT specifies a time
index.
Example: iT = 1:5:21 specifies every fifth time-step up to 21.
Data Types: double
Output Arguments
qx — x-component of the heat flux
array
x-component of the heat flux, returned as an array. The first array dimension represents
the node index. The second array dimension represents the time step.
y-component of the heat flux, returned as an array. The first array dimension represents
the node index. The second array dimension represents the time step.
5-220
evaluateHeatFlux
z-component of the heat flux, returned as an array. The first array dimension represents
the node index. The second array dimension represents the time step.
See Also
SteadyStateThermalResults | ThermalModel | TransientThermalResults |
evaluateHeatRate | evaluateTemperatureGradient | interpolateTemperature
Introduced in R2017a
5-221
5 Functions — Alphabetical List
evaluateHeatRate
Package: pde
Syntax
Qn = evaluateHeatRate(thermalresults,RegionType,RegionID)
Description
Qn = evaluateHeatRate(thermalresults,RegionType,RegionID) returns the
integrated heat flow rate normal to the boundary specified by RegionType and
RegionID.
Examples
Compute the heat flow rate across a face of the block geometry.
thermalmodel = createpde('thermal','steadystate');
importGeometry(thermalmodel,'Block.stl');
pdegplot(thermalmodel,'FaceLabels','on','FaceAlpha',0.5)
5-222
evaluateHeatRate
Apply constant temperatures on the opposite ends of the block. All other faces are
insulated by default.
thermalBC(thermalmodel,'Face',1,'Temperature',100);
thermalBC(thermalmodel,'Face',3,'Temperature',50);
Generate mesh.
generateMesh(thermalmodel,'GeometricOrder','linear');
5-223
5 Functions — Alphabetical List
thermalresults = solve(thermalmodel);
Qn = evaluateHeatRate(thermalresults,'Face',3)
Qn = 4.0000e+04
Compute the heat flow rate across the surface of the cooling sphere.
thermalmodel = createpde('thermal','transient');
gm = multisphere(1);
thermalmodel.Geometry = gm;
Generate mesh.
generateMesh(thermalmodel,'GeometricOrder','linear');
thermalProperties(thermalmodel,'ThermalConductivity',80, ...
'SpecificHeat',460, ...
'MassDensity',7800);
thermalBC(thermalmodel,'Face',1,...
'ConvectionCoefficient',500, ...
'AmbientTemperature',30);
thermalIC(thermalmodel,800);
5-224
evaluateHeatRate
tlist = 0:100:2000;
result = solve(thermalmodel,tlist);
Compute the heat flow rate across the surface of the sphere over time.
Qn = evaluateHeatRate(result,'Face',1);
plot(tlist,Qn)
xlabel('Time')
ylabel('Heat Flow Rate')
5-225
5 Functions — Alphabetical List
Input Arguments
thermalresults — Solution of thermal problem
SteadyStateThermalResults object
Geometric region type, specified as 'Face' for 3-D geometry or 'Edge' for 2-D
geometry.
Example: Qn = evaluateHeatRate(thermalresults,'Face',3)
Data Types: char | string
Geometric region ID, specified as a positive integer. Find the region IDs using the
pdegplot function with the 'FaceLabels' (3-D) or 'EdgeLabels' (2-D) value set to
'on'.
Example: Qn = evaluateHeatRate(thermalresults,'Face',3)
Data Types: double
Output Arguments
Qn — Heat flow rate
real number | vector of real numbers
Heat flow rate, returned as a real number or, for time-dependent results, a vector of real
numbers. This value represents the integrated heat flow rate, measured in energy per
unit time, flowing in the direction normal to the boundary. Qn is positive if the heat flows
out of the domain, and negative if the heat flows into the domain.
5-226
evaluateHeatRate
See Also
SteadyStateThermalResults | ThermalModel | TransientThermalResults |
evaluateHeatFlux | evaluateTemperatureGradient | interpolateTemperature
Introduced in R2017a
5-227
5 Functions — Alphabetical List
evaluatePrincipalStrain
Package: pde
Syntax
pStrain = evaluatePrincipalStrain(structuralresults)
Description
pStrain = evaluatePrincipalStrain(structuralresults) evaluates principal
strain at nodal locations using strain values from structuralresults. For transient
and frequency response structural models, evaluatePrincipalStrain evaluates
principal strain for all time- or frequency-steps, respectively.
Examples
Solve a static structural model representing a bimetallic cable under tension, and
compute octahedral shear strain.
structuralmodel = createpde('structural','static-solid');
Create the geometry and include it in the model. Plot the geometry.
gm = multicylinder([0.01,0.015],0.05);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on', ...
'CellLabels','on', ...
'FaceAlpha',0.5)
5-228
evaluatePrincipalStrain
Specify the Young's modulus and Poisson's ratio for each metal.
structuralProperties(structuralmodel,'Cell',1,'YoungsModulus',110E9, ...
'PoissonsRatio',0.28);
structuralProperties(structuralmodel,'Cell',2,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3);
5-229
5 Functions — Alphabetical List
generateMesh(structuralmodel);
structuralresults = solve(structuralmodel)
structuralresults =
StaticStructuralResults with properties:
pStrain = evaluatePrincipalStrain(structuralresults);
Use the principal strain to evaluate the first and second invariant of strain.
5-230
evaluatePrincipalStrain
Evaluate the principal strain and octahedral shear strain in a beam under a harmonic
excitation.
structuralmodel = createpde('structural','transient-solid');
5-231
5 Functions — Alphabetical List
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
structuralBC(structuralmodel,'Face',5,'Constraint','fixed');
5-232
evaluatePrincipalStrain
Apply a sinusoidal displacement along the y-direction on the end opposite the fixed end of
the beam.
structuralBC(structuralmodel,'Face',3,'YDisplacement',1E-4,'Frequency',50);
Generate a mesh.
generateMesh(structuralmodel,'Hmax',0.01);
structuralIC(structuralmodel,'Displacement',[0;0;0],'Velocity',[0;0;0]);
tlist = 0:0.002:0.2;
structuralresults = solve(structuralmodel,tlist);
pStrain = evaluatePrincipalStrain(structuralresults);
Use the principal strain to evaluate the first and second invariants.
figure
pdeplot3D(structuralmodel,'ColorMapData',tauOct(:,end))
5-233
5 Functions — Alphabetical List
Input Arguments
structuralresults — Solution of structural analysis problem
StaticStructuralResults object | TransientStructuralResults object |
FrequencyStructuralResults object
5-234
evaluatePrincipalStrain
Output Arguments
pStrain — Principal strain at nodal locations
structure array
See Also
StaticStructuralResults | StructuralModel | evaluatePrincipalStress |
evaluateReaction | interpolateDisplacement | interpolateStrain |
interpolateStress | interpolateVonMisesStress
Introduced in R2017b
5-235
5 Functions — Alphabetical List
evaluatePrincipalStress
Package: pde
Syntax
pStress = evaluatePrincipalStress(structuralresults)
Description
pStress = evaluatePrincipalStress(structuralresults) evaluates principal
stress at nodal locations using stress values from structuralresults. For transient
and frequency response structural models, evaluatePrincipalStress evaluates
principal stress for all time- and frequency-steps, respectively.
Examples
Solve a static structural model representing a bimetallic cable under tension, and
compute octahedral shear stress.
structuralmodel = createpde('structural','static-solid');
gm = multicylinder([0.01,0.015],0.05);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on', ...
'CellLabels','on', ...
'FaceAlpha',0.5)
5-236
evaluatePrincipalStress
Specify the Young's modulus and Poisson's ratio for each metal.
structuralProperties(structuralmodel,'Cell',1,'YoungsModulus',110E9, ...
'PoissonsRatio',0.28);
structuralProperties(structuralmodel,'Cell',2,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3);
5-237
5 Functions — Alphabetical List
generateMesh(structuralmodel);
structuralresults = solve(structuralmodel)
structuralresults =
StaticStructuralResults with properties:
pStress = evaluatePrincipalStress(structuralresults);
Use the principal stress to evaluate the first and second invariant of stress.
5-238
evaluatePrincipalStress
Evaluate the principal stress and octahedral shear stress in a beam under a harmonic
excitation.
structuralmodel = createpde('structural','transient-solid');
Create the geometry and include it in the model. Plot the geometry.
5-239
5 Functions — Alphabetical List
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
structuralBC(structuralmodel,'Face',5,'Constraint','fixed');
5-240
evaluatePrincipalStress
Apply a sinusoidal displacement along the y-direction on the end opposite the fixed end of
the beam.
structuralBC(structuralmodel,'Face',3,'YDisplacement',1E-4,'Frequency',50);
Generate a mesh.
generateMesh(structuralmodel,'Hmax',0.01);
structuralIC(structuralmodel,'Displacement',[0;0;0],'Velocity',[0;0;0]);
tlist = 0:0.002:0.2;
structuralresults = solve(structuralmodel,tlist);
pStress = evaluatePrincipalStress(structuralresults);
Use the principal stress to evaluate the first and second invariants.
figure
pdeplot3D(structuralmodel,'ColorMapData',tauOct(:,end))
5-241
5 Functions — Alphabetical List
Input Arguments
structuralresults — Solution of structural analysis problem
StaticStructuralResults object | TransientStructuralResults object |
FrequencyStructuralResults object
5-242
evaluatePrincipalStress
Output Arguments
pStress — Principal stress at nodal locations
structure array
See Also
StaticStructuralResults | StructuralModel | evaluatePrincipalStrain |
evaluateReaction | interpolateDisplacement | interpolateStrain |
interpolateStress | interpolateVonMisesStress
Introduced in R2017b
5-243
5 Functions — Alphabetical List
evaluateReaction
Package: pde
Syntax
F = evaluateReaction(structuralresults,RegionType,RegionID)
Description
F = evaluateReaction(structuralresults,RegionType,RegionID) evaluates
reaction forces on the boundary specified by RegionType and RegionID. The function
uses the global Cartesian coordinate system. For transient and frequency response
structural models, evaluateReaction evaluates reaction forces for all time- and
frequency-steps, respectively.
Examples
structuralmodel = createpde('structural','static-solid');
Create a cuboid geometry and include it in the model. Plot the geometry.
structuralmodel.Geometry = multicuboid(0.01,0.01,0.05);
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5);
5-244
evaluateReaction
Fix one end of the bar and apply pressure to the opposite end.
structuralBC(structuralmodel,'Face',1,'Constraint','fixed')
ans =
StructuralBC with properties:
RegionType: 'Face'
RegionID: 1
Vectorized: 'off'
5-245
5 Functions — Alphabetical List
Boundary Loads
Force: []
SurfaceTraction: []
Pressure: []
TranslationalStiffness: []
structuralBoundaryLoad(structuralmodel,'Face',2,'Pressure',100)
ans =
StructuralBC with properties:
RegionType: 'Face'
RegionID: 2
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: []
Pressure: 100
TranslationalStiffness: []
generateMesh(structuralmodel,'Hmax',0.003);
structuralresults = solve(structuralmodel);
5-246
evaluateReaction
reaction = evaluateReaction(structuralresults,'Face',1)
Evaluate the reaction forces at the fixed end of a beam subject to harmonic excitation.
structuralmodel = createpde('structural','transient-solid');
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
5-247
5 Functions — Alphabetical List
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
structuralBC(structuralmodel,'Face',5,'Constraint','fixed');
Apply a sinusoidal displacement along the y-direction on the end opposite the fixed end of
the beam.
structuralBC(structuralmodel,'Face',3,'YDisplacement',1E-4,'Frequency',50);
5-248
evaluateReaction
Generate a mesh.
generateMesh(structuralmodel,'Hmax',0.01);
structuralIC(structuralmodel,'Displacement',[0;0;0],'Velocity',[0;0;0]);
tlist = 0:0.002:0.2;
structuralresults = solve(structuralmodel,tlist);
reaction = evaluateReaction(structuralresults,'Face',5)
Input Arguments
structuralresults — Solution of structural analysis problem
StaticStructuralResults object | TransientStructuralResults object |
FrequencyStructuralResults object
Geometric region type, specified as 'Edge' for a 2-D model or 'Face' for a 3-D model.
Example: evaluateReaction(structuralresults,'Face',2)
Data Types: char | string
5-249
5 Functions — Alphabetical List
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Example: evaluateReaction(structuralresults,'Face',2)
Data Types: double
Output Arguments
F — Reaction forces
structure array
Reaction forces, returned as a structure array. The array fields represent the integrated
reaction forces and surface traction vector, which are computed by using the state of
stress on the boundary and the outward normal.
See Also
StaticStructuralResults | StructuralModel | evaluatePrincipalStrain |
evaluatePrincipalStress | interpolateDisplacement | interpolateStrain |
interpolateStress | interpolateVonMisesStress
Introduced in R2017b
5-250
evaluateStrain
evaluateStrain
Package: pde
Syntax
nodalStrain = evaluateStrain(structuralresults)
Description
nodalStrain = evaluateStrain(structuralresults) evaluates strain at nodal
locations for all time- or frequency-steps.
Examples
structuralmodel = createpde('structural','transient-solid');
Create the geometry and include it in the model. Plot the geometry.
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
5-251
5 Functions — Alphabetical List
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
structuralBC(structuralmodel,'Face',5,'Constraint','fixed');
Apply a sinusoidal displacement along the y-direction on the end opposite the fixed end of
the beam.
structuralBC(structuralmodel,'Face',3,'YDisplacement',1E-4,'Frequency',50);
5-252
evaluateStrain
Generate a mesh.
generateMesh(structuralmodel,'Hmax',0.01);
structuralIC(structuralmodel,'Displacement',[0,0,0],'Velocity',[0,0,0]);
tlist = 0:0.002:0.2;
structuralresults = solve(structuralmodel,tlist);
strain = evaluateStrain(structuralresults);
Plot the normal strain along x-direction for the last time-step.
figure
pdeplot3D(structuralmodel,'ColorMapData',strain.exx(:,end))
title('x-Direction Normal Strain in the Beam of the Last Time-Step')
5-253
5 Functions — Alphabetical List
Input Arguments
structuralresults — Solution of dynamic structural analysis problem
TransientStructuralResults object | FrequencyStructuralResults object
5-254
evaluateStrain
Output Arguments
nodalStrain — Strain at nodes
structure array
Strain at the nodes, returned as a structure array with the fields representing the
components of strain tensor at nodal locations.
See Also
StructuralModel | TransientStructuralResults | evaluatePrincipalStrain |
evaluatePrincipalStress | evaluateReaction | evaluateStress |
evaluateVonMisesStress | interpolateAcceleration |
interpolateDisplacement | interpolateStrain | interpolateStress |
interpolateVelocity | interpolateVonMisesStress
Introduced in R2018a
5-255
5 Functions — Alphabetical List
evaluateStress
Package: pde
Syntax
nodalStress = evaluateStress(structuralresults)
Description
nodalStress = evaluateStress(structuralresults) evaluates stress at nodal
locations for all time- or frequency-steps.
Examples
structuralmodel = createpde('structural','transient-solid');
Create the geometry and include it in the model. Plot the geometry.
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
5-256
evaluateStress
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
structuralBC(structuralmodel,'Face',5,'Constraint','fixed');
Apply a sinusoidal displacement along the y-direction on the end opposite the fixed end of
the beam.
structuralBC(structuralmodel,'Face',3,'YDisplacement',1E-4,'Frequency',50);
5-257
5 Functions — Alphabetical List
Generate a mesh.
generateMesh(structuralmodel,'Hmax',0.01);
structuralIC(structuralmodel,'Displacement',[0,0,0],'Velocity',[0,0,0]);
tlist = 0:0.002:0.2;
structuralresults = solve(structuralmodel,tlist);
stress = evaluateStress(structuralresults);
Plot the normal stress along x-direction for the last time-step.
figure
pdeplot3D(structuralmodel,'ColorMapData',stress.sxx(:,end))
title('x-Direction Normal Stress in the Beam of the Last Time-Step')
5-258
evaluateStress
Input Arguments
structuralresults — Solution of dynamic structural analysis problem
TransientStructuralResults object | FrequencyStructuralResults object
5-259
5 Functions — Alphabetical List
Output Arguments
nodalStress — Stress at nodes
structure array
Stress at the nodes, returned as a structure array with the fields representing the
components of a stress tensor at nodal locations.
See Also
StructuralModel | TransientStructuralResults | evaluatePrincipalStrain |
evaluatePrincipalStress | evaluateReaction | evaluateStrain |
evaluateVonMisesStress | interpolateAcceleration |
interpolateDisplacement | interpolateStrain | interpolateStress |
interpolateVelocity | interpolateVonMisesStress
Introduced in R2018a
5-260
evaluateTemperatureGradient
evaluateTemperatureGradient
Package: pde
Syntax
[gradTx,gradTy] = evaluateTemperatureGradient(thermalresults,xq,yq)
[gradTx,gradTy,gradTz] = evaluateTemperatureGradient(thermalresults,
xq,yq,zq)
[ ___ ] = evaluateTemperatureGradient(thermalresults,querypoints)
[ ___ ] = evaluateTemperatureGradient( ___ ,iT)
Description
[gradTx,gradTy] = evaluateTemperatureGradient(thermalresults,xq,yq)
returns the interpolated values of temperature gradients of the thermal model solution
thermalresults at the 2-D points specified in xq and yq. This syntax is valid for both
the steady-state and transient thermal models.
[gradTx,gradTy,gradTz] = evaluateTemperatureGradient(thermalresults,
xq,yq,zq) returns the interpolated temperature gradients at the 3-D points specified in
xq, yq, and zq. This syntax is valid for both the steady-state and transient thermal
models.
[ ___ ] = evaluateTemperatureGradient(thermalresults,querypoints)
returns the interpolated values of the temperature gradients at the points specified in
querypoints. This syntax is valid for both the steady-state and transient thermal
models.
The first dimension of gradTx, gradTy, and, in 3-D case, gradTz corresponds to query
points. The second dimension corresponds to time-steps iT.
5-261
5 Functions — Alphabetical List
Examples
For a 2-D steady-state thermal model, evaluate temperature gradients at the nodal
locations and at the points specified by x and y coordinates.
thermalmodel = createpde('thermal');
R1 = [3,4,-1,1,1,-1,1,1,-1,-1]';
g = decsg(R1,'R1',('R1')');
geometryFromEdges(thermalmodel,g);
pdegplot(thermalmodel,'EdgeLabels','on')
xlim([-1.5 1.5])
axis equal
5-262
evaluateTemperatureGradient
Assuming that this geometry represents an iron plate, the thermal conductivity is
79 . 5 W /(mK).
thermalProperties(thermalmodel,'ThermalConductivity',79.5,'Face',1);
Apply a constant temperature of 300 K to the bottom of the plate (edge 3). Also, assume
that the top of the plate (edge 1) is insulated, and apply convection on the two sides of the
plate (edges 2 and 4).
thermalBC(thermalmodel,'Edge',3,'Temperature',300);
thermalBC(thermalmodel,'Edge',1,'HeatFlux',0);
thermalBC(thermalmodel,'Edge',[2 4], ...
'ConvectionCoefficient',25, ...
'AmbientTemperature',50);
5-263
5 Functions — Alphabetical List
generateMesh(thermalmodel);
results = solve(thermalmodel)
results =
SteadyStateThermalResults with properties:
The solver finds the temperatures and temperature gradients at the nodal locations. To
access these values, use results.Temperature, results.XGradients, and so on. For
example, plot the temperature gradients at nodal locations.
figure;
pdeplot(thermalmodel,'FlowData',[results.XGradients results.YGradients]);
5-264
evaluateTemperatureGradient
Create a grid specified by x and y coordinates, and evaluate temperature gradients to the
grid.
v = linspace(-0.5,0.5,11);
[X,Y] = meshgrid(v);
[gradTx,gradTy] = evaluateTemperatureGradient(results,X,Y);
Reshape the gradTx and gradTy vectors, and plot the resulting temperature gradients.
gradTx = reshape(gradTx,size(X));
gradTy = reshape(gradTy,size(Y));
figure
quiver(X,Y,gradTx,gradTy)
5-265
5 Functions — Alphabetical List
Alternatively, you can specify the grid by using a matrix of query points.
gradTx = reshape(gradTx,size(X));
gradTy = reshape(gradTy,size(Y));
figure
quiver(X,Y,gradTx,gradTy)
5-266
evaluateTemperatureGradient
For a 3-D steady-state thermal model, evaluate temperature gradients at the nodal
locations and at the points specified by x, y, and z coordinates.
thermalmodel = createpde('thermal');
5-267
5 Functions — Alphabetical List
importGeometry(thermalmodel,'Block.stl');
pdegplot(thermalmodel,'FaceLabels','on','FaceAlpha',0.5)
title('Copper block, cm')
axis equal
Assuming that this is a copper block, the thermal conductivity of the block is
approximately 4 W /(cmK).
thermalProperties(thermalmodel,'ThermalConductivity',4);
Apply a constant temperature of 373 K to the left side of the block (edge 1) and a constant
temperature of 573 K to the right side of the block.
thermalBC(thermalmodel,'Face',1,'Temperature',373);
thermalBC(thermalmodel,'Face',3,'Temperature',573);
5-268
evaluateTemperatureGradient
thermalBC(thermalmodel,'Face',4,'HeatFlux',-20);
generateMesh(thermalmodel);
thermalresults = solve(thermalmodel)
thermalresults =
SteadyStateThermalResults with properties:
The solver finds the values of temperatures and temperature gradients at the nodal
locations. To access these values, use results.Temperature, results.XGradients,
and so on.
[X,Y,Z] = meshgrid(1:26:100,1:6:20,1:11:50);
[gradTx,gradTy,gradTz] = evaluateTemperatureGradient(thermalresults,X,Y,Z);
Reshape the gradTx, gradTy, and gradTz vectors, and plot the resulting temperature
gradients.
gradTx = reshape(gradTx,size(X));
gradTy = reshape(gradTy,size(Y));
gradTz = reshape(gradTz,size(Z));
figure
quiver3(X,Y,Z,gradTx,gradTy,gradTz)
axis equal
xlabel('x')
ylabel('y')
zlabel('z')
5-269
5 Functions — Alphabetical List
Alternatively, you can specify the grid by using a matrix of query points.
gradTx = reshape(gradTx,size(X));
gradTy = reshape(gradTy,size(Y));
gradTz = reshape(gradTz,size(Z));
figure
quiver3(X,Y,Z,gradTx,gradTy,gradTz)
axis equal
xlabel('x')
5-270
evaluateTemperatureGradient
ylabel('y')
zlabel('z')
Solve a 2-D transient heat transfer problem on a square domain and compute
temperature gradients at the convective boundary.
thermalmodel = createpde('thermal','transient');
5-271
5 Functions — Alphabetical List
g = @squareg;
geometryFromEdges(thermalmodel,g);
pdegplot(thermalmodel,'EdgeLabels','on')
xlim([-1.2 1.2])
ylim([-1.2 1.2])
axis equal
Assign the following thermal properties: thermal conductivity is 100 W /(m∘C), mass
density is 7800 kg/m3, and specific heat is 500 J/(kg∘C).
5-272
evaluateTemperatureGradient
thermalProperties(thermalmodel,'ThermalConductivity',100, ...
'MassDensity',7800, ...
'SpecificHeat',500);
Apply insulated boundary conditions on three edges and the free convection boundary
condition on the right edge.
thermalBC(thermalmodel,'Edge',[1 3 4],'HeatFlux',0);
thermalBC(thermalmodel,'Edge',2, ...
'ConvectionCoefficient',5000, ...
'AmbientTemperature',25);
Set the initial conditions: uniform room temperature across domain and higher
temperature on the left edge.
thermalIC(thermalmodel,25);
thermalIC(thermalmodel,100,'Edge',4);
Generate a mesh and solve the problem using 0:1000:200000 as a vector of times.
generateMesh(thermalmodel);
tlist = 0:1000:200000;
thermalresults = solve(thermalmodel,tlist)
thermalresults =
TransientThermalResults with properties:
Define a line at convection boundary and compute temperature gradients across that line.
X = -1:0.1:1;
Y = ones(size(X));
[gradTx,gradTy] = evaluateTemperatureGradient(thermalresults,X,Y,1:length(tlist));
Plot the interpolated gradient component gradTx along the x axis for the following
values from the time interval tlist.
5-273
5 Functions — Alphabetical List
figure
t = [51:50:201];
for i = t
p(i) = plot(X,gradTx(:,i),'DisplayName', strcat('t=', num2str(tlist(i))));
hold on
end
legend(p(t))
xlabel('x')
ylabel('gradTx')
5-274
evaluateTemperatureGradient
Input Arguments
thermalresults — Solution of thermal problem
SteadyStateThermalResults object | TransientThermalResults object
5-275
5 Functions — Alphabetical List
Query points, specified as a real matrix with either two rows for 2-D geometry, or three
rows for 3-D geometry. evaluateTemperatureGradient evaluates the temperature
gradient at the coordinate points querypoints(:,i), so each column of querypoints
contains exactly one 2-D or 3-D query point.
Example: For 2-D geometry, querypoints = [0.5 0.5 0.75 0.75; 1 2 0 0.5]
Data Types: double
iT — Time indices
vector of positive integers
Time indices, specified as a vector of positive integers. Each entry in iT specifies a time
index.
Example: iT = 1:5:21 specifies every fifth time-step up to 21.
Data Types: double
Output Arguments
gradTx — x-component of the temperature gradient
matrix
5-276
evaluateTemperatureGradient
x-component of the temperature gradient, returned as a matrix. For query points that are
outside the geometry, gradTx = NaN.
y-component of the temperature gradient, returned as a matrix. For query points that are
outside the geometry, gradTy = NaN.
z-component of the temperature gradient, returned as a matrix. For query points that are
outside the geometry, gradTz = NaN.
See Also
SteadyStateThermalResults | ThermalModel | TransientThermalResults |
evaluateHeatFlux | evaluateHeatRate | interpolateTemperature
Introduced in R2017a
5-277
5 Functions — Alphabetical List
evaluateVonMisesStress
Package: pde
Syntax
vmStress = evaluateVonMisesStress(structuralresults)
Description
vmStress = evaluateVonMisesStress(structuralresults) evaluates von Mises
stress at nodal locations for all time- or frequency-steps.
Examples
structuralmodel = createpde('structural','transient-solid');
Create the geometry and include it in the model. Plot the geometry.
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
5-278
evaluateVonMisesStress
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
structuralBC(structuralmodel,'Face',5,'Constraint','fixed');
Apply a sinusoidal displacement along the y-direction on the end opposite the fixed end of
the beam.
structuralBC(structuralmodel,'Face',3,'YDisplacement',1E-4,'Frequency',50);
5-279
5 Functions — Alphabetical List
Generate a mesh.
generateMesh(structuralmodel,'Hmax',0.01);
structuralIC(structuralmodel,'Displacement',[0;0;0],'Velocity',[0;0;0]);
tlist = 0:0.002:0.2;
structuralresults = solve(structuralmodel,tlist);
vmStress = evaluateVonMisesStress(structuralresults);
figure
pdeplot3D(structuralmodel,'ColorMapData',vmStress(:,end))
title('von Mises Stress in the Beam for the Last Time-Step')
5-280
evaluateVonMisesStress
Input Arguments
structuralresults — Solution of dynamic structural analysis problem
TransientStructuralResults object | FrequencyStructuralResults object
5-281
5 Functions — Alphabetical List
Output Arguments
vmStress — Von Mises Stress at nodes
matrix
Von Mises Stress at the nodes, returned as a matrix. The rows of the matrix contain the
values of von Mises stress at nodal locations, while the columns correspond to the time or
frequency steps.
See Also
StructuralModel | TransientStructuralResults | evaluatePrincipalStrain |
evaluatePrincipalStress | evaluateReaction | evaluateStrain |
evaluateStress | interpolateAcceleration | interpolateDisplacement |
interpolateStrain | interpolateStress | interpolateVelocity |
interpolateVonMisesStress
Introduced in R2018a
5-282
FEMesh Properties
FEMesh Properties
Mesh object
Description
An FEMesh object contains a description of the finite element mesh. A PDEModel
container has an FEMesh object in its Mesh property.
Properties
Properties
Mesh nodes, returned as a matrix. Nodes is a D-by-Nn matrix, where D is the number of
geometry dimensions (2 or 3), and Nn is the number of nodes in the mesh. Each column of
Nodes contains the x, y, and in 3-D, z coordinates for that mesh node.
2-D meshes have nodes at the mesh triangle corners for linear elements, and at the
corners and edge midpoints for 'quadratic' elements. 3-D meshes have nodes at
tetrahedral vertices, and the 'quadratic' elements have additional nodes at the center
points of each edge. See “Mesh Data” on page 2-171.
Data Types: double
Mesh elements, returned as an M-by-Ne matrix, where Ne is the number of elements in the
mesh, and M is:
5-283
5 Functions — Alphabetical List
Each column in Elements contains the indices of the nodes for that mesh element.
Data Types: double
Target maximum mesh element size, returned as a positive real number. The maximum
mesh element size is the length of the longest edge in the mesh. The generateMesh
Hmax name-value pair sets the target maximum size at the time it creates the mesh.
generateMesh can occasionally create a mesh with some elements that exceed
MaxElementSize by a few percent.
Data Types: double
Target minimum mesh element size, returned as a positive real number. The minimum
mesh element size is the length of the shortest edge in the mesh. The Hmin name-value
pair passed to the generateMesh function sets the target minimum size the at the time it
creates the mesh. generateMesh can occasionally create a mesh with some elements
that are smaller than MinElementSize.
Data Types: double
5-284
FEMesh Properties
See Also
PDEModel | area | findElements | findNodes | generateMesh | meshQuality |
meshToPet | volume
Topics
“Solve Problems Using PDEModel Objects” on page 2-3
“Finite Element Method Basics” on page 1-13
“Mesh Data” on page 2-171
Introduced in R2015a
5-285
5 Functions — Alphabetical List
findBodyLoad
Package: pde
Syntax
bl = findBodyLoad(structuralmodel.BodyLoads,RegionType,RegionID)
Description
bl = findBodyLoad(structuralmodel.BodyLoads,RegionType,RegionID)
returns the body load assigned to a geometric region of the structural model. A body load
must use units consistent with the geometry and other model attributes.
Examples
structuralModel = createpde('structural','static-solid');
gm = multicuboid(0.5,0.1,0.1);
structuralModel.Geometry = gm;
pdegplot(structuralModel,'FaceAlpha',0.5)
5-286
findBodyLoad
Specify the Young's modulus, Poisson's ratio, and mass density. Notice that the mass
density value is required for modeling gravitational effects.
structuralProperties(structuralModel,'YoungsModulus',210E3, ...
'PoissonsRatio',0.3,...
'MassDensity',2.7E-6);
structuralBodyLoad(structuralModel,'GravitationalAcceleration',[0;0;-9.8]);
findBodyLoad(structuralModel.BodyLoads,'Cell',1)
5-287
5 Functions — Alphabetical List
ans =
BodyLoadAssignment with properties:
RegionType: 'Cell'
RegionID: 1
GravitationalAcceleration: [3x1 double]
Temperature: []
TimeStep: []
Input Arguments
structuralmodel.BodyLoads — Body loads
BodyLoads property of StructuralModel object
Geometric region type, specified as 'Face' for a 2-D model or 'Cell' for a 3-D model.
Example: findBodyLoad(structuralmodel.BodyLoads,'Cell',1)
Data Types: char | string
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Example: findBodyLoad(structuralmodel.BodyLoads,'Cell',1)
Data Types: double
Output Arguments
bl — Body load assignment
BodyLoadAssignment object
5-288
findBodyLoad
See Also
structuralBodyLoad
Introduced in R2017b
5-289
5 Functions — Alphabetical List
findBoundaryConditions
Package: pde
Syntax
BCregion = findBoundaryConditions(BCs,RegionType,RegionID)
Description
BCregion = findBoundaryConditions(BCs,RegionType,RegionID) returns
boundary condition BCregion assigned to the specified region.
Examples
Create a PDE model and import a simple block geometry. Plot the geometry displaying the
face labels.
model = createpde(3);
importGeometry(model,'Block.stl');
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
5-290
findBoundaryConditions
applyBoundaryCondition(model,'dirichlet','Face',1:2,'u',[0,0,0]);
On face 3, set the Neumann boundary condition for equation 1 and Dirichlet boundary
condition for equations 2 and 3.
Set Neumann boundary conditions with opposite signs on faces 5 and 6 for all equations.
5-291
5 Functions — Alphabetical List
applyBoundaryCondition(model,'neumann','Face',4:5,'g',[1;1;1]);
applyBoundaryCondition(model,'neumann','Face',6,'g',[-1;-1;-1]);
ans =
BoundaryCondition with properties:
BCType: 'dirichlet'
RegionType: 'Face'
RegionID: [1 2]
r: []
h: []
g: []
q: []
u: [0 0 0]
EquationIndex: []
Vectorized: 'off'
ans =
BoundaryCondition with properties:
BCType: 'mixed'
RegionType: 'Face'
RegionID: 3
r: [3x1 double]
h: [3x3 double]
g: [3x1 double]
q: [3x3 double]
u: []
EquationIndex: []
Vectorized: 'off'
ans =
BoundaryCondition with properties:
5-292
findBoundaryConditions
BCType: 'neumann'
RegionType: 'Face'
RegionID: [4 5]
r: []
h: []
g: [3x1 double]
q: []
u: []
EquationIndex: []
Vectorized: 'off'
Input Arguments
BCs — Boundary conditions of a PDE model
BoundaryConditions property of a PDE model
Geometric region type, specified as 'Face' for 3-D geometry or 'Edge' for 2-D
geometry.
Example: findBoundaryConditions(model.BoundaryConditions,'Face',3)
Data Types: char | string
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot with the 'FaceLabels' (3-D) or 'EdgeLabels' (2-D) value set to
'on'.
Example: findBoundaryConditions(model.BoundaryConditions,'Face',3)
Data Types: double
5-293
5 Functions — Alphabetical List
Output Arguments
BCregion — Boundary condition for a particular region
BoundaryCondition object
See Also
BoundaryCondition | applyBoundaryCondition
Topics
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2016b
5-294
findCoefficients
findCoefficients
Package: pde
Syntax
CA = findCoefficients(coeffs,RegionType,RegionID)
Description
CA = findCoefficients(coeffs,RegionType,RegionID) returns the active
coefficient assignment CA for the coefficients in the specified region.
Examples
model = createpde();
geometryFromEdges(model,@lshapeg);
pdegplot(model,'FaceLabels','on')
ylim([-1.1,1.1])
axis equal
5-295
5 Functions — Alphabetical List
ca =
CoefficientAssignment with properties:
RegionType: 'face'
5-296
findCoefficients
RegionID: [1 3]
m: 0
d: 0
c: 13
a: 0
f: 2
Input Arguments
coeffs — Model coefficients
EquationCoefficients property of a PDE model
Geometric region type, specified as 'Face' for a 2-D model, or 'Cell' for a 3-D model.
Example: ca = findCoefficients(coeffs,'Face',[1,3])
Data Types: char | string
RegionID — Region ID
vector of positive integers
Region ID, specified as a vector of positive integers. View the subdomain labels for a 2-D
model using pdegplot(model,'FaceLabels','on'). Currently, there are no
subdomains for 3-D models, so the only acceptable value for a 3-D model is 1.
Example: ca = findCoefficients(coeffs,'Face',[1,3])
Data Types: double
5-297
5 Functions — Alphabetical List
Output Arguments
CA — Coefficient assignment
CoefficientAssignment object
See Also
CoefficientAssignment | specifyCoefficients
Topics
“View, Edit, and Delete PDE Coefficients” on page 2-109
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2016a
5-298
findElements
findElements
Package: pde
Syntax
elemIDs = findElements(mesh,'region',RegionType,RegionID)
elemIDs = findElements(mesh,'box',xlim,ylim)
elemIDs = findElements(mesh,'box',xlim,ylim,zlim)
elemIDs = findElements(mesh,'radius',center,radius)
elemIDs = findElements(mesh,'attached',nodeID)
Description
elemIDs = findElements(mesh,'region',RegionType,RegionID) returns the
IDs of the mesh elements that belong to the specified geometric region.
5-299
5 Functions — Alphabetical List
Examples
model = createpde;
Include the geometry of the built-in function lshapeg. Plot the geometry.
geometryFromEdges(model,@lshapeg);
pdegplot(model,'FaceLabels','on','EdgeLabels','on')
5-300
findElements
Generate a mesh.
mesh = generateMesh(model,'Hmax',0.5);
Ef2 = findElements(mesh,'region','Face',2);
figure
pdemesh(mesh,'ElementLabels','on')
hold on
pdemesh(mesh.Nodes,mesh.Elements(:,Ef2),'EdgeColor','green')
5-301
5 Functions — Alphabetical List
5-302
findElements
Generate a mesh.
mesh = generateMesh(model,'Hmax',2,'Hmin',0.4)
mesh =
FEMesh with properties:
5-303
5 Functions — Alphabetical List
figure
pdemesh(model)
hold on
pdemesh(mesh.Nodes,mesh.Elements(:,Eb),'EdgeColor','green')
5-304
findElements
model = createpde;
importGeometry(model,'PlateHolePlanar.stl');
pdegplot(model)
Generate a mesh.
5-305
5 Functions — Alphabetical List
mesh = generateMesh(model,'Hmax',2,'Hmin',0.4,'GeometricOrder','linear')
mesh =
FEMesh with properties:
Find the elements located within radius 2 from the center [5,10].
Er = findElements(mesh,'radius',[5 10],2);
figure
pdemesh(model)
hold on
pdemesh(mesh.Nodes,mesh.Elements(:,Er),'EdgeColor','green')
5-306
findElements
5-307
5 Functions — Alphabetical List
Generate a linear triangular mesh by setting the geometric order value to linear. This
mesh contains only corner nodes.
mesh = generateMesh(model,'Hmax',2,'Hmin',0.4, ...
'GeometricOrder','linear');
N_ID = 10
5-308
findElements
En = 1×3
95 97 98
Highlight the node and the elements in green on the mesh plot.
figure
pdemesh(model)
hold on
plot(mesh.Nodes(1,N_ID),mesh.Nodes(2,N_ID),'or','Color','g', ...
'MarkerFaceColor','g')
pdemesh(mesh.Nodes,mesh.Elements(:,En),'EdgeColor','green')
5-309
5 Functions — Alphabetical List
Input Arguments
mesh — Mesh object
Mesh property of a PDEModel object | output of generateMesh
Mesh object, specified as the Mesh property of a PDEModel object or as the output of
generateMesh.
Example: model.Mesh
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Example: findElements(mesh,'region','Face',1:3)
Data Types: double
x-limits of the bounding box, specified as a two-element row vector. The first element of
xlim is the lower x-bound, and the second element is the upper x-bound.
Example: findElements(mesh,'box',[5 10],[10 20])
Data Types: double
y-limits of the bounding box, specified as a two-element row vector. The first element of
ylim is the lower y-bound, and the second element is the upper y-bound.
Example: findElements(mesh,'box',[5 10],[10 20])
5-310
findElements
z-limits of the bounding box, specified as a two-element row vector. The first element of
zlim is the lower z-bound, and the second element is the upper z-bound. You can specify
zlim only for 3-D meshes.
Example: findElements(mesh,'box',[5 10],[10 20],[1 2])
Data Types: double
Center of the bounding circle or sphere, specified as a two-element row vector for a 2-D
mesh or three-element row vector for a 3-D mesh. The elements of these vectors contain
the coordinates of the center of a circle or a sphere.
Example: findElements(mesh,'radius',[0 0 0],0.5)
Data Types: double
ID of the corner node of the element, specified as a positive integer or a vector of positive
integers. The findElements function can find an ID of the element by the ID of the
corner node of the element. The function ignores IDs of the nodes located in the middle of
element edges. For multiple nodes, specify nodeID as a vector.
Example: findElements(mesh,'attached',[7 8 21])
Data Types: double
5-311
5 Functions — Alphabetical List
Output Arguments
elemIDs — Element IDs
positive integer | row vector of positive integers
See Also
FEMesh Properties | area | findNodes | meshQuality | volume
Topics
“Finite Element Method Basics” on page 1-13
Introduced in R2018a
5-312
findHeatSource
findHeatSource
Package: pde
Syntax
hsa = findHeatSource(thermalmodel.HeatSources,RegionType,RegionID)
Description
hsa = findHeatSource(thermalmodel.HeatSources,RegionType,RegionID)
returns the heat source value hsa assigned to the specified region.
Examples
thermalmodel = createpde('thermal');
geometryFromEdges(thermalmodel,@lshapeg);
pdegplot(thermalmodel,'FaceLabels','on')
ylim([-1.1 1.1])
axis equal
5-313
5 Functions — Alphabetical List
Specify that face 1 generates heat at 10 W/m^3, face 2 generates heat at 20 W/m^3, and
face 3 generates heat at 30 W/m^3.
internalHeatSource(thermalmodel,10,'Face',1);
internalHeatSource(thermalmodel,20,'Face',2);
internalHeatSource(thermalmodel,30,'Face',3);
hsaFace1 = findHeatSource(thermalmodel.HeatSources,'Face',1)
hsaFace1 =
HeatSourceAssignment with properties:
5-314
findHeatSource
RegionType: 'face'
RegionID: 1
HeatSource: 10
hsaFace2 =
HeatSourceAssignment with properties:
RegionType: 'face'
RegionID: 2
HeatSource: 20
hsaFace3 = hsa(2)
hsaFace3 =
HeatSourceAssignment with properties:
RegionType: 'face'
RegionID: 3
HeatSource: 30
Create a geometry that consists of three stacked cylinders and include the geometry in a
thermal model.
gm = multicylinder(10,[1 2 3],'ZOffset',[0 1 3])
gm =
DiscreteGeometry with properties:
NumCells: 3
NumFaces: 7
NumEdges: 4
NumVertices: 4
5-315
5 Functions — Alphabetical List
thermalmodel = createpde('thermal');
thermalmodel.Geometry = gm;
pdegplot(thermalmodel,'CellLabels','on','FaceAlpha',0.5)
Specify that the cylinder C1 generates heat at 10 W /m3, the cylinder C2 generates heat at
20 W /m3, and the cylinder C3 generates heat at 30 W /m3.
internalHeatSource(thermalmodel,10,'Cell',1);
internalHeatSource(thermalmodel,20,'Cell',2);
internalHeatSource(thermalmodel,30,'Cell',3);
hsaCell1 = findHeatSource(thermalmodel.HeatSources,'Cell',1)
5-316
findHeatSource
hsaCell1 =
HeatSourceAssignment with properties:
RegionType: 'cell'
RegionID: 1
HeatSource: 10
hsaCell2 =
HeatSourceAssignment with properties:
RegionType: 'cell'
RegionID: 2
HeatSource: 20
hsaCell3 = hsa(2)
hsaCell3 =
HeatSourceAssignment with properties:
RegionType: 'cell'
RegionID: 3
HeatSource: 30
Input Arguments
thermalmodel.HeatSources — Internal heat source of the model
HeatSources property of a thermal model
Geometric region type, specified as 'Face' for a 2-D model or 'Cell' for a 3-D model.
5-317
5 Functions — Alphabetical List
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using the pdegplot function.
Data Types: double
Output Arguments
hsa — Heat source assignment
HeatSourceAssignment object
See Also
HeatSourceAssignment | internalHeatSource
Introduced in R2017a
5-318
findInitialConditions
findInitialConditions
Package: pde
Syntax
ic = findInitialConditions(ics,RegionType,RegionID)
Description
ic = findInitialConditions(ics,RegionType,RegionID) returns the active
initial condition assignment ic for the initial conditions in the specified region.
Examples
This example shows find the active initial conditions for a region.
model = createpde();
geometryFromEdges(model,@lshapeg);
pdegplot(model,'FaceLabels','on')
ylim([-1.1,1.1])
axis equal
5-319
5 Functions — Alphabetical List
ic =
GeometricInitialConditions with properties:
RegionType: 'face'
5-320
findInitialConditions
RegionID: [1 3]
InitialValue: 13
InitialDerivative: []
Input Arguments
ics — Model initial conditions
InitialConditions property of a PDE model
Geometric region type, specified as 'Edge' for a 2-D model, 'Face' for a 2-D model or
3-D model, or 'Cell' for a 3-D model.
Example: ca = findInitialConditions(ics,'Face',[1,3])
Data Types: char | string
RegionID — Region ID
vector of positive integers
Region ID, specified as a vector of positive integers. View the subdomain labels for a 2-D
model using pdegplot(model,'FaceLabels','on'). Currently, there are no
subdomains for 3-D models, so the only acceptable value for a 3-D model is 1.
Example: ca = findInitialConditions(ics,'Face',[1,3])
Data Types: double
Output Arguments
ic — Initial condition assignment
GeometricInitialConditions object | NodalInitialConditions object
5-321
5 Functions — Alphabetical List
See Also
GeometricInitialConditions | NodalInitialConditions | setInitialConditions
Topics
“View, Edit, and Delete Initial Conditions” on page 2-116
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2016a
5-322
findNodes
findNodes
Package: pde
Syntax
nodes = findNodes(mesh,'region',RegionType,RegionID)
nodes = findNodes(mesh,'box',xlim,ylim)
nodes = findNodes(mesh,'box',xlim,ylim,zlim)
nodes = findNodes(mesh,'radius',center,radius)
nodes = findNodes(mesh,'nearest',point)
Description
nodes = findNodes(mesh,'region',RegionType,RegionID) returns the IDs of
the mesh nodes that belong to the specified geometric region.
Examples
5-323
5 Functions — Alphabetical List
model = createpde;
Include the geometry of the built-in function lshapeg. Plot the geometry.
geometryFromEdges(model,@lshapeg);
pdegplot(model,'FaceLabels','on','EdgeLabels','on')
Generate a mesh.
5-324
findNodes
mesh = generateMesh(model,'Hmax',0.5);
Nf2 = findNodes(mesh,'region','Face',2);
figure
pdemesh(model,'NodeLabels','on')
hold on
plot(mesh.Nodes(1,Nf2),mesh.Nodes(2,Nf2),'ok','MarkerFaceColor','g')
5-325
5 Functions — Alphabetical List
5-326
findNodes
model = createpde;
importGeometry(model,'PlateHolePlanar.stl');
pdegplot(model)
Generate a mesh.
mesh = generateMesh(model,'Hmax',2,'Hmin',0.4,'GeometricOrder','linear');
5-327
5 Functions — Alphabetical List
5-328
findNodes
model = createpde;
importGeometry(model,'PlateHolePlanar.stl');
pdegplot(model)
Generate a mesh.
mesh = generateMesh(model,'Hmax',2,'Hmin',0.4,'GeometricOrder','linear');
Find the nodes located within radius 2 from the center [5 10].
5-329
5 Functions — Alphabetical List
Nb = findNodes(mesh,'radius',[5 10],2);
Find the node closest to a specified point and highlight it on the mesh plot.
5-330
findNodes
model = createpde;
importGeometry(model,'PlateHolePlanar.stl');
pdegplot(model)
Generate a mesh.
mesh = generateMesh(model,'Hmax',2,'Hmin',0.4);
5-331
5 Functions — Alphabetical List
N_ID = findNodes(mesh,'nearest',[15;10])
N_ID = 10
figure
pdemesh(model)
hold on
plot(mesh.Nodes(1,N_ID),mesh.Nodes(2,N_ID),'or','MarkerFaceColor','g')
5-332
findNodes
Input Arguments
mesh — Mesh object
Mesh property of a PDEModel object | output of generateMesh
Mesh object, specified as the Mesh property of a PDEModel object or as the output of
generateMesh.
Example: model.Mesh
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Example: findNodes(mesh,'region','Face',1:3)
Data Types: double
x-limits of the bounding box, specified as a two-element row vector. The first element of
xlim is the lower x-bound, and the second element is the upper x-bound.
Example: findNodes(mesh,'box',[5 10],[10 20])
Data Types: double
y-limits of the bounding box, specified as a two-element row vector. The first element of
ylim is the lower y-bound, and the second element is the upper y-bound.
Example: findNodes(mesh,'box',[5 10],[10 20])
5-333
5 Functions — Alphabetical List
z-limits of the bounding box, specified as a two-element row vector. The first element of
zlim is the lower z-bound, and the second element is the upper z-bound. You can specify
zlim only for 3-D meshes.
Example: findNodes(mesh,'box',[5 10],[10 20],[1 2])
Data Types: double
Center of the bounding circle or sphere, specified as a two-element row vector for a 2-D
mesh or three-element row vector for a 3-D mesh. The elements of these vectors contain
the coordinates of the center of a circle or a sphere.
Example: findNodes(mesh,'radius',[0 0 0],0.5)
Data Types: double
5-334
findNodes
Output Arguments
nodes — Node IDs
positive integer | row vector of positive integers
See Also
FEMesh Properties | area | findElements | meshQuality | volume
Topics
“Finite Element Method Basics” on page 1-13
Introduced in R2018a
5-335
5 Functions — Alphabetical List
findStructuralBC
Package: pde
Find structural boundary conditions and boundary loads assigned to geometric region
Syntax
sbca = findStructuralBC(structuralmodel.BoundaryConditions,
RegionType,RegionID)
Description
sbca = findStructuralBC(structuralmodel.BoundaryConditions,
RegionType,RegionID) returns the structural boundary conditions and boundary loads
assigned to the region specified by RegionType and RegionID. The function returns
structural boundary conditions assigned by structuralBC and boundary loads assigned
by structuralBoundaryLoad.
Examples
Find the structural boundary conditions for the faces of a 3-D geometry.
structuralmodel = createpde('structural','static-solid');
Include the block geometry in the model and plot the geometry.
importGeometry(structuralmodel,'Block.stl');
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
5-336
findStructuralBC
structuralBoundaryLoad(structuralmodel,'Face',1,'SurfaceTraction',[100;10;300]);
structuralBoundaryLoad(structuralmodel,'Face',3,'Pressure',300);
structuralBC(structuralmodel,'Face',[5,6],'Constraint','free');
5-337
5 Functions — Alphabetical List
sbca = findStructuralBC(structuralmodel.BoundaryConditions,'Face',[1,3]);
sbcaFace1 = sbca(1)
sbcaFace1 =
StructuralBC with properties:
RegionType: 'Face'
RegionID: 1
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: [3x1 double]
Pressure: []
TranslationalStiffness: []
sbcaFace3 = sbca(2)
sbcaFace3 =
StructuralBC with properties:
RegionType: 'Face'
RegionID: 3
Vectorized: 'off'
Boundary Loads
5-338
findStructuralBC
Force: []
SurfaceTraction: []
Pressure: 300
TranslationalStiffness: []
sbca = findStructuralBC(structuralmodel.BoundaryConditions,'Face',[5,6]);
sbcaFace5 = sbca(1)
sbcaFace5 =
StructuralBC with properties:
RegionType: 'Face'
RegionID: [5 6]
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: []
Pressure: []
TranslationalStiffness: []
sbcaFace6 = sbca(2)
sbcaFace6 =
StructuralBC with properties:
RegionType: 'Face'
RegionID: [5 6]
Vectorized: 'off'
5-339
5 Functions — Alphabetical List
XDisplacement: []
YDisplacement: []
ZDisplacement: []
Constraint: "free"
Radius: []
Reference: []
Boundary Loads
Force: []
SurfaceTraction: []
Pressure: []
TranslationalStiffness: []
Input Arguments
structuralmodel.BoundaryConditions — Structural boundary conditions
BoundaryConditions property of StructuralModel object
Geometric region type, specified as 'Edge' for a 2-D model or 'Face' for a 3-D model.
Example: findStructuralBC(structuralmodel.BoundaryConditions,'Edge',1)
Data Types: char | string
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Example:
findStructuralBC(structuralmodel.BoundaryConditions,'Face',1:3)
Data Types: double
5-340
findStructuralBC
Output Arguments
sbca — Structural boundary conditions and boundary loads assignment
StructuralBC object
See Also
structuralBC | structuralBoundaryLoad
Introduced in R2017b
5-341
5 Functions — Alphabetical List
findStructuralIC
Package: pde
Syntax
sica = findStructuralIC(structuralmodel.InitialConditions,
RegionType,RegionID)
Description
sica = findStructuralIC(structuralmodel.InitialConditions,
RegionType,RegionID) returns the initial displacement and velocity assigned to the
specified region.
Examples
Find the initial displacement and velocity assigned to the cells of a 3-D geometry.
structuralmodel = createpde('structural','transient-solid');
Create the geometry consisting of the three nested cylinders and include it in the model.
Plot the geometry.
gm = multicylinder([5 10 15],2);
structuralmodel = createpde('structural','transient-solid');
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'CellLabels','on','FaceAlpha',0.5)
5-342
findStructuralIC
Set the initial conditions for each cell. When you specify only the initial velocity or initial
displacement, structuralIC assumes that the omitted parameter is zero.
structuralIC(structuralmodel,'Displacement',[0;0;0],'Velocity',[0;0;0],'Cell',1);
structuralIC(structuralmodel,'Displacement',[0;0.1;0],'Cell',2);
structuralIC(structuralmodel,'Velocity',[0;0.2;0],'Cell',3);
SICACell1 = findStructuralIC(structuralmodel.InitialConditions,'Cell',1)
SICACell1 =
GeometricStructuralICs with properties:
5-343
5 Functions — Alphabetical List
RegionType: 'Cell'
RegionID: 1
InitialDisplacement: [3x1 double]
InitialVelocity: [3x1 double]
SICACell1.InitialDisplacement
ans = 3×1
0
0
0
SICACell1.InitialVelocity
ans = 3×1
0
0
0
Use a static solution as an initial condition for a dynamic structural model. Check and plot
the initial displacement.
staticmodel = createpde('structural','static-solid');
Create the geometry and include it in the model. Plot the geometry.
gm = multicuboid(0.06,0.005,0.01);
staticmodel.Geometry = gm;
pdegplot(staticmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
5-344
findStructuralIC
structuralProperties(staticmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3,...
'MassDensity',7800);
structuralBC(staticmodel,'Face',5,'Constraint','fixed');
structuralBoundaryLoad(staticmodel,'Face',3,'SurfaceTraction',[0;1E6;0]);
generateMesh(staticmodel,'Hmax',0.02);
Rstatic = solve(staticmodel);
5-345
5 Functions — Alphabetical List
dynamicmodel = createpde('structural','transient-solid');
gm = multicuboid(0.06,0.005,0.01);
dynamicmodel.Geometry = gm;
structuralBC(dynamicmodel,'Face',5,'Constraint','fixed');
generateMesh(dynamicmodel,'Hmax',0.02);
structuralIC(dynamicmodel,Rstatic)
ans =
NodalStructuralICs with properties:
sica = findStructuralIC(dynamicmodel.InitialConditions,'Cell',1)
sica =
NodalStructuralICs with properties:
pdeplot3D(dynamicmodel,'ColorMapData',sica.InitialDisplacement(:,3))
title('Initial Displacement in the Z-direction')
5-346
findStructuralIC
Input Arguments
structuralmodel.InitialConditions — Initial conditions
InitialConditions property of a StructuralModel object
5-347
5 Functions — Alphabetical List
Geometric region type, specified as 'Face', 'Edge', or 'Vertex' for a 2-D model or 3-
D model, or 'Cell' for a 3-D model.
Data Types: char
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Data Types: double
Output Arguments
sica — Structural initial condition assignment
GeometricStructuralICs object | NodalStructuralICs object
See Also
GeometricStructuralICs Properties | NodalStructuralICs Properties | StructuralModel |
structuralIC
Introduced in R2018a
5-348
findStructuralProperties
findStructuralProperties
Package: pde
Syntax
smpa = findStructuralProperties(structuralmodel.MaterialProperties,
RegionType,RegionID)
Description
smpa = findStructuralProperties(structuralmodel.MaterialProperties,
RegionType,RegionID) returns the structural material properties assigned to the
specified region. Structural properties include the Young's modulus, Poisson's ratio, and
mass density of the material.
Examples
Find Young's modulus and Poisson's ratio for cells of a 3-D geometry.
structuralmodel = createpde('structural','static-solid');
Create the geometry consisting of three stacked cylinders and include it in the model.
Plot the geometry.
5-349
5 Functions — Alphabetical List
Assign different values of the Young's modulus and Poisson's ratio to each cell.
structuralProperties(structuralmodel,'Cell',1,'YoungsModulus',200E9, ...
'PoissonsRatio',0.3);
structuralProperties(structuralmodel,'Cell',2,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3);
structuralProperties(structuralmodel,'Cell',3,'YoungsModulus',110E9, ...
'PoissonsRatio',0.35);
mC1 =
StructuralMaterialAssignment with properties:
5-350
findStructuralProperties
RegionType: 'Cell'
RegionID: 1
YoungsModulus: 2.0000e+11
PoissonsRatio: 0.3000
MassDensity: []
CTE: []
mC23 = findStructuralProperties(structuralmodel.MaterialProperties,'Cell',[2,3]);
mC2 = mC23(1)
mC2 =
StructuralMaterialAssignment with properties:
RegionType: 'Cell'
RegionID: 2
YoungsModulus: 2.1000e+11
PoissonsRatio: 0.3000
MassDensity: []
CTE: []
mC3 = mC23(2)
mC3 =
StructuralMaterialAssignment with properties:
RegionType: 'Cell'
RegionID: 3
YoungsModulus: 1.1000e+11
PoissonsRatio: 0.3500
MassDensity: []
CTE: []
Input Arguments
structuralmodel.MaterialProperties — Material properties
MaterialProperties property of StructuralModel object
5-351
5 Functions — Alphabetical List
Geometric region type, specified as 'Face' for a 2-D model or 'Cell' for a 3-D model.
Example:
findStructuralProperties(structuralmodel.MaterialProperties,'Cell',1
)
Data Types: char | string
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Example:
findStructuralProperties(structuralmodel.MaterialProperties,'Face',1
:3)
Data Types: double
Output Arguments
smpa — Material properties assignment
StructuralMaterialAssignment object
See Also
StructuralMaterialAssignment Properties | structuralProperties
Introduced in R2017b
5-352
findThermalBC
findThermalBC
Package: pde
Syntax
tbca = findThermalBC(thermalmodel.BoundaryConditions,RegionType,
RegionID)
Description
tbca = findThermalBC(thermalmodel.BoundaryConditions,RegionType,
RegionID) returns the thermal boundary condition assigned to the specified region.
Examples
thermalmodel = createpde('thermal');
geometryFromEdges(thermalmodel,@squareg);
pdegplot(thermalmodel,'EdgeLabels','on')
ylim([-1.1 1.1])
axis equal
5-353
5 Functions — Alphabetical List
tbcaEdge1 =
ThermalBC with properties:
5-354
findThermalBC
RegionType: 'Edge'
RegionID: [1 3]
Temperature: 100
HeatFlux: []
ConvectionCoefficient: []
Emissivity: []
AmbientTemperature: []
Vectorized: 'off'
tbca = findThermalBC(thermalmodel.BoundaryConditions,'Edge',[3:4]);
tbcaEdge3 = tbca(1)
tbcaEdge3 =
ThermalBC with properties:
RegionType: 'Edge'
RegionID: [1 3]
Temperature: 100
HeatFlux: []
ConvectionCoefficient: []
Emissivity: []
AmbientTemperature: []
Vectorized: 'off'
tbcaEdge4 = tbca(2)
tbcaEdge4 =
ThermalBC with properties:
RegionType: 'Edge'
RegionID: 4
Temperature: []
HeatFlux: 20
ConvectionCoefficient: []
Emissivity: []
AmbientTemperature: []
Vectorized: 'off'
5-355
5 Functions — Alphabetical List
thermalmodel = createpde('thermal','transient');
gm = importGeometry(thermalmodel,'Block.stl');
pdegplot(thermalmodel,'FaceLabels','on','FaceAlpha',0.5)
thermalBC(thermalmodel,'Face',1,'Temperature',100);
thermalBC(thermalmodel,'Face',3,'Temperature',300);
5-356
findThermalBC
thermalBC(thermalmodel,'Face',[5,6],...
'ConvectionCoefficient',5,...
'AmbientTemperature',27);
tbcaFace1 =
ThermalBC with properties:
RegionType: 'Face'
RegionID: 1
Temperature: 100
HeatFlux: []
ConvectionCoefficient: []
Emissivity: []
AmbientTemperature: []
Vectorized: 'off'
tbcaFace3 = tbca(2)
tbcaFace3 =
ThermalBC with properties:
RegionType: 'Face'
RegionID: 3
Temperature: 300
HeatFlux: []
ConvectionCoefficient: []
Emissivity: []
AmbientTemperature: []
Vectorized: 'off'
tbcaFace5 =
ThermalBC with properties:
RegionType: 'Face'
RegionID: [5 6]
5-357
5 Functions — Alphabetical List
Temperature: []
HeatFlux: []
ConvectionCoefficient: 5
Emissivity: []
AmbientTemperature: 27
Vectorized: 'off'
tbcaFace6 = findThermalBC(thermalmodel.BoundaryConditions,'Face',6)
tbcaFace6 =
ThermalBC with properties:
RegionType: 'Face'
RegionID: [5 6]
Temperature: []
HeatFlux: []
ConvectionCoefficient: 5
Emissivity: []
AmbientTemperature: 27
Vectorized: 'off'
Input Arguments
thermalmodel.BoundaryConditions — Boundary conditions of a thermal model
BoundaryConditions property of a thermal model
Geometric region type, specified as 'Face' for 3-D geometry or 'Edge' for 2-D
geometry.
Data Types: char | string
5-358
findThermalBC
Geometric region ID, specified as a vector of positive integers. Find the region IDs using
pdegplot with the 'FaceLabels' (3-D) or 'EdgeLabels' (2-D) value set to 'on'.
Data Types: double
Output Arguments
tbca — Thermal boundary condition for a particular region
ThermalBC object
See Also
ThermalBC | thermalBC
Introduced in R2017a
5-359
5 Functions — Alphabetical List
findThermalIC
Package: pde
Syntax
tica = findThermalIC(thermalmodel.InitialConditions,RegionType,
RegionID)
Description
tica = findThermalIC(thermalmodel.InitialConditions,RegionType,
RegionID) returns the thermal initial condition assigned to the specified region.
Examples
thermalmodel = createpde('thermal','transient');
geometryFromEdges(thermalmodel,@lshapeg);
pdegplot(thermalmodel,'FaceLabels','on')
ylim([-1.1 1.1])
axis equal
5-360
findThermalIC
ticaFace1 =
GeometricThermalICs with properties:
RegionType: 'face'
RegionID: 1
5-361
5 Functions — Alphabetical List
InitialTemperature: 10
ticaFace2 =
GeometricThermalICs with properties:
RegionType: 'face'
RegionID: 2
InitialTemperature: 20
ticaFace3 = tica(2)
ticaFace3 =
GeometricThermalICs with properties:
RegionType: 'face'
RegionID: 3
InitialTemperature: 30
Create a geometry that consists of three nested cylinders and include the geometry in a
transient thermal model.
gm = multicylinder([5 10 15],2)
gm =
DiscreteGeometry with properties:
NumCells: 3
NumFaces: 9
NumEdges: 6
NumVertices: 6
5-362
findThermalIC
thermalmodel = createpde('thermal','transient');
thermalmodel.Geometry = gm;
pdegplot(thermalmodel,'CellLabels','on','FaceAlpha',0.5)
thermalIC(thermalmodel,0,'Cell',1);
thermalIC(thermalmodel,100,'Cell',2);
thermalIC(thermalmodel,0,'Cell',3);
ticaCell1 = findThermalIC(thermalmodel.InitialConditions,'Cell',1)
5-363
5 Functions — Alphabetical List
ticaCell1 =
GeometricThermalICs with properties:
RegionType: 'cell'
RegionID: 1
InitialTemperature: 0
tica = findThermalIC(thermalmodel.InitialConditions,'Cell',[2:3]);
ticaCell2 = tica(1)
ticaCell2 =
GeometricThermalICs with properties:
RegionType: 'cell'
RegionID: 2
InitialTemperature: 100
ticaCell3 = tica(2)
ticaCell3 =
GeometricThermalICs with properties:
RegionType: 'cell'
RegionID: 3
InitialTemperature: 0
thermalmodel = createpde('thermal','transient');
gm = @squareg;
geometryFromEdges(thermalmodel,gm);
pdegplot(thermalmodel,'FaceLabels','on')
ylim([-1.1 1.1])
axis equal
5-364
findThermalIC
Specify material properties, heat source, set initial and boundary conditions.
thermalProperties(thermalmodel,'ThermalConductivity',500,...
'MassDensity',200,...
'SpecificHeat',100);
internalHeatSource(thermalmodel,2);
thermalBC(thermalmodel,'Edge',[1 3],'Temperature',100);
thermalIC(thermalmodel,0);
generateMesh(thermalmodel);
tlist = 0:0.5:10;
result1 = solve(thermalmodel,tlist)
5-365
5 Functions — Alphabetical List
result1 =
TransientThermalResults with properties:
tica =
GeometricThermalICs with properties:
RegionType: 'face'
RegionID: 1
InitialTemperature: 0
Now, resume the analysis and solve the problem for times from 10 to 15 seconds. Use the
previously obtained solution for 10 seconds as an initial condition. Since 10 seconds is the
last element in tlist, you do not need to specify the solution time index. By default,
thermalIC uses the last solution index.
ic = thermalIC(thermalmodel,result1);
tica =
NodalThermalICs with properties:
pdeplot(thermalmodel,'XYData',tica.InitialTemperature)
5-366
findThermalIC
Input Arguments
thermalmodel.InitialConditions — Initial conditions of a thermal model
InitialConditions property of a thermal model
5-367
5 Functions — Alphabetical List
Geometric region type, specified as 'Edge', 'Face', or 'Vertex' for a 2-D model or 3-
D model, or 'Cell' for a 3-D model.
Data Types: char | string
Geometric region ID, specified as a vector of positive integers. Find the region IDs using
the pdegplot function with the 'FaceLabels' (3-D) or 'EdgeLabels' (2-D) value set
to 'on'.
Data Types: double
Output Arguments
tica — Thermal initial condition for a particular region
GeometricThermalICs object | NodalThermalICs object
See Also
GeometricThermalICs | NodalThermalICs | thermalIC
Introduced in R2017a
5-368
findThermalProperties
findThermalProperties
Package: pde
Syntax
tmpa = findThermalProperties(thermalmodel.MaterialProperties,
RegionType,RegionID)
Description
tmpa = findThermalProperties(thermalmodel.MaterialProperties,
RegionType,RegionID) returns thermal material properties tmpa assigned to the
specified region.
Examples
Find Thermal Conductivity, Mass Density, and Specific Heat for Faces of 2-D
Geometry
thermalmodel = createpde('thermal','transient');
geometryFromEdges(thermalmodel,@lshapeg);
pdegplot(thermalmodel,'FaceLabels','on')
ylim([-1.1,1.1])
axis equal
5-369
5 Functions — Alphabetical List
thermalProperties(thermalmodel,'ThermalConductivity',10,...
'MassDensity',1,...
'SpecificHeat',0.1,...
'Face',1);
5-370
findThermalProperties
thermalProperties(thermalmodel,'ThermalConductivity',20,...
'MassDensity',2,...
'SpecificHeat',0.2,...
'Face',2);
For face 1, specify the following thermal properties: thermal conductivity is 30 W/(m*C),
mass density is 3 kg/m^3, specific heat is 0.3 J/(kg*C).
thermalProperties(thermalmodel,'ThermalConductivity',30,...
'MassDensity',3,...
'SpecificHeat',0.3,...
'Face',3);
mpaFace1 = findThermalProperties(thermalmodel.MaterialProperties,'Face',1)
mpaFace1 =
ThermalMaterialAssignment with properties:
RegionType: 'face'
RegionID: 1
ThermalConductivity: 10
MassDensity: 1
SpecificHeat: 0.1000
mpa = findThermalProperties(thermalmodel.MaterialProperties,'Face',[2,3]);
mpaFace2 = mpa(1)
mpaFace2 =
ThermalMaterialAssignment with properties:
5-371
5 Functions — Alphabetical List
RegionType: 'face'
RegionID: 2
ThermalConductivity: 20
MassDensity: 2
SpecificHeat: 0.2000
mpaFace3 = mpa(2)
mpaFace3 =
ThermalMaterialAssignment with properties:
RegionType: 'face'
RegionID: 3
ThermalConductivity: 30
MassDensity: 3
SpecificHeat: 0.3000
Create a geometry that consists of three stacked cylinders and include the geometry in a
thermal model.
gm =
DiscreteGeometry with properties:
NumCells: 3
NumFaces: 7
NumEdges: 4
NumVertices: 4
thermalmodel = createpde('thermal');
thermalmodel.Geometry = gm;
pdegplot(thermalmodel,'CellLabels','on','FaceAlpha',0.5)
5-372
findThermalProperties
5-373
5 Functions — Alphabetical List
mpaCell1 =
ThermalMaterialAssignment with properties:
RegionType: 'cell'
RegionID: 1
ThermalConductivity: 10
MassDensity: []
SpecificHeat: []
mpa = findThermalProperties(thermalmodel.MaterialProperties,'Cell',2:3);
mpaCell2 = mpa(1)
mpaCell2 =
ThermalMaterialAssignment with properties:
RegionType: 'cell'
RegionID: 2
ThermalConductivity: 20
MassDensity: []
SpecificHeat: []
mpaCell3 = mpa(2)
mpaCell3 =
ThermalMaterialAssignment with properties:
RegionType: 'cell'
RegionID: 3
ThermalConductivity: 30
MassDensity: []
SpecificHeat: []
Input Arguments
thermalmodel.MaterialProperties — Material properties of the model
MaterialProperties property of a thermal model
5-374
findThermalProperties
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Example:
findThermalProperties(thermalmodel.MaterialProperties,'Face',1:3)
Data Types: double
Output Arguments
tmpa — Material properties assignment
ThermalMaterialAssignment object
See Also
ThermalMaterialAssignment | thermalProperties
Introduced in R2017a
5-375
5 Functions — Alphabetical List
generateMesh
Package: pde
Syntax
generateMesh(model)
generateMesh(model,Name,Value)
mesh = generateMesh( ___ )
Description
generateMesh(model) creates a mesh and stores it in the model object. model must
contain geometry. To include 2-D geometry in a model, use geometryFromEdges. To
include 3-D geometry, use importGeometry or geometryFromMesh.
generateMesh can return slightly different meshes in different releases. For example,
the number of elements in the mesh can change. Avoid writing code that relies on
explicitly specified node and element IDs.
mesh = generateMesh( ___ ) also returns the mesh to the MATLAB workspace, using
any of the previous syntaxes.
Examples
5-376
generateMesh
model = createpde(1);
geometryFromEdges(model,@lshapeg);
generateMesh(model);
pdeplot(model)
5-377
5 Functions — Alphabetical List
model = createpde(1);
importGeometry(model,'BracketTwoHoles.stl');
generateMesh(model)
ans =
FEMesh with properties:
pdeplot3D(model)
5-378
generateMesh
Create a mesh with target maximum element size 5 instead of the default 7.3485.
generateMesh(model,'Hmax',5)
ans =
FEMesh with properties:
5-379
5 Functions — Alphabetical List
pdeplot3D(model)
Input Arguments
model — Model object
PDEModel object | ThermalModel object | StructuralModel object
5-380
generateMesh
Mesh growth rate, specified as the comma-separated pair consisting of Hgrad and a
number greater than or equal to 1 and less than or equal to 2.
Example: generateMesh(model,'Hgrad',1.3);
Data Types: double
Target maximum mesh edge length, specified as the comma-separated pair consisting of
Hmax and a positive real number.
5-381
5 Functions — Alphabetical List
generateMesh estimates the default value of Hmax from overall dimensions of the
geometry.
Small Hmax values let you create finer meshes, but mesh generation can take a very long
time in this case. You can interrupt mesh generation by using Ctrl+C. Note that
generateMesh can take additional time to respond to the interrupt.
Example: generateMesh(model,'Hmax',0.25);
Data Types: double
Target minimum mesh edge length, specified as the comma-separated pair consisting of
Hmin and a nonnegative real number.
generateMesh estimates the default value of Hmin from overall dimensions of the
geometry.
Example: generateMesh(model,'Hmin',0.05);
Data Types: double
Output Arguments
mesh — Mesh description
FEMesh object
5-382
generateMesh
More About
Element
An element is a basic unit in the finite-element method.
For 3-D problems, an element is a tetrahedron with either four or ten points. A four-point
(linear) tetrahedron has nodes only at its corners. A ten-point (quadratic) tetrahedron has
nodes at its corners and at the center point of each edge.
See Also
FEMesh | PDEModel | geometryFromEdges | importGeometry
Topics
“Solve Problems Using PDEModel Objects” on page 2-3
“Finite Element Method Basics” on page 1-13
“Mesh Data” on page 2-171
“Mesh Data as [p,e,t] Triples” on page 2-168
Introduced in R2015a
5-383
5 Functions — Alphabetical List
GeometricInitialConditions Properties
Initial conditions over a region or region boundary
Description
A GeometricInitialConditions object contains a description of the initial conditions
over a geometric region or boundary of the region. A PDEModel container has a vector of
GeometricInitialConditions objects in its
InitialConditions.InitialConditionAssignments property.
Set initial conditions for your model using the setInitialConditions function.
Properties
Properties
Region type, returned as 'face' for a 2-D region, or 'cell' for a 3-D region.
Data Types: char | string
RegionID — Region ID
vector of positive integers
Initial value, returned as a scalar, vector, or function handle. For details, see
setInitialConditions.
5-384
GeometricInitialConditions Properties
Initial derivative, returned as a scalar, vector, or function handle. For details, see
setInitialConditions.
Data Types: double | function_handle
Complex Number Support: Yes
See Also
NodalInitialConditions | findInitialConditions | setInitialConditions
Topics
“Set Initial Conditions” on page 2-113
“View, Edit, and Delete Initial Conditions” on page 2-116
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2016a
5-385
5 Functions — Alphabetical List
GeometricStructuralICs Properties
Initial displacement and velocity over a region
Description
A GeometricStructuralICs object contains a description of the initial displacement
and velocity over a geometric region for a transient structural model. A
StructuralModel container has a vector of GeometricStructuralICs objects in its
InitialConditions.StructuralICAssignments property.
To set initial conditions for your structural model, use the structuralIC function.
Properties
Properties
Geometric region type, returned as 'Face', 'Edge', or 'Vertex' for a 2-D model or 3-D
model, or 'Cell' for a 3-D model.
Data Types: char | string
Geometric region ID, returned as a vector of positive integers. Find the region IDs by
using pdegplot.
Data Types: double
Initial displacement, returned as a numeric vector or function handle. For details, see
structuralIC.
5-386
GeometricStructuralICs Properties
Initial velocity, returned as a numeric vector or function handle. For details, see
structuralIC.
Data Types: double | function_handle
See Also
NodalStructuralICs Properties | findStructuralIC | structuralIC
Introduced in R2018a
5-387
5 Functions — Alphabetical List
GeometricThermalICs Properties
Initial temperature over a region or region boundary
Description
A GeometricThermalICs object contains a description of the initial temperature over a
geometric region or a boundary of the region. A ThermalModel container has a vector of
GeometricThermalICs objects in its InitialConditions.ThermalICAssignments
property.
Set initial conditions for your model using the thermalIC function.
Properties
Properties
Region type, returned as 'Vertex', 'Edge', or 'Face' for a 2-D or 3-D region, or
'Cell' for a 3-D region.
Data Types: char | string
RegionID — Region ID
vector of positive integers
Initial temperature, returned as a scalar, vector, or function handle. For details, see
thermalIC.
5-388
GeometricThermalICs Properties
See Also
NodalThermalICs | findThermalIC | thermalIC
Introduced in R2017a
5-389
5 Functions — Alphabetical List
NodalInitialConditions Properties
Initial conditions at mesh nodes
Description
A NodalInitialConditions object contains a description of the initial conditions at
mesh nodes. A PDEModel container has a vector of NodalInitialConditions objects
in its InitialConditions.InitialConditionAssignments property.
Set initial conditions for your model using the setInitialConditions function.
Properties
Properties
Initial value, returned as a scalar, vector, or function handle. For details, see
setInitialConditions.
Data Types: double | function_handle
Complex Number Support: Yes
Initial derivative, returned as a scalar, vector, or function handle. For details, see
setInitialConditions.
Data Types: double | function_handle
Complex Number Support: Yes
See Also
GeometricInitialConditions | findInitialConditions | setInitialConditions
5-390
NodalInitialConditions Properties
Topics
“Set Initial Conditions” on page 2-113
“View, Edit, and Delete Initial Conditions” on page 2-116
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2016b
5-391
5 Functions — Alphabetical List
NodalStructuralICs Properties
Initial displacement and velocity at mesh nodes
Description
A NodalStructuralICs object contains a description of the initial displacement and
velocity at mesh nodes. A StructuralModel container has a vector of
GeometricStructuralICs objects in its
InitialConditions.StructuralICAssignments property.
To set initial conditions for your structural model, use the structuralIC function.
Properties
Properties
Initial displacement, returned as a numeric vector or function handle. For details, see
structuralIC.
Data Types: double | function_handle
Initial velocity, returned as a numeric vector or function handle. For details, see
structuralIC.
Data Types: double | function_handle
See Also
GeometricStructuralICs Properties | findStructuralIC | structuralIC
5-392
NodalStructuralICs Properties
Introduced in R2018a
5-393
5 Functions — Alphabetical List
NodalThermalICs Properties
Initial temperature at mesh nodes
Description
A NodalThermalICs object contains a description of the initial temperatures at mesh
nodes. A ThermalModel container has a vector of NodalThermalICs objects in its
InitialConditions.ThermalICAssignments property.
Set initial conditions for your model using the thermalIC function.
Properties
Properties
Initial temperature, returned as a scalar, vector, or function handle. For details, see
thermalIC.
Data Types: double | function_handle
See Also
GeometricThermalICs | findThermalIC | thermalIC
Introduced in R2017a
5-394
geometryFromEdges
geometryFromEdges
Package: pde
Syntax
geometryFromEdges(model,g)
pg = geometryFromEdges(model,g)
Description
geometryFromEdges(model,g) adds the 2-D geometry described in g to the model
container.
Examples
model = createpde;
Define a circle in a rectangle, place these in one matrix, and create a set formula that
subtracts the circle from the rectangle.
R1 = [3,4,-1,1,1,-1,0.5,0.5,-0.75,-0.75]';
C1 = [1,0.5,-0.25,0.25]';
C1 = [C1;zeros(length(R1) - length(C1),1)];
5-395
5 Functions — Alphabetical List
gm = [R1,C1];
sf = 'R1-C1';
5-396
geometryFromEdges
Input Arguments
model — Model object
PDEModel object | ThermalModel object | StructuralModel object
g — Geometry description
decomposed geometry matrix | name of a geometry function | handle to a geometry
function
Output Arguments
pg — Geometry object
AnalyticGeometry object
See Also
AnalyticGeometry | PDEModel
Topics
“Solve PDEs with Constant Boundary Conditions” on page 2-131
5-397
5 Functions — Alphabetical List
Introduced in R2015a
5-398
geometryFromMesh
geometryFromMesh
Package: pde
Syntax
geometryFromMesh(model,nodes,elements)
geometryFromMesh(model,nodes,elements,ElementIDToRegionID)
[G,mesh] = geometryFromMesh(model,nodes,elements)
Description
geometryFromMesh(model,nodes,elements) creates geometry within model. For
planar and volume triangulated meshes, this function also incorporates nodes in the
model.Mesh.Nodes property and elements in the model.Mesh.Elements property. To
replace the imported mesh with a mesh having a different target element size, use
generateMesh.
If elements represents a surface triangular mesh that bounds a closed volume, then
geometryFromMesh creates the geometry, but does not incorporate the mesh into the
corresponding properties of the model. To generate a mesh in this case, use
generateMesh.
geometryFromMesh(model,nodes,elements,ElementIDToRegionID) creates a
multidomain geometry. Here, ElementIDToRegionID specifies the subdomain IDs for
each element of the mesh.
Examples
5-399
5 Functions — Alphabetical List
Load a tetrahedral mesh into your workspace. The tetmesh file ships with your software.
Put the data in the correct shape for geometryFromMesh.
load tetmesh
nodes = X';
elements = tet';
Create a PDE model and import the mesh into the model.
model = createpde();
geometryFromMesh(model,nodes,elements);
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
5-400
geometryFromMesh
Create a geometric block from the convex hull of a mesh grid of points.
5-401
5 Functions — Alphabetical List
z = z(:);
K = convhull(x,y,z);
nodes = [x';y';z'];
elements = K';
model = createpde();
geometryFromMesh(model,nodes,elements);
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
5-402
geometryFromMesh
Create a 3-D geometry using the MATLAB alphaShape function. First, create an
alphaShape object of a block with a cylindrical hole. Then import the geometry into a
PDE model from the alphaShape boundary.
5-403
5 Functions — Alphabetical List
Create a unit disk. Remove all the mesh grid points that fall inside the unit disk, and
include the unit disk points.
t = (pi/24:pi/24:2*pi)';
x = cos(t);
y = sin(t);
circShp = alphaShape(x,y,2);
in = inShape(circShp,xg,yg);
xg = [xg(~in); cos(t)];
yg = [yg(~in); sin(t)];
Create 3-D copies of the remaining mesh grid points, with the z-coordinates ranging from
0 through 1. Combine the points into an alphaShape object.
zg = ones(numel(xg),1);
xg = repmat(xg,5,1);
yg = repmat(yg,5,1);
zg = zg*(0:.25:1);
zg = zg(:);
shp = alphaShape(xg,yg,zg);
[elements,nodes] = boundaryFacets(shp);
nodes = nodes';
elements = elements';
model = createpde();
geometryFromMesh(model,nodes,elements);
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
5-404
geometryFromMesh
5-405
5 Functions — Alphabetical List
model = createpde;
geometryFromMesh(model,nodes,elements,ElementIdToRegionId);
pdegplot(model,'FaceLabels','on')
5-406
geometryFromMesh
load MultidomainMesh3D
model = createpde;
geometryFromMesh(model,nodes,elements,ElementIdToRegionId);
pdegplot(model,'CellLabels','on')
5-407
5 Functions — Alphabetical List
Input Arguments
model — Model object
PDEModel object | ThermalModel object | StructuralModel object
5-408
geometryFromMesh
Mesh nodes, specified as a matrix of real numbers. The matrix size is 2-by-Nnodes for a 2-
D case and 3-by-Nnodes for a 3-D case. Nnodes is the number of nodes in the mesh.
• A mesh on the geometry surface has size 3-by-Nelements. Each column of elements
contains the indices of the triangle corner nodes for a surface element. In this case,
the resulting geometry does not contain a full mesh. Create the mesh using the
generateMesh function.
• Linear elements have size 4-by-Nelements. Each column of elements contains the
indices of the tetrahedral corner nodes for an element.
• Quadratic elements have size 10-by-Nelements. Each column of elements contains
the indices of the tetrahedral corner nodes and the tetrahedral edge midpoint nodes
for an element.
For details on node numbering for linear and quadratic elements, see “Mesh Data” on
page 2-171.
Data Types: double
Domain information for each mesh element, specified as a vector of positive integers.
Each element is an ID of a geometric region for an element of the mesh. The length of this
vector equals the number of elements in the mesh.
Data Types: double
5-409
5 Functions — Alphabetical List
Output Arguments
G — Geometry
handle to model.Geometry
See Also
DiscreteGeometry | alphaShape | generateMesh | importGeometry
Topics
“STL File Import” on page 2-41
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2015b
5-410
HeatSourceAssignment Properties
HeatSourceAssignment Properties
Heat source assignments
Description
A HeatSourceAssignment object contains a description of the heat sources for a
thermal model. A ThermalModel container has a vector of HeatSourceAssignment
objects in its HeatSources.HeatSourceAssignments property.
Create heat source assignments for your thermal model using the internalHeatSource
function.
Properties
Properties
Region type, returned as 'Face' for a 2-D region, or 'Cell' for a 3-D region.
Data Types: char | string
RegionID — Region ID
vector of positive integers
Heat source value, returned as a number or a function handle. A heat source with a
negative value is called a heat sink.
5-411
5 Functions — Alphabetical List
See Also
findHeatSource | internalHeatSource
Introduced in R2017a
5-412
hyperbolic
hyperbolic
(Not recommended) Solve hyperbolic PDE problem
Syntax
u = hyperbolic(u0,ut0,tlist,model,c,a,f,d)
u = hyperbolic(u0,ut0,tlist,b,p,e,t,c,a,f,d)
u = hyperbolic(u0,ut0,tlist,Kc,Fc,B,ud,M)
u = hyperbolic( ___ ,rtol)
u = hyperbolic( ___ ,rtol,atol)
u = hyperbolic(u0,ut0,tlist,Kc,Fc,B,ud,M, ___ ,'DampingMatrix',D)
u = hyperbolic( ___ ,'Stats','off')
Description
Hyperbolic equation solver
∂2 u
d − ∇ ⋅ c ∇u + au = f
∂t2
∂2 u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t2
The variables c, a, f, and d can depend on position, time, and the solution u and its
gradient.
5-413
5 Functions — Alphabetical List
∂2 u
d − ∇ ⋅ c ∇u + au = f
∂t2
∂2 u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t2
with geometry, mesh, and boundary conditions specified in model, with initial value u0
and initial derivative with respect to time ut0. The variables c, a, f, and d in the equation
correspond to the function coefficients c, a, f, and d respectively.
u = hyperbolic( ___ ,'Stats','off') turns off the display of internal ODE solver
statistics during the solution process.
Examples
Hyperbolic Equation
∂2 u
= Δu
∂t2
5-414
hyperbolic
model = createpde;
geometryFromEdges(model,@squareg);
pdegplot(model,'EdgeLabels','on')
ylim([-1.1,1.1])
axis equal
∇u ⋅ n = 0
for y = ± 1. (The Neumann boundary condition is the default condition, so the second
specification is redundant.)
5-415
5 Functions — Alphabetical List
applyBoundaryCondition(model,'dirichlet','Edge',[2,4],'u',0);
applyBoundaryCondition(model,'neumann','Edge',[1,3],'g',0);
u0 = 'atan(cos(pi/2*x))';
ut0 = '3*sin(pi*x).*exp(cos(pi*y))';
tlist = linspace(0,5,31);
c = 1;
a = 0;
f = 0;
d = 1;
generateMesh(model,'GeometricOrder','linear','Hmax',0.1);
u1 = hyperbolic(u0,ut0,tlist,model,c,a,f,d);
figure
pdeplot(model,'XYData',u1(:,1))
5-416
hyperbolic
figure
pdeplot(model,'XYData',u1(:,end))
5-417
5 Functions — Alphabetical List
For a version of this example with animation, see “Wave Equation on Square Domain”.
∂2 u
= Δu
∂t2
5-418
hyperbolic
on the square domain specified by squareg, using a geometry function to specify the
geometry, a boundary function to specify the boundary conditions, and using initmesh to
create the finite element mesh.
g = @squareg;
pdegplot(g,'EdgeLabels','on')
ylim([-1.1,1.1])
axis equal
∇u ⋅ n = 0
5-419
5 Functions — Alphabetical List
for y = ± 1. (The Neumann boundary condition is the default condition, so the second
specification is redundant.)
b = @squareb3;
u0 = 'atan(cos(pi/2*x))';
ut0 = '3*sin(pi*x).*exp(cos(pi*y))';
tlist = linspace(0,5,31);
c = 1;
a = 0;
f = 0;
d = 1;
[p,e,t] = initmesh(g);
u = hyperbolic(u0,ut0,tlist,b,p,e,t,c,a,f,d);
figure
pdeplot(p,e,t,'XYData',u(:,1))
5-420
hyperbolic
figure
pdeplot(p,e,t,'XYData',u(:,end))
5-421
5 Functions — Alphabetical List
For a version of this example with animation, see “Wave Equation on Square Domain”.
model = createpde();
importGeometry(model,'BracketWithHole.stl');
figure
5-422
hyperbolic
pdegplot(model,'FaceLabels','on')
view(30,30)
title('Bracket with Face Labels')
figure
pdegplot(model,'FaceLabels','on')
view(-134,-32)
title('Bracket with Face Labels, Rear View')
5-423
5 Functions — Alphabetical List
c = 1;
a = 0;
f = 0.5;
d = 1;
generateMesh(model);
Create initial conditions and boundary conditions. The boundary condition for the rear
face is Dirichlet with value 0. All other faces have the default boundary condition. The
5-424
hyperbolic
initial condition is u(0) = 0, du/dt(0) = x/2. Give the initial condition on the
derivative by calculating the x-position of each node in xpts, and passing x/2.
applyBoundaryCondition(model,'Face',4,'u',0);
u0 = 0;
xpts = model.Mesh.Nodes(1,:);
ut0 = xpts(:)/2;
[Kc,Fc,B,ud] = assempde(model,c,a,f);
[~,M,~] = assema(model,0,d,f);
tlist = linspace(0,5,50);
u = hyperbolic(u0,ut0,tlist,Kc,Fc,B,ud,M);
View the solution at a few times. Scale all the plots to have the same color range by using
the caxis command.
umax = max(max(u));
umin = min(min(u));
subplot(2,2,1)
pdeplot3D(model,'ColorMapData',u(:,5))
caxis([umin umax])
title('Time 1/2')
subplot(2,2,2)
pdeplot3D(model,'ColorMapData',u(:,10))
caxis([umin umax])
title('Time 1')
subplot(2,2,3)
pdeplot3D(model,'ColorMapData',u(:,15))
caxis([umin umax])
title('Time 3/2')
subplot(2,2,4)
pdeplot3D(model,'ColorMapData',u(:,20))
5-425
5 Functions — Alphabetical List
caxis([umin umax])
title('Time 2')
The solution seems to have a frequency of one, because the plots at times 1/2 and 3/2
show maximum values, and those at times 1 and 2 show minimum values.
Solve a hyperbolic problem that includes damping. You must use the finite element matrix
form to use damping.
5-426
hyperbolic
model = createpde();
importGeometry(model,'BracketWithHole.stl');
figure
pdegplot(model,'FaceLabels','on')
view(30,30)
title('Bracket with Face Labels')
figure
pdegplot(model,'FaceLabels','on')
view(-134,-32)
title('Bracket with Face Labels, Rear View')
5-427
5 Functions — Alphabetical List
c = 1;
a = 0;
f = 0.5;
d = 1;
generateMesh(model);
Create initial conditions and boundary conditions. The boundary condition for the rear
face is Dirichlet with value 0. All other faces have the default boundary condition. The
5-428
hyperbolic
initial condition is u(0) = 0, du/dt(0) = x/2. Give the initial condition on the
derivative by calculating the x-position of each node in xpts, and passing x/2.
applyBoundaryCondition(model,'Face',4,'u',0);
u0 = 0;
xpts = model.Mesh.Nodes(1,:);
ut0 = xpts(:)/2;
[Kc,Fc,B,ud] = assempde(model,c,a,f);
[~,M,~] = assema(model,0,d,f);
Damping = 0.1*M;
tlist = linspace(0,5,50);
u = hyperbolic(u0,ut0,tlist,Kc,Fc,B,ud,M,'DampingMatrix',Damping);
Plot the maximum value at each time. The oscillations damp slightly as time increases.
plot(max(u))
xlabel('Time')
ylabel('Maximum value')
title('Maximum of Solution')
5-429
5 Functions — Alphabetical List
Input Arguments
u0 — Initial condition
vector | character vector | character array | string scalar | string vector
Initial condition, specified as a scalar, vector of nodal values, character vector, character
array, string scalar, or string vector. The initial condition is the value of the solution u at
the initial time, specified as a column vector of values at the nodes. The nodes are either
p in the [p,e,t] data structure, or are model.Mesh.Nodes.
5-430
hyperbolic
char('x.^2 + 5*cos(x.*y)',...
'tanh(x.*y)./(1+z.^2)')
Example: x.^2+5*cos(y.*x)
Data Types: double | char | string
Complex Number Support: Yes
Initial derivative, specified as a vector, character vector, character array, string scalar, or
string vector. The initial gradient is the value of the derivative of the solution u at the
initial time, specified as a vector of values at the nodes. The nodes are either p in the
[p,e,t] data structure, or are model.Mesh.Nodes.
char('x.^2 + 5*cos(x.*y)',...
'tanh(x.*y)./(1+z.^2)')
Example: p(1,:).^2+5*cos(p(2,:).*p(1,:))
Data Types: double | char | string
Complex Number Support: Yes
5-431
5 Functions — Alphabetical List
Solution times, specified as a real vector. The solver returns the solution to the PDE at the
solution times.
Example: 0:0.2:4
Data Types: double
c — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. c represents the c coefficient in the scalar
PDE
∂2 u
d − ∇ ⋅ c ∇u + au = f
∂t2
∂2 u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t2
Example: 'cosh(x+y.^2)'
Data Types: double | char | string | function_handle
Complex Number Support: Yes
a — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. a represents the a coefficient in the scalar
PDE
5-432
hyperbolic
∂2 u
d − ∇ ⋅ c ∇u + au = f
∂t2
∂2 u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t2
Example: 2*eye(3)
Data Types: double | char | string | function_handle
Complex Number Support: Yes
f — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. f represents the f coefficient in the scalar
PDE
∂2 u
d − ∇ ⋅ c ∇u + au = f
∂t2
∂2 u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t2
Example: char('sin(x)';'cos(y)';'tan(z)')
Data Types: double | char | string | function_handle
Complex Number Support: Yes
d — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. d represents the d coefficient in the scalar
PDE
5-433
5 Functions — Alphabetical List
∂2 u
d − ∇ ⋅ c ∇u + au = f
∂t2
∂2 u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t2
Example: 2*eye(3)
Data Types: double | char | string | function_handle
Complex Number Support: Yes
b — Boundary conditions
boundary matrix | boundary file
Boundary conditions, specified as a boundary matrix or boundary file. Pass a boundary file
as a function handle or as a file name. A boundary matrix is generally an export from the
PDE Modeler app.
Example: b = 'circleb1', b = "circleb1", or b = @circleb1
Data Types: double | char | string | function_handle
p — Mesh points
matrix
Mesh points, specified as a 2-by-Np matrix of points, where Np is the number of points in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
e — Mesh edges
matrix
Mesh edges, specified as a 7-by-Ne matrix of edges, where Ne is the number of edges in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
5-434
hyperbolic
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
t — Mesh triangles
matrix
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
Kc — Stiffness matrix
sparse matrix | full matrix
Stiffness matrix, specified as a sparse matrix or as a full matrix. See “Elliptic Equations”
on page 5-79. Typically, Kc is the output of assempde.
Fc — Load vector
vector
Load vector, specified as a vector. See “Elliptic Equations” on page 5-79. Typically, Fc is
the output of assempde.
B — Dirichlet nullspace
sparse matrix
Dirichlet nullspace, returned as a sparse matrix. See “Algorithms” on page 5-79. Typically,
B is the output of assempde.
ud — Dirichlet vector
vector
Dirichlet vector, returned as a vector. See “Algorithms” on page 5-79. Typically, ud is the
output of assempde.
5-435
5 Functions — Alphabetical List
M — Mass matrix
sparse matrix | full matrix
Mass matrix. specified as a sparse matrix or a full matrix. See “Elliptic Equations” on
page 5-79.
To obtain the input matrices for pdeeig, hyperbolic or parabolic, run both assema
and assempde:
[Kc,Fc,B,ud] = assempde(model,c,a,f);
[~,M,~] = assema(model,0,d,f);
Note Create the M matrix using assema with d, not a, as the argument before f.
D — Damping matrix
matrix
Damping matrix, specified as a matrix. D has the same size as the stiffness matrix Kc or
the mass matrix M. When you include D, hyperbolic solves the following ODE for the
variable v:
5-436
hyperbolic
2
d v dv
BT MB + BT DB + Kv = F
dt 2 dt
with initial condition u0 and initial derivative ut0. Then hyperbolic returns the solution
u = B*v + ud.
Output Arguments
u — PDE solution
matrix
PDE solution, returned as a matrix. The matrix is Np*N-by-T, where Np is the number of
nodes in the mesh, N is the number of equations in the PDE (N = 1 for a scalar PDE), and
T is the number of solution times, meaning the length of tlist. The solution matrix has
the following structure.
• The first Np elements of each column in u represent the solution of equation 1, then
next Np elements represent the solution of equation 2, etc. The solution u is the value
at the corresponding node in the mesh.
• Column i of u represents the solution at time tlist(i).
To plot the solution, use pdeplot for 2-D geometry, or see “Plot 3-D Solutions and Their
Gradients” on page 3-325.
Algorithms
Hyperbolic Equations
Partial Differential Equation Toolbox solves equations of the form
5-437
5 Functions — Alphabetical List
∂2 u ∂u
m +d − ∇ · c ∇u + au = f
∂t 2 ∂t
When the d coefficient is 0, but m is not, the documentation calls this a hyperbolic
equation, whether or not it is mathematically of the hyperbolic form.
Using the same ideas as for the parabolic equation, hyperbolic implements the
numerical solution of
∂2 u
m − ∇ ⋅ c ∇u + au = f
∂t2
for x in Ω, where x represents a 2-D or 3-D point, with the initial conditions
u x, 0 = u0 x
∂u
x, 0 = v0 x
∂t
for all x in Ω, and usual boundary conditions. In particular, solutions of the equation utt -
cΔu = 0 are waves moving with speed c.
Using a given mesh of Ω, the method of lines yields the second order ODE system
2
d U
M + KU = F
dt2
Ui 0 = u0 xi ∀i
d
U 0 = v0 xi ∀i
dt i
after we eliminate the unknowns fixed by Dirichlet boundary conditions. As before, the
stiffness matrix K and the mass matrix M are assembled with the aid of the function
assempde from the problems
hyperbolic internally calls assema, assemb, and assempde to create finite element
matrices corresponding to the problem. It calls ode15s to solve the resulting system of
ordinary differential equations.
5-438
hyperbolic
p4
p1
p2 p3
r s
ϕ1 = 1 − r − s − t
ϕ2 = r
ϕ3 = s
ϕ4 = t
For a quadratic tetrahedron, there are additional nodes at the edge midpoints.
5-439
5 Functions — Alphabetical List
p4
p8
p9 p1 p10
p5 p7
p2 p3
p6
r s
2
ϕ1 = 2 1 − r − s − t − 1−r−s−t
ϕ2 = 2r 2 − r
ϕ3 = 2s2 − s
ϕ4 = 2t2 − t
ϕ5 = 4r 1 − r − s − t
ϕ6 = 4rs
ϕ7 = 4s 1 − r − s − t
ϕ8 = 4t 1 − r − s − t
ϕ9 = 4rt
ϕ10 = 4st
As in the 2-D case, a 3-D basis function ϕi takes the value 0 at all nodes j, except for node
i, where it takes the value 1.
Systems of PDEs
Partial Differential Equation Toolbox software can also handle systems of N partial
differential equations over the domain Ω. We have the elliptic system
5-440
hyperbolic
− ∇ ⋅ c ⊗ ∇u + au = f
∂u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t
∂2 u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t2
− ∇ ⋅ c ⊗ ∇u + au = λdu
For 2-D systems, the notation ∇ ⋅ (c ⊗ ∇u) represents an N-by-1 matrix with an (i,1)-
component
N
∂ ∂ ∂ ∂ ∂ ∂ ∂ ∂
∑ c
∂x i, j, 1, 1 ∂x
+ c
∂x i, j, 1, 2 ∂y
+ c
∂y i, j, 2, 1 ∂x
+ c u
∂y i, j, 2, 2 ∂y j
j=1
For 3-D systems, the notation ∇ ⋅ (c ⊗ ∇u) represents an N-by-1 matrix with an (i,1)-
component
N
∂ ∂ ∂ ∂ ∂ ∂
∑ c
∂x i, j, 1, 1 ∂x
+ c
∂x i, j, 1, 2 ∂y
+ c u
∂x i, j, 1, 3 ∂z j
j=1
N
∂ ∂ ∂ ∂ ∂ ∂
+ ∑ c
∂y i, j, 2, 1 ∂x
+ c
∂y i, j, 2, 2 ∂y
+ c u
∂y i, j, 2, 3 ∂z j
j=1
N
∂ ∂ ∂ ∂ ∂ ∂
+ ∑ c
∂z i, j, 3, 1 ∂x
+ c
∂z i, j, 3, 2 ∂y
+ c u
∂z i, j, 3, 3 ∂z j
j=1
The symbols a and d denote N-by-N matrices, and f denotes a column vector of length N.
The elements cijkl, aij, dij, and fi of c, a, d, and f are stored row-wise in the MATLAB
matrices c, a, d, and f. The case of identity, diagonal, and symmetric matrices are
handled as special cases. For the tensor cijkl this applies both to the indices i and j, and to
the indices k and l.
5-441
5 Functions — Alphabetical List
Partial Differential Equation Toolbox software does not check the ellipticity of the
problem, and it is quite possible to define a system that is not elliptic in the mathematical
sense. The preceding procedure that describes the scalar case is applied to each
component of the system, yielding a symmetric positive definite system of equations
whenever the differential system possesses these characteristics.
The boundary conditions now in general are mixed, i.e., for each point on the boundary a
combination of Dirichlet and generalized Neumann conditions,
hu = r
n · c ⊗ ∇u + qu = g + h′μ
For 2-D systems, the notation n · c ⊗ ∇u represents an N-by-1 matrix with (i,1)-
component
N
∂ ∂ ∂ ∂
∑ cos(α)ci, j, 1, 1
∂x
+ cos(α)ci, j, 1, 2
∂y
+ sin(α)ci, j, 2, 1
∂x
+ sin(α)ci, j, 2, 2 u
∂y j
j=1
For 3-D systems, the notation n · c ⊗ ∇u represents an N-by-1 matrix with (i,1)-
component
N
∂ ∂ ∂
∑ cos(α)ci, j, 1, 1
∂x
+ cos(α)ci, j, 1, 2
∂y
+ cos(α)ci, j, 1, 3 u
∂z j
j=1
N
∂ ∂ ∂
+ ∑ cos(β)ci, j, 2, 1
∂x
+ cos(β)ci, j, 2, 2
∂y
+ cos(β)ci, j, 2, 3 u
∂z j
j=1
N
∂ ∂ ∂
+ ∑ cos(γ)ci, j, 3, 1
∂x
+ cos(γ)ci, j, 3, 2
∂y
+ cos(γ)ci, j, 3, 3 u
∂z j
j=1
There are M Dirichlet conditions and the h-matrix is M-by-N, M ≥ 0. The generalized
Neumann condition contains a source h′μ, where the Lagrange multipliers μ are
computed such that the Dirichlet conditions become satisfied. In a structural mechanics
problem, this term is exactly the reaction force necessary to satisfy the kinematic
constraints described by the Dirichlet conditions.
5-442
hyperbolic
The rest of this section details the treatment of the Dirichlet conditions and may be
skipped on a first reading.
hu = r
L(h′hu − h′r)
When this number is increased, hu = r will be more accurately satisfied, but the potential
ill-conditioning of the modified equations will become more serious.
The second method is also applicable to general mixed conditions with nondiagonal h,
and is free of the ill-conditioning, but is more involved computationally. Assume that there
are Np nodes in the mesh. Then the number of unknowns is NpN = Nu. When Dirichlet
boundary conditions fix some of the unknowns, the linear system can be correspondingly
reduced. This is easily done by removing rows and columns when u values are given, but
here we must treat the case when some linear combinations of the components of u are
given, hu = r. These are collected into HU = R where H is an M-by-Nu matrix and R is an
M-vector.
KU +H´ µ = F
HU = R.
The constraints can be solved for M of the U-variables, the remaining called V, an Nu – M
vector. The null space of H is spanned by the columns of B, and U = BV + ud makes U
satisfy the Dirichlet conditions. A permutation to block-diagonal form exploits the sparsity
of H to speed up the following computation to find B in a numerically stable way. µ can be
eliminated by pre-multiplying by B´ since, by the construction, HB = 0 or B´H´ = 0. The
reduced system becomes
B´ KBV = B´ F – B´Kud
5-443
5 Functions — Alphabetical List
See Also
solvepde
5-444
importGeometry
importGeometry
Package: pde
Syntax
importGeometry(model,geometryfile)
gd = importGeometry(model,geometryfile)
Description
importGeometry(model,geometryfile) creates a geometry container from the
specified STL geometry file, and includes the geometry in the model container.
Examples
5-445
5 Functions — Alphabetical List
Import a planar STL geometry into a PDE model. When importing a planar geometry,
importGeometry converts it to a 2-D geometry by mapping it to the X-Y plane.
5-446
importGeometry
ans =
DiscreteGeometry with properties:
NumCells: 0
NumFaces: 1
NumEdges: 5
NumVertices: 5
pdegplot(model,'EdgeLabels','on')
5-447
5 Functions — Alphabetical List
Input Arguments
model — Model object
PDEModel object | ThermalModel object | StructuralModel object
Path to STL file, specified as a character vector or a string scalar ending with the file
extension .stl or .STL.
Example: '../geometries/Carburetor.stl'
Data Types: char | string
Output Arguments
gd — Geometry description
DiscreteGeometry object
Limitations
• importGeometry does not allow you to import a multidomain 2-D or 3-D geometry
where subdomains have any common points. If the subdomains of the geometry have
common points, the toolbox still treats these subdomains as disconnected, without any
common interface between them. Each subdomain has its own mesh.
5-448
importGeometry
Because of this limitation, you cannot import nested 3-D geometries directly. As a
workaround, you can import a mesh and then create a multidomain geometry from the
mesh by using the geometryFromMesh function.
Tips
• STL format approximates the boundary of a CAD geometry by a collection of triangles,
and importGeometry reconstructs the faces and edges from this data.
Reconstruction from STL data is not precise and can result in a loss of edges and,
therefore, the merging of adjacent faces. Typically, lost edges are the edges between
two adjacent faces meeting at a small angle, or smooth edges bounding blend
surfaces. Usually, the loss of such edges does not affect the analysis workflow.
• Because STL geometries approximate the original CAD geometries, areas and volumes
of STL and CAD geometries can differ.
See Also
DiscreteGeometry | PDEModel | geometryFromMesh | pdegplot
Topics
“STL File Import” on page 2-41
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2015a
5-449
5 Functions — Alphabetical List
initmesh
Create initial 2-D mesh
Note This page describes the legacy workflow. New features might not be compatible
with the legacy workflow. For the corresponding step in the recommended workflow, see
generateMesh.
Syntax
[p,e,t] = initmesh(g)
[p,e,t] = initmesh(g,'PropertyName',PropertyValue,...)
Description
[p,e,t] = initmesh(g) returns a triangular mesh using the 2-D geometry
specification g. initmesh uses a Delaunay triangulation algorithm. The mesh size is
determined from the shape of the geometry and from name-value pair settings.
g describes the geometry of the PDE problem. g can be a Decomposed Geometry matrix,
the name of a Geometry file, or a function handle to a Geometry file.
In the Point matrix p, the first and second rows contain x- and y-coordinates of the points
in the mesh.
In the Edge matrix e, the first and second rows contain indices of the starting and ending
point, the third and fourth rows contain the starting and ending parameter values, the
fifth row contains the edge segment number, and the sixth and seventh row contain the
left- and right-hand side subdomain numbers.
In the Triangle matrix t, the first three rows contain indices to the corner points, given in
counter clockwise order, and the fourth row contains the subdomain number.
5-450
initmesh
The Hmax property controls the size of the triangles on the mesh. initmesh creates a
mesh where triangle edge lengths are approximately Hmax or less.
The Hgrad property determines the mesh growth rate away from a small part of the
geometry. The default value is 1.3, i.e., a growth rate of 30%. Hgrad cannot be equal to
either of its bounds, 1 and 2.
Both the Box and Init property are related to the way the mesh algorithm works. By
turning on Box you can get a good idea of how the mesh generation algorithm works
within the bounding box. By turning on Init you can see the initial triangulation of the
boundaries. By using the command sequence
[p,e,t] = initmesh(dl,'hmax',inf,'init','on');
[uxy,tn,a2,a3] = tri2grid(p,t,zeros(size(p,2)),x,y);
n = t(4,tn);
you can determine the subdomain number n of the point xy. If the point is outside the
geometry, tn is NaN and the command n = t(4,tn) results in a failure.
The Jiggle property is used to control whether jiggling of the mesh should be attempted
(see jigglemesh for details). Jiggling can be done until the minimum or the mean of the
5-451
5 Functions — Alphabetical List
quality of the triangles decreases. JiggleIter can be used to set an upper limit on the
number of iterations.
The MesherVersion property chooses the algorithm for mesh generation. The 'R2013a'
algorithm runs faster, and can triangulate more geometries than the 'preR2013a'
algorithm. Both algorithms use Delaunay triangulation.
Examples
Make a simple triangular mesh of the L-shaped membrane in the PDE Modeler app.
Before you do anything in the PDE Modeler app, set the Maximum edge size to inf in
the Mesh Parameters dialog box. You open the dialog box by selecting the Parameters
option from the Mesh menu. Also select the items Show Node Labels and Show
Triangle Labels in the Mesh menu. Then create the initial mesh by pressing the Δ
button. (This can also be done by selecting the Initialize Mesh option from the Mesh
menu.)
5-452
initmesh
The corresponding mesh data structures can be exported to the main workspace by
selecting the Export Mesh option from the Mesh menu.
p
p =
-1 1 1 0 0 -1
-1 -1 1 1 0 0
e
e =
1 2 3 4 5 6
2 3 4 5 6 1
0 0 0 0 0 0
1 1 1 1 1 1
5-453
5 Functions — Alphabetical List
1 2 3 4 5 6
1 1 1 1 1 1
0 0 0 0 0 0
t
t =
1 2 3 1
2 3 4 5
5 5 5 6
1 1 1 1
References
George, P. L., Automatic Mesh Generation — Application to Finite Element Methods,
Wiley, 1991.
See Also
decsg | jigglemesh | refinemesh
Topics
“Mesh Data” on page 2-171
5-454
internalHeatSource
internalHeatSource
Package: pde
Syntax
internalHeatSource(thermalmodel,heatSourceValue)
internalHeatSource(thermalmodel,heatSourceValue,RegionType,RegionID)
heatSource = internalHeatSource( ___ )
Description
internalHeatSource(thermalmodel,heatSourceValue) specifies an internal heat
source for the thermal model. This syntax declares that the entire geometry is a heat
source.
Note Use internalHeatSource for specifying internal heat generators, that is, for
specifying heat sources that belong to the geometry of the model. To specify a heat influx
from an external source, use the thermalBC function with the HeatFlux parameter.
internalHeatSource(thermalmodel,heatSourceValue,RegionType,RegionID)
specifies geometry regions of type RegionType with ID numbers in RegionID as heat
sources. Always specify heatSourceValue first, then specify RegionType and
RegionID.
Examples
5-455
5 Functions — Alphabetical List
Set thermal conductivity to 0.2, mass density to 2700e-9, and specific heat to 920.
thermalProperties(thermalmodel,'ThermalConductivity',0.2, ...
'MassDensity',2700e-9, ...
'SpecificHeat',920)
ans =
ThermalMaterialAssignment with properties:
RegionType: 'cell'
RegionID: 1
ThermalConductivity: 0.2000
MassDensity: 2.7000e-06
SpecificHeat: 920
Specify that the entire geometry generates heat at the rate 2e-4.
internalHeatSource(thermalmodel,2e-4)
ans =
HeatSourceAssignment with properties:
RegionType: 'cell'
RegionID: 1
HeatSource: 2.0000e-04
5-456
internalHeatSource
geometryFromEdges(thermalModel,dl);
Set thermal conductivity to 50, mass density to 2500, and specific heat to 600.
thermalProperties(thermalModel,'ThermalConductivity',50, ...
'MassDensity',2500, ...
'SpecificHeat',600);
internalHeatSource(thermalModel,25,'Face',1)
ans =
HeatSourceAssignment with properties:
RegionType: 'face'
RegionID: 1
HeatSource: 25
Use a function handle to specify an internal heat source that depends on coordinates.
Create a thermal model for transient analysis and include the geometry. The geometry is
a rod with a circular cross section. The 2-D model is a rectangular strip whose y-
dimension extends from the axis of symmetry to the outer surface, and whose x-dimension
extends over the actual length of the rod.
thermalmodel = createpde('thermal','transient');
g = decsg([3 4 -1.5 1.5 1.5 -1.5 0 0 .2 .2]');
geometryFromEdges(thermalmodel,g);
5-457
5 Functions — Alphabetical List
The heat is generated within the rod due to the radioactive decay. Therefore, the entire
geometry is an internal nonlinear heat source and can be represented by a function of the
y-coordinate, for example, q = 2000y.
q = @(location,state)2000*location.y;
ans =
HeatSourceAssignment with properties:
RegionType: 'face'
RegionID: 1
HeatSource: @(location,state)2000*location.y
Input Arguments
thermalmodel — Thermal model
ThermalModel object
Thermal model, specified as a ThermalModel object. The model contains the geometry,
mesh, thermal properties of the material, internal heat source, boundary conditions, and
initial conditions.
Example: thermalmodel = createpde('thermal','steadystate')
Geometric region type, specified as 'Face' for a 2-D model or 'Cell' for a 3-D model.
Example: internalHeatSource(thermalmodel,25,'Cell',1)
Data Types: char | string
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
5-458
internalHeatSource
Example: internalHeatSource(thermalmodel,25,'Cell',1:3)
Data Types: double
Heat source value, specified as a number or a function handle. Use a function handle to
specify the internal heat source that depends on space, time, or temperature. The
function must be of the form
heatSourceValue = heatSourceFun(location,state)
The solver passes location data as a structure array with the fields location.x,
location.y, and, for 3-D problems, location.z. The state data is a structure array
with the fields state.u, state.ux, state.uy, state.uz (for 3-D problems), and
state.time (for transient problems). The state.u field contains the solution vector.
The state.ux, state.uy, state.uz fields are estimates of the solution’s partial
derivatives at the corresponding points of the location structure. The state.time field
contains time at evaluation points.
Output Arguments
heatSource — Handle to heat source
object
See Also
thermalBC | thermalProperties
Introduced in R2017a
5-459
5 Functions — Alphabetical List
interpolateAcceleration
Package: pde
Interpolate acceleration at arbitrary spatial locations for all time or frequency steps for
dynamic structural model
Syntax
intrpAccel = interpolateAcceleration(structuralresults,xq,yq)
intrpAccel = interpolateAcceleration(structuralresults,xq,yq,zq)
intrpAccel = interpolateAcceleration(structuralresults,querypoints)
Description
intrpAccel = interpolateAcceleration(structuralresults,xq,yq) returns
the interpolated acceleration values at the 2-D points specified in xq and yq for all time
or frequency steps.
intrpAccel = interpolateAcceleration(structuralresults,querypoints)
uses the points specified in querypoints.
Examples
structuralmodel = createpde('structural','transient-solid');
5-460
interpolateAcceleration
Create the geometry and include it in the model. Plot the geometry.
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
5-461
5 Functions — Alphabetical List
structuralBC(structuralmodel,'Face',5,'Constraint','fixed');
Apply a sinusoidal displacement along the y-direction on the end opposite the fixed end of
the beam.
structuralBC(structuralmodel,'Face',3,'YDisplacement',1E-4,'Frequency',50);
Generate a mesh.
generateMesh(structuralmodel,'Hmax',0.01);
structuralIC(structuralmodel,'Displacement',[0;0;0],'Velocity',[0;0;0]);
tlist = 0:0.002:0.2;
structuralresults = solve(structuralmodel,tlist);
coordsMidSpan = [0;0;0.005];
intrpAccel = interpolateAcceleration(structuralresults,coordsMidSpan);
figure
plot(structuralresults.SolutionTimes,intrpAccel.ay)
title('Y-Acceleration of the Geometric Center of the Beam')
5-462
interpolateAcceleration
Input Arguments
structuralresults — Solution of dynamic structural analysis problem
TransientStructuralResults object | FrequencyStructuralResults object
5-463
5 Functions — Alphabetical List
Query points, specified as a real matrix with either two rows for 2-D geometry or three
rows for 3-D geometry. interpolateAcceleration evaluates accelerations at the
5-464
interpolateAcceleration
Output Arguments
intrpAccel — Accelerations at query points
structure array
Accelerations at the query points, returned as a structure array with fields representing
spatial components of acceleration at the query points. For query points that are outside
the geometry, intrpAccel returns NaN.
See Also
StructuralModel | TransientStructuralResults | evaluatePrincipalStrain |
evaluatePrincipalStress | evaluateReaction | evaluateStrain |
evaluateStress | evaluateVonMisesStress | interpolateDisplacement |
interpolateStrain | interpolateStress | interpolateVelocity |
interpolateVonMisesStress
Introduced in R2018a
5-465
5 Functions — Alphabetical List
interpolateDisplacement
Package: pde
Syntax
intrpDisp = interpolateDisplacement(structuralresults,xq,yq)
intrpDisp = interpolateDisplacement(structuralresults,xq,yq,zq)
intrpDisp = interpolateDisplacement(structuralresults,querypoints)
Description
intrpDisp = interpolateDisplacement(structuralresults,xq,yq) returns
the interpolated displacement values at the 2-D points specified in xq and yq. For
transient and frequency response structural models, interpolateDisplacement
returns the interpolated displacement values for all time- or frequency-steps, respectively.
intrpDisp = interpolateDisplacement(structuralresults,querypoints)
uses points specified in querypoints.
Examples
structuralmodel = createpde('structural','static-planestrain');
5-466
interpolateDisplacement
geometryFromEdges(structuralmodel,@squareg);
pdegplot(structuralmodel,'EdgeLabels','on')
axis equal
structuralProperties(structuralmodel,'PoissonsRatio',0.3, ...
'YoungsModulus',210E3);
structuralBC(structuralmodel,'XDisplacement',0.001,'Edge',1);
5-467
5 Functions — Alphabetical List
structuralBC(structuralmodel,'Constraint','fixed','Edge',3);
generateMesh(structuralmodel);
structuralresults = solve(structuralmodel);
Create a grid and interpolate the x- and y-components of the displacement to the grid.
v = linspace(-1,1,21);
[X,Y] = meshgrid(v);
intrpDisp = interpolateDisplacement(structuralresults,X,Y);
Reshape the displacement components to the shape of the grid. Plot the displacement.
ux = reshape(intrpDisp.ux,size(X));
uy = reshape(intrpDisp.uy,size(Y));
quiver(X,Y,ux,uy)
5-468
interpolateDisplacement
Solve a static structural model representing a bimetallic cable under tension, and
interpolate the displacement on a cross-section of the cable.
structuralmodel = createpde('structural','static-solid');
Create the geometry and include it in the model. Plot the geometry.
5-469
5 Functions — Alphabetical List
gm = multicylinder([0.01,0.015],0.05);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','CellLabels','on','FaceAlpha',0.5)
Specify the Young's modulus and Poisson's ratio for each metal.
structuralProperties(structuralmodel,'Cell',1,'YoungsModulus',110E9, ...
'PoissonsRatio',0.28);
structuralProperties(structuralmodel,'Cell',2,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3);
structuralBC(structuralmodel,'Face',[1,4],'Constraint','fixed');
5-470
interpolateDisplacement
structuralBoundaryLoad(structuralmodel,'Face',[2,5],'SurfaceTraction',[0;0;100]);
generateMesh(structuralmodel);
structuralresults = solve(structuralmodel)
structuralresults =
StaticStructuralResults with properties:
[X,Y] = meshgrid(linspace(-0.015,0.015,50));
Z = ones(size(X))*0.025;
intrpDisp = interpolateDisplacement(structuralresults,X,Y,Z);
surf(X,Y,reshape(intrpDisp.uz,size(X)))
5-471
5 Functions — Alphabetical List
Alternatively, you can specify the grid by using a matrix of query points.
querypoints = [X(:),Y(:),Z(:)]';
intrpDisp = interpolateDisplacement(structuralresults,querypoints);
surf(X,Y,reshape(intrpDisp.uz,size(X)))
5-472
interpolateDisplacement
structuralmodel = createpde('structural','transient-solid');
Create the geometry and include it in the model. Plot the geometry.
5-473
5 Functions — Alphabetical List
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
structuralBC(structuralmodel,'Face',5,'Constraint','fixed');
5-474
interpolateDisplacement
Apply a sinusoidal displacement along the y-direction on the end opposite the fixed end of
the beam.
structuralBC(structuralmodel,'Face',3,'YDisplacement',1E-4,'Frequency',50);
Generate a mesh.
generateMesh(structuralmodel,'Hmax',0.01);
structuralIC(structuralmodel,'Displacement',[0;0;0],'Velocity',[0;0;0]);
tlist = 0:0.002:0.2;
structuralresults = solve(structuralmodel,tlist);
coordsMidSpan = [0;0;0.005];
intrpDisp = interpolateDisplacement(structuralresults,coordsMidSpan);
figure
plot(structuralresults.SolutionTimes,intrpDisp.uy)
title('y-Displacement of the Geometric Center of the Beam')
5-475
5 Functions — Alphabetical List
Input Arguments
structuralresults — Solution of structural analysis problem
StaticStructuralResults object | TransientStructuralResults object |
FrequencyStructuralResults object
5-476
interpolateDisplacement
5-477
5 Functions — Alphabetical List
Query points, specified as a real matrix with either two rows for 2-D geometry or three
rows for 3-D geometry. interpolateDisplacement evaluates the displacements at the
coordinate points querypoints(:,i), so each column of querypoints contains exactly
one 2-D or 3-D query point.
Example: For 2-D geometry, querypoints = [0.5,0.5,0.75,0.75; 1,2,0,0.5]
Data Types: double
Output Arguments
intrpDisp — Displacements at query points
structure array
Displacements at the query points, returned as a structure array with fields representing
spatial components of displacement at the query points. For query points that are outside
the geometry, intrpDisp returns NaN.
See Also
StaticStructuralResults | StructuralModel | TransientStructuralResults |
evaluatePrincipalStrain | evaluatePrincipalStress | evaluateReaction |
evaluateStrain | evaluateStress | evaluateVonMisesStress |
interpolateAcceleration | interpolateStrain | interpolateStress |
interpolateVelocity | interpolateVonMisesStress
Introduced in R2017b
5-478
interpolateSolution
interpolateSolution
Package: pde
Syntax
uintrp = interpolateSolution(results,xq,yq)
uintrp = interpolateSolution(results,xq,yq,zq)
uintrp = interpolateSolution(results,querypoints)
Description
uintrp = interpolateSolution(results,xq,yq) returns the interpolated values
of the solution to the scalar stationary equation specified in results at the 2-D points
specified in xq and yq.
uintrp = interpolateSolution( ___ ,iU), for any previous syntax, returns the
interpolated values of the solution to the system of stationary equations for equation
indices iU.
5-479
5 Functions — Alphabetical List
Examples
Interpolate the solution to a scalar problem along a line and plot the result.
Create the solution to the problem −Δu = 1 on the L-shaped membrane with zero
Dirichlet boundary conditions.
model = createpde;
geometryFromEdges(model,@lshapeg);
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
specifyCoefficients(model,'m',0,...
'd',0,...
'c',1,...
'a',0,...
'f',1);
generateMesh(model,'Hmax',0.05);
results = solvepde(model);
Interpolate the solution along the straight line from (x,y) = (-1,-1) to (1,1). Plot
the interpolated solution.
xq = linspace(-1,1,101);
yq = xq;
uintrp = interpolateSolution(results,xq,yq);
plot(xq,uintrp)
xlabel('x')
ylabel('u(x)')
5-480
interpolateSolution
Calculate the mean exit time of a Brownian particle from a region that contains absorbing
(escape) boundaries and reflecting boundaries. Use the Poisson's equation with constant
coefficients and 3-D rectangular block geometry to model this problem.
model = createpde;
importGeometry(model,'Block.stl');
applyBoundaryCondition(model,'dirichlet','Face',[1,2,5],'u',0);
5-481
5 Functions — Alphabetical List
specifyCoefficients(model,'m',0,...
'd',0,...
'c',1,...
'a',0,...
'f',2);
generateMesh(model);
results = solvepde(model);
[X,Y,Z] = meshgrid(0:135,0:35,0:61);
uintrp = interpolateSolution(results,X,Y,Z);
uintrp = reshape(uintrp,size(X));
Create a contour slice plot for five fixed values of the y coordinate.
contourslice(X,Y,Z,uintrp,[],0:4:16,[])
colormap jet
xlabel('x')
ylabel('y')
zlabel('z')
xlim([0,100])
ylim([0,20])
zlim([0,50])
axis equal
view(-50,22)
colorbar
5-482
interpolateSolution
Solve a scalar stationary problem and interpolate the solution to a dense grid.
Create the solution to the problem −Δu = 1 on the L-shaped membrane with zero
Dirichlet boundary conditions.
model = createpde;
geometryFromEdges(model,@lshapeg);
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',1);
5-483
5 Functions — Alphabetical List
generateMesh(model,'Hmax',0.05);
results = solvepde(model);
v = linspace(-1,1,101);
[X,Y] = meshgrid(v);
querypoints = [X(:),Y(:)]';
uintrp = interpolateSolution(results,querypoints);
uintrp = reshape(uintrp,size(X));
mesh(X,Y,uintrp)
xlabel('x')
ylabel('y')
5-484
interpolateSolution
Create the solution to a two-component system and plot the two components along a
planar slice through the geometry.
Create a PDE model for two components. Import the geometry of a torus.
model = createpde(2);
importGeometry(model,'Torus.stl');
pdegplot(model,'FaceLabels','on');
5-485
5 Functions — Alphabetical List
gfun = @(region,state)[0,region.z-40];
applyBoundaryCondition(model,'neumann','Face',1,'g',gfun);
ufun = @(region,state)[region.x-40,0];
applyBoundaryCondition(model,'dirichlet','Face',1,'u',ufun);
specifyCoefficients(model,'m',0,...
'd',0,...
'c',[1;0;1;0;0;1;0;0;1;0;1;0;1;0;0;1;0;1;0;0;1],...
'a',0,...
'f',[1;1]);
5-486
interpolateSolution
generateMesh(model);
results = solvepde(model);
Interpolate the results on a plane that slices the torus for each of the two components.
[X,Z] = meshgrid(0:100);
Y = 15*ones(size(X));
uintrp = interpolateSolution(results,X,Y,Z,[1,2]);
sol1 = reshape(uintrp(:,1),size(X));
sol2 = reshape(uintrp(:,2),size(X));
figure
surf(X,Z,sol1)
title('Component 1')
5-487
5 Functions — Alphabetical List
figure
surf(X,Z,sol2)
title('Component 2')
5-488
interpolateSolution
model = createpde(1);
geometryFromEdges(model,@lshapeg);
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
specifyCoefficients(model,'m',0,...
'd',1,...
5-489
5 Functions — Alphabetical List
'c',1,...
'a',0,...
'f',0);
r = [0,100];
generateMesh(model,'Hmax',1/50);
results = solvepdeeig(model,r);
5-490
interpolateSolution
Interpolate the eigenvector corresponding to the fifth eigenvalue to a coarse grid and plot
the result.
[xq,yq] = meshgrid(-1:0.1:1);
uintrp = interpolateSolution(results,xq,yq,5);
uintrp = reshape(uintrp,size(xq));
surf(xq,yq,uintrp)
5-491
5 Functions — Alphabetical List
Import slab geometry for a 3-D problem with three solution components. Plot the
geometry.
model = createpde(3);
importGeometry(model,'Plate10x10x1.stl');
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
5-492
interpolateSolution
Set boundary conditions such that face 2 is fixed (zero deflection in any direction) and
face 5 has a load of 1e3 in the positive z-direction. This load causes the slab to bend
upward. Set the initial condition that the solution is zero, and its derivative with respect
to time is also zero.
applyBoundaryCondition(model,'dirichlet','Face',2,'u',[0,0,0]);
applyBoundaryCondition(model,'neumann','Face',5,'g',[0,0,1e3]);
setInitialConditions(model,0,0);
Create PDE coefficients for the equations of linear elasticity. Set the material properties
to be similar to those of steel. See “Linear Elasticity Equations” on page 3-150.
E = 200e9;
nu = 0.3;
5-493
5 Functions — Alphabetical List
specifyCoefficients(model,'m',1,...
'd',0,...
'c',elasticityC3D(E,nu),...
'a',0,...
'f',[0;0;0]);
generateMesh(model,'Hmax',1);
tlist = 0:1e-4:5e-3;
results = solvepde(model,tlist);
Interpolate the solution at fixed x- and z-coordinates in the centers of their ranges, 5 and
0.5 respectively. Interpolate for y from 0 through 10 in steps of 0.2. Obtain just
component 3, the z-component of the solution.
yy = 0:0.2:10;
zz = 0.5*ones(size(yy));
xx = 10*zz;
component = 3;
uintrp = interpolateSolution(results,xx,yy,zz,component,1:length(tlist));
The solution is a 51-by-1-by-51 array. Use squeeze to remove the singleton dimension.
Removing the singleton dimension transforms this array to a 51-by-51 matrix which
simplifies indexing into it.
uintrp = squeeze(uintrp);
[X,Y] = ndgrid(yy,tlist);
figure
surf(X,Y,uintrp)
xlabel('Y')
ylabel('Time')
title('Deflection at x = 5, z = 0.5')
zlim([0,14e-5])
5-494
interpolateSolution
Input Arguments
results — PDE solution
StationaryResults object (default) | TimeDependentResults object |
EigenResults object
5-495
5 Functions — Alphabetical List
interpolateSolution converts query points to column vectors xq(:), yq(:), and (if
present) zq(:). The returned solution is a column vector of the same size. To ensure that
the dimensions of the returned solution is consistent with the dimensions of the original
query points, use reshape. For example, use uintrp =
reshape(gradxuintrp,size(xq)).
Data Types: double
Query points, specified as a real matrix with either two rows for 2-D geometry, or three
rows for 3-D geometry. interpolateSolution evaluates the solution at the coordinate
points querypoints(:,i), so each column of querypoints contains exactly one 2-D or
3-D query point.
5-496
interpolateSolution
iU — Equation indices
vector of positive integers
Time or mode indices, specified as a vector of positive integers. Each entry in iT specifies
a time index for time-dependent solutions, or a mode index for eigenvalue solutions.
Example: iT = 1:5:21 specifies the time or mode for every fifth solution up to 21.
Data Types: double
Output Arguments
uintrp — Solution at query points
array
Solution at query points, returned as an array. For query points that are outside the
geometry, uintrp = NaN. For details about dimensions of the solution, see “Dimensions
of Solutions, Gradients, and Fluxes” on page 3-347.
See Also
PDEModel | StationaryResults | TimeDependentResults | evaluateGradient
Topics
“Plot 2-D Solutions and Their Gradients” on page 3-314
“Plot 3-D Solutions and Their Gradients” on page 3-325
“Dimensions of Solutions, Gradients, and Fluxes” on page 3-347
5-497
5 Functions — Alphabetical List
Introduced in R2015b
5-498
interpolateStrain
interpolateStrain
Package: pde
Syntax
intrpStrain = interpolateStrain(structuralresults,xq,yq)
intrpStrain = interpolateStrain(structuralresults,xq,yq,zq)
intrpStrain = interpolateStrain(structuralresults,querypoints)
Description
intrpStrain = interpolateStrain(structuralresults,xq,yq) returns the
interpolated strain values at the 2-D points specified in xq and yq. For transient and
frequency-response structural models, interpolateStrain interpolates strain for all
time- or frequency-steps, respectively.
Examples
structuralmodel = createpde('structural','static-planestrain');
5-499
5 Functions — Alphabetical List
geometryFromEdges(structuralmodel,@squareg);
pdegplot(structuralmodel,'EdgeLabels','on')
axis equal
structuralProperties(structuralmodel,'PoissonsRatio',0.3, ...
'YoungsModulus',210E3);
structuralBC(structuralmodel,'XDisplacement',0.001,'Edge',1);
5-500
interpolateStrain
structuralBC(structuralmodel,'Constraint','fixed','Edge',3);
generateMesh(structuralmodel);
structuralresults = solve(structuralmodel);
Create a grid and interpolate the x- and y-components of the normal strain to the grid.
v = linspace(-1,1,101);
[X,Y] = meshgrid(v);
intrpStrain = interpolateStrain(structuralresults,X,Y);
Reshape the x-component of the normal strain to the shape of the grid and plot it.
exx = reshape(intrpStrain.exx,size(X));
px = pcolor(X,Y,exx);
px.EdgeColor='none';
colorbar
5-501
5 Functions — Alphabetical List
Reshape the y-component of the normal strain to the shape of the grid and plot it.
eyy = reshape(intrpStrain.eyy,size(Y));
figure
py = pcolor(X,Y,eyy);
py.EdgeColor='none';
colorbar
5-502
interpolateStrain
Solve a static structural model representing a bimetallic cable under tension, and
interpolate strain on a cross-section of the cable.
structuralmodel = createpde('structural','static-solid');
Create the geometry and include it in the model. Plot the geometry.
5-503
5 Functions — Alphabetical List
gm = multicylinder([0.01,0.015],0.05);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','CellLabels','on','FaceAlpha',0.5)
Specify the Young's modulus and Poisson's ratio for each metal.
structuralProperties(structuralmodel,'Cell',1,'YoungsModulus',110E9, ...
'PoissonsRatio',0.28);
structuralProperties(structuralmodel,'Cell',2,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3);
structuralBC(structuralmodel,'Face',[1,4],'Constraint','fixed');
5-504
interpolateStrain
structuralBoundaryLoad(structuralmodel,'Face',[2,5],'SurfaceTraction',[0;0;100]);
generateMesh(structuralmodel);
structuralresults = solve(structuralmodel)
structuralresults =
StaticStructuralResults with properties:
[X,Y] = meshgrid(linspace(-0.015,0.015,50));
Z = ones(size(X))*0.025;
intrpStrain = interpolateStrain(structuralresults,X,Y,Z);
surf(X,Y,reshape(intrpStrain.ezz,size(X)))
5-505
5 Functions — Alphabetical List
Alternatively, you can specify the grid by using a matrix of query points.
querypoints = [X(:),Y(:),Z(:)]';
intrpStrain = interpolateStrain(structuralresults,querypoints);
surf(X,Y,reshape(intrpStrain.ezz,size(X)))
5-506
interpolateStrain
Interpolate the strain at the geometric center of a beam under a harmonic excitation.
5-507
5 Functions — Alphabetical List
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
Apply a sinusoidal displacement along the y-direction on the end opposite the fixed end of
the beam.
5-508
interpolateStrain
structuralBC(structuralmodel,'Face',3,'YDisplacement',1E-4,'Frequency',50);
Generate a mesh.
generateMesh(structuralmodel,'Hmax',0.01);
structuralIC(structuralmodel,'Displacement',[0;0;0],'Velocity',[0;0;0]);
tlist = 0:0.002:0.2;
structuralresults = solve(structuralmodel,tlist);
coordsMidSpan = [0;0;0.005];
intrpStrain = interpolateStrain(structuralresults,coordsMidSpan);
figure
plot(structuralresults.SolutionTimes,intrpStrain.exx)
title('X-Direction Normal Strain at Beam Center')
5-509
5 Functions — Alphabetical List
Input Arguments
structuralresults — Solution of structural analysis problem
StaticStructuralResults object | TransientStructuralResults object |
FrequencyStructuralResults object
5-510
interpolateStrain
interpolateStrain converts query points to column vectors xq(:), yq(:), and (if
present) zq(:). The function returns strains as a structure array with fields of the same
size as these column vectors. To ensure that the dimensions of the returned solution are
consistent with the dimensions of the original query points, use the reshape function.
For example, use intrpStrain = reshape(intrpStrain.exx,size(xq)).
Data Types: double
Query points, specified as a real matrix with either two rows for 2-D geometry or three
rows for 3-D geometry. interpolateStrain evaluates the strains at the coordinate
points querypoints(:,i), so each column of querypoints contains exactly one 2-D or
3-D query point.
5-511
5 Functions — Alphabetical List
Output Arguments
intrpStrain — Strains at query points
structure array
Strains at the query points, returned as a structure array with fields representing spatial
components of strain at the query points. For query points that are outside the geometry,
intrpStrain returns NaN.
See Also
StaticStructuralResults | StructuralModel | evaluatePrincipalStrain |
evaluatePrincipalStress | evaluateReaction | interpolateDisplacement |
interpolateStress | interpolateVonMisesStress
Introduced in R2017b
5-512
interpolateStress
interpolateStress
Package: pde
Syntax
intrpStress = interpolateStress(structuralresults,xq,yq)
intrpStress = interpolateStress(structuralresults,xq,yq,zq)
intrpStress = interpolateStress(structuralresults,querypoints)
Description
intrpStress = interpolateStress(structuralresults,xq,yq) returns the
interpolated stress values at the 2-D points specified in xq and yq. For transient and
frequency-response structural models, interpolateStress interpolates stress for all
time- or frequency-steps, respectively.
Examples
structuralmodel = createpde('structural','static-planestrain');
5-513
5 Functions — Alphabetical List
geometryFromEdges(structuralmodel,@squareg);
pdegplot(structuralmodel,'EdgeLabels','on')
axis equal
structuralProperties(structuralmodel,'PoissonsRatio',0.3, ...
'YoungsModulus',210E3);
structuralBC(structuralmodel,'XDisplacement',0.001,'Edge',1);
5-514
interpolateStress
structuralBC(structuralmodel,'Constraint','fixed','Edge',3);
generateMesh(structuralmodel);
structuralresults = solve(structuralmodel);
Create a grid and interpolate the x- and y-components of the normal stress to the grid.
v = linspace(-1,1,151);
[X,Y] = meshgrid(v);
intrpStress = interpolateStress(structuralresults,X,Y);
Reshape the x-component of the normal stress to the shape of the grid and plot it.
sxx = reshape(intrpStress.sxx,size(X));
px = pcolor(X,Y,sxx);
px.EdgeColor='none';
colorbar
5-515
5 Functions — Alphabetical List
Reshape the y-component of the normal stress to the shape of the grid and plot it.
syy = reshape(intrpStress.syy,size(Y));
figure
py = pcolor(X,Y,syy);
py.EdgeColor='none';
colorbar
5-516
interpolateStress
Solve a static structural model representing a bimetallic cable under tension, and
interpolate stress on a cross-section of the cable.
structuralmodel = createpde('structural','static-solid');
Create the geometry and include it in the model. Plot the geometry.
5-517
5 Functions — Alphabetical List
gm = multicylinder([0.01,0.015],0.05);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','CellLabels','on','FaceAlpha',0.5)
Specify the Young's modulus and Poisson's ratio for each metal.
structuralProperties(structuralmodel,'Cell',1,'YoungsModulus',110E9, ...
'PoissonsRatio',0.28);
structuralProperties(structuralmodel,'Cell',2,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3);
structuralBC(structuralmodel,'Face',[1,4],'Constraint','fixed');
5-518
interpolateStress
structuralBoundaryLoad(structuralmodel,'Face',[2,5],'SurfaceTraction',[0;0;100]);
generateMesh(structuralmodel);
structuralresults = solve(structuralmodel)
structuralresults =
StaticStructuralResults with properties:
[X,Y] = meshgrid(linspace(-0.015,0.015,50));
Z = ones(size(X))*0.025;
intrpStress = interpolateStress(structuralresults,X,Y,Z);
surf(X,Y,reshape(intrpStress.szz,size(X)))
5-519
5 Functions — Alphabetical List
Alternatively, you can specify the grid by using a matrix of query points.
querypoints = [X(:),Y(:),Z(:)]';
intrpStress = interpolateStress(structuralresults,querypoints);
surf(X,Y,reshape(intrpStress.szz,size(X)))
5-520
interpolateStress
Interpolate the stress at the geometric center of a beam under a harmonic excitation.
5-521
5 Functions — Alphabetical List
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
Apply a sinusoidal displacement along the y-direction on the end opposite the fixed end of
the beam.
5-522
interpolateStress
structuralBC(structuralmodel,'Face',3,'YDisplacement',1E-4,'Frequency',50);
Generate a mesh.
generateMesh(structuralmodel,'Hmax',0.01);
structuralIC(structuralmodel,'Displacement',[0;0;0],'Velocity',[0;0;0]);
tlist = 0:0.002:0.2;
structuralresults = solve(structuralmodel,tlist);
coordsMidSpan = [0;0;0.005];
intrpStress = interpolateStress(structuralresults,coordsMidSpan);
figure
plot(structuralresults.SolutionTimes,intrpStress.sxx)
title('X-Direction Normal Stress at Beam Center')
5-523
5 Functions — Alphabetical List
Input Arguments
structuralresults — Solution of structural analysis problem
StaticStructuralResults object | TransientStructuralResults object |
FrequencyStructuralResults object
5-524
interpolateStress
interpolateStress converts the query points to column vectors xq(:), yq(:), and (if
present) zq(:). It returns stresses as a structure array with fields of the same size as
these column vectors. To ensure that the dimensions of the returned solution are
consistent with the dimensions of the original query points, use the reshape function.
For example, use intrpStress = reshape(intrpStress.sxx,size(xq)).
Data Types: double
Query points, specified as a real matrix with either two rows for 2-D geometry or three
rows for 3-D geometry. interpolateStress evaluates stresses at the coordinate points
querypoints(:,i), so each column of querypoints contains exactly one 2-D or 3-D
query point.
5-525
5 Functions — Alphabetical List
Output Arguments
intrpStress — Stresses at query points
structure array
Stresses at the query points, returned as a structure array with fields representing spatial
components of stress at the query points. For query points that are outside the geometry,
intrpStress returns NaN.
See Also
StaticStructuralResults | StructuralModel | evaluatePrincipalStrain |
evaluatePrincipalStress | evaluateReaction | interpolateDisplacement |
interpolateStrain | interpolateVonMisesStress
Introduced in R2017b
5-526
interpolateTemperature
interpolateTemperature
Package: pde
Syntax
Tintrp = interpolateTemperature(thermalresults,xq,yq)
Tintrp = interpolateTemperature(thermalresults,xq,yq,zq)
Tintrp = interpolateTemperature(thermalresults,querypoints)
Tintrp = interpolateTemperature( ___ ,iT)
Description
Tintrp = interpolateTemperature(thermalresults,xq,yq) returns the
interpolated temperature values at the 2-D points specified in xq and yq. This syntax is
valid for both the steady-state and transient thermal models.
Examples
5-527
5 Functions — Alphabetical List
thermalmodel = createpde('thermal');
R1 = [3,4,-1,1,1,-1,1,1,-1,-1]';
g = decsg(R1, 'R1', ('R1')');
geometryFromEdges(thermalmodel,g);
pdegplot(thermalmodel,'EdgeLabels','on')
xlim([-1.5,1.5])
axis equal
Assuming that this is an iron plate, assign a thermal conductivity of 79.5 W/(m*K).
Because this is a steady-state model, you do not need to assign mass density or specific
heat values.
5-528
interpolateTemperature
thermalProperties(thermalmodel,'ThermalConductivity',79.5,'Face',1);
Apply a constant temperature of 300 K to the bottom of the plate (edge 3). Also, assume
that the top of the plate (edge 1) is insulated, and apply convection on the two sides of the
plate (edges 2 and 4).
thermalBC(thermalmodel,'Edge',3,'Temperature',300);
thermalBC(thermalmodel,'Edge',1,'HeatFlux',0);
thermalBC(thermalmodel,'Edge',[2,4],...
'ConvectionCoefficient',25,...
'AmbientTemperature',50);
generateMesh(thermalmodel);
results = solve(thermalmodel)
results =
SteadyStateThermalResults with properties:
The solver finds the values of temperatures and temperature gradients at the nodal
locations. To access these values, use results.Temperature, results.XGradients,
and so on. For example, plot the temperatures at nodal locations.
figure;
pdeplot(thermalmodel,'XYData',results.Temperature,...
'Contour','on','ColorMap','hot');
5-529
5 Functions — Alphabetical List
Interpolate the resulting temperatures to a grid covering the central portion of the
geometry, for x and y from -0.5 to 0.5.
v = linspace(-0.5,0.5,11);
[X,Y] = meshgrid(v);
Tintrp = interpolateTemperature(results,X,Y);
Tintrp = reshape(Tintrp,size(X));
figure
contourf(X,Y,Tintrp)
5-530
interpolateTemperature
colormap(hot)
colorbar
Alternatively, you can specify the grid by using a matrix of query points.
querypoints = [X(:),Y(:)]';
Tintrp = interpolateTemperature(results,querypoints);
5-531
5 Functions — Alphabetical List
thermalmodel = createpde('thermal');
importGeometry(thermalmodel,'Block.stl');
pdegplot(thermalmodel,'FaceLabels','on','FaceAlpha',0.5)
title('Copper block, cm')
axis equal
Assuming that this is a copper block, the thermal conductivity of the block is
approximately 4 W/(cm*K).
thermalProperties(thermalmodel,'ThermalConductivity',4);
5-532
interpolateTemperature
Apply a constant temperature of 373 K to the left side of the block (edge 1) and a constant
temperature of 573 K at the right side of the block.
thermalBC(thermalmodel,'Face',1,'Temperature',373);
thermalBC(thermalmodel,'Face',3,'Temperature',573);
thermalBC(thermalmodel,'Face',4,'HeatFlux',-20);
generateMesh(thermalmodel);
thermalresults = solve(thermalmodel)
thermalresults =
SteadyStateThermalResults with properties:
The solver finds the values of temperatures and temperature gradients at the nodal
locations. To access these values, use results.Temperature, results.XGradients,
and so on. For example, plot temperatures at nodal locations.
figure;
pdeplot3D(thermalmodel,'ColorMapData',thermalresults.Temperature)
5-533
5 Functions — Alphabetical List
[X,Y,Z] = meshgrid(1:16:100,1:6:20,1:7:50);
Tintrp = interpolateTemperature(thermalresults,X,Y,Z);
figure
Tintrp = reshape(Tintrp,size(X));
contourslice(X,Y,Z,Tintrp,[],1:6:20,[])
5-534
interpolateTemperature
xlabel('x')
ylabel('y')
zlabel('z')
xlim([1,100])
ylim([1,20])
zlim([1,50])
axis equal
view(-50,22)
colorbar
Alternatively, you can specify the grid by using a matrix of query points.
querypoints = [X(:),Y(:),Z(:)]';
Tintrp = interpolateTemperature(thermalresults,querypoints);
5-535
5 Functions — Alphabetical List
Create a contour slice plot for four fixed values of the z coordinate.
figure
Tintrp = reshape(Tintrp,size(X));
contourslice(X,Y,Z,Tintrp,[],[],1:7:50)
xlabel('x')
ylabel('y')
zlabel('z')
xlim([1,100])
ylim([1,20])
zlim([1,50])
axis equal
view(-50,22)
colorbar
5-536
interpolateTemperature
Solve a 2-D transient heat transfer problem on a square domain and compute
temperatures at the convective boundary.
thermalmodel = createpde('thermal','transient');
5-537
5 Functions — Alphabetical List
g = @squareg;
geometryFromEdges(thermalmodel,g);
pdegplot(thermalmodel,'EdgeLabels','on')
xlim([-1.2,1.2])
ylim([-1.2,1.2])
axis equal
5-538
interpolateTemperature
thermalProperties(thermalmodel,'ThermalConductivity',100,...
'MassDensity',7800,...
'SpecificHeat',500);
Apply insulated boundary conditions on three edges and the free convection boundary
condition on the right edge.
thermalBC(thermalmodel,'Edge',[1,3,4],'HeatFlux',0);
thermalBC(thermalmodel,'Edge',2,...
'ConvectionCoefficient',5000,...
'AmbientTemperature',25);
Set the initial conditions: uniform room temperature across domain and higher
temperature on the left edge.
thermalIC(thermalmodel,25);
thermalIC(thermalmodel,100,'Edge',4);
Generate a mesh and solve the problem using 0:1000:200000 as a vector of times.
generateMesh(thermalmodel);
tlist = 0:1000:200000;
thermalresults = solve(thermalmodel,tlist)
thermalresults =
TransientThermalResults with properties:
Define a line at convection boundary and compute temperature gradients across that line.
X = -1:0.1:1;
Y = ones(size(X));
Tintrp = interpolateTemperature(thermalresults,X,Y,1:length(tlist));
Plot the interpolated temperature Tintrp along the x axis for the following values from
the time interval tlist.
5-539
5 Functions — Alphabetical List
figure
t = [51:50:201];
for i = t
p(i) = plot(X,Tintrp(:,i),'DisplayName', strcat('t=', num2str(tlist(i))));
hold on
end
legend(p(t))
xlabel('x')
ylabel('Tintrp')
5-540
interpolateTemperature
Input Arguments
thermalresults — Solution of thermal problem
SteadyStateThermalResults object | TransientThermalResults object
5-541
5 Functions — Alphabetical List
Query points, specified as a real matrix with either two rows for 2-D geometry, or three
rows for 3-D geometry. interpolateTemperature evaluates temperatures at the
coordinate points querypoints(:,i), so each column of querypoints contains exactly
one 2-D or 3-D query point.
Example: For 2-D geometry, querypoints = [0.5,0.5,0.75,0.75; 1,2,0,0.5]
Data Types: double
iT — Time indices
vector of positive integers
Time indices, specified as a vector of positive integers. Each entry in iT specifies a time
index.
Example: iT = 1:5:21 specifies every fifth time-step up to 21.
Data Types: double
Output Arguments
Tintrp — Temperatures at query points
array
Temperatures at query points, returned as an array. For query points that are outside the
geometry, Tintrp = NaN.
See Also
SteadyStateThermalResults | ThermalModel | TransientThermalResults |
evaluateHeatFlux | evaluateHeatRate | evaluateTemperatureGradient
Topics
“Dimensions of Solutions, Gradients, and Fluxes” on page 3-347
5-542
interpolateTemperature
Introduced in R2017a
5-543
5 Functions — Alphabetical List
interpolateVelocity
Package: pde
Interpolate velocity at arbitrary spatial locations for all time or frequency steps for
dynamic structural model
Syntax
intrpVel = interpolateVelocity(structuralresults,xq,yq)
intrpVel = interpolateVelocity(structuralresults,xq,yq,zq)
intrpVel = interpolateVelocity(structuralresults,querypoints)
Description
intrpVel = interpolateVelocity(structuralresults,xq,yq) returns the
interpolated velocity values at the 2-D points specified in xq and yq for all time or
frequency steps.
Examples
structuralmodel = createpde('structural','transient-solid');
5-544
interpolateVelocity
Create the geometry and include it in the model. Plot the geometry.
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
5-545
5 Functions — Alphabetical List
structuralBC(structuralmodel,'Face',5,'Constraint','fixed');
Apply a sinusoidal displacement along the y-direction on the end opposite the fixed end of
the beam.
structuralBC(structuralmodel,'Face',3,'YDisplacement',1E-4,'Frequency',50);
Generate a mesh.
generateMesh(structuralmodel,'Hmax',0.01);
structuralIC(structuralmodel,'Displacement',[0;0;0],'Velocity',[0;0;0]);
tlist = 0:0.002:0.2;
structuralresults = solve(structuralmodel,tlist);
coordsMidSpan = [0;0;0.005];
intrpVel = interpolateVelocity(structuralresults,coordsMidSpan);
figure
plot(structuralresults.SolutionTimes,intrpVel.vy)
title('Y-Velocity of the Geometric Center of the Beam')
5-546
interpolateVelocity
Input Arguments
structuralresults — Solution of dynamic structural analysis problem
TransientStructuralResults object | FrequencyStructuralResults object
5-547
5 Functions — Alphabetical List
interpolateVelocity converts query points to column vectors xq(:), yq(:), and (if
present) zq(:). It returns velocities as a structure array with fields of the same size as
these column vectors. To ensure that the dimensions of the returned solution are
consistent with the dimensions of the original query points, use the reshape function.
For example, use intrpVel = reshape(intrpVel.ux,size(xq)).
Data Types: double
Query points, specified as a real matrix with either two rows for 2-D geometry or three
rows for 3-D geometry. interpolateVelocity evaluates velocities at the coordinate
points querypoints(:,i), so each column of querypoints contains exactly one 2-D or
3-D query point.
5-548
interpolateVelocity
Output Arguments
intrpVel — Velocities at query points
structure array
Velocities at the query points, returned as a structure array with fields representing
spatial components of velocity at the query points. For query points that are outside the
geometry, intrpVel returns NaN.
See Also
StructuralModel | TransientStructuralResults | evaluatePrincipalStrain |
evaluatePrincipalStress | evaluateReaction | evaluateStrain |
evaluateStress | evaluateVonMisesStress | interpolateAcceleration |
interpolateDisplacement | interpolateStrain | interpolateStress |
interpolateVonMisesStress
Introduced in R2018a
5-549
5 Functions — Alphabetical List
interpolateVonMisesStress
Package: pde
Syntax
intrpVMStress = interpolateVonMisesStress(structuralresults,xq,yq)
intrpVMStress = interpolateVonMisesStress(structuralresults,xq,yq,
zq)
intrpVMStress = interpolateVonMisesStress(structuralresults,
querypoints)
Description
intrpVMStress = interpolateVonMisesStress(structuralresults,xq,yq)
returns the interpolated von Mises stress values at the 2-D points specified in xq and yq.
For transient and frequency-response structural models, interpolateVonMisesStress
interpolates von Mises stress for all time- or frequency-steps, respectively.
intrpVMStress = interpolateVonMisesStress(structuralresults,xq,yq,
zq) uses the 3-D points specified in xq, yq, and zq.
intrpVMStress = interpolateVonMisesStress(structuralresults,
querypoints) uses the points specified in querypoints.
Examples
structuralmodel = createpde('structural','static-planestrain');
5-550
interpolateVonMisesStress
geometryFromEdges(structuralmodel,@squareg);
pdegplot(structuralmodel,'EdgeLabels','on')
axis equal
structuralProperties(structuralmodel,'PoissonsRatio',0.3, ...
'YoungsModulus',210E3);
structuralBC(structuralmodel,'XDisplacement',0.001,'Edge',1);
5-551
5 Functions — Alphabetical List
structuralBC(structuralmodel,'Constraint','fixed','Edge',3);
generateMesh(structuralmodel);
structuralresults = solve(structuralmodel);
Create a grid and interpolate the von Mises stress to the grid.
v = linspace(-1,1,151);
[X,Y] = meshgrid(v);
intrpVMStress = interpolateVonMisesStress(structuralresults,X,Y);
Reshape the von Mises stress to the shape of the grid and plot it.
VMStress = reshape(intrpVMStress,size(X));
p = pcolor(X,Y,VMStress);
p.EdgeColor='none';
colorbar
5-552
interpolateVonMisesStress
Interpolate Von Mises Stress for 3-D Static Structural Analysis Problem
Solve a static structural model representing a bimetallic cable under tension, and
interpolate the von Mises stress on a cross-section of the cable.
structuralmodel = createpde('structural','static-solid');
Create the geometry and include it in the model. Plot the geometry.
5-553
5 Functions — Alphabetical List
gm = multicylinder([0.01,0.015],0.05);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','CellLabels','on','FaceAlpha',0.5)
Specify the Young's modulus and Poisson's ratio for each metal.
structuralProperties(structuralmodel,'Cell',1,'YoungsModulus',110E9, ...
'PoissonsRatio',0.28);
structuralProperties(structuralmodel,'Cell',2,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3);
structuralBC(structuralmodel,'Face',[1,4],'Constraint','fixed');
5-554
interpolateVonMisesStress
structuralBoundaryLoad(structuralmodel,'Face',[2,5],'SurfaceTraction',[0;0;100]);
generateMesh(structuralmodel);
structuralresults = solve(structuralmodel)
structuralresults =
StaticStructuralResults with properties:
[X,Y] = meshgrid(linspace(-0.015,0.015,50));
Z = ones(size(X))*0.025;
IntrpVMStress = interpolateVonMisesStress(structuralresults,X,Y,Z);
surf(X,Y,reshape(IntrpVMStress,size(X)))
5-555
5 Functions — Alphabetical List
Alternatively, you can specify the grid by using a matrix of query points.
querypoints = [X(:),Y(:),Z(:)]';
IntrpVMStress = interpolateVonMisesStress(structuralresults,querypoints);
surf(X,Y,reshape(IntrpVMStress,size(X)))
5-556
interpolateVonMisesStress
Interpolate the von Mises stress at the geometric center of a beam under a harmonic
excitation.
structuralmodel = createpde('structural','transient-solid');
Create the geometry and include it in the model. Plot the geometry.
5-557
5 Functions — Alphabetical List
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
structuralBC(structuralmodel,'Face',5,'Constraint','fixed');
5-558
interpolateVonMisesStress
Apply a sinusoidal displacement along the y-direction on the end opposite the fixed end of
the beam.
structuralBC(structuralmodel,'Face',3,'YDisplacement',1E-4,'Frequency',50);
Generate a mesh.
generateMesh(structuralmodel,'Hmax',0.01);
structuralIC(structuralmodel,'Displacement',[0;0;0],'Velocity',[0;0;0]);
tlist = 0:0.002:0.2;
structuralresults = solve(structuralmodel,tlist);
Interpolate the von Mises stress at the geometric center of the beam.
coordsMidSpan = [0;0;0.005];
intrpStress = interpolateStress(structuralresults,coordsMidSpan);
Plot the von Mises stress at the geometric center of the beam.
figure
plot(structuralresults.SolutionTimes,intrpStress.sxx)
title('von Mises Stress at Beam Center')
5-559
5 Functions — Alphabetical List
Input Arguments
structuralresults — Solution of structural analysis problem
StaticStructuralResults object | TransientStructuralResults object |
FrequencyStructuralResults object
5-560
interpolateVonMisesStress
Query points, specified as a real matrix with either two rows for 2-D geometry or three
rows for 3-D geometry. interpolateVonMisesStress evaluates the von Mises stress at
5-561
5 Functions — Alphabetical List
Output Arguments
intrpVMStress — von Mises stress at query points
column vector
For query points that are outside the geometry, intrpVMStress = NaN.
See Also
StaticStructuralResults | StructuralModel | evaluatePrincipalStrain |
evaluatePrincipalStress | evaluateReaction | interpolateDisplacement |
interpolateStrain | interpolateStress
Introduced in R2017b
5-562
jigglemesh
jigglemesh
(Not recommended) Jiggle internal points of triangular mesh
Note This page describes the legacy workflow. New features might not be compatible
with the legacy workflow. For the corresponding step in the recommended workflow, see
generateMesh.
Syntax
p1 = jigglemesh(p,e,t)
p1 = jigglemesh(p,e,t,'PropertyName',PropertyValue,...)
Description
p1 = jigglemesh(p,e,t) jiggles the triangular mesh by adjusting the node point
positions. The quality of the mesh normally increases.
Each mesh point that is not located on an edge segment is moved toward the center of
mass of the polygon formed by the adjacent triangles. This process is repeated according
to the settings of the Opt and Iter variables:
• When Opt is set to 'off' this process is repeated Iter times (default: 1).
• When Opt is set to 'mean' the process is repeated until the mean triangle quality
does not significantly increase, or until the bound Iter is reached (default: 20).
5-563
5 Functions — Alphabetical List
• When Opt is set to 'minimum' the process is repeated until the minimum triangle
quality does not significantly increase, or until the bound Iter is reached (default:
20).
Examples
Mesh Jiggling
Create a triangular mesh of the L-shaped membrane, first without jiggling, and then jiggle
the mesh.
[p,e,t] = initmesh('lshapeg','jiggle','off');
q = pdetriq(p,t);
pdeplot(p,e,t,'XYData',q,'ColorBar','on','XYStyle','flat')
5-564
jigglemesh
p1 = jigglemesh(p,e,t,'opt','mean','iter',inf);
q = pdetriq(p1,t);
pdeplot(p1,e,t,'XYData',q,'ColorBar','on','XYStyle','flat')
5-565
5 Functions — Alphabetical List
See Also
initmesh | pdetriq
Topics
“Mesh Data” on page 2-171
5-566
meshQuality
meshQuality
Package: pde
Syntax
Q = meshQuality(mesh)
Q = meshQuality(mesh,elemIDs)
Q = meshQuality( ___ ,'aspect-ratio')
Description
Q = meshQuality(mesh) returns a row vector of numbers from 0 through 1
representing shape quality of all elements of the mesh. Here, 1 corresponds to the
optimal shape of the element.
Examples
model = createpde;
5-567
5 Functions — Alphabetical List
mesh =
FEMesh with properties:
5-568
meshQuality
MinElementSize: 17.5000
MeshGradation: 1.5000
GeometricOrder: 'quadratic'
pdemesh(model)
Evaluate the shape quality of all mesh elements. Display the first five values.
Q = meshQuality(mesh);
Q(1:5)
ans = 1×5
5-569
5 Functions — Alphabetical List
Find the elements with the quality values less than 0.2.
pdemesh(mesh,'FaceAlpha',0.5)
hold on
pdemesh(mesh.Nodes,mesh.Elements(:,elemIDs),'FaceColor','blue','EdgeColor','blue')
5-570
meshQuality
figure
hist(Q)
xlabel('Element Shape Quality','fontweight','b')
ylabel('Number of Elements','fontweight','b')
Qworst = min(Q)
Qworst = 0.1691
elemIDs = find(Q==Qworst)
5-571
5 Functions — Alphabetical List
elemIDs = 1×2
10 136
model = createpde;
importGeometry(model,'PlateSquareHolePlanar.stl');
pdegplot(model)
5-572
meshQuality
mesh = generateMesh(model,'Hmax',20)
mesh =
FEMesh with properties:
5-573
5 Functions — Alphabetical List
pdemesh(model)
Find the IDs of the elements within a box enclosing the center of the plate.
elemIDs = findElements(mesh,'box',[25,75],[80,120]);
Q = meshQuality(mesh,elemIDs)
Q = 1×12
5-574
meshQuality
Find the elements with the quality values less than 0.4.
elemIDs04 = elemIDs(Q < 0.4)
elemIDs04 = 1×4
9 19 69 83
Highlight these elements in green on the mesh plot. Zoom in to see the details.
pdemesh(mesh,'ElementLabels','on')
hold on
pdemesh(mesh.Nodes,mesh.Elements(:,elemIDs04),'EdgeColor','green')
zoom(10)
5-575
5 Functions — Alphabetical List
Determine the shape quality of mesh elements by using the ratios of minimal to maximal
dimensions.
model = createpde(1);
geometryFromEdges(model,@lshapeg);
mesh = generateMesh(model);
pdeplot(model)
5-576
meshQuality
Evaluate the shape quality of mesh elements by using the minimal to maximal dimensions
ratio. Display the first five values.
Q = meshQuality(mesh,'aspect-ratio');
Q(1:5)
ans = 1×5
Evaluate the shape quality of mesh elements by using the default setting. Display the first
five values.
5-577
5 Functions — Alphabetical List
Q = meshQuality(mesh);
Q(1:5)
ans = 1×5
Input Arguments
mesh — Mesh object
Mesh property of a PDEModel object | output of generateMesh
Mesh object, specified as the Mesh property of a PDEModel object or as the output of
generateMesh.
Example: model.Mesh
Output Arguments
Q — Shape quality of mesh elements
row vector of numbers from 0 through 1
Shape quality of mesh elements, returned as a row vector of numbers from 0 through 1.
The value 0 corresponds to a deflated element with zero area or volume. The value 1
corresponds to an element of optimal shape.
Example: [0.9150 0.7787 0.9417 0.2744 0.9843 0.9181]
Data Types: double
5-578
meshQuality
References
[1] Knupp, Patrick M. "Matrix Norms & the Condition Number: A General Framework to
Improve Mesh Quality via Node-Movement." In Proceedings, 8th International
Meshing Roundtable. Lake Tahoe, CA, October 1999: 13-22.
See Also
FEMesh Properties | area | findElements | findNodes | volume
Topics
“Finite Element Method Basics” on page 1-13
Introduced in R2018a
5-579
5 Functions — Alphabetical List
meshToPet
Package: pde
Note This page describes the legacy workflow. New features might not be compatible
with the [p,e,t] representation of FEMesh data.
Syntax
[p,e,t] = meshToPet(mesh)
Description
[p,e,t] = meshToPet(mesh) extracts the legacy [p,e,t] mesh representation from
a FEMesh object.
Examples
This example shows how to convert a mesh in object form to [p,e,t] form.
Create a 2-D PDE geometry and incorporate it into a model object. View the geometry.
model = createpde(1);
R1 = [3,4,-1,1,1,-1,-.4,-.4,.4,.4]';
C1 = [1,.5,0,.2]';
% Pad C1 with zeros to enable concatenation with R1
C1 = [C1;zeros(length(R1)-length(C1),1)];
geom = [R1,C1];
ns = (char('R1','C1'))';
sf = 'R1-C1';
5-580
meshToPet
gd = decsg(geom,sf,ns);
geometryFromEdges(model,gd);
pdegplot(model,'EdgeLabels','on')
xlim([-1.1 1.1])
axis equal
generateMesh(model);
pdemesh(model)
axis equal
5-581
5 Functions — Alphabetical List
[p,e,t] = meshToPet(model.Mesh);
size(p)
ans = 1×2
2 956
size(e)
5-582
meshToPet
ans = 1×2
7 160
size(t)
ans = 1×2
7 438
Input Arguments
mesh — Mesh object
Mesh property of a PDEModel object | output of generateMesh
Mesh object, specified as the Mesh property of a PDEModel object or as the output of
generateMesh.
Example: model.Mesh
Output Arguments
p — Mesh points
2-by-Np matrix | 3-by-Np matrix
Mesh points, returned as a 2-by-Np matrix (2-D geometry) or a 3-by-Np matrix (3-D
geometry). Np is the number of points (nodes) in the mesh. Column k of p consists of the
x-coordinate of point k in p(1,k), the y-coordinate of point k in p(2,k), and, for 3-D, the
z-coordinate of point k in p(3,k). For details, see “Mesh Data” on page 2-171.
e — Mesh edges
7-by-Ne matrix | mesh associativity object
Mesh edges, returned as a 7-by-Ne matrix (2-D), or a mesh associativity object (3-D). Ne is
the number of edges in the mesh. An edge is a pair of points in p containing a boundary
between subdomains, or containing an outer boundary. For details, see “Mesh Data” on
page 2-171.
5-583
5 Functions — Alphabetical List
t — Mesh elements
4-by-Nt matrix | 7-by-Nt matrix | 5-by-Nt matrix | 11-by-Nt matrix
Mesh elements, returned as a 4-by-Nt matrix (2-D with linear elements), a 7-by-Nt matrix
(2-D with quadratic elements), a 5-by-Nt matrix (3-D with linear elements), or an 11-by-Nt
matrix (3-D with quadratic elements). Nt is the number of triangles or tetrahedra in the
mesh.
The t(i,k), with i ranging from 1 through end - 1, contain indices to the corner
points and possibly edge centers of element k. For details, see “Mesh Data” on page 2-
171. The last row, t(end,k), contains the subdomain number of the element.
Tips
• Use meshToPet to obtain the p and t data for interpolation using pdeInterpolant.
See Also
FEMesh | generateMesh
Topics
“Mesh Data” on page 2-171
Introduced in R2015a
5-584
multicuboid
multicuboid
Create geometry formed by several cubic cells
Syntax
gm = multicuboid(W,D,H)
gm = multicuboid(W,D,H,Name,Value)
Description
gm = multicuboid(W,D,H) creates a geometry by combining several cubic cells.
When creating each cuboid, multicuboid uses the following coordinate system.
5-585
5 Functions — Alphabetical List
Examples
Create a geometry that consists of three nested cuboids of the same height and include
this geometry in a PDE model.
Create the geometry by using the multicuboid function. The resulting geometry
consists of three cells.
gm = multicuboid([2 3 5],[4 6 10],3)
gm =
DiscreteGeometry with properties:
NumCells: 3
NumFaces: 18
NumEdges: 36
NumVertices: 24
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
5-586
multicuboid
model.Geometry = gm
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
pdegplot(model,'CellLabels','on','FaceAlpha',0.5)
5-587
5 Functions — Alphabetical List
Stacked Cuboids
Create a geometry that consists of four stacked cuboids and include this geometry in a
PDE model.
Create the geometry by using the multicuboid function with the ZOffset argument.
The resulting geometry consists of four cells stacked on top of each other.
gm = multicuboid(5,10,[1 2 3 4],'ZOffset',[0 1 3 6])
gm =
DiscreteGeometry with properties:
5-588
multicuboid
NumCells: 4
NumFaces: 21
NumEdges: 36
NumVertices: 20
model = createpde
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
model.Geometry = gm
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
pdegplot(model,'CellLabels','on','FaceAlpha',0.5)
5-589
5 Functions — Alphabetical List
Single Cuboid
Create a geometry that consists of a single cuboid and include this geometry in a PDE
model.
Use the multicuboid function to create a single cuboid. The resulting geometry consists
of one cell.
gm = multicuboid(5,10,7)
gm =
DiscreteGeometry with properties:
5-590
multicuboid
NumCells: 1
NumFaces: 6
NumEdges: 12
NumVertices: 8
model = createpde
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
model.Geometry = gm
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
pdegplot(model,'CellLabels','on')
5-591
5 Functions — Alphabetical List
Hollow Cube
Create a hollow cube by using the multicuboid function with the Void argument. The
resulting geometry consists of one cell.
gm =
DiscreteGeometry with properties:
5-592
multicuboid
NumCells: 1
NumFaces: 10
NumEdges: 24
NumVertices: 16
model = createpde
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
model.Geometry = gm
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
pdegplot(model,'CellLabels','on','FaceAlpha',0.5)
5-593
5 Functions — Alphabetical List
Input Arguments
W — Cell width
positive real number | vector of positive real numbers
Cell width, specified as a positive real number or a vector of positive real numbers. If W is
a vector, then W(i) specifies the width of the ith cell.
Width W, depth D, and height H can be scalars or vectors of the same length. For a
combination of scalar and vector inputs, multicuboid replicates the scalar arguments
into vectors of the same length.
5-594
multicuboid
Note All cells in the geometry either must have the same height, or must have both the
same width and the same depth.
D — Cell depth
positive real number | vector of positive real numbers
Cell depth, specified as a positive real number or a vector of positive real numbers. If D is
a vector, then D(i) specifies the depth of the ith cell.
Width W, depth D, and height H can be scalars or vectors of the same length. For a
combination of scalar and vector inputs, multicuboid replicates the scalar arguments
into vectors of the same length.
Note All cells in the geometry either must have the same height, or must have both the
same width and the same depth.
H — Cell height
positive real number | vector of positive real numbers
Cell height, specified as a positive real number or a vector of positive real numbers. If H is
a vector, then H(i) specifies the height of the ith cell.
Width W, depth D, and height H can be scalars or vectors of the same length. For a
combination of scalar and vector inputs, multicuboid replicates the scalar arguments
into vectors of the same length.
Note All cells in the geometry either must have the same height, or must have both the
same width and the same depth.
5-595
5 Functions — Alphabetical List
Z offset for each cell, specified as a vector of real numbers. ZOffset(i) specifies the Z
offset of the ith cell. This vector must have the same length as the width vector W, depth
vector D, or height vector H.
Note The ZOffset argument is valid only if the width and depth are constant for all cells
in the geometry.
Empty cell indicator, specified as a vector of logical true or false values. This vector
must have the same length as the width vector W, depth vector D, or the height vector H.
The value true corresponds to an empty cell. By default, multicuboid assumes that all
cells are not empty.
Example: gm = multicuboid([1 2],[1 2],[3 3],'Void',[true,false])
Data Types: double
Output Arguments
gm — Geometry object
DiscreteGeometry object
5-596
multicuboid
Limitations
• multicuboid lets you create only geometries consisting of stacked or nested cuboids.
For nested cuboids, the height must be the same for all cells in the geometry. For
stacked cuboids, the width and depth must be the same for all cells in the geometry.
Use the ZOffset argument to stack the cells on top of each other without overlapping
them.
• multicuboid does not let you create nested cuboids of the same width and depth.
The call multicuboid(w,d,[h1,h2,...]) is not supported.
See Also
DiscreteGeometry | multicylinder | multisphere
Introduced in R2017a
5-597
5 Functions — Alphabetical List
multicylinder
Create geometry formed by several cylindrical cells
Syntax
gm = multicylinder(R,H)
gm = multicylinder(R,H,Name,Value)
Description
gm = multicylinder(R,H) creates a geometry by combining several cylindrical cells.
When creating each cylinder, multicylinder uses the following coordinate system.
5-598
multicylinder
Examples
Create a geometry that consists of three nested cylinders of the same height and include
this geometry in a PDE model.
Create the geometry by using the multicylinder function. The resulting geometry
consists of three cells.
gm = multicylinder([5 10 15],2)
gm =
DiscreteGeometry with properties:
NumCells: 3
NumFaces: 9
NumEdges: 6
NumVertices: 6
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
model =
PDEModel with properties:
5-599
5 Functions — Alphabetical List
PDESystemSize: 1
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
5-600
multicylinder
Stacked Cylinders
Create a geometry that consists of three stacked cylinders and include this geometry in a
PDE model.
Create the geometry by using the multicylinder function with the ZOffset argument.
The resulting geometry consists of four cells stacked on top of each other.
gm =
DiscreteGeometry with properties:
NumCells: 4
NumFaces: 9
NumEdges: 5
NumVertices: 5
model = createpde
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
model.Geometry = gm
model =
PDEModel with properties:
5-601
5 Functions — Alphabetical List
PDESystemSize: 1
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
pdegplot(model,'CellLabels','on','FaceAlpha',0.5)
5-602
multicylinder
Single Cylinder
Create a geometry that consists of a single cylinder and include this geometry in a PDE
model.
Use the multicylinder function to create a single cylinder. The resulting geometry
consists of one cell.
gm = multicylinder(5,10)
gm =
DiscreteGeometry with properties:
NumCells: 1
NumFaces: 3
NumEdges: 2
NumVertices: 2
model = createpde
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
model.Geometry = gm
model =
PDEModel with properties:
5-603
5 Functions — Alphabetical List
PDESystemSize: 1
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
pdegplot(model,'CellLabels','on')
5-604
multicylinder
Hollow Cylinder
Create a hollow cylinder by using the multicylinder function with the Void argument.
The resulting geometry consists of one cell.
gm = multicylinder([9 10],10,'Void',[true,false])
gm =
DiscreteGeometry with properties:
NumCells: 1
NumFaces: 4
NumEdges: 4
NumVertices: 4
model = createpde
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
model.Geometry = gm
model =
PDEModel with properties:
PDESystemSize: 1
5-605
5 Functions — Alphabetical List
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
pdegplot(model,'CellLabels','on','FaceAlpha',0.5)
5-606
multicylinder
Input Arguments
R — Cell radius
positive real number | vector of positive real numbers
Cell radius, specified as a positive real number or a vector of positive real numbers. If R is
a vector, then R(i) specifies the radius of the ith cell.
Radius R and height H can be scalars or vectors of the same length. For a combination of
scalar and vector inputs, multicylinder replicates the scalar arguments into vectors of
the same length.
Note Either radius or height must be the same for all cells in the geometry.
H — Cell height
positive real number | vector of positive real numbers
Cell height, specified as a positive real number or a vector of positive real numbers. If H is
a vector, then H(i) specifies the height of the ith cell.
Radius R and height H can be scalars or vectors of the same length. For a combination of
scalar and vector inputs, multicylinder replicates the scalar arguments into vectors of
the same length.
Note Either radius or height must be the same for all cells in the geometry.
5-607
5 Functions — Alphabetical List
Z-offset for each cell, specified as a vector of real numbers. ZOffset(i) specifies the Z-
offset of the ith cell. This vector must have the same length as the radius vector R or
height vector H.
Note The ZOffset argument is valid only if the radius is the same for all cells in the
geometry.
Empty cell indicator, specified as a vector of logical true or false values. This vector
must have the same length as the radius vector R or the height vector H.
The value true corresponds to an empty cell. By default, multicylinder assumes that
all cells are not empty.
Example: gm = multicylinder([1 2],1,'Void',[true,false])
Data Types: double
Output Arguments
gm — Geometry object
DiscreteGeometry object
Tip A cylinder has one cell, three faces, and two edges. Also, since every edge has a start
and an end vertex, a cylinder has vertices. Both edges are circles, their start and end
vertices coincide. Thus, a cylinder has two vertices - one for each edge.
5-608
multicylinder
Limitations
• multicylinder lets you create only geometries consisting of stacked or nested
cylinders. For nested cylinders, the height must be the same for all cells in the
geometry. For stacked cylinders, the radius must be the same for all cells in the
geometry. Use the ZOffset argument to stack the cells on top of each over without
overlapping them.
• multicylinder does not let you create nested cylinders of the same radius. The call
multicylinder(r,[h1,h2,...]) is not supported.
See Also
DiscreteGeometry | multicuboid | multisphere
Introduced in R2017a
5-609
5 Functions — Alphabetical List
multisphere
Create geometry formed by several spherical cells
Syntax
gm = multisphere(R)
gm = multisphere(R,'Void',eci)
Description
gm = multisphere(R) creates a geometry by combining several spherical cells.
When creating each sphere, multisphere uses the following coordinate system.
5-610
multisphere
Examples
Nested Spheres
Create a geometry that consists of three nested spheres and include this geometry in a
PDE model.
Create the geometry by using the multisphere function. The resulting geometry
consists of three cells.
gm = multisphere([5 10 15])
gm =
DiscreteGeometry with properties:
NumCells: 3
NumFaces: 3
NumEdges: 0
NumVertices: 0
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
model =
PDEModel with properties:
5-611
5 Functions — Alphabetical List
PDESystemSize: 1
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
5-612
multisphere
Single Sphere
Create a geometry that consists of a single sphere and include this geometry in a PDE
model.
Use the multisphere function to create a single sphere. The resulting geometry consists
of one cell.
gm = multisphere(5)
gm =
DiscreteGeometry with properties:
NumCells: 1
NumFaces: 1
NumEdges: 0
NumVertices: 0
model = createpde
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
model.Geometry = gm
model =
PDEModel with properties:
5-613
5 Functions — Alphabetical List
PDESystemSize: 1
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
pdegplot(model,'CellLabels','on')
5-614
multisphere
Hollow Sphere
Create a hollow sphere by using the multisphere function with the Void argument. The
resulting geometry consists of one cell.
gm = multisphere([9 10],'Void',[true,false])
gm =
DiscreteGeometry with properties:
NumCells: 1
NumFaces: 2
NumEdges: 0
NumVertices: 0
model = createpde
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
model.Geometry = gm
model =
PDEModel with properties:
PDESystemSize: 1
5-615
5 Functions — Alphabetical List
IsTimeDependent: 0
Geometry: [1x1 DiscreteGeometry]
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
Input Arguments
R — Cell radius
positive real number | vector of positive real numbers
Cell radius, specified as a positive real number or a vector of positive real numbers. If R is
a vector, then R(i) specifies the radius of the ith cell.
Example: gm = multisphere([1,2,3])
Empty cell indicator, specified as a vector of logical true and false values. This vector
must have the same length as the radius vector R.
The value true corresponds to an empty cell. By default, multisphere assumes that all
cells are not empty.
Example: gm = multisphere([1,2,3],'Void',[false,true,false])
Output Arguments
gm — Geometry object
DiscreteGeometry object
See Also
DiscreteGeometry | multicuboid | multicylinder
5-616
multisphere
Topics
“Heat Conduction in Multidomain Geometry with Nonuniform Heat Flux”
Introduced in R2017a
5-617
5 Functions — Alphabetical List
parabolic
(Not recommended) Solve parabolic PDE problem
Syntax
u = parabolic(u0,tlist,model,c,a,f,d)
u = parabolic(u0,tlist,b,p,e,t,c,a,f,d)
u = parabolic(u0,tlist,Kc,Fc,B,ud,M)
u = parabolic( ___ ,rtol)
u = parabolic( ___ ,rtol,atol)
u = parabolic( ___ ,'Stats','off')
Description
Parabolic equation solver
∂u
d − ∇ ⋅ c ∇u + au = f
∂t
∂u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t
The variables c, a, f, and d can depend on position, time, and the solution u and its
gradient.
∂u
d − ∇ ⋅ c ∇u + au = f
∂t
5-618
parabolic
∂u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t
with geometry, mesh, and boundary conditions specified in model, and with initial value
u0. The variables c, a, f, and d in the equation correspond to the function coefficients c, a,
f, and d respectively.
u = parabolic( ___ ,rtol) and u = parabolic( ___ ,rtol,atol), for any of the
previous input arguments, modify the solution process by passing to the ODE solver a
relative tolerance rtol, and optionally an absolute tolerance atol.
Examples
Parabolic Equation
∂u
= Δu
∂t
model = createpde;
geometryFromEdges(model,@squareg);
pdegplot(model,'EdgeLabels','on')
ylim([-1.1,1.1])
axis equal
5-619
5 Functions — Alphabetical List
2
Set the initial condition to have u(0) = 1 on the disk x2 + y2 ≤ 0 . 4 and u(0) = 0
elsewhere.
p = model.Mesh.Nodes;
u0 = zeros(size(p,2),1);
ix = find(sqrt(p(1,:).^2 + p(2,:).^2) <= 0.4);
u0(ix) = ones(size(ix));
5-620
parabolic
tlist = linspace(0,0.1,21);
c = 1;
a = 0;
f = 0;
d = 1;
u = parabolic(u0,tlist,model,c,a,f,d);
Plot the initial condition, the solution at the final time, and two intermediate solutions.
figure
subplot(2,2,1)
pdeplot(model,'XYData',u(:,1));
axis equal
title('t = 0')
subplot(2,2,2)
pdeplot(model,'XYData',u(:,5))
axis equal
title('t = 0.02')
subplot(2,2,3)
pdeplot(model,'XYData',u(:,11))
axis equal
title('t = 0.05')
subplot(2,2,4)
pdeplot(model,'XYData',u(:,end))
axis equal
title('t = 0.1')
5-621
5 Functions — Alphabetical List
∂u
= Δu
∂t
on the square domain specified by squareg, using a geometry function to specify the
geometry, a boundary function to specify the boundary conditions, and using initmesh to
create the finite element mesh.
5-622
parabolic
Set Dirichlet boundary conditions u = 0 on all edges. The squareb1 function specifies
these boundary conditions.
b = @squareb1;
5-623
5 Functions — Alphabetical List
2
Set the initial condition to have u(0) = 1 on the disk x2 + y2 ≤ 0 . 4 and u(0) = 0
elsewhere.
u0 = zeros(size(p,2),1);
ix = find(sqrt(p(1,:).^2 + p(2,:).^2) <= 0.4);
u0(ix) = ones(size(ix));
tlist = linspace(0,0.1,21);
c = 1;
a = 0;
f = 0;
d = 1;
u = parabolic(u0,tlist,b,p,e,t,c,a,f,d);
Plot the initial condition, the solution at the final time, and two intermediate solutions.
figure
subplot(2,2,1)
pdeplot(p,e,t,'XYData',u(:,1));
axis equal
title('t = 0')
subplot(2,2,2)
pdeplot(p,e,t,'XYData',u(:,5))
axis equal
title('t = 0.02')
subplot(2,2,3)
pdeplot(p,e,t,'XYData',u(:,11))
axis equal
title('t = 0.05')
subplot(2,2,4)
5-624
parabolic
pdeplot(p,e,t,'XYData',u(:,end))
axis equal
title('t = 0.1')
Create finite element matrices that encode a parabolic problem, and solve the problem.
5-625
5 Functions — Alphabetical List
model = createpde(1);
importGeometry(model,'Block.stl');
handl = pdegplot(model,'FaceLabels','on');
view(-42,24)
handl(1).FaceAlpha = 0.5;
Faces 1, 4, and 6 of the slab are kept at 0 degrees. The other faces are insulated. Include
the boundary condition on faces 1, 4, and 6. You do not need to include the boundary
condition on the other faces because the default condition is insulated.
applyBoundaryCondition(model,'dirichlet','Face',[1,4,6],'u',0);
5-626
parabolic
−3
u0 = 10 xyz .
generateMesh(model);
p = model.Mesh.Nodes;
x = p(1,:);
y = p(2,:);
z = p(3,:);
u0 = x.*y.*z*1e-3;
∂u
d − ∇ ⋅ (c ∇u) + au = f .
∂t
Suppose the thermal conductivity of the block leads to a c coefficient value of 1. The
values of the other coefficients in this problem are d = 1, a = 0, and f = 0.
d = 1;
c = 1;
a = 0;
f = 0;
Solve the problem at time steps of 1 for times ranging from 0 to 40.
tlist = linspace(0,40,41);
u = parabolic(u0,tlist,Kc,Fc,B,ud,M);
35 successful steps
0 failed attempts
72 function evaluations
1 partial derivatives
11 LU decompositions
71 solutions of linear systems
Plot the solution on the outside of the block at times 0, 10, 25, and 40. Ensure that the
coloring is the same for all plots.
umin = min(min(u));
umax = max(max(u));
subplot(2,2,1)
5-627
5 Functions — Alphabetical List
pdeplot3D(model,'ColorMapData',u(:,1))
colorbar off
view(125,22)
title 't = 0'
caxis([umin umax]);
subplot(2,2,2)
pdeplot3D(model,'ColorMapData',u(:,11))
colorbar off
view(125,22)
title 't = 10'
caxis([umin umax]);
subplot(2,2,3)
pdeplot3D(model,'ColorMapData',u(:,26))
colorbar off
view(125,22)
title 't = 25'
caxis([umin umax]);
subplot(2,2,4)
pdeplot3D(model,'ColorMapData',u(:,41))
colorbar off
view(125,22)
title 't = 40'
caxis([umin umax]);
5-628
parabolic
Input Arguments
u0 — Initial condition
vector | character vector | character array | string scalar | string vector
Initial condition, specified as a scalar, vector of nodal values, character vector, character
array, string scalar, or string vector. The initial condition is the value of the solution u at
the initial time, specified as a column vector of values at the nodes. The nodes are either
p in the [p,e,t] data structure, or are model.Mesh.Nodes.
5-629
5 Functions — Alphabetical List
char('x.^2 + 5*cos(x.*y)',...
'tanh(x.*y)./(1+z.^2)')
Example: x.^2+5*cos(y.*x)
Data Types: double | char | string
Complex Number Support: Yes
Solution times, specified as a real vector. The solver returns the solution to the PDE at the
solution times.
Example: 0:0.2:4
Data Types: double
c — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. c represents the c coefficient in the scalar
PDE
∂u
d − ∇ ⋅ c ∇u + au = f
∂t
5-630
parabolic
∂u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t
Example: 'cosh(x+y.^2)'
Data Types: double | char | string | function_handle
Complex Number Support: Yes
a — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. a represents the a coefficient in the scalar
PDE
∂u
d − ∇ ⋅ c ∇u + au = f
∂t
∂u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t
Example: 2*eye(3)
Data Types: double | char | string | function_handle
Complex Number Support: Yes
f — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. f represents the f coefficient in the scalar
PDE
∂u
d − ∇ ⋅ c ∇u + au = f
∂t
5-631
5 Functions — Alphabetical List
∂u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t
Example: char('sin(x)';'cos(y)';'tan(z)')
Data Types: double | char | string | function_handle
Complex Number Support: Yes
d — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. d represents the d coefficient in the scalar
PDE
∂u
d − ∇ ⋅ c ∇u + au = f
∂t
∂u
d − ∇ ⋅ c ⊗ ∇u + au = f
∂t
Example: 2*eye(3)
Data Types: double | char | string | function_handle
Complex Number Support: Yes
b — Boundary conditions
boundary matrix | boundary file
Boundary conditions, specified as a boundary matrix or boundary file. Pass a boundary file
as a function handle or as a file name. A boundary matrix is generally an export from the
PDE Modeler app.
Example: b = 'circleb1', b = "circleb1", or b = @circleb1
Data Types: double | char | string | function_handle
p — Mesh points
matrix
Mesh points, specified as a 2-by-Np matrix of points, where Np is the number of points in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
5-632
parabolic
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
e — Mesh edges
matrix
Mesh edges, specified as a 7-by-Ne matrix of edges, where Ne is the number of edges in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
t — Mesh triangles
matrix
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
Kc — Stiffness matrix
sparse matrix | full matrix
Stiffness matrix, specified as a sparse matrix or as a full matrix. See “Elliptic Equations”
on page 5-79. Typically, Kc is the output of assempde.
Fc — Load vector
vector
Load vector, specified as a vector. See “Elliptic Equations” on page 5-79. Typically, Fc is
the output of assempde.
5-633
5 Functions — Alphabetical List
B — Dirichlet nullspace
sparse matrix
Dirichlet nullspace, returned as a sparse matrix. See “Algorithms” on page 5-79. Typically,
B is the output of assempde.
ud — Dirichlet vector
vector
Dirichlet vector, returned as a vector. See “Algorithms” on page 5-79. Typically, ud is the
output of assempde.
M — Mass matrix
sparse matrix | full matrix
Mass matrix. specified as a sparse matrix or a full matrix. See “Elliptic Equations” on
page 5-79.
To obtain the input matrices for pdeeig, hyperbolic or parabolic, run both assema
and assempde:
[Kc,Fc,B,ud] = assempde(model,c,a,f);
[~,M,~] = assema(model,0,d,f);
Note Create the M matrix using assema with d, not a, as the argument before f.
5-634
parabolic
Example: 2e-7
Data Types: double
Output Arguments
u — PDE solution
matrix
PDE solution, returned as a matrix. The matrix is Np*N-by-T, where Np is the number of
nodes in the mesh, N is the number of equations in the PDE (N = 1 for a scalar PDE), and
T is the number of solution times, meaning the length of tlist. The solution matrix has
the following structure.
• The first Np elements of each column in u represent the solution of equation 1, then
next Np elements represent the solution of equation 2, etc. The solution u is the value
at the corresponding node in the mesh.
• Column i of u represents the solution at time tlist(i).
To plot the solution, use pdeplot for 2-D geometry, or see “Plot 3-D Solutions and Their
Gradients” on page 3-325.
Algorithms
Reducing Parabolic Equations to Elliptic Equations
parabolic internally calls assema, assemb, and assempde to create finite element
matrices corresponding to the problem. It calls ode15s to solve the resulting system of
ordinary differential equations.
∂2 u ∂u
m +d − ∇ · c ∇u + au = f
∂t2 ∂t
When the m coefficient is 0, but d is not, the documentation refers to the equation as
parabolic, whether or not it is mathematically in parabolic form.
5-635
5 Functions — Alphabetical List
∂u
d − ∇ ⋅ c ∇u + au = f in Ω
∂t
where x represents a 2-D or 3-D point and there are boundary conditions of the same kind
as for the elliptic equation on ∂Ω.
∂u
ρC − ∇ · k ∇u + h u − u∞ = f
∂t
in the presence of distributed heat loss to the surroundings. ρ is the density, C is the
thermal capacity, k is the thermal conductivity, h is the film coefficient, u∞ is the ambient
temperature, and f is the heat source.
For time-independent coefficients, the steady-state solution of the equation is the solution
to the standard elliptic equation
–∇ · (c∇u) + au = f.
Assuming a mesh on Ω and t ≥ 0, expand the solution to the PDE (as a function of x) in
the Finite Element Method basis:
u(x, t) = ∑ Ui(t)ϕi(x)
i
Plugging the expansion into the PDE, multiplying with a test function ϕj, integrating over
Ω, and applying Green's formula and the boundary conditions yield
dUi t
∑ ∫ dϕ jϕi dt
dx + ∑ ∫ ∇ϕ ⋅ c ∇ϕ
j i + aϕ jϕi dx + ∫ qϕ ϕ ds U (t)
j i i
i Ω i Ω ∂Ω
= ∫ f ϕ dx + ∫ gϕ ds
Ω
j
∂Ω
j ∀j
In matrix notation, we have to solve the linear, large and sparse ODE system
5-636
parabolic
dU
M + KU = F
dt
Ui(0) = u0(xi)
yields the solution to the PDE at each node xi and time t. Note that K and F are the
stiffness matrix and the right-hand side of the elliptic problem
–∇ · (c∇u) + au = f in Ω
with the original boundary conditions, while M is just the mass matrix of the problem
–∇ · (0∇u) + du = 0 in Ω.
When the Dirichlet conditions are time dependent, F contains contributions from time
derivatives of h and r. These derivatives are evaluated by finite differences of the user-
specified data.
The ODE system is ill conditioned. Explicit time integrators are forced by stability
requirements to very short time steps while implicit solvers can be expensive since they
solve an elliptic problem at every time step. The numerical integration of the ODE system
is performed by the MATLAB ODE Suite functions, which are efficient for this class of
problems. The time step is controlled to satisfy a tolerance on the error, and factorizations
of coefficient matrices are performed only when necessary. When coefficients are time
dependent, the necessity of reevaluating and refactorizing the matrices each time step
may still make the solution time consuming, although parabolic reevaluates only that
which varies with time. In certain cases a time-dependent Dirichlet matrix h(t) may cause
the error control to fail, even if the problem is mathematically sound and the solution u(t)
is smooth. This can happen because the ODE integrator looks only at the reduced solution
v with u = Bv + ud. As h changes, the pivoting scheme employed for numerical stability
may change the elimination order from one step to the next. This means that B, v, and ud
all change discontinuously, although u itself does not.
See Also
solvepde
5-637
5 Functions — Alphabetical List
5-638
pdeadgsc
pdeadgsc
(Not recommended) Select triangles using relative tolerance criterion
Syntax
bt = pdeadgsc(p,t,c,a,f,u,errf,tol)
Description
bt = pdeadgsc(p,t,c,a,f,u,errf,tol) returns indices of triangles to be refined in
bt. Used from adaptmesh to select the triangles to be further refined. The geometry of
the PDE problem is given by the mesh data p and t. For more details, see “Mesh Data” on
page 2-171.
Triangles are selected using the criterion errf>tol*scale, where scale is calculated
as follows:
Let cmax, amax, fmax, and umax be the maximum of c, a, f, and u, respectively. Let l be
the side of the smallest axis-aligned square that contains the geometry.
5-639
5 Functions — Alphabetical List
See Also
generateMesh
5-640
pdeadworst
pdeadworst
(Not recommended) Select triangles relative to worst value
Syntax
bt = pdeadworst(p,t,c,a,f,u,errf,wlevel)
Description
bt = pdeadworst(p,t,c,a,f,u,errf,wlevel) returns indices of triangles to be
refined in bt. Used from adaptmesh to select the triangles to be further refined.
The geometry of the PDE problem is given by the mesh data p and t. For details, see
“Mesh Data” on page 2-171.
wlevel is the error level relative to the worst error. wlevel must be between 0 and 1.
See Also
generateMesh
5-641
5 Functions — Alphabetical List
pdearcl
Interpolation between parametric representation and arc length
Syntax
pp = pdearcl(p,xy,s,s0,s1)
Description
pp = pdearcl(p,xy,s,s0,s1) returns parameter values for a parametrized curve
corresponding to a given set of arc length values.
p is a monotone row vector of parameter values and xy is a matrix with two rows giving
the corresponding points on the curve.
The first point of the curve is given the arc length value s0 and the last point the value
s1.
On return, pp contains parameter values corresponding to the arc length values specified
in s.
The arc length values s, s0, and s1 can be an affine transformation of the arc length.
5-642
pdecgrad
pdecgrad
(Not recommended) Flux of PDE solution
Syntax
[cgxu,cgyu] = pdecgrad(p,t,c,u)
[cgxu,cgyu] = pdecgrad(p,t,c,u,time)
[cgxu,cgyu] = pdecgrad(p,t,c,u,time,sdl)
Description
[cgxu,cgyu] = pdecgrad(p,t,c,u) returns the flux, c ⊗ ∇u, evaluated at the center
of each triangle.
There is one column for each triangle in t in both cgxu and cgyu.
The gradient computed by pdegrad is actually the same everywhere in the triangle
interior because pdegrad uses only linear basis functions. The boundaries of triangles
are a special case: here the derivatives might be discontinuous. However, the flux c ⊗ ∇u
can vary inside a triangle because the coefficient c can vary.
5-643
5 Functions — Alphabetical List
The geometry of the PDE problem is given by the mesh data p and t. Details on the mesh
data representation can be found in the entry on initmesh.
The scalar optional argument time is used for parabolic and hyperbolic problems, if c
depends on t, the time.
The optional argument sdl restricts the computation to the subdomains in the list sdl.
See Also
evaluateCGradient | evaluateGradient
5-644
pdecirc
pdecirc
Package: pde
Syntax
pdecirc(xc,yc,R)
pdecirc(xc,yc,R,label)
Description
pdecirc(xc,yc,R) draws a circle with the center at (xc,yc) and the radius R. The
pdecirc command opens the PDE Modeler app with the specified circle already drawn in
it. If the app is already open, pdecirc adds the specified circle to the app window
without deleting any existing shapes.
pdecirc updates the state of the geometry description matrix inside the PDE Modeler
app to include the circle. You can export the geometry description matrix from the PDE
Modeler app to the MATLAB Workspace by selecting DrawExport Geometry
Description, Set Formula, Labels.... For details on the format of the geometry
description matrix, see decsg.
Examples
Open the PDE Modeler app window containing a circle with the center at (0,0) and the
radius 1.
pdecirc(0,0,1)
5-645
5 Functions — Alphabetical List
Call the pdecirc command again to draw a circle with the center at (0,0.25) and the
radius 0.5. The pdecirc command adds the second circle to the app window without
deleting the first.
pdecirc(0,0.25,0.5)
5-646
pdecirc
5-647
5 Functions — Alphabetical List
Open the PDE Modeler app window containing a circle with the center at (0,0) and the
radius 1. Assign the name circle1 to this circle.
pdecirc(0,0,1,'circle1')
5-648
pdecirc
5-649
5 Functions — Alphabetical List
Input Arguments
xc — x-coordinate of center
real number
yc — y-coordinate of center
real number
R — Radius
positive number
label — Name
character vector | string scalar
Tips
pdecirc opens the PDE Modeler app and draws a circle. If, instead, you want to draw
circles in a MATLAB figure window, choose one of these approaches:
t = linspace(0,2*pi);
plot(cos(t),sin(t))
• Use the rectangle function with the Curvature name-value pair set to [1 1].
• Use the Image Processing Toolbox™ viscircles function.
5-650
pdecirc
See Also
PDE Modeler | pdeellip | pdepoly | pderect
5-651
5 Functions — Alphabetical List
pdecont
Shorthand command for contour plot
Note This page describes the legacy workflow. New features might not be compatible
with the legacy workflow.
Syntax
pdecont(p,t,u)
pdecont(p,t,u,n)
pdecont(p,t,u,v)
h = pdecont(p,t,u)
h = pdecont(p,t,u,n)
h = pdecont(p,t,u,v)
Description
pdecont(p,t,u) draws 10 level curves of the PDE node or triangle data u. h =
pdecont(p,t,u) additionally returns handles to the drawn axes objects.
The geometry of the PDE problem is given by the mesh data p and t. For details on the
mesh data representation, see “Mesh Data” on page 2-171.
5-652
pdecont
pdeplot(p,[],t,'XYData',u,'XYStyle','off','Contour',...
'on','Levels',n,'ColorBar','off');
If you want to have more control over your contour plot, use pdeplot instead of
pdecont.
Examples
Plot the contours of the solution to the equation −Δu = 1 over the geometry defined by
the L-shaped membrane. Use Dirichlet boundary conditions u = 0 on ∂Ω.
[p,e,t] = initmesh('lshapeg');
[p,e,t] = refinemesh('lshapeg',p,e,t);
u = assempde('lshapeb',p,e,t,1,0,1);
pdecont(p,t,u)
5-653
5 Functions — Alphabetical List
See Also
pdemesh | pdeplot | pdesurf
5-654
pdeeig
pdeeig
(Not recommended) Solve eigenvalue PDE problem
Syntax
[v,l] = pdeeig(model,c,a,d,r)
[v,l] = pdeeig(b,p,e,t,c,a,d,r)
[v,l] = pdeeig(Kc,B,M,r)
Description
[v,l] = pdeeig(model,c,a,d,r) produces the solution to the FEM formulation of
the scalar PDE eigenvalue problem
− ∇ ⋅ (c ∇u) + au = λdu on Ω
− ∇ ⋅ (c ⊗ ∇u) + au = λdu on Ω
with geometry, boundary conditions, and mesh specified in model, a PDEModel object.
The eigenvalue PDE problem is a homogeneous problem, i.e., only boundary conditions
where g = 0 and r = 0 can be used. The nonhomogeneous part is removed automatically.
Kc ui = λB´MBui
u = Bui
5-655
5 Functions — Alphabetical List
Examples
Compute the eigenvalues that are less than 100, and compute the corresponding
eigenmodes for − ∇u = λu on the geometry of the L-shaped membrane.
model = createpde;
geometryFromEdges(model,@lshapeg);
applyBoundaryCondition(model,'edge',1:model.Geometry.NumEdges,'u',0);
generateMesh(model,'GeometricOrder','linear','Hmax',0.02);
c = 1;
a = 0;
d = 1;
r = [-Inf 100];
[v,l] = pdeeig(model,c,a,d,r);
5-656
pdeeig
ans = 9.6506
Display the first eigenmode, and compare it to the built-in membrane plot.
pdeplot(model,'XYData',v(:,1),'ZData',v(:,1))
5-657
5 Functions — Alphabetical List
figure
membrane(1,20,9,9) % the MATLAB function
5-658
pdeeig
ans = 92.5248
figure
pdeplot(model,'XYData',v(:,16),'ZData',v(:,16)) % sixteenth eigenmode
5-659
5 Functions — Alphabetical List
Compute the eigenvalues that are less than 100, and compute the corresponding
eigenmodes for − ∇u = λu on the geometry of the L-shaped membrane, using the legacy
syntax.
Use the geometry in lshapeg. For more information about this syntax, see “Parametrized
Function for 2-D Geometry Creation” on page 2-12.
g = @lshapeg;
pdegplot(g,'EdgeLabels','on')
5-660
pdeeig
axis equal
ylim([-1.1,1.1])
5-661
5 Functions — Alphabetical List
[p,e,t] = initmesh(g,'Hmax',0.02);
[v,l] = pdeeig(b,p,e,t,c,a,d,r);
5-662
pdeeig
l(1)
ans = 9.6481
Import a simple 3-D geometry and find eigenvalues and eigenvectors from the associated
finite element matrices.
model = createpde();
importGeometry(model,'BracketWithHole.stl');
figure
pdegplot(model,'FaceLabels','on')
view(30,30)
title('Bracket with Face Labels')
5-663
5 Functions — Alphabetical List
figure
pdegplot(model,'FaceLabels','on')
view(-134,-32)
title('Bracket with Face Labels, Rear View')
5-664
pdeeig
Set coefficients c = 1, a = 0, and d = 1. Collect eigenvalues that are less than 100.
c = 1;
a = 0;
d = 1;
r = [-Inf 100];
5-665
5 Functions — Alphabetical List
[v,l] = pdeeig(Kc,B,M,r);
l([1,2])
ans = 2×1
0.0000
42.8670
pdeplot3D(model,'ColorMapData',v(:,2))
5-666
pdeeig
Input Arguments
model — PDE model
PDEModel object
c — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
5-667
5 Functions — Alphabetical List
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. c represents the c coefficient in the scalar
PDE
− ∇ ⋅ (c ∇u) + au = λdu on Ω
− ∇ ⋅ (c ⊗ ∇u) + au = λdu on Ω
Example: 'cosh(x+y.^2)'
Data Types: double | char | string | function_handle
Complex Number Support: Yes
a — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. a represents the a coefficient in the scalar
PDE
− ∇ ⋅ (c ∇u) + au = λdu on Ω
− ∇ ⋅ (c ⊗ ∇u) + au = λdu on Ω
Example: 2*eye(3)
Data Types: double | char | string | function_handle
Complex Number Support: Yes
d — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. d represents the d coefficient in the scalar
PDE
− ∇ ⋅ (c ∇u) + au = λdu on Ω
5-668
pdeeig
− ∇ ⋅ (c ⊗ ∇u) + au = λdu on Ω
Example: 2*eye(3)
Data Types: double | char | string | function_handle
Complex Number Support: Yes
r — Eigenvalue range
two-element real vector
Eigenvalue range, specified as a two-element real vector. Real parts of eigenvalues λ fall
in the range r(1) ≤ λ ≤ r(2). r(1) can be -Inf. The algorithm returns all eigenvalues
in this interval in the l output, up to a maximum of 99 eigenvalues.
Example: [-Inf,100]
Data Types: double
b — Boundary conditions
boundary matrix | boundary file
Boundary conditions, specified as a boundary matrix or boundary file. Pass a boundary file
as a function handle or as a file name. A boundary matrix is generally an export from the
PDE Modeler app.
Example: b = 'circleb1', b = "circleb1", or b = @circleb1
Data Types: double | char | string | function_handle
p — Mesh points
matrix
Mesh points, specified as a 2-by-Np matrix of points, where Np is the number of points in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
e — Mesh edges
matrix
5-669
5 Functions — Alphabetical List
Mesh edges, specified as a 7-by-Ne matrix of edges, where Ne is the number of edges in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
t — Mesh triangles
matrix
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
Kc — Stiffness matrix
sparse matrix | full matrix
Stiffness matrix, specified as a sparse matrix or as a full matrix. See “Elliptic Equations”
on page 5-79. Typically, Kc is the output of assempde.
B — Dirichlet nullspace
sparse matrix
Dirichlet nullspace, returned as a sparse matrix. See “Algorithms” on page 5-79. Typically,
B is the output of assempde.
M — Mass matrix
sparse matrix | full matrix
Mass matrix. specified as a sparse matrix or a full matrix. See “Elliptic Equations” on
page 5-79.
To obtain the input matrices for pdeeig, hyperbolic or parabolic, run both assema
and assempde:
5-670
pdeeig
[Kc,Fc,B,ud] = assempde(model,c,a,f);
[~,M,~] = assema(model,0,d,f);
Note Create the M matrix using assema with d, not a, as the argument before f.
Output Arguments
v — Eigenvectors
matrix
Then v has size Np*N-by-ev. Each column of v corresponds to the eigenvectors of one
eigenvalue. In each column, the first Np elements correspond to the eigenvector of
equation 1 evaluated at the mesh nodes, the next Np elements correspond to equation 2,
etc.
l — Eigenvalues
vector
Eigenvalues, returned as a vector. The real parts of l are in the interval r. The real parts
of l are monotone increasing.
5-671
5 Functions — Alphabetical List
Limitations
In the standard case c and d are positive in the entire region. All eigenvalues are positive,
and 0 is a good choice for a lower bound of the interval. The cases where either c or d is
zero are discussed next.
• If d = 0 in a subregion, the mass matrix M becomes singular. This does not cause any
trouble, provided that c > 0 everywhere. The pencil (K,M) has a set of infinite
eigenvalues.
• If c = 0 in a subregion, the stiffness matrix K becomes singular, and the pencil (K,M)
has many zero eigenvalues. With an interval containing zero, pdeeig goes on for a
very long time to find all the zero eigenvalues. Choose a positive lower bound away
from zero but below the smallest nonzero eigenvalue.
• If there is a region where both c = 0 and d = 0, we get a singular pencil. The whole
eigenvalue problem is undetermined, and any value is equally plausible as an
eigenvalue.
Some of the awkward cases are detected by pdeeig. If the shifted matrix is singular,
another shift is attempted. If the matrix with the new shift is still singular a good guess is
that the entire pencil (K,M) is singular.
If you try any problem not belonging to the standard case, you must use your knowledge
of the original physical problem to interpret the results from the computation.
Tips
• The equation coefficients cannot depend on the solution u or its gradient.
Algorithms
Eigenvalue Equations
Partial Differential Equation Toolbox software handles the following basic eigenvalue
problem:
− ∇ ⋅ c ∇u + au = λdu
5-672
pdeeig
The numerical solution is found by discretizing the equation and solving the resulting
algebraic eigenvalue problem. Let us first consider the discretization. Expand u in the
FEM basis, multiply with a basis element, and integrate on the domain Ω. This yields the
generalized eigenvalue equation
KU = λMU
The matrices K and M are produced by calling assema for the equations
In the most common case, when the function d(x) is positive, the mass matrix M is
positive definite symmetric. Likewise, when c(x) is positive and we have Dirichlet
boundary conditions, the stiffness matrix K is also positive definite.
The generalized eigenvalue problem, KU = λMU, is now solved by the Arnoldi algorithm
applied to a shifted and inverted matrix with restarts until all eigenvalues in the user-
specified interval have been found.
Let us describe how this is done in more detail. You may want to look at the examples
“Eigenvalues and Eigenmodes of L-Shaped Membrane” on page 3-287 or “Eigenvalues
and Eigenmodes of Square” on page 3-299, where actual runs are reported.
First a shift µ is determined close to where we want to find the eigenvalues. When both K
and M are positive definite, it is natural to take µ = 0, and get the smallest eigenvalues; in
other cases take any point in the interval [lb,ub] where eigenvalues are sought. Subtract
µM from the eigenvalue equation and get (K - µM)U = (λ - µ)MU. Then multiply with the
inverse of this shifted matrix and get
1 −1
U = K − μM MU
λ−μ
5-673
5 Functions — Alphabetical List
This is a standard eigenvalue problem AU = θU, with the matrix A = (K – µM)-1M and
eigenvalues
1
θi =
λi − μ
The Arnoldi algorithm computes an orthonormal basis V where the shifted and inverted
operator A is represented by a Hessenberg matrix H,
(The subscripts mean that Vj and Ej have j columns and Hj,j has j rows and columns. When
no subscripts are used we deal with vectors and matrices of size n.)
Some of the eigenvalues of this Hessenberg matrix Hj,j eventually give good
approximations to the eigenvalues of the original pencil (K,M) when the basis grows in
dimension j, and less and less of the eigenvector is hidden in the residual matrix Ej.
The basis V is built one column vj at a time. The first vector v1 is chosen at random, as n
normally distributed random numbers. In step j, the first j vectors are already computed
and form the n ×j matrix Vj. The next vector vj+1 is computed by first letting A operate on
the newest vector vj, and then making the result orthogonal to all the previous vectors.
AV j = V jH j, j + v j + 1h j + 1, jeTj
where Hj,j is a j×j Hessenberg matrix with the vectors hj as columns. The second term on
the right-hand side has nonzeros only in the last column; the earlier normalization factors
show up in the subdiagonal of Hj,j.
The eigensolution of the small Hessenberg matrix H gives approximations to some of the
eigenvalues and eigenvectors of the large matrix operator Aj,j in the following way.
Compute eigenvalues θi and eigenvectors si of Hj,j,
5-674
pdeeig
This residual has to be small in norm for θi to be a good eigenvalue approximation. The
norm of the residual is
ri = h j + 1, js j, i
the product of the last subdiagonal element of the Hessenberg matrix and the last
element of its eigenvector. It seldom happens that hj+1,j gets particularly small, but after
sufficiently many steps j there are always some eigenvectors si with small last elements.
The long vector Vj+1 is of unit norm.
It is not necessary to actually compute the eigenvector approximation yi to get the norm
of the residual; we only need to examine the short vectors si, and flag those with tiny last
components as converged. In a typical case n may be 2000, while j seldom exceeds 50, so
all computations that involve only matrices and vectors of size j are much cheaper than
those involving vectors of length n.
This eigenvalue computation and test for convergence is done every few steps j, until all
approximations to eigenvalues inside the interval [lb,ub] are flagged as converged. When
n is much larger than j, this is done very often, for smaller n more seldom. When all
eigenvalues inside the interval have converged, or when j has reached a prescribed
maximum, the converged eigenvectors, or more appropriately Schur vectors, are
computed and put in the front of the basis V.
After this, the Arnoldi algorithm is restarted with a random vector, if all approximations
inside the interval are flagged as converged, or else with the best unconverged
approximate eigenvector yi. In each step j of this second Arnoldi run, the vector is made
orthogonal to all vectors in V including the converged Schur vectors from the previous
runs. This way, the algorithm is applied to a projected matrix, and picks up a second copy
of any double eigenvalue there may be in the interval. If anything in the interval
converges during this second run, a third is attempted and so on, until no more
approximate eigenvalues θi show up inside. Then the algorithm signals convergence. If
there are still unconverged approximate eigenvalues after a prescribed maximum number
of steps, the algorithm signals nonconvergence and reports all solutions it has found.
This is a heuristic strategy that has worked well on both symmetric, nonsymmetric, and
even defective eigenvalue problems. There is a tiny theoretical chance of missing an
eigenvalue, if all the random starting vectors happen to be orthogonal to its eigenvector.
5-675
5 Functions — Alphabetical List
The shifted and inverted matrix A = (K – µM)–1M is needed only to operate on a vector vj
in the Arnoldi algorithm. This is done by computing an LU factorization,
P(K – µM)Q = LU
using the sparse MATLAB command lu (P and Q are permutations that make the
triangular factors L and U sparse and the factorization numerically stable). This
factorization needs to be done only once, in the beginning, then x = Avj is computed as,
x = QU–1L–1PMvj
with one sparse matrix vector multiplication, a permutation, sparse forward- and back-
substitutions, and a final renumbering.
See Also
solvepdeeig
5-676
pdeellip
pdeellip
Package: pde
Syntax
pdeellip(xc,yc,a,b,phi)
pdeellip(xc,yc,a,b,phi,label)
Description
pdeellip(xc,yc,a,b,phi) draws an ellipse with the center at (xc,yc), the semiaxes a
and b, and the rotation phi (in radians). The pdeellip command opens the PDE Modeler
app with the specified ellipse drawn in it. If the app is already open, pdeellip adds the
specified ellipse to the app window without deleting any existing shapes.
pdeellip updates the state of the geometry description matrix inside the PDE Modeler
app to include the ellipse. You can export the geometry description matrix from the PDE
Modeler app to the MATLAB Workspace by selecting DrawExport Geometry
Description, Set Formula, Labels.... For details on the format of the geometry
description matrix, see decsg.
Examples
Open the PDE Modeler app window containing an ellipse with the center at (0,0) and the
semiaxes 1 and 0.3. Rotate the ellipse by π/4 counterclockwise.
pdeellip(0,0,1,0.3,pi/4)
5-677
5 Functions — Alphabetical List
Call the pdeellip command again to draw an ellipse with the same center and semiaxes,
but rotate it by π/2 counterclockwise. The pdeellip command adds the second ellipse to
the app window without deleting the first.
pdeellip(0,0,1,0.3,pi/2)
5-678
pdeellip
5-679
5 Functions — Alphabetical List
Open the PDE Modeler app window containing an ellipse with the center at (0,0) and the
semiaxes 1 and 0.3. Rotate the ellipse by π/4 counterclockwise. Assign the name
ellipse1 to this ellipse.
pdeellip(0,0,1,0.3,pi/4,'ellipse1')
5-680
pdeellip
5-681
5 Functions — Alphabetical List
Input Arguments
xc — x-coordinate of center
real number
yc — y-coordinate of center
real number
a — Semiaxis
positive number
b — Semiaxis
positive number
phi — Rotation
real number
Rotation of the ellipse, specified as a real number. The rotation value is measured in
radians.
Data Types: double
label — Name
character vector | string scalar
5-682
pdeellip
See Also
PDE Modeler | pdecirc | pdepoly | pderect
5-683
5 Functions — Alphabetical List
pdeent
Indices of triangles neighboring given set of triangles
Note This page describes the legacy workflow. New features might not be compatible
with the legacy workflow. For the corresponding step in the recommended workflow, see
generateMesh.
Syntax
ntl = pdeent(t,tl)
Description
Given triangle data t and a list of triangle indices tl, ntl contains indices of the
triangles in tl and their immediate neighbors, i.e., those whose intersection with tl is
nonempty.
See Also
generateMesh
5-684
pdegplot
pdegplot
Plot PDE geometry
Syntax
pdegplot(g)
pdegplot(g,Name,Value)
h = pdegplot( ___ )
Description
pdegplot(g) plots the geometry of a PDE problem, as described in g.
h = pdegplot( ___ ) returns handles to the graphics, using any of the previous
syntaxes.
Examples
g = [2 1 1 1 1 1 1 1 1 4 4;
-1 -0.6 -0.5 -0.4 -0.5 0.4 0.5 0.6 0.5 -1 0.17;
1 -0.5 -0.4 -0.5 -0.6 0.5 0.6 0.5 0.4 0.17 1;
0 -0.25 -0.35 -0.25 -0.15 -0.25 -0.35 -0.25 -0.15 0 -0.74;
0 -0.35 -0.25 -0.15 -0.25 -0.35 -0.25 -0.15 -0.25 -0.74 0;
0 0 0 0 0 0 0 0 0 1 1;
1 1 1 1 1 1 1 1 1 0 0;
0 -0.5 -0.5 -0.5 -0.5 0.5 0.5 0.5 0.5 0 0;
0 -0.25 -0.25 -0.25 -0.25 -0.25 -0.25 -0.25 -0.25 0 0;
5-685
5 Functions — Alphabetical List
View the vertex labels, edge labels, and the face label. Add space at the top of the plot to
see the top edge clearly.
pdegplot(g,'VertexLabels','on','EdgeLabels','on','FaceLabels','on')
ylim([-.8,.1])
5-686
pdegplot
Import a 3-D geometry file. Plot the geometry and turn on face labels. To see the labels on
all faces of the geometry, set the transparency to 0.5.
model = createpde;
importGeometry(model,'BracketWithHole.stl');
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
5-687
5 Functions — Alphabetical List
Import a 3-D geometry file. Plot the geometry and turn on cell labels.
model = createpde;
importGeometry(model,'DampingMounts.stl');
pdegplot(model,'CellLabels','on')
5-688
pdegplot
Input Arguments
g — Geometry description
PDEModel object | output of decsg | decomposed geometry matrix | name of geometry
file | function handle to geometry file
• PDEModel object
• Output of decsg
5-689
5 Functions — Alphabetical List
The argument SubdomainLabels is not recommended. Use FaceLabels for both 2-D
and 3-D geometries instead.
Example: pdegplot(g,'FaceLabels','on')
Boundary edge labels for 2-D or 3-D geometry, specified as 'off' or 'on'.
Example: 'EdgeLabels','on'
Data Types: char | string
Boundary face labels for 2-D or 3-D geometry, specified as 'off' or 'on'.
5-690
pdegplot
Example: 'FaceLabels','on'
Data Types: char | string
Surface transparency for 3-D geometry, specified as the comma-separated pair consisting
of 'FaceAlpha' and a real number from 0 through 1. The default value 1 indicates no
transparency. The value 0 indicates complete transparency.
Example: 'FaceAlpha',0.5
Data Types: double
Output Arguments
h — Handles to graphics objects
vector
Alternative Functionality
App
If you create 2-D geometry in the PDE Modeler app, you can view the geometry from
Boundary Mode. To see the edge labels, select Boundary > Show Edge Labels. To see
the face labels, select PDE > Show Subdomain Labels.
5-691
5 Functions — Alphabetical List
See Also
PDE Modeler | decsg | importGeometry | wgeom
Topics
“Create Geometry and Remove Face Boundaries” on page 2-8
“STL File Import” on page 2-41
“Solve Problems Using PDEModel Objects” on page 2-3
5-692
pdegrad
pdegrad
(Not recommended) Gradient of PDE solution
Syntax
[ux,uy] = pdegrad(p,t,u)
[ux,uy] = pdegrad(p,t,u,sdl)
Description
[ux,uy] = pdegrad(p,t,u) returns the gradient of u evaluated at the center of each
triangle.
∂ui
∂x
∂ui
∂y
Although pdegrad returns the value of the gradient at the center of a triangle, the
gradient is actually the same everywhere in the triangle interior. This is because pdegrad
uses only linear basis functions. The boundaries of triangles are a special case: here the
derivatives might be discontinuous.
The geometry of the PDE problem is given by the mesh data p and t. For details on the
mesh data representation, see initmesh.
5-693
5 Functions — Alphabetical List
The optional argument sdl restricts the computation to the subdomains in the list sdl.
See Also
evaluateGradient
5-694
pdeInterpolant
pdeInterpolant
Interpolant for nodal data to selected locations
Description
An interpolant allows you to evaluate a PDE solution at any point within the geometry.
Partial Differential Equation Toolbox solvers return solution values at the nodes, meaning
the mesh points. To evaluate an interpolated solution at other points within the geometry,
create a pdeInterpolant object, and then call the evaluate function.
Creation
Syntax
F = pdeInterpolant(p,t,u)
Description
F = pdeInterpolant(p,t,u) returns an interpolant F based on the data points p,
elements t, and data values at the points, u.
Use meshToPet to obtain the p and t data for interpolation using pdeInterpolant.
Input Arguments
p — Data point locations
matrix with two or three rows
5-695
5 Functions — Alphabetical List
Data point locations, specified as a matrix with two or three rows. Each column of p is a
2-D or 3-D point. For details, see “Mesh Data” on page 2-171.
For 2-D problems, construct p using the initmesh function, or export from the Mesh
menu of the PDE Modeler app. For 2-D or 3-D geometry using a PDEModel object, obtain
p using the meshToPet function on model.Mesh. For example, [p,e,t] =
initmesh(g) or [p,e,t] = meshToPet(model.Mesh).
t — Triangulation elements
matrix
Triangulation elements, specified as a matrix. For details, see “Mesh Data” on page 2-171.
For 2-D problems, construct t using the initmesh function, or export from the Mesh
menu of the PDE Modeler app. For 2-D or 3-D geometry using a PDEModel object, obtain
t using the meshToPet function on model.Mesh. For example, [p,e,t] =
initmesh(g) or [p,e,t] = meshToPet(model.Mesh).
The dimensions of the matrix u depend on the problem. If np is the number of columns of
p, and N is the number of equations in the PDE system, then u has N*np rows. The first np
rows correspond to equation 1, the next np rows correspond to equation 2, etc. For
parabolic or hyperbolic problems, u has one column for each solution time; otherwise, u is
a column vector.
Object Functions
evaluate Interpolate data to selected locations
Examples
5-696
pdeInterpolant
Create Interpolant
This example shows how to create a pdeInterpolant from the solution to a scalar PDE.
Solve the equation −Δu = 1 on the unit disk with zero Dirichlet conditions.
g0 = [1;0;0;1]; % circle centered at (0,0) with radius 1
sf = 'C1';
g = decsg(g0,sf,sf'); % decomposed geometry matrix
problem = allzerobc(g); % zero Dirichlet conditions
[p,e,t] = initmesh(g);
c = 1;
a = 0;
f = 1;
u = assempde(problem,p,e,t,c,a,f);
uOut = 4×1
0.2485
0.1854
0.1230
0.1852
The values uOut(2) and uOut(4) are nearly equal, as they should be for symmetric
points in this symmetric problem.
See Also
evaluate | tri2grid
Topics
“Mesh Data” on page 2-171
5-697
5 Functions — Alphabetical List
Introduced in R2014b
5-698
pdeintrp
pdeintrp
(Not recommended) Interpolate from node data to triangle midpoint data
Syntax
ut = pdeintrp(p,t,un)
Description
ut = pdeintrp(p,t,un) gives linearly interpolated values at triangle midpoints from
the values at node points.
The geometry of the PDE problem is given by the mesh data p and t. For details on the
mesh data representation, see initmesh.
Let N be the dimension of the PDE system, np the number of node points, and nt the
number of triangles. The components of the node data are stored in un either as N
columns of length np or as an ordinary solution vector. The first np values of un describe
the first component, the following np values of un describe the second component, and so
on. The components of triangle data are stored in ut as N rows of length nt.
Caution
pdeprtni and pdeintrp are not inverse functions. The interpolation introduces some
averaging.
See Also
evaluateGradient | interpolateSolution | solvepde
5-699
5 Functions — Alphabetical List
5-700
pdejmps
pdejmps
(Not recommended) Error estimates for adaptation
Syntax
errf = pdejmps(p,t,c,a,f,u,alfa,beta,m)
Description
errf = pdejmps(p,t,c,a,f,u,alfa,beta,m) calculates the error indication
function used for adaptation. The columns of errf correspond to triangles, and the rows
correspond to the different equations in the PDE system.
The formula for computing the error indicator E(K) for each triangle K is
1/2
m 1 2m 2
2 τ ∈∑∂K τ
E K =α h f − au K+β h [nτ ⋅ (c ∇uh)]
where nτ is the unit normal of edge τ and the braced term is the jump in flux across the
element edge, where α and β are weight indices and m is an order parameter. The norm is
an L2 norm computed over the element K. The error indicator is stored in errf as column
vectors, one for each triangle in t. For more details, see the "Algorithms" section on the
adaptmesh page.
5-701
5 Functions — Alphabetical List
pdemesh
Plot PDE mesh
Syntax
pdemesh(model)
pdemesh(mesh)
pdemesh(nodes,elements)
pdemesh(model,u)
pdemesh( ___ ,Name,Value)
pdemesh(p,e,t)
pdemesh(p,e,t,u)
h = pdemesh( ___ )
Description
pdemesh(model) plots the mesh contained in a 2-D or 3-D model object of type
PDEModel.
pdemesh(mesh) plots the mesh defined as a Mesh property of a 2-D or 3-D model object
of type PDEModel.
pdemesh(model,u) plots solution data u as a 3-D plot. This syntax is valid only for 2-D
geometry.
pdemesh( ___ ,Name,Value) plots the mesh or solution data using any of the
arguments in the previous syntaxes and one or more Name,Value pair arguments.
pdemesh(p,e,t,u) plots PDE node or triangle data u using a mesh plot. The function
plots the node data if u is a column vector , and triangle data if u is a row vector.
5-702
pdemesh
If you want to have more control over your mesh plot, use pdeplot or pdeplot3D
instead of pdemesh.
h = pdemesh( ___ ) returns handles to the graphics, using any of the arguments of the
previous syntaxes.
Examples
Create a mesh plot and display the node and element labels of the mesh.
Create a PDE model. Include the geometry of the built-in function lshapeg. Mesh the
geometry.
model = createpde;
geometryFromEdges(model,@lshapeg);
mesh = generateMesh(model);
pdemesh(model)
5-703
5 Functions — Alphabetical List
pdemesh(mesh)
5-704
pdemesh
Another approach is to use the nodes and elements of the mesh as input arguments for
pdemesh.
pdemesh(mesh.Nodes,mesh.Elements)
5-705
5 Functions — Alphabetical List
pdemesh(model,'NodeLabels','on')
5-706
pdemesh
xlim([-0.4,0.4])
ylim([-0.4,0.4])
5-707
5 Functions — Alphabetical List
pdemesh(model,'ElementLabels','on')
xlim([-0.4,0.4])
ylim([-0.4,0.4])
5-708
pdemesh
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
specifyCoefficients(model,'m',0,...
'd',0,...
'c',1,...
'a',0,...
'f',1);
generateMesh(model);
results = solvepde(model)
results =
StationaryResults with properties:
5-709
5 Functions — Alphabetical List
u = results.NodalSolution;
The pdemesh function ignores NodeLabels and ElementLabels when you plot solution
data as a 3-D plot.
5-710
pdemesh
5-711
5 Functions — Alphabetical List
model = createpde;
Include the geometry of the built-in function lshapeg. Plot the geometry.
geometryFromEdges(model,@lshapeg);
pdegplot(model,'FaceLabels','on','EdgeLabels','on')
5-712
pdemesh
Generate a mesh.
mesh = generateMesh(model,'Hmax',0.5);
5-713
5 Functions — Alphabetical List
Now solve Poisson's equation −Δu = 1 over the geometry defined by the L-shaped
membrane. Use Dirichlet boundary conditions u = 0 on δΩ, and plot the result.
u = assempde('lshapeb',p,e,t,1,0,1);
pdemesh(p,e,t,u)
5-714
pdemesh
Input Arguments
model — Model object
PDEModel object | ThermalModel object | StructuralModel object
5-715
5 Functions — Alphabetical List
u — PDE solution
vector | matrix
Mesh object, specified as the Mesh property of a PDEModel object or as the output of
generateMesh.
Example: model.Mesh
Nodal coordinates, specified as a 2-by-NumNodes matrix for a 2-D mesh and 3-by-
NumNodes matrix for a 3-D mesh. NumNodes is the number of nodes.
5-716
pdemesh
p — Mesh points
matrix
5-717
5 Functions — Alphabetical List
Mesh points, specified as a 2-by-Np matrix of points, where Np is the number of points in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
e — Mesh edges
matrix
Mesh edges, specified as a 7-by-Ne matrix of edges, where Ne is the number of edges in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
t — Mesh triangles
matrix
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
5-718
pdemesh
pdemesh ignores NodeLabels when you plot solution data as a 3-D plot.
Example: 'NodeLabels','on'
Data Types: char | string
pdemesh ignores ElementLabels when you plot solution data as a 3-D plot.
Example: 'ElementLabels','on'
Data Types: char | string
Surface transparency for 3-D geometry, specified as the comma-separated pair consisting
of 'FaceAlpha' and a real number from 0 through 1. The default value 1 indicates no
transparency. The value 0 indicates complete transparency.
Example: 'FaceAlpha',0.5
Data Types: double
Color of mesh edges, specified as a short or long color name or an RGB triplet. By default,
for 2-D meshes the edges within one face are blue (RGB triplet [0 0 1]) and the edges
between faces are red (RGB triplet [1 0 0]). For 3-D meshes, the default edge color is
black (RGB triplet [0 0 0]).
The short names and long names are character vectors that specify one of eight
predefined colors. The RGB triplet is a three-element row vector whose elements specify
5-719
5 Functions — Alphabetical List
the intensities of the red, green, and blue components of the color; the intensities must be
in the range [0 1]. The following table lists the predefined colors and their RGB triplet
equivalents.
Example: 'EdgeColor','green'
Data Types: double | char | string
Color of mesh faces for 3-D meshes, specified as a short or long color name or an RGB
triplet. The default face color is cyan (RGB triplet [0 1 1]). For details about available
colors, see “'EdgeColor'” on page 5-0 .
Example: 'FaceColor','green'
Data Types: double | char | string
Output Arguments
h — Handles to graphics objects
vector
5-720
pdemesh
See Also
pdegplot | pdeplot | pdeplot3D | pdesurf
Topics
“Mesh Data” on page 2-171
5-721
5 Functions — Alphabetical List
PDEModel
PDE model object
Description
A PDEModel object contains information about a PDE problem: the number of equations,
geometry, mesh, and boundary conditions.
Creation
Create a PDEModel object using createpde. Initially, the only nonempty property is
PDESystemSize. It is 1 for scalar problems.
Properties
PDESystemSize — Number of equations
1 (default) | positive integer
Number of equations, N, returned as a positive integer. See “Equations You Can Solve
Using PDE Toolbox” on page 1-3.
Example: 1
Data Types: double
5-722
PDEModel
• AnalyticGeometry object for 2-D geometry. You create this geometry using the
geometryFromEdges function.
• DiscreteGeometry object for 3-D geometry. You create this geometry using the
importGeometry function or the geometryFromMesh function.
Mesh for solution, returned as an FEMesh object. You create the mesh using the
generateMesh function.
In case of NodalInitialConditions, you use the results of previous analysis to set the
initial conditions or initial guess. The geometry and mesh of the previous analysis and
current model must be the same.
5-723
5 Functions — Alphabetical List
Algorithm options for the PDE solvers, returned as a PDESolverOptions object. The
properties of PDESolverOptions include absolute and relative tolerances for internal
ODE solvers, maximum solver iterations, and so on.
Object Functions
applyBoundaryCondition Add boundary condition to PDEModel container
generateMesh Create triangular or tetrahedral mesh
geometryFromEdges Create 2-D geometry from decomposed geometry matrix
geometryFromMesh Create 2-D or 3-D geometry from mesh
importGeometry Import 2-D or 3-D geometry from STL data
setInitialConditions Give initial conditions or initial solution
specifyCoefficients Specify coefficients in a PDE model
solvepde Solve PDE specified in a PDEModel
solvepdeeig Solve PDE eigenvalue problem specified in a PDEModel
Examples
model = createpde()
model =
PDEModel with properties:
PDESystemSize: 1
IsTimeDependent: 0
Geometry: []
EquationCoefficients: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
5-724
PDEModel
Include a torus geometry, zero Dirichlet boundary conditions, coefficients for Poisson's
equation, and the default mesh.
importGeometry(model,'Torus.stl');
applyBoundaryCondition(model,'dirichlet','face',1,'u',0);
specifyCoefficients(model,'m',0,...
'd',0,...
'c',1,...
'a',0,...
'f',1);
generateMesh(model);
results = solvepde(model)
results =
StationaryResults with properties:
See Also
applyBoundaryCondition | createpde | generateMesh | geometryFromEdges |
geometryFromMesh | importGeometry | pdegplot | pdeplot | pdeplot3D |
setInitialConditions | specifyCoefficients
Topics
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2015a
5-725
5 Functions — Alphabetical List
pdenonlin
(Not recommended) Solve nonlinear elliptic PDE problem
Syntax
u = pdenonlin(model,c,a,f)
u = pdenonlin(b,p,e,t,c,a,f)
u = pdenonlin( ___ ,Name,Value)
[u,res] = pdenonlin( ___ )
Description
u = pdenonlin(model,c,a,f) solves the nonlinear PDE
− ∇ ⋅ c ∇u + au = f
with geometry, boundary conditions, and finite element mesh in model, and coefficients c,
a, and f. In this context, “nonlinear” means some coefficient in c, a, or f depends on the
solution u or its gradient. If the PDE is a system of equations
(model.PDESystemSize > 1), then pdenonlin solves the system of equations
− ∇ ⋅ c ⊗ ∇u + au = f
u = pdenonlin( ___ ,Name,Value), for any previous arguments, modifies the solution
process with Name, Value pairs.
[u,res] = pdenonlin( ___ ) also returns the norm of the Newton step residuals res.
5-726
pdenonlin
Examples
Solve a minimal surface problem. Because this problem has a nonlinear c coefficient, use
pdenonlin to solve it.
Create a model and include circular geometry using the built-in circleg function.
model = createpde;
geometryFromEdges(model,@circleg);
a = 0;
f = 0;
c = '1./sqrt(1+ux.^2+uy.^2)';
boundaryfun = @(region,state)region.x.^2;
applyBoundaryCondition(model,'edge',1:model.Geometry.NumEdges,...
'u',boundaryfun,'Vectorized','on');
generateMesh(model,'GeometricOrder','linear','Hmax',0.1);
u = pdenonlin(model,c,a,f);
pdeplot(model,'XYData',u,'ZData',u)
5-727
5 Functions — Alphabetical List
Solve the minimal surface problem using the legacy approach for creating boundary
conditions and geometry.
Create the geometry using the built-in circleg function. Plot the geometry to see the
edge labels.
g = @circleg;
pdegplot(g,'EdgeLabels','on')
axis equal
5-728
pdenonlin
Create Dirichlet boundary conditions with value x2.Create the following file and save it on
your Matlab™ path.
for k = 1:ne
x1 = p(1,e(1,k)); % x at first point in segment
x2 = p(1,e(2,k)); % x at second point in segment
5-729
5 Functions — Alphabetical List
a = 0;
f = 0;
c = '1./sqrt(1+ux.^2+uy.^2)';
b = @pdex2bound;
[p,e,t] = initmesh(g,'Hmax',0.1);
u = pdenonlin(b,p,e,t,c,a,f);
pdeplot(p,e,t,'XYData',u,'ZData',u)
5-730
pdenonlin
Import the geometry from the BracketWithHole.stl file. Plot the geometry and face
labels.
model = createpde();
importGeometry(model,'BracketWithHole.stl');
figure
pdegplot(model,'FaceLabels','on')
5-731
5 Functions — Alphabetical List
view(30,30)
title('Bracket with Face Labels')
figure
pdegplot(model,'FaceLabels','on')
view(-134,-32)
title('Bracket with Face Labels, Rear View')
5-732
pdenonlin
Set a Dirichlet boundary condition with value 1000 on the back face, which is face 4. Set
the large faces 1 and 7, and also the circular face 11, to have Neumann boundary
conditions with value g = -10. Do not set boundary conditions on the other faces. Those
faces default to Neumann boundary conditions with value g = 0.
applyBoundaryCondition(model,'Face',4,'u',1000);
applyBoundaryCondition(model,'Face',[1,7,11],'g',-10);
Set the c coefficient to 1, f to 0.1, and a to the nonlinear value '0.1 + 0.001*u.^2'.
c = 1;
f = 0.1;
a = '0.1 + 0.001*u.^2';
5-733
5 Functions — Alphabetical List
Generate the mesh and solve the PDE. Start from the initial guess u0 = 1000, which
matches the value you set on face 4. Turn on the Report option to observe the
convergence during the solution.
generateMesh(model);
u = pdenonlin(model,c,a,f,'U0',1000,'Report','on');
pdeplot3D(model,'ColorMapData',u)
5-734
pdenonlin
Input Arguments
model — PDE model
PDEModel object
c — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
5-735
5 Functions — Alphabetical List
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. c represents the c coefficient in the scalar
PDE
− ∇ ⋅ c ∇u + au = f
− ∇ ⋅ c ⊗ ∇u + au = f
Example: 'cosh(x+y.^2)'
Data Types: double | char | string | function_handle
Complex Number Support: Yes
a — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. a represents the a coefficient in the scalar
PDE
− ∇ ⋅ c ∇u + au = f
− ∇ ⋅ c ⊗ ∇u + au = f
Example: 2*eye(3)
Data Types: double | char | string | function_handle
Complex Number Support: Yes
f — PDE coefficient
scalar | matrix | character vector | character array | string scalar | string vector |
coefficient function
PDE coefficient, specified as a scalar, matrix, character vector, character array, string
scalar, string vector, or coefficient function. f represents the f coefficient in the scalar
PDE
− ∇ ⋅ c ∇u + au = f
5-736
pdenonlin
− ∇ ⋅ c ⊗ ∇u + au = f
Example: char('sin(x)';'cos(y)';'tan(z)')
Data Types: double | char | string | function_handle
Complex Number Support: Yes
b — Boundary conditions
boundary matrix | boundary file
Boundary conditions, specified as a boundary matrix or boundary file. Pass a boundary file
as a function handle or as a file name. A boundary matrix is generally an export from the
PDE Modeler app.
Example: b = 'circleb1', b = "circleb1", or b = @circleb1
Data Types: double | char | string | function_handle
p — Mesh points
matrix
Mesh points, specified as a 2-by-Np matrix of points, where Np is the number of points in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
e — Mesh edges
matrix
Mesh edges, specified as a 7-by-Ne matrix of edges, where Ne is the number of edges in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
t — Mesh triangles
matrix
5-737
5 Functions — Alphabetical List
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
• 'full' means numerical evaluation of the full Jacobian based on the sparse version of
the numjac function. 3-D geometry uses only 'full', any other specification yields
an error.
• 'fixed' specifies a fixed-point iteration matrix where the Jacobian is approximated
by the stiffness matrix. This is the 2-D geometry default.
• 'lumped' specifies a “lumped” approximation as described in “Nonlinear Equations”
on page 5-741. This approximation is based on the numerical differentiation of the
coefficients.
Example: u = pdenonlin(model,c,a,f,'Jacobian','full')
Data Types: char | string
5-738
pdenonlin
For systems of N equations, and a mesh with Np nodes, give a column vector with N*Np
components. The nodes are either model.Mesh.Nodes, or the p data from initmesh or
meshToPet. See “Mesh Data” on page 2-171.
The first Np elements contain the values of component 1, where the value of element k
corresponds to node p(k). The next Np points contain the values of component 2, etc. It
can be convenient to first represent the initial conditions u0 as an Np-by-N matrix, where
the first column contains entries for component 1, the second column contains entries for
component 2, etc. The final representation of the initial conditions is u0(:).
Example: u = pdenonlin(model,c,a,f,'U0','x.^2-y.^2')
Data Types: double | char | string
Complex Number Support: Yes
Residual size at termination, specified as a positive scalar. pdenonlin iterates until the
residual size is less than 'Tol'.
Example: u = pdenonlin(model,c,a,f,'Tol',1e-6)
Data Types: double
5-739
5 Functions — Alphabetical List
Residual norm, specified as the p value for Lp norm, or as 'energy'. p can be any
positive real value, Inf, or -Inf. The p norm of a vector v is sum(abs(v)^p)^(1/p).
See norm.
Example: u = pdenonlin(model,c,a,f,'Norm',2)
Data Types: double | char | string
Output Arguments
u — PDE solution
vector
• If the PDE is scalar, meaning only one equation, then u is a column vector
representing the solution u at each node in the mesh. u(i) is the solution at the ith
column of model.Mesh.Nodes or the ith column of p.
• If the PDE is a system of N > 1 equations, then u is a column vector with N*Np
elements, where Np is the number of nodes in the mesh. The first Np elements of u
represent the solution of equation 1, then next Np elements represent the solution of
equation 2, etc.
To plot the solution, use pdeplot for 2-D geometry, or see “Plot 3-D Solutions and Their
Gradients” on page 3-325.
Norm of Newton step residuals, returned as a scalar. For information about the algorithm,
see “Nonlinear Equations” on page 5-741.
5-740
pdenonlin
Tips
• If the Newton iteration does not converge, pdenonlin displays the error message Too
many iterations or Stepsize too small.
• If the initial guess produces matrices containing NaN or Inf elements, pdenonlin
displays the error message Unsuitable initial guess U0 (default: U0 =
0).
• If you have very small coefficients, or very small geometric dimensions, pdenonlin
can fail to converge, or can converge to an incorrect solution. If so, you can sometimes
obtain better results by scaling the coefficients or geometry dimensions to be of order
one.
Algorithms
Nonlinear Equations
The basic idea is to use Gauss-Newton iterations to solve the nonlinear equations. Say you
are trying to solve the equation
In the FEM setting you solve the weak form of r(u) = 0. Set as usual
u(x) = ∑ U jϕ j
where x represents a 2-D or 3-D point. Then multiply the equation by an arbitrary test
function ϕi, integrate on the domain Ω, and use Green's formula and the boundary
conditions to obtain
0=ρU = ∑
j Ω
∫ c x, U ∇ϕ j(x) ⋅ ∇ϕ j(x) + a x, U ϕ j(x)ϕi(x) dx
+ ∫ q x, U ϕ (x)ϕ (x) ds U
∂Ω
j i j
−
Ω
∫ f x, U ϕ (x) dx − ∫ g x, U ϕ (x) ds
i
∂Ω
i
5-741
5 Functions — Alphabetical List
ρ(U) = (K + M + Q)U – (F + G)
where the matrices K, M, Q and the vectors F and G are produced by assembling the
problem
Assume that you have a guess U(n) of the solution. If U(n) is close enough to the exact
solution, an improved approximation U(n+1) is obtained by solving the linearized problem
∂ρ U(n)
U(n + 1) − U(n) = − αρ U(n)
∂U
where α is a positive number. (It is not necessary that ρ(U) = 0 have a solution even if
ρ(u) = 0 has.) In this case, the Gauss-Newton iteration tends to be the minimizer of the
residual, i.e., the solution of minU ρ(U) .
and
−1
∂ρ U(n)
pn = ρ U(n)
∂U
is called a descent direction for ρ(U) , where ⋅ is the L2-norm. The iteration is
where α ≤ 1 is chosen as large as possible such that the step has a reasonable descent.
The Gauss-Newton method is local, and convergence is assured only when U(0) is close
enough to the solution. In general, the first guess may be outside the region of
convergence. To improve convergence from bad initial guesses, a damping strategy is
implemented for choosing α, the Armijo-Goldstein line search. It chooses the largest
5-742
pdenonlin
damping coefficient α out of the sequence 1, 1/2, 1/4, . . . such that the following
inequality holds:
α
ρ U(n) − ρ U(n) + αpn ≥ ρ U(n)
2
which guarantees a reduction of the residual norm by at least 1 – α/2. Each step of the
line-search algorithm requires an evaluation of the residual ρ U(n) + αpn .
An important point of this strategy is that when U(n) approaches the solution, then α→1
and thus the convergence rate increases. If there is a solution to ρ(U) = 0, the scheme
ultimately recovers the quadratic convergence rate of the standard Newton iteration.
Closely related to the preceding problem is the choice of the initial guess U(0). By default,
the solver sets U(0) and then assembles the FEM matrices K and F and computes
U(1) = K–1F
The damped Gauss-Newton iteration is then started with U(1), which should be a better
guess than U(0). If the boundary conditions do not depend on the solution u, then U(1)
satisfies them even if U(0) does not. Furthermore, if the equation is linear, then U(1) is the
exact FEM solution and the solver does not enter the Gauss-Newton loop.
In some situations you may already have a good approximation and the nonlinear solver
can be started with it, avoiding the slow convergence regime. This idea is used in the
adaptive mesh generator. It computes a solution U on a mesh, evaluates the error, and
may refine certain triangles. The interpolant of U is a very good starting guess for the
solution on the refined mesh.
∂ρ U(n)
Jn =
∂U
5-743
5 Functions — Alphabetical List
which implies the assembling of the FEM matrices for the triangles containing grid point
i. A very simple approximation to Jn, which gives a fixed point iteration, is also possible as
follows. Essentially, for a given U(n), compute the FEM matrices K and F and set
U(n+1) = K–1F .
This is equivalent to approximating the Jacobian with the stiffness matrix. Indeed, since
ρ(U(n)) = KU(n) – F, putting Jn = K yields
In many cases the convergence rate is slow, but the cost of each iteration is cheap.
The Partial Differential Equation Toolbox nonlinear solver also provides for a compromise
between the two extremes. To compute the derivative of the mapping U→KU, proceed as
follows. The a term has been omitted for clarity, but appears again in the final result.
∂ KU i
∂U j
1
= lim ∑
ε 0ε l
∫c U + εϕ
Ω
j ∇ϕl ∇ϕi dx Ul + εδl, j
− ∫c U ∇ϕ ∇ϕ dxU
Ω
l i l
= ∫c U ∇ϕ ∇ϕ dx + ∑ ∫ϕ ∂u
Ω
j
∂c
i ∇ϕ ∇ϕ dxU
l Ω
j l i l
The second term is “lumped,” i.e., replaced by a diagonal matrix that contains the row
sums. Since Σjϕj = 1, the second term is approximated by
δi, j ∑
l Ω
∫ ∂u
∂c
∇ϕ ∇ϕ dxU
l i l
which is the ith component of K(c')U, where K(c') is the stiffness matrix associated with the
coefficient ∂c/∂u rather than c. The same reasoning can be applied to the derivative of the
mapping U→MU. The derivative of the mapping U→ –F is exactly
− ∫ ∂u
Ω
∂f
ϕ ϕ dx i j
5-744
pdenonlin
which is the mass matrix associated with the coefficient ∂f/∂u. Thus the Jacobian of the
residual ρ(U) is approximated by
where the differentiation is with respect to u, K and M designate stiffness and mass
matrices, and their indices designate the coefficients with respect to which they are
assembled. At each Gauss-Newton iteration, the nonlinear solver assembles the matrices
corresponding to the equations
− ∇ ⋅ (c ∇u) + (a − f ′)u = 0
− ∇ ⋅ (c′ ∇u) + a′u = 0
and then produces the approximate Jacobian. The differentiations of the coefficients are
done numerically.
In the general setting of elliptic systems, the boundary conditions are appended to the
stiffness matrix to form the full linear system:
K H′ U F
KU = = =F
H 0 μ R
where the coefficients of K and F may depend on the solution U. The “lumped” approach
approximates the derivative mapping of the residual by
J H′
H 0
The nonlinearities of the boundary conditions and the dependencies of the coefficients on
the derivatives of U are not properly linearized by this scheme. When such nonlinearities
are strong, the scheme reduces to the fix-point iteration and may converge slowly or not
at all. When the boundary conditions are linear, they do not affect the convergence
properties of the iteration schemes. In the Neumann case they are invisible (H is an
empty matrix) and in the Dirichlet case they merely state that the residual is zero on the
corresponding boundary points.
See Also
solvepde
5-745
5 Functions — Alphabetical List
5-746
pdeplot
pdeplot
Plot solution or mesh for 2-D problem
Syntax
pdeplot(model,'XYData',results.NodalSolution)
pdeplot(model,'XYData',results.Temperature,'ColorMap','hot')
pdeplot(
model,'XYData',results.VonMisesStress,'Deformation',results.Displace
ment)
pdeplot(model,'XYData',results.ModeShapes.ux)
pdeplot(model)
pdeplot(mesh)
pdeplot(nodes,elements)
pdeplot(p,e,t)
Description
pdeplot(model,'XYData',results.NodalSolution) plots the solution of a model
at nodal locations as a colored surface plot using the default 'jet' colormap.
pdeplot(
model,'XYData',results.VonMisesStress,'Deformation',results.Displace
ment) plots the von Mises stress and shows the deformed shape for a 2-D structural
analysis model.
5-747
5 Functions — Alphabetical List
pdeplot(mesh) plots the mesh defined as a Mesh property of a 2-D model object of type
PDEModel.
pdeplot( ___ ,Name,Value) plots the mesh, the data at the nodal locations, or both the
mesh and the data, depending on the Name,Value pair arguments. Use any arguments
from the previous syntaxes.
Specify at least one of the FlowData (vector field plot), XYData (colored surface plot), or
ZData (3-D height plot) name-value pairs. Otherwise, pdeplot plots the mesh with no
data. You can combine any number of plot types.
h = pdeplot( ___ ) returns a handle to a plot, using any of the previous syntaxes.
Examples
Create a PDE model. Include the geometry of the built-in function lshapeg. Mesh the
geometry and plot it.
model = createpde;
geometryFromEdges(model,@lshapeg);
mesh = generateMesh(model);
pdeplot(model)
5-748
pdeplot
pdeplot(mesh)
5-749
5 Functions — Alphabetical List
Another approach is to use the nodes and elements of the mesh as input arguments for
pdeplot.
pdeplot(mesh.Nodes,mesh.Elements)
5-750
pdeplot
Display the node labels. Use xlim and ylim to zoom in on particular nodes.
pdeplot(model,'NodeLabels','on')
xlim([-0.2,0.2])
ylim([-0.2,0.2])
5-751
5 Functions — Alphabetical List
pdeplot(model,'ElementLabels','on')
xlim([-0.2,0.2])
ylim([-0.2,0.2])
5-752
pdeplot
Solution Plots
Create a PDE model. Include the geometry of the built-in function lshapeg. Mesh the
geometry.
model = createpde;
geometryFromEdges(model,@lshapeg);
generateMesh(model);
5-753
5 Functions — Alphabetical List
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
specifyCoefficients(model,'m',0, ...
'd',0, ...
'c',1, ...
'a',0, ...
'f',1);
results = solvepde(model)
results =
StationaryResults with properties:
u = results.NodalSolution;
pdeplot(model,'XYData',u)
5-754
pdeplot
pdeplot(model,'XYData',u,'ZData',u)
5-755
5 Functions — Alphabetical List
Create a PDE model. Include the geometry of the built-in function lshapeg. Mesh the
geometry.
model = createpde;
geometryFromEdges(model,@lshapeg);
generateMesh(model);
5-756
pdeplot
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
specifyCoefficients(model,'m',0, ...
'd',0, ...
'c',1, ...
'a',0, ...
'f',1);
results = solvepde(model)
results =
StationaryResults with properties:
ux = results.XGradients;
uy = results.YGradients;
pdeplot(model,'FlowData',[ux,uy])
5-757
5 Functions — Alphabetical List
Composite Plot
Plot the solution of a 2-D PDE in 3-D with the 'jet' coloring and a mesh, and include a
quiver plot. Get handles to the axes objects.
Create a PDE model. Include the geometry of the built-in function lshapeg. Mesh the
geometry.
model = createpde;
geometryFromEdges(model,@lshapeg);
generateMesh(model);
5-758
pdeplot
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
specifyCoefficients(model,'m',0, ...
'd',0, ...
'c',1, ...
'a',0, ...
'f',1);
results = solvepde(model)
results =
StationaryResults with properties:
u = results.NodalSolution;
ux = results.XGradients;
uy = results.YGradients;
Plot the solution in 3-D with the 'jet' coloring and a mesh, and include the gradient as a
quiver plot.
h = pdeplot(model,'XYData',u,'ZData',u, ...
'FaceAlpha',0.5, ...
'FlowData',[ux,uy], ...
'ColorMap','jet', ...
'Mesh','on')
5-759
5 Functions — Alphabetical List
h =
3x1 graphics array:
Patch
Quiver
ColorBar
5-760
pdeplot
thermalmodel = createpde('thermal','transient');
5-761
5 Functions — Alphabetical List
thermalProperties(thermalmodel,'ThermalConductivity',10, ...
'MassDensity',2, ...
'SpecificHeat',0.1, ...
'Face',1);
5-762
pdeplot
thermalProperties(thermalmodel,'ThermalConductivity',2, ...
'MassDensity',1, ...
'SpecificHeat',0.1, ...
'Face',2);
Assume that the diamond-shaped region is a heat source with a density of 4 W /m3.
internalHeatSource(thermalmodel,4,'Face',2);
thermalBC(thermalmodel,'Temperature',0,'Edge',[1 2 7 8]);
thermalIC(thermalmodel,0);
generateMesh(thermalmodel);
The dynamics for this problem are very fast. The temperature reaches a steady state in
about 0.1 seconds. To capture the interesting part of the dynamics, set the solution time
to logspace(-2,-1,10). This command returns 10 logarithmically spaced solution
times between 0.01 and 0.1.
tlist = logspace(-2,-1,10);
thermalresults = solve(thermalmodel,tlist)
thermalresults =
TransientThermalResults with properties:
5-763
5 Functions — Alphabetical List
ZGradients: []
Mesh: [1x1 FEMesh]
5-764
pdeplot
structuralmodel = createpde('structural','static-planestrain');
Create the geometry and include it in the model. Plot the geometry.
geometryFromEdges(structuralmodel,@squareg);
pdegplot(structuralmodel,'EdgeLabels','on')
axis equal
structuralProperties(structuralmodel,'PoissonsRatio',0.3, ...
'YoungsModulus',210E3);
5-765
5 Functions — Alphabetical List
structuralBC(structuralmodel,'XDisplacement',0.001,'Edge',1);
structuralBC(structuralmodel,'Constraint','fixed','Edge',3);
generateMesh(structuralmodel);
structuralresults = solve(structuralmodel);
Plot the deformed shape using the default scale factor. By default, pdeplot internally
determines the scale factor based on the dimensions of the geometry and the magnitude
of deformation.
pdeplot(structuralmodel,'XYData',structuralresults.VonMisesStress, ...
'Deformation',structuralresults.Displacement, ...
'ColorMap','jet')
5-766
pdeplot
pdeplot(structuralmodel,'XYData',structuralresults.VonMisesStress, ...
'Deformation',structuralresults.Displacement, ...
'DeformationScaleFactor',500,...
'ColorMap','jet')
5-767
5 Functions — Alphabetical List
pdeplot(structuralmodel,'XYData',structuralresults.VonMisesStress, ...
'ColorMap','jet')
5-768
pdeplot
Find the fundamental (lowest) mode of a 2-D cantilevered beam, assuming prevalence of
the plane-stress condition.
Specify the following geometric and structural properties of the beam, along with a unit
plane-stress thickness.
length = 5;
height = 0.1;
E = 3E7;
5-769
5 Functions — Alphabetical List
nu = 0.3;
rho = 0.3/386;
structuralmodel = createpde('structural','modal-planestress');
gdm = [3;4;0;length;length;0;0;0;height;height];
g = decsg(gdm,'S1',('S1')');
geometryFromEdges(structuralmodel,g);
Define a maximum element size (five elements through the beam thickness).
hmax = height/5;
msh=generateMesh(structuralmodel,'Hmax',hmax);
structuralProperties(structuralmodel,'YoungsModulus',E, ...
'MassDensity',rho, ...
'PoissonsRatio',nu);
structuralBC(structuralmodel,'Edge',4,'Constraint','fixed');
Compute the analytical fundamental frequency (Hz) using the beam theory.
I = height^3/12;
analyticalOmega1 = 3.516*sqrt(E*I/(length^4*(rho*height)))/(2*pi)
analyticalOmega1 = 126.9498
Specify a frequency range that includes an analytically computed frequency and solve the
model.
modalresults = solve(structuralmodel,'FrequencyRange',[0,1e6])
modalresults =
ModalStructuralResults with properties:
The solver finds natural frequencies and modal displacement values at nodal locations. To
access these values, use modalresults.NaturalFrequencies and
modalresults.ModeShapes.
5-770
pdeplot
modalresults.NaturalFrequencies/(2*pi)
ans = 32×1
105 ×
0.0013
0.0079
0.0222
0.0433
0.0711
0.0983
0.1055
0.1462
0.1930
0.2455
⋮
modalresults.ModeShapes
pdeplot(structuralmodel,'XYData',modalresults.ModeShapes.uy(:,1))
title(['First Mode with Frequency ', ...
num2str(modalresults.NaturalFrequencies(1)/(2*pi)),' Hz'])
axis equal
5-771
5 Functions — Alphabetical List
Plot the p,e,t mesh. Display the solution using 2-D and 3-D colored plots.
Create the geometry, mesh, boundary conditions, PDE coefficients, and solution.
[p,e,t] = initmesh('lshapeg');
u = assempde('lshapeb',p,e,t,1,0,1);
5-772
pdeplot
pdeplot(p,e,t,'XYData',u)
5-773
5 Functions — Alphabetical List
pdeplot(p,e,t,'XYData',u,'ZData',u)
5-774
pdeplot
Input Arguments
model — Model object
PDEModel object | ThermalModel object | StructuralModel object
5-775
5 Functions — Alphabetical List
Mesh object, specified as the Mesh property of a PDEModel object or as the output of
generateMesh.
Example: model.Mesh
p — Mesh points
matrix
Mesh points, specified as a 2-by-Np matrix of points, where Np is the number of points in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
5-776
pdeplot
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
e — Mesh edges
matrix
Mesh edges, specified as a 7-by-Ne matrix of edges, where Ne is the number of edges in
the mesh. For a description of the (p,e,t) matrices, see “Mesh Data” on page 2-171.
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
t — Mesh triangles
matrix
Typically, you use the p, e, and t data exported from the PDE Modeler app, or generated
by initmesh or refinemesh.
Example: [p,e,t] = initmesh(gd)
Data Types: double
5-777
5 Functions — Alphabetical List
Tip Specify at least one of the FlowData (vector field plot), XYData (colored surface
plot), or ZData (3-D height plot) name-value pairs. Otherwise, pdeplot plots the mesh
with no data.
Data Plots
Colored surface plot data, specified as the comma-separated pair consisting of 'XYData'
and a vector. If you use a [p,e,t] representation, specify data for points in a vector of
length size(p,2), or specify data for triangles in a vector of length size(t,2).
• Typically, you set XYData to the solution u. The pdeplot function uses XYData for
coloring both 2-D and 3-D plots.
• pdeplot uses the colormap specified in the ColorMap name-value pair, using the
style specified in the XYStyle name-value pair.
• When the Contour name-value pair is 'on', pdeplot also plots level curves of
XYData.
• pdeplot plots the real part of complex data.
To plot the kth component of a solution to a PDE system, extract the relevant part of the
solution. For example, when using a PDEModel object, specify:
results = solvepde(model);
u = results.NodalSolution; % each column of u has one component of u
pdeplot(model,'XYData',u(:,k)) % data for column k
5-778
pdeplot
Example: 'XYData',u
Data Types: double
Data for the 3-D plot heights, specified as the comma-separated pair consisting of
'ZData' and a matrix. If you use a [p,e,t] representation, provide data for points in a
vector of length size(p,2) or data for triangles in a vector of length size(t,2).
• Typically, you set ZData to u, the solution. The XYData name-value pair sets the
coloring of the 3-D plot.
• The ZStyle name-value pair specifies whether the plot is continuous or discontinuous.
• pdeplot plots the real part of complex data.
To plot the kth component of a solution to a PDE system, extract the relevant part of the
solution. For example, when using a PDEModel object, specify:
results = solvepde(model);
u = results.NodalSolution; % each column of u has one component of u
pdeplot(model,'XYData',u(:,k),'ZData',u(:,k)) % data for column k
5-779
5 Functions — Alphabetical List
Example: 'ZData',u
Data Types: double
3-D plot style, specified as the comma-separated pair consisting of 'ZStyle' and one of
these values:
If you use ZStyle without specifying the ZData name-value pair, then pdeplot ignores
ZStyle.
Example: 'ZStyle','discontinuous'
Data Types: char | string
Data for the quiver plot on page 5-785, specified as the comma-separated pair consisting
of 'FlowData' and an M-by-2 matrix, where M is the number of mesh nodes. FlowData
contains the x and y values of the field at the mesh points.
results = solvepde(model);
gradx = results.XGradients;
grady = results.YGradients;
pdeplot(model,'FlowData',[gradx grady])
5-780
pdeplot
When you use ZData to represent a 2-D PDE solution as a 3-D plot and you also include a
quiver plot, the quiver plot appears in the z = 0 plane.
Indicator to show the quiver plot, specified as the comma-separated pair consisting of
'FlowStyle' and 'arrow' or 'off'. Here, 'arrow' displays the quiver plot on page 5-
785 specified by the FlowData name-value pair.
Example: 'FlowStyle','off'
Data Types: char | string
Indicator to convert the mesh data to x-y grid before plotting, specified as the comma-
separated pair consisting of 'XYGrid' and 'off' or 'on'.
Note This conversion can change the geometry and lessen the quality of the plot.
[~,tn,a2,a3] = tri2grid(p,t,u,x,y);
pdeplot(p,e,t,'XYGrid','on','GridParam',[tn;a2;a3],'XYData',u)
5-781
5 Functions — Alphabetical List
For details on the grid data and its x and y arguments, see tri2grid. The tri2grid
function does not work with PDEModel objects.
Example: 'GridParam',[tn;a2;a3]
Data Types: double
Mesh Plots
Data for plotting the deformed shape for a structural analysis model, specified as the
comma-separated pair consisting of 'Deformation' and the Displacement property of
the StaticStructuralResults object. This property is a structure array with the fields
containing displacement components at the nodal locations.
Example: 'Deformation',structuralresults.Displacement
Data Types: struct
5-782
pdeplot
Scaling factor for plotting the deformed shape, specified as the comma-separated pair
consisting of 'DeformationScaleFactor' and a real number. Use this argument with
the Deformation name-value pair. The default value is defined internally, based on the
dimensions of the geometry and the magnitude of the deformation.
Example: 'DeformationScaleFactor',100
Data Types: double
ColorMap — Colormap
'cool' (default) | ColorMap value or matrix of such values
Indicator to show the mesh, specified as the comma-separated pair consisting of 'Mesh'
and 'on' or 'off'. Specify 'on' to show the mesh in the plot.
Example: 'Mesh','on'
5-783
5 Functions — Alphabetical List
Surface transparency for 3-D geometry, specified as the comma-separated pair consisting
of 'FaceAlpha' and a real number from 0 through 1. The default value 1 indicates no
transparency. The value 0 indicates complete transparency.
Example: 'FaceAlpha',0.5
Data Types: double
Levels for contour plot, specified as the comma-separated pair consisting of 'Levels'
and a positive integer or a vector of level values.
5-784
pdeplot
Example: 'Levels',16
Data Types: double
Output Arguments
h — Handles to graphics objects
vector
More About
Quiver Plot
A quiver plot is a plot of a vector field. It is also called a flow plot.
Arrows show the direction of the field, with the lengths of the arrows showing the relative
sizes of the field strength. For details on quiver plots, see quiver.
See Also
PDEModel | pdeplot3D
Topics
“Plot 2-D Solutions and Their Gradients” on page 3-314
“Deflection of Piezoelectric Actuator” on page 3-12
“Mesh Data” on page 2-171
“Solve Problems Using PDEModel Objects” on page 2-3
5-785
5 Functions — Alphabetical List
pdeplot3D
Plot solution or surface mesh for 3-D problem
Syntax
pdeplot3D(model,'ColorMapData',results.NodalSolution)
pdeplot3D(model,'ColorMapData',results.Temperature)
pdeplot3D(
model,'ColorMapData',results.VonMisesStress,'Deformation',results.Di
splacement)
pdeplot3D(model)
pdeplot3D(mesh)
pdeplot3D(nodes,elements)
Description
pdeplot3D(model,'ColorMapData',results.NodalSolution) plots the solution at
nodal locations as colors on the surface of the 3-D geometry specified in model.
pdeplot3D(
model,'ColorMapData',results.VonMisesStress,'Deformation',results.Di
splacement) plots the von Mises stress and shows the deformed shape for a 3-D
structural analysis model.
pdeplot3D(mesh) plots the mesh defined as a Mesh property of a 3-D model object of
type PDEModel.
5-786
pdeplot3D
pdeplot3D( ___ ,Name,Value) plots the surface mesh, the data at nodal locations, or
both the mesh and data, depending on the Name,Value pair arguments. Use any
arguments from the previous syntaxes.
h = pdeplot3D( ___ ) returns a handle to a plot, using any of the previous syntaxes.
Examples
Plot a PDE solution on the geometry surface. First, create a PDE model and import a 3-D
geometry file. Specify boundary conditions and coefficients. Mesh the geometry and solve
the problem.
model = createpde;
importGeometry(model,'Block.stl');
applyBoundaryCondition(model,'dirichlet','Face',[1:4],'u',0);
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',2);
generateMesh(model);
results = solvepde(model)
results =
StationaryResults with properties:
u = results.NodalSolution;
pdeplot3D(model,'ColorMapData',u)
5-787
5 Functions — Alphabetical List
thermalmodel = createpde('thermal');
5-788
pdeplot3D
importGeometry(thermalmodel,'Block.stl');
pdegplot(thermalmodel,'FaceLabel','on','FaceAlpha',0.5)
axis equal
thermalProperties(thermalmodel,'ThermalConductivity',80);
Apply a constant temperature of 100 ∘C to the left side of the block (face 1) and a constant
temperature of 300 ∘C to the right side of the block (face 3). All other faces are insulated
by default.
thermalBC(thermalmodel,'Face',1,'Temperature',100);
thermalBC(thermalmodel,'Face',3,'Temperature',300);
5-789
5 Functions — Alphabetical List
generateMesh(thermalmodel);
thermalresults = solve(thermalmodel)
thermalresults =
SteadyStateThermalResults with properties:
The solver finds the temperatures and temperature gradients at the nodal locations. To
access these values, use thermalresults.Temperature,
thermalresults.XGradients, and so on. For example, plot temperatures at the nodal
locations.
pdeplot3D(thermalmodel,'ColorMapData',thermalresults.Temperature)
5-790
pdeplot3D
For a 3-D steady-state thermal model, evaluate heat flux at the nodal locations and at the
points specified by x, y, and z coordinates.
thermalmodel = createpde('thermal');
5-791
5 Functions — Alphabetical List
importGeometry(thermalmodel,'Block.stl');
pdegplot(thermalmodel,'FaceLabels','on','FaceAlpha',0.5)
title('Copper block, cm')
axis equal
Assuming that this is a copper block, the thermal conductivity of the block is
approximately 4 W /(cmK).
thermalProperties(thermalmodel,'ThermalConductivity',4);
Apply a constant temperature of 373 K to the left side of the block (face 1) and a constant
temperature of 573 K to the right side of the block (face 3).
thermalBC(thermalmodel,'Face',1,'Temperature',373);
thermalBC(thermalmodel,'Face',3,'Temperature',573);
5-792
pdeplot3D
thermalBC(thermalmodel,'Face',4,'HeatFlux',-20);
generateMesh(thermalmodel);
thermalresults = solve(thermalmodel)
thermalresults =
SteadyStateThermalResults with properties:
[qx,qy,qz] = evaluateHeatFlux(thermalresults);
figure
pdeplot3D(thermalmodel,'FlowData',[qx qy qz])
5-793
5 Functions — Alphabetical List
Create a grid specified by x, y, and z coordinates, and evaluate heat flux to the grid.
[X,Y,Z] = meshgrid(1:26:100,1:6:20,1:11:50);
[qx,qy,qz] = evaluateHeatFlux(thermalresults,X,Y,Z);
Reshape the qx, qy, and qz vectors, and plot the resulting heat flux.
qx = reshape(qx,size(X));
qy = reshape(qy,size(Y));
qz = reshape(qz,size(Z));
figure
quiver3(X,Y,Z,qx,qy,qz)
5-794
pdeplot3D
Alternatively, you can specify the grid by using a matrix of query points.
qx = reshape(qx,size(X));
qy = reshape(qy,size(Y));
qz = reshape(qz,size(Z));
figure
quiver3(X,Y,Z,qx,qy,qz)
5-795
5 Functions — Alphabetical List
structuralmodel = createpde('structural','static-solid');
importGeometry(structuralmodel,'SquareBeam.STL');
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
5-796
pdeplot3D
structuralProperties(structuralmodel,'PoissonsRatio',0.3, ...
'YoungsModulus',210E3);
structuralBC(structuralmodel,'Face',6,'Constraint','fixed');
structuralBoundaryLoad(structuralmodel,'Face',5,'SurfaceTraction',[0;0;-2]);
5-797
5 Functions — Alphabetical List
generateMesh(structuralmodel);
structuralresults = solve(structuralmodel);
Plot the deformed shape with the von Mises stress using the default scale factor. By
default, pdeplot3D internally determines the scale factor based on the dimensions of the
geometry and the magnitude of deformation.
figure
pdeplot3D(structuralmodel,'ColorMapData',structuralresults.VonMisesStress, ...
'Deformation',structuralresults.Displacement)
5-798
pdeplot3D
'Deformation',structuralresults.Displacement, ...
'DeformationScaleFactor',500)
figure
pdeplot3D(structuralmodel,'ColorMapData',structuralresults.VonMisesStress)
5-799
5 Functions — Alphabetical List
Create the geometry and include it in the model. Plot the geometry.
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
5-800
pdeplot3D
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
Apply a sinusoidal displacement along the y-direction on the end opposite the fixed end of
the beam.
5-801
5 Functions — Alphabetical List
structuralBC(structuralmodel,'Face',3,'YDisplacement',1E-4,'Frequency',50);
Generate a mesh.
generateMesh(structuralmodel,'Hmax',0.01);
structuralIC(structuralmodel,'Displacement',[0;0;0],'Velocity',[0;0;0]);
tlist = 0:0.002:0.2;
structuralresults = solve(structuralmodel,tlist);
vmStress = evaluateVonMisesStress(structuralresults);
figure
pdeplot3D(structuralmodel,'ColorMapData',vmStress(:,end))
title('von Mises Stress in the Beam for the Last Time-Step')
5-802
pdeplot3D
model = createpde;
importGeometry(model,'Tetrahedron.stl');
mesh = generateMesh(model,'Hmax',20,'GeometricOrder','linear');
pdeplot3D(model)
5-803
5 Functions — Alphabetical List
pdeplot3D(mesh)
5-804
pdeplot3D
Another approach is to use the nodes and elements of the mesh as input arguments for
pdeplot3D.
pdeplot3D(mesh.Nodes,mesh.Elements)
5-805
5 Functions — Alphabetical List
pdeplot3D(model,'NodeLabels','on')
view(101,12)
5-806
pdeplot3D
pdeplot3D(model,'ElementLabels','on')
view(101,12)
5-807
5 Functions — Alphabetical List
Input Arguments
model — Model object
PDEModel object | ThermalModel object | StructuralModel object
5-808
pdeplot3D
Mesh object, specified as the Mesh property of a PDEModel object or as the output of
generateMesh.
Example: model.Mesh
5-809
5 Functions — Alphabetical List
5-810
pdeplot3D
Example: 'ColorMapData',results.NodalSolution(:,1)
Data Types: double
Data for the quiver plot on page 5-785, specified as the comma-separated pair consisting
of 'FlowData' and an M-by-3 matrix, where M is the number of mesh nodes. FlowData
contains the x, y, and z values of the field at the mesh points. Set FlowData as follows:
results = solvepde(model);
[cgradx,cgrady,cgradz] = evaluateCGradient(results);
pdeplot3D(model,'FlowData',[cgradx cgrady cgradz])
Indicator to show the mesh, specified as the comma-separated pair consisting of 'Mesh'
and 'on' or 'off'. Specify 'on' to show the mesh in the plot.
Example: 'Mesh','on'
Data Types: char | string
5-811
5 Functions — Alphabetical List
Example: 'ElementLabels','on'
Data Types: char | string
Surface transparency for 3-D geometry, specified as the comma-separated pair consisting
of 'FaceAlpha' and a real number from 0 through 1. The default value 1 indicates no
transparency. The value 0 indicates complete transparency.
Example: 'FaceAlpha',0.5
Data Types: double
Output Arguments
h — Handles to graphics objects
vector
See Also
PDEModel | pdeplot
Topics
“Plot 3-D Solutions and Their Gradients” on page 3-325
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2015a
5-812
pdepoly
pdepoly
Package: pde
Syntax
pdepoly(X,Y)
pdepoly(X,Y,label)
Description
pdepoly(X,Y) draws a polygon with the corner coordinates (vertices) defined by X and
Y. The pdepoly command opens the PDE Modeler app with the specified polygon drawn
in it. If the app is already open, pdepoly adds the specified polygon to the app window
without deleting any existing shapes.
pdepoly updates the state of the geometry description matrix inside the PDE Modeler
app to include the polygon. You can export the geometry description matrix from the PDE
Modeler app to the MATLAB Workspace by selecting DrawExport Geometry
Description, Set Formula, Labels.... For details on the format of the geometry
description matrix, see decsg.
Examples
Open the PDE Modeler app window containing a polygon representing the L-shaped
membrane geometry.
pdepoly([-1 0 0 1 1 -1],[0 0 1 1 -1 -1])
5-813
5 Functions — Alphabetical List
Call the pdepoly command again to draw the diamond-shaped region with corners in
(0.5,0), (1,-0.5), (0.5,-1), and (0,-0.5). The pdepoly command adds the
second polygon to the app window without deleting the first.
5-814
pdepoly
5-815
5 Functions — Alphabetical List
Open the PDE Modeler app window with a polygon representing the L-shaped membrane
geometry. Assign the name L-shaped-membrane to this polygon.
5-816
pdepoly
5-817
5 Functions — Alphabetical List
Input Arguments
X — x-coordinates of vertices
vector of real numbers
Y — y-coordinates of vertices
vector of real numbers
label — Name
character vector | string scalar
Tips
• pdepoly opens the PDE Modeler app and draws a polygon. If, instead, you want to
draw polygons in a MATLAB figure, use the plot function, for example:
x = [-1,-0.5,-0.5,0,1.5,-0.5,-1];
y = [-1,-1,-0.5,0,0.5,0.9,-1];
plot(x,y,'.-')
See Also
PDE Modeler | pdecirc | pdeellip | pderect
5-818
pdeprtni
pdeprtni
(Not recommended) Interpolate from triangle midpoint data to node data
Syntax
un = pdeprtni(p,t,ut)
Description
un = pdeprtni(p,t,ut) gives linearly interpolated values at node points from the
values at triangle midpoints.
The geometry of the PDE problem is given by the mesh data p and t. For details on the
mesh data representation, see initmesh.
Let N be the dimension of the PDE system, np the number of node points, and nt the
number of triangles. The components of triangle data in ut are stored as N rows of length
nt. The components of the node data are stored in un as N columns of length np.
Caution
pdeprtni and pdeintrp are not inverse functions. The interpolation introduces some
averaging.
See Also
interpolateSolution | solvepde
5-819
5 Functions — Alphabetical List
pderect
Package: pde
Syntax
pderect([xmin xmax ymin ymax])
pderect([xmin xmax ymin ymax], label)
Description
pderect([xmin xmax ymin ymax]) draws a rectangle with the corner coordinates
defined by [xmin xmax ymin ymax]. The pderect command opens the PDE Modeler
app with the specified rectangle drawn in it. If the app is already open, pderect adds the
specified rectangle to the app window without deleting any existing shapes.
pderect updates the state of the geometry description matrix inside the PDE Modeler
app to include the rectangle. You can export the geometry description matrix from the
PDE Modeler app to the MATLAB Workspace by selecting DrawExport Geometry
Description, Set Formula, Labels.... For details on the format of the geometry
description matrix, see decsg.
Examples
Open the PDE Modeler app window containing a rectangle with the corners at
(-1,-0.5), (-1,0.5), (1,0.5), and (1,-0.5).
5-820
pderect
Call the pderect command again to draw a square with the corners at (-0.25,-0.25),
(-0.25,0.25), (0.25,0.25), and (0.25,-0.25). The pderect command adds the
square to the app window without deleting the rectangle.
5-821
5 Functions — Alphabetical List
5-822
pderect
Open the PDE Modeler app window and draw a rectangle with the corners at (-1,-0.5),
(-1,0.5), (1,0.5), and (1,-0.5). Assign the name rectangle1 to this rectangle.
5-823
5 Functions — Alphabetical List
5-824
pderect
Input Arguments
[xmin xmax ymin ymax] — Corner coordinates
vector of real numbers
label — Name
character vector | string scalar
Tips
• pderect opens the PDE Modeler app and draws a rectangle. If, instead, you want to
draw rectangles in a MATLAB figure, use the rectangle function, for example,
rectangle('Position',[1,2,5,6]).
See Also
PDE Modeler | pdecirc | pdeellip | pdepoly
5-825
5 Functions — Alphabetical List
Note pdesdp and pdesdt are not recommended. Use findNodes and findElements
instead.
Syntax
c = pdesdp(p,e,t)
[i,c] = pdesdp(p,e,t)
c = pdesdp(p,e,t,sdl)
[i,c] = pdesdp(p,e,t,sdl)
i = pdesdt(t)
i = pdesdt(t,sdl)
i = pdesde(e)
i = pdesde(e,sdl)
Description
[i,c] = pdesdp(p,e,t,sdl) given mesh data p, e, and t and a list of subdomain
numbers sdl, the function returns all points belonging to those subdomains. A point can
belong to several subdomains, and the points belonging to the domains in sdl are divided
into two disjoint sets. i contains indices of the points that wholly belong to the
subdomains listed in sdl, and c lists points that also belongs to the other subdomains.
c = pdesdp(p,e,t,sdl) returns indices of points that belong to more than one of the
subdomains in sdl.
5-826
pdesdp, pdesde, pdesdt
5-827
5 Functions — Alphabetical List
pdesmech
(Not recommended) Calculate structural mechanics tensor functions
Note pdesmech is not recommended. Use the PDE Modeler app instead.
Syntax
ux = pdesmech(p,t,c,u,'PropertyName',PropertyValue,...)
Description
ux = pdesmech(p,t,c,u,'PropertyName',PropertyValue,...) returns a tensor
expression evaluated at the center of each triangle. The tensor expressions are stresses
and strains for structural mechanics applications with plane stress or plane strain
conditions. pdesmech is intended to be used for postprocessing of a solution computed
using the structural mechanics application modes of the PDE Modeler app, after
exporting the solution, the mesh, and the PDE coefficients to the MATLAB workspace.
Poisson's ratio, nu, has to be supplied explicitly for calculations of shear stresses and
strains, and for the von Mises effective stress in plane strain mode.
5-828
pdesmech
• ∂u
'ux', which is
∂x
• ∂u
'uy', which is
∂y
• ∂v
'vx', which is
∂x
• ∂v
'vy', which is
∂y
• 'exx', the x-direction strain (εx)
• 'eyy', the y-direction strain (εy)
• 'exy', the shear strain (γxy)
• 'sxx', the x-direction stress (σx)
• 'syy', the y-direction stress (σy)
• 'sxy', the shear stress (τxy)
• 'e1', the first principal strain (ε1)
• 'e2', the second principal strain (ε2)
• 's1', the first principal stress (σ1)
5-829
5 Functions — Alphabetical List
Examples
Assuming that a problem has been solved using the application mode Structural
Mechanics, Plane Stress, and that the solution u, the mesh data p and t, and the PDE
coefficient c all have been exported to the MATLAB workspace, the x-direction strain is
computed as
sx = pdesmech(p,t,c,u,'tensor','sxx');
To compute the von Mises effective stress for a plane strain problem with Poisson's ratio
equal to 0.3, type
mises = pdesmech(p,t,c,u,'tensor','vonmises',...
'application','pn','nu',0.3);
5-830
PDESolverOptions Properties
PDESolverOptions Properties
Algorithm options for solvers
Description
A PDESolverOptions object contains options used by the solvers when solving a
structural, thermal, or general PDE problem specified as a StructuralModel,
ThermalModel, or PDEModel object, respectively. StructuralModel, ThermalModel,
and PDEModel objects contain a PDESolverOptions object in their SolverOptions
property.
Solvers for structural modal analysis problems and reduced-order modeling use the
Lanczos algorithm.
Properties
Statistics and Convergence Report
Flag to display the internal solver statistics and the convergence report during the
solution process, returned as 'off' or 'on'.
Example: model.SolverOptions.ReportStatistics = 'on'
Data Types: char
ODE Solver
Absolute tolerance for the internal ODE solver, returned as a positive real number.
Absolute tolerance is a threshold below which the value of the solution component is
unimportant. This property determines the accuracy when the solution approaches zero.
5-831
5 Functions — Alphabetical List
Relative tolerance for the internal ODE solver, returned as a positive real number. This
tolerance is a measure of the error relative to the size of each solution component.
Roughly, it controls the number of correct digits in all solution components, except those
smaller than thresholds imposed by AbsoluteTolerance. The default value corresponds
to 0.1% accuracy.
Example: model.SolverOptions.RelativeTolerance = 5.0000e-03
Data Types: double
Nonlinear Solver
Acceptable residual tolerance for the internal nonlinear solver, returned as a positive real
number. The nonlinear solver iterates until the residual size is less than the value of
ResidualTolerance.
Example: model.SolverOptions.ResidualTolerance = 5.0000e-04
Data Types: double
Maximal number of Gauss-Newton iterations for the internal nonlinear solver, returned as
a positive integer.
Example: model.SolverOptions.MaxIterations = 30
Data Types: double
5-832
PDESolverOptions Properties
Minimum damping of the search direction for the internal nonlinear solver, returned as a
positive real number. For details, see “Nonlinear Solver Algorithm” on page 5-834.
Example: model.SolverOptions.MinStep = 1.5259e-7
Data Types: double
Type of norm for computing the residual for the internal nonlinear solver, returned as
Inf, -Inf, a positive real number, or 'energy'.
ρ ∞
= maxi ρ i
ρ −∞
= mini ρ i
1
N
p p
∑ ρk
k=1
ρ p = 1
Np
ρ = ρT Kρ
Here, K is the combined stiffness matrix defined in “Nonlinear Solver Algorithm” on page
5-834.
Example: model.SolverOptions.ResidualNorm = 'energy'
Data Types: double | char
Lanczos Solver
5-833
5 Functions — Alphabetical List
Maximum number of Lanczos shifts, specified as a positive integer. Increase this value
when computing a large number of eigenpairs.
Example: model.SolverOptions.MaxShift = 500
Data Types: double
Block size for block Lanczos recurrence, specified as a positive integer. The default
number ranges from 7 to 25, depending on the size of the stiffness matrix K.
Example: model.SolverOptions.BlockSize = 20
Data Types: double
Algorithms
Nonlinear Solver Algorithm
The residual equation of a nonlinear PDE is as follows:
r u = − ∇⋅ c u ∇ u +a u u−f u =0
To obtain a discretized residual equation, apply the finite element method (FEM) to a
partial differential equation as described in “Finite Element Method Basics” on page 1-13:
ρ U =K U U−F U =0
The nonlinear solver uses a Gauss-Newton iteration scheme applied to the finite element
matrices. Use a Taylor series expansion to obtain the linearized system for the residual:
∂ρ Un
ρ Un + 1 ≅ ρ Un + Un + 1 − Un + … = 0
∂U
∂ρ Un
Un + 1 − Un = − ρ Un
∂U
5-834
PDESolverOptions Properties
−1
∂ρ Un
pn = − ρ Un
∂U
The Gauss-Newton iteration minimizes the residual, that is, the solution of minU ρ U ,
using the equation
Un + 1 = Un + αpn
Here, ɑ ≤ 1 is a positive number, that must be set as large as possible so that the step has
a reasonable descent. For a sufficiently small ɑ,
ρ Un + αpn < ρ Un
For the Gauss-Newton algorithm to converge, U0 must be close enough to the solution.
The first guess is often outside the region of convergence. The Armijo-Goldstein line
search (a damping strategy for choosing ɑ) helps to improve convergence from bad initial
guesses. This method chooses the largest damping coefficient ɑ out of the sequence 1,
1/2, 1/4, . . . such that the following inequality holds:
α
ρ Un − ρ Un + αpn ≥ ρ Un
2
Using the Armijo-Goldstein line search guarantees a reduction of the residual norm by at
least 1 − α/2. Each step of the line-search algorithm must evaluate the residual
ρ Un + αpn .
With this strategy, when Un approaches the solution, α→1, thus, the convergence rate
increases.
See Also
PDEModel | solvepde | solvepdeeig
Introduced in R2016a
5-835
5 Functions — Alphabetical List
pdesurf
Shorthand command for surface plot
Note This page describes the legacy workflow. Use it when you work with legacy code
and do not plan to convert it to use the recommended approach. Otherwise, use pdeplot.
Syntax
pdesurf(p,t,u)
Description
pdesurf(p,t,u) plots a 3-D surface of PDE node or triangle data. If u is a column
vector, node data is assumed, and continuous style and interpolated shading are used. If u
is a row vector, triangle data is assumed, and discontinuous style and flat shading are
used.
For node data, this command is just shorthand for the call
pdeplot(p,[],t,'XYData',u,'XYStyle','interp',...
'ZData',u,'ZStyle','continuous',...
'ColorBar','off');
pdeplot(p,[],t,'XYData',u,'XYStyle','flat',...
'ZData',u,'ZStyle','discontinuous',...
'ColorBar','off');
If you want to have more control over your surface plot, use pdeplot instead of
pdesurf.
5-836
pdesurf
Examples
Surface plot of the solution to the equation −Δu = 1 over the geometry defined by the L-
shaped membrane. Use Dirichlet boundary conditions u = 0 on ∂Ω.
[p,e,t] = initmesh('lshapeg');
[p,e,t] = refinemesh('lshapeg',p,e,t);
u = assempde('lshapeb',p,e,t,1,0,1);
pdesurf(p,t,u)
5-837
5 Functions — Alphabetical List
See Also
pdecont | pdemesh | pdeplot
5-838
PDE Modeler
PDE Modeler
Create complex 2-D geometries by drawing, overlapping, and rotating basic shapes
Description
The PDE Modeler app provides an interactive interface for solving 2-D geometry
problems. Using the app, you can create complex geometries by drawing, overlapping,
and rotating basic shapes, such as circles, polygons and so on. The app also includes
preset modes for applications, such as electrostatics, magnetostatics, heat transfer, and
so on.
You can choose to export data to the MATLAB workspace from any step in the app and
continue your work outside the app.
Note The app does not support 3-D geometry problems and systems of more than two
PDEs.
5-839
5 Functions — Alphabetical List
Examples
• “Solve 2-D PDEs Using the PDE Modeler App” on page 1-6
• “Open the PDE Modeler App” on page 4-2
• “2-D Geometry Creation in PDE Modeler App” on page 4-3
• “Specify Boundary Conditions in the PDE Modeler App” on page 4-15
• “Specify Coefficients in PDE Modeler App” on page 4-18
• “Specify Mesh Parameters in the PDE Modeler App” on page 4-29
• “Adjust Solve Parameters in the PDE Modeler App” on page 4-31
• “Plot the Solution in the PDE Modeler App” on page 4-38
• “von Mises Effective Stress and Displacements: PDE Modeler App” on page 3-3
• “Heat Transfer in Block with Cavity: PDE Modeler App” on page 3-233
• “Heat Distribution in Circular Cylindrical Rod: PDE Modeler App” on page 3-275
• “Heat Transfer Between Two Squares Made of Different Materials: PDE Modeler
App” on page 3-185
• “Poisson's Equation on Unit Disk: PDE Modeler App” on page 3-199
• “Poisson’s Equation with Complex 2-D Geometry: PDE Modeler App” on page 1-9
• “Electrostatic Potential in Air-Filled Frame: PDE Modeler App” on page 3-147
• “Magnetic Field in Two-Pole Electric Motor: PDE Modeler App” on page 3-157
• “Wave Equation on Square Domain: PDE Modeler App” on page 3-284
• “Scattering Problem: PDE Modeler App” on page 3-215
• “Skin Effect in Copper Wire with Circular Cross Section: PDE Modeler App” on page
3-174
• “Poisson's Equation on Unit Disk: PDE Modeler App” on page 3-199
• “Minimal Surface Problem: PDE Modeler App” on page 3-225
• “Current Density Between Two Metallic Conductors: PDE Modeler App” on page 3-
182
• “L-Shaped Membrane with Rounded Corner: PDE Modeler App” on page 3-296
• “Eigenvalues and Eigenmodes of Square: PDE Modeler App” on page 3-306
• “Eigenvalues and Eigenmodes of L-Shaped Membrane: PDE Modeler App” on page
3-293
5-840
PDE Modeler
Programmatic Use
pdeModeler opens the PDE Modeler app or brings focus to the app if it is already open.
pdecirc(xc,yc,r) opens the PDE Modeler app and draws a circle with center in
(xc,yc) and radius r.
pdeellip(xc,yc,a,b,phi) opens the PDE Modeler app and draws an ellipse with
center in (xc,yc) and semiaxes a and b. The rotation of the ellipse (in radians) is phi.
pdepoly(x,y) opens the PDE Modeler app and draws a polygon with corner coordinates
defined by x and y.
pderect([xmin xmax ymin ymax]) opens the PDE Modeler app and draws a
rectangle with corner coordinates defined by [xmin xmax ymin ymax].
See Also
Functions
pdecirc | pdeellip | pdepoly | pderect
Topics
“Solve 2-D PDEs Using the PDE Modeler App” on page 1-6
“Open the PDE Modeler App” on page 4-2
“2-D Geometry Creation in PDE Modeler App” on page 4-3
“Specify Boundary Conditions in the PDE Modeler App” on page 4-15
“Specify Coefficients in PDE Modeler App” on page 4-18
“Specify Mesh Parameters in the PDE Modeler App” on page 4-29
“Adjust Solve Parameters in the PDE Modeler App” on page 4-31
“Plot the Solution in the PDE Modeler App” on page 4-38
“von Mises Effective Stress and Displacements: PDE Modeler App” on page 3-3
“Heat Transfer in Block with Cavity: PDE Modeler App” on page 3-233
“Heat Distribution in Circular Cylindrical Rod: PDE Modeler App” on page 3-275
“Heat Transfer Between Two Squares Made of Different Materials: PDE Modeler App” on
page 3-185
“Poisson's Equation on Unit Disk: PDE Modeler App” on page 3-199
“Poisson’s Equation with Complex 2-D Geometry: PDE Modeler App” on page 1-9
“Electrostatic Potential in Air-Filled Frame: PDE Modeler App” on page 3-147
“Magnetic Field in Two-Pole Electric Motor: PDE Modeler App” on page 3-157
5-841
5 Functions — Alphabetical List
5-842
pdetrg
pdetrg
(Not recommended) Triangle geometry data
Syntax
[ar,a1,a2,a3] = pdetrg(p,t)
[ar,g1x,g1y,g2x,g2y,g3x,g3y] = pdetrg(p,t)
Description
[ar,a1,a2,a3] = pdetrg(p,t) returns the area of each triangle in ar and half of the
negative cotangent of each angle in a1, a2, and a3.
The triangular mesh of the PDE problem is given by the mesh data p and t. For details on
the mesh data representation, see initmesh.
5-843
5 Functions — Alphabetical List
pdetriq
(Not recommended) Triangle quality measure
Syntax
q = pdetriq(p,t)
Description
q = pdetriq(p,t) returns a triangle quality measure given mesh data.
The triangular mesh is given by the mesh data p, e, and t. For details on the mesh data
representation, see initmesh.
4a 3
q= 2 2 2
h1 + h2 + h3
where a is the area and h1, h2, and h3 the side lengths of the triangle.
References
Bank, Randolph E., PLTMG: A Software Package for Solving Elliptic Partial Differential
Equations, User's Guide 6.0, Society for Industrial and Applied Mathematics,
Philadelphia, PA, 1990.
5-844
pdetriq
See Also
Introduced before R2006a
5-845
5 Functions — Alphabetical List
poiasma
(Not recommended) Boundary point matrix contributions for fast solvers of Poisson's
equation
Note poiasma is not recommended. To solve Poisson's equations, use solvepde. For
details, see “Solve Problems Using PDEModel Objects”.
Syntax
K = poiasma(n1,n2,h1,h2)
K = poiasma(n1,n2)
K = poiasma(n)
Description
K = poiasma(n1,n2,h1,h2) assembles the contributions to the stiffness matrix from
boundary points. n1 and n2 are the numbers of points in the first and second directions,
and h1 and h2 are the mesh spacings. K is a sparse n1*n2-by-n1*n2 matrix. The point
numbering is the canonical numbering for a rectangular mesh.
K = poiasma(n) uses n1 = n2 = n.
See Also
Introduced before R2006a
5-846
poicalc
poicalc
Fast solver for Poisson's equation on rectangular grid
Note poicalc is not recommended. To solve Poisson's equations, use solvepde. For
details, see “Solve Problems Using PDEModel Objects”.
Syntax
u = poicalc(f,h1,h2,n1,n2)
u = poicalc(f,h1,h2)
u = poicalc(f)
Description
u = poicalc(f,h1,h2,n1,n2) calculates the solution of Poisson's equation for the
interior points of an evenly spaced rectangular grid. The columns of u contain the
solutions corresponding to the columns of the right-hand side f. h1 and h2 are the
spacings in the first and second direction, and n1 and n2 are the number of points.
The number of rows in f must be n1*n2. If n1 and n2 are not given, the square root of
the number of rows of f is assumed. If h1 and h2 are not given, they are assumed to be
equal.
The ordering of the rows in u and f is the canonical ordering of interior points, as
returned by poiindex.
The solution is obtained by sine transforms in the first direction and tridiagonal matrix
solution in the second direction. n1 should be 1 less than a power of 2 for best
performance.
5-847
5 Functions — Alphabetical List
See Also
Introduced before R2006a
5-848
poiindex
poiindex
(Not recommended) Indices of points in canonical ordering for rectangular grid
Note poiindex is not recommended. To solve Poisson's equations, use solvepde. For
details, see “Solve Problems Using PDEModel Objects”.
Syntax
[n1,n2,h1,h2,i,c,ii,cc] = poiindex(p,e,t,sd)
Description
[n1,n2,h1,h2,i,c,ii,cc] = poiindex(p,e,t,sd) identifies a given grid p, e, t in
the subdomain sd as an evenly spaced rectangular grid. If the grid is not rectangular, n1
is 0 on return. Otherwise n1 and n2 are the number of points in the first and second
directions, h1 and h2 are the spacings. i and ii are of length (n1-2)*(n2-2) and
contain indices of interior points. i contains indices of the original mesh, whereas ii
contains indices of the canonical ordering. c and cc are of length n1*n2-
(n1-2)*(n2-2) and contain indices of border points. ii and cc are increasing.
In the canonical ordering, points are numbered from left to right and then from bottom to
top. Thus if n1 = 3 and n2 = 5, then ii = [5 8 11] and cc = [1 2 3 4 6 7 9 10
12 13 14 15].
5-849
5 Functions — Alphabetical List
poimesh
(Not recommended) Make regular mesh on rectangular geometry
Note poimesh is not recommended. To solve Poisson's equations, use solvepde. For
details, see “Solve Problems Using PDEModel Objects”.
Syntax
[p,e,t] = poimesh(g,nx,ny)
[p,e,t] = poimesh(g,n)
[p,e,t] = poimesh(g)
Description
[p,e,t] = poimesh(g,nx,ny) constructs a regular mesh on the rectangular geometry
specified by g, by dividing the “x edge” into nx pieces and the “y edge” into ny pieces,
and placing (nx+1)*(ny+1) points at the intersections.
The “x edge” is the one that makes the smallest angle with the x-axis.
The triangular mesh is described by the mesh data p, e, and t. For details on the mesh
data representation, see initmesh.
For best performance with poisolv, the larger of nx and ny should be a power of 2.
5-850
poisolv
poisolv
(Not recommended) Fast solution of Poisson's equation on rectangular grid
Note poisolv is not recommended. To solve Poisson's equations, use solvepde. For
details, see “Solve Problems Using PDEModel Objects”.
Syntax
u = poisolv(b,p,e,t,f)
Description
u = poisolv(b,p,e,t,f) solves Poisson's equation with Dirichlet boundary conditions
on a regular rectangular grid. A combination of sine transforms and tridiagonal solutions
is used for increased performance.
The boundary conditions b must specify Dirichlet conditions for all boundary points.
The mesh p, e, and t must be a regular rectangular grid. For details on the mesh data
representation, see initmesh.
References
Strang, Gilbert, Introduction to Applied Mathematics, Wellesley-Cambridge Press,
Cambridge, MA, 1986, pp. 453–458.
5-851
5 Functions — Alphabetical List
reconstructSolution
Package: pde
Syntax
structuralresults = reconstructSolution(Rcb,u,ut,utt,tlist)
Description
structuralresults = reconstructSolution(Rcb,u,ut,utt,tlist) recovers
the full solution from the reduced-order model Rcb, displacement u, velocity ut, and
acceleration utt. Typically, the displacement, velocity, and acceleration are the values
returned by Simscape™.
Examples
Knowing the solution in terms of the interface DoFs and modal DoFs, reconstruct the
solution for the full model.
modelT = createpde('structural','transient-solid');
gm = multicuboid(0.05,0.003,0.003);
modelT.Geometry = gm;
5-852
reconstructSolution
figure
pdegplot(modelT,'FaceLabels','on','FaceAlpha',0.5)
view([71 4])
figure
pdegplot(modelT,'EdgeLabels','on','FaceAlpha',0.5)
view([71 4])
5-853
5 Functions — Alphabetical List
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(modelT,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
Generate a mesh.
5-854
reconstructSolution
generateMesh(modelT);
structuralBoundaryLoad(modelT,'Vertex',loadedVertex, ...
'Force',[0;0;10],'Frequency',6000);
Define superelement interfaces using the fixed and loaded boundaries. In this case, the
reduced order model retains the DoFs on the fixed face and the loaded vertex while
condensing all other DoFs in favor of modal DoFs. For better performance, use the set of
edges bounding face 5 instead of using the entire face.
structuralSEInterface(modelT,'Edge',[2 8 11 12]);
structuralSEInterface(modelT,'Vertex',loadedVertex);
rom = reduce(modelT,'FrequencyRange',[-0.1,5e5]);
Next, use the reduced order model to simulate the transient dynamics. Use the ode15s
function directly to integrate the reduced system ODE. Working with the reduced model
requires indexing into the reduced system matrices rom.K and rom.M. First, construct
mappings of indices of K and M to loaded and fixed DoFs by using the data available in
rom.
Create a function that returns DoF IDs given node IDs and the number of nodes.
Knowing the DoF IDs for the given node IDs, use the intersect function to find the
required indices.
numNodes = size(rom.Mesh.Nodes,2);
5-855
5 Functions — Alphabetical List
loadedNode = findNodes(rom.Mesh,'region','Vertex',loadedVertex);
loadDoFs = getDoF(loadedNode,numNodes);
[~,loadNodeROMIds,~] = intersect(rom.RetainedDoF,loadDoFs);
In the reduced matrices rom.K and rom.M, generalized modal DoFs appear after the
retained DoFs.
Because fixed-end DoFs are not a part of the ODE system, the indices for the ODE DoFs in
reduced matrices are as follows.
odeDoFs = [loadNodeROMIds;fixedIntModeIds];
The relevant components of rom.K and rom.M for time integration are:
Kconstrained = rom.K(odeDoFs,odeDoFs);
Mconstrained = rom.M(odeDoFs,odeDoFs);
numODE = numel(odeDoFs);
Now you have a second-order system of ODEs. To use ode15s, convert this into a system
of first-order ODEs by applying linearization. Such a first-order system is twice the size of
the second-order system.
The specified concentrated force load in the full system is along the z-direction, which is
the third DoF in the ODE system. Accounting for the linearization to obtain the first-order
system gives the loaded ODE DoF.
loadODEDoF = numODE + 3;
Specify the mass matrix and the Jacobian for the ODE solver.
odeoptions = odeset;
odeoptions = odeset(odeoptions,'Jacobian',-Kode);
odeoptions = odeset(odeoptions,'Mass',Mode);
u0 = zeros(2*numODE,1);
5-856
reconstructSolution
Solve the reduced system by using ode15s and the helper function CMSODEf, which is
defined at the end of this example.
tlist = 0:0.00005:3E-3;
sol = ode15s(@(t,y) CMSODEf(t,y,Kode,Fode,loadODEDoF),tlist,u0,odeoptions);
Compute the values of the ODE variable and the time derivatives.
[displ,vel] = deval(sol,tlist);
Knowing the solution in terms of the interface DoFs and modal DoFs, you can reconstruct
the solution for the full model. The reconstructSolution function requires the
displacement, velocity, and acceleration at all DoFs in rom. Construct the complete
solution vector, including the zero values at the fixed DoFs.
u = zeros(size(rom.K,1),numel(tlist));
ut = zeros(size(rom.K,1),numel(tlist));
utt = zeros(size(rom.K,1),numel(tlist));
u(odeDoFs,:) = displ(1:numODE,:);
ut(odeDoFs,:) = vel(1:numODE,:);
utt(odeDoFs,:) = vel(numODE+1:2*numODE,:);
RTrom = reconstructSolution(rom,u,ut,utt,tlist);
Compute the displacement in the interior at the center of the beam using the
reconstructed solution.
coordCenter = [0;0;0];
iDispRTrom = interpolateDisplacement(RTrom, coordCenter);
figure
plot(tlist,iDispRTrom.uz)
title('Z-Displacement at Geometric Center')
5-857
5 Functions — Alphabetical List
function f = CMSODEf(t,u,Kode,Fode,loadedVertex)
Fode(loadedVertex) = 10*sin(6000*t);
f = -Kode*u +Fode;
end
Input Arguments
Rcb — Structural results obtained using Craig-Bampton order reduction method
ReducedStructuralModel object
5-858
reconstructSolution
Structural results obtained using the Craig-Bampton order reduction method, specified as
a ReducedStructuralModel object.
u — Displacement
matrix
Displacement, specified as a matrix. The number of rows in the matrix must equal the
sum of the numbers of interface degrees of freedom and the number of modes. The X-
displacements at the retained degrees of freedom must appear first, then the y-
displacements, and, for a 3-D geometry, z-displacements, followed by the generalized
modal degrees of freedom. The number of columns must equal the number of elements in
tlist.
Data Types: double
ut — Velocity
matrix
Velocity, specified as a matrix. The number of rows in the matrix must equal the sum of
the numbers of interface degrees of freedom and the number of modes. The X-velocities
at the retained degrees of freedom must appear first, then the y-velocities, and, for a 3-D
geometry, z-velocities, followed by the generalized modal degrees of freedom. The
number of columns must equal the number of elements in tlist.
Data Types: double
utt — Acceleration
matrix
Acceleration, specified as a matrix. The number of rows in the matrix must equal the sum
of the numbers of interface degrees of freedom and the number of modes. The X-
accelerations at the retained degrees of freedom must appear first, then the y-
accelerations, and, for a 3-D geometry, z-accelerations, followed by the generalized modal
degrees of freedom. The number of columns must equal the number of elements in
tlist.
Data Types: double
Solution times for solving the reduced-order model, specified as a real vector.
Data Types: double
5-859
5 Functions — Alphabetical List
Output Arguments
structuralresults — Transient structural results
TransientStructuralResults object
See Also
ReducedStructuralModel | StructuralModel | reduce | solve | structuralBC |
structuralSEInterface
Introduced in R2019b
5-860
reduce
reduce
Package: pde
Syntax
Rcb = reduce(structuralmodel,'FrequencyRange',[omega1,omega2])
Description
Rcb = reduce(structuralmodel,'FrequencyRange',[omega1,omega2]) reduces
a structural analysis model to the fixed interface modes in the frequency range
[omega1,omega2] and the boundary interface degrees of freedom.
Examples
Reduce the model to the fixed interface modes in the specified frequency range and the
boundary interface degrees of freedom.
structuralmodel = createpde('structural','transient-solid');
gm = multicuboid(0.1,0.01,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
5-861
5 Functions — Alphabetical List
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',70E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',2700);
Generate a mesh.
generateMesh(structuralmodel);
Specify the ends of the beam as structural superelement interfaces. The reduced-order
model technique retains the degrees of freedom on the superelement interfaces while
condensing the degrees of freedom on all other boundaries. For better performance, use
the set of edges that bound each side of the beam instead of using the entire face.
5-862
reduce
structuralSEInterface(structuralmodel,'Edge',[4,6,9,10]);
structuralSEInterface(structuralmodel,'Edge',[2,8,11,12]);
Reduce the model to the fixed interface modes in the frequency range [-Inf,500000]
and the boundary interface degrees of freedom.
R = reduce(structuralmodel,'FrequencyRange',[-Inf,500000])
R =
ReducedStructuralModel with properties:
K: [166x166 double]
M: [166x166 double]
NumModes: 22
RetainedDoF: [144x1 double]
ReferenceLocations: []
Mesh: [1x1 FEMesh]
Input Arguments
structuralmodel — Structural model
StructuralModel object
Frequency range, specified as a vector of two elements. Define omega1 as slightly smaller
than the lowest expected frequency and omega2 as slightly larger than the highest
expected frequency. For example, if the lowest expected frequency is zero, then use a
small negative value for omega1.
Example: [-0.1,1000]
Data Types: double
5-863
5 Functions — Alphabetical List
Output Arguments
Rcb — Structural results obtained using Craig-Bampton order reduction method
ReducedStructuralModel object
Structural results obtained using the Craig-Bampton order reduction method, returned as
a ReducedStructuralModel object.
See Also
ReducedStructuralModel | StructuralModel | reconstructSolution | solve |
structuralBC | structuralSEInterface
Introduced in R2019b
5-864
ReducedStructuralModel
ReducedStructuralModel
Reduced order structural model results
Description
A ReducedStructuralModel object contains the stiffness matrix K, mass matrix M,
mesh, multipoint constraint reference locations, and IDs of retained degrees of freedom.
To expand this data to a full solution that includes displacement, velocity, and
acceleration, use reconstructSolution.
Creation
Reduce a structural model by using the reduce function. This function returns structural
results obtained using the Craig-Bampton reduced order method as a
ReducedStructuralModel object.
Properties
K — Reduced stiffness matrix
real matrix
• For models without multipoint constraints, N is the sum of the number of retained
degrees of freedom and the number of fixed interface modes.
• For models with Nmp multipoint constraints, N is the sum of 6*Nmp and the number of
fixed interface modes.
5-865
5 Functions — Alphabetical List
• For models without multipoint constraints, N is the sum of the number of retained
degrees of freedom and the number of fixed interface modes.
• For models with Nmp multipoint constraints, N is the sum of 6*Nmp and the number of
fixed interface modes.
Finite element mesh, returned as a FEMesh object. For details, see FEMesh.
Object Functions
reconstructSolution Recover full-model transient solution from reduced-order model
results
Examples
5-866
ReducedStructuralModel
Reduce the model to the fixed interface modes in the specified frequency range and the
boundary interface degrees of freedom.
structuralmodel = createpde('structural','transient-solid');
gm = multicuboid(0.1,0.01,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
5-867
5 Functions — Alphabetical List
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',70E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',2700);
Generate a mesh.
generateMesh(structuralmodel);
Specify the ends of the beam as structural superelement interfaces. The reduced-order
model technique retains the degrees of freedom on the superelement interfaces while
condensing the degrees of freedom on all other boundaries. For better performance, use
the set of edges that bound each side of the beam instead of using the entire face.
structuralSEInterface(structuralmodel,'Edge',[4,6,9,10]);
structuralSEInterface(structuralmodel,'Edge',[2,8,11,12]);
Reduce the model to the fixed interface modes in the frequency range [-Inf,500000]
and the boundary interface degrees of freedom.
R = reduce(structuralmodel,'FrequencyRange',[-Inf,500000])
R =
ReducedStructuralModel with properties:
K: [166x166 double]
M: [166x166 double]
NumModes: 22
RetainedDoF: [144x1 double]
ReferenceLocations: []
Mesh: [1x1 FEMesh]
More About
Degrees of Freedom (DoFs)
In Partial Differential Equation Toolbox, each node of a 2-D or 3-D geometry has two or
three degrees of freedom (DoFs), respectively. DoFs correspond to translational
displacements. If the number of mesh points in a model is NumNodes, then the toolbox
assigns the IDs to the degrees of freedom as follows:
5-868
ReducedStructuralModel
See Also
StructuralModel | reconstructSolution | reduce | structuralBC |
structuralSEInterface
Introduced in R2019b
5-869
5 Functions — Alphabetical List
refinemesh
Refine triangular mesh
Note This page describes the legacy workflow. New features might not be compatible
with the legacy workflow. For the corresponding step in the recommended workflow, see
generateMesh.
Syntax
[p1,e1,t1] = refinemesh(g,p,e,t)
[p1,e1,t1] = refinemesh(g,p,e,t,'regular')
[p1,e1,t1] = refinemesh(g,p,e,t,'longest')
[p1,e1,t1] = refinemesh(g,p,e,t,it)
[p1,e1,t1] = refinemesh(g,p,e,t,it,'regular')
[p1,e1,t1] = refinemesh(g,p,e,t,it,'longest')
[p1,e1,t1,u1] = refinemesh(g,p,e,t,u)
[p1,e1,t1,u1] = refinemesh(g,p,e,t,u,'regular')
[p1,e1,t1,u1] = refinemesh(g,p,e,t,u,'longest')
[p1,e1,t1,u1] = refinemesh(g,p,e,t,u,it)
[p1,e1,t1,u1] = refinemesh(g,p,e,t,u,it,'regular')
[p1,e1,t1,u1] = refinemesh(g,p,e,t,u,it,'longest')
Description
[p1,e1,t1] = refinemesh(g,p,e,t) returns a refined version of the triangular
mesh specified by the geometry g, Point matrix p, Edge matrix e, and Triangle matrix t.
5-870
refinemesh
The triangular mesh is given by the mesh data p, e, and t. For details on the mesh data
representation, see “Mesh Data” on page 2-171.
The default refinement method is regular refinement, where all of the specified triangles
are divided into four triangles of the same shape. Longest edge refinement, where the
longest edge of each specified triangle is bisected, can be demanded by giving longest
as a final parameter. Using regular as a final parameter results in regular refinement.
Some triangles outside of the specified set may also be refined to preserve the
triangulation and its quality.
Examples
Mesh Refinement
Refine the mesh of the L-shaped membrane several times. Plot the mesh for the geometry
of the L-shaped membrane.
[p,e,t] = initmesh('lshapeg','hmax',inf);
subplot(2,2,1), pdemesh(p,e,t)
[p,e,t] = refinemesh('lshapeg',p,e,t);
subplot(2,2,2), pdemesh(p,e,t)
[p,e,t] = refinemesh('lshapeg',p,e,t);
subplot(2,2,3), pdemesh(p,e,t)
[p,e,t] = refinemesh('lshapeg',p,e,t);
subplot(2,2,4), pdemesh(p,e,t)
5-871
5 Functions — Alphabetical List
subplot
Algorithms
The algorithm is described by the following steps:
5-872
refinemesh
See Also
initmesh | pdeent | pdesdt
Topics
“Mesh Data” on page 2-171
5-873
5 Functions — Alphabetical List
setInitialConditions
Package: pde
Syntax
setInitialConditions(model,u0)
setInitialConditions(model,u0,ut0)
setInitialConditions( ___ ,RegionType,RegionID)
setInitialConditions(model,results)
setInitialConditions(model,results,iT)
ic = setInitialConditions( ___ )
Description
setInitialConditions(model,u0) sets initial conditions in model. Use this syntax
for stationary nonlinear problems or time-dependent problems where the time derivative
is first order.
5-874
setInitialConditions
iT. If you do not specify the time index iT, setInitialConditions uses the last
solution time in results.
Examples
Create a PDE model, import geometry, and set the initial condition to 50 on the entire
geometry.
model = createpde();
importGeometry(model,'BracketWithHole.stl');
setInitialConditions(model,50);
Create a PDE model for a system with five components. Import the Block.stl geometry.
model = createpde(5);
importGeometry(model,'Block.stl');
Set the initial conditions for each component to twice the component number.
u0 = [2:2:10]';
setInitialConditions(model,u0)
ans =
GeometricInitialConditions with properties:
RegionType: 'cell'
RegionID: 1
InitialValue: [5x1 double]
InitialDerivative: []
5-875
5 Functions — Alphabetical List
Set different initial conditions on each portion of the L-shaped membrane geometry.
Create a model, set the geometry function, and view the subdomain labels.
model = createpde();
geometryFromEdges(model,@lshapeg);
pdegplot(model,'FaceLabels','on')
axis equal
ylim([-1.1,1.1])
5-876
setInitialConditions
Set subdomain 1 to initial value -1, subdomain 2 to initial value 1, and subdomain 3 to
initial value 5.
setInitialConditions(model,-1);
setInitialConditions(model,1,'Face',2);
setInitialConditions(model,5,'Face',3);
The initial setting applies to the entire geometry. The subsequent settings override the
initial settings for regions 2 and 3.
Set initial conditions for the L-shaped membrane geometry to be x2 + y2, except in the
lower left square where it is x2 − y4.
model = createpde();
geometryFromEdges(model,@lshapeg);
pdegplot(model,'FaceLabels','on')
axis equal
ylim([-1.1,1.1])
5-877
5 Functions — Alphabetical List
Set the initial conditions on region 2 to x2 − y4. This setting overrides the first setting
because you apply it after the first setting.
5-878
setInitialConditions
Hyperbolic equations have nonzero m coefficient, so you must set both the u0 and ut0
arguments.
model = createpde(3);
importGeometry(model,'Block.stl');
Set the initial condition value to be 0 for all components. Set the initial derivative.
x
4+
x2 + y2 + z2
ut0 = 5 − tanh z
y
10 2
x + y 2 + z2
To create this initial gradient, write a function file, and ensure that the function is on your
MATLAB path.
M = length(location.x);
ut0 = zeros(3,M);
denom = location.x.^2+location.y.^2+location.z.^2;
ut0(1,:) = 4 + location.x./denom;
ut0(2,:) = 5 - tanh(location.z);
ut0(3,:) = 10*location.y./denom;
end
setInitialConditions(model,0,@ut0fun)
ans =
GeometricInitialConditions with properties:
5-879
5 Functions — Alphabetical List
RegionType: 'cell'
RegionID: 1
InitialValue: 0
InitialDerivative: @ut0fun
Set initial conditions using the solution from a previous analysis on the same geometry
and mesh.
5-880
setInitialConditions
Include the geometry in a PDE model, set boundary and initial conditions, and specify
coefficients.
model = createpde();
geometryFromEdges(model,dl);
% Set boundary conditions that the upper and left edges are at temperature 10.
applyBoundaryCondition(model,'dirichlet','Edge',[2,3],'u',10);
5-881
5 Functions — Alphabetical List
specifyCoefficients(model,'m',0,...
'd',1,...
'c',1,...
'a',0,...
'f',0);
generateMesh(model,'Hmax',0.05);
tlist = 0:0.01:0.5;
results = solvepde(model,tlist);
Plot the solution for times 0.02, 0.04, 0.1, and 0.5.
sol = results.NodalSolution;
subplot(2,2,1)
pdeplot(model,'XYData',sol(:,3))
title('Time 0.02')
subplot(2,2,2)
pdeplot(model,'XYData',sol(:,5))
title('Time 0.04')
subplot(2,2,3)
pdeplot(model,'XYData',sol(:,11))
title('Time 0.1')
subplot(2,2,4)
pdeplot(model,'XYData',sol(:,51))
title('Time 0.5')
5-882
setInitialConditions
Now, resume the analysis and solve the problem for times from 1/2 to 1. Use the
previously obtained solution for time 1/2 as an initial condition. Since 1/2 is the last
element in tlist, you do not need to specify the solution time index. By default,
setInitialConditions uses the last solution index.
setInitialConditions(model,results)
ans =
NodalInitialConditions with properties:
5-883
5 Functions — Alphabetical List
tlist1 = 0.5:0.01:1.0;
results1 = solvepde(model,tlist1);
sol1 = results1.NodalSolution;
figure
subplot(2,2,1)
pdeplot(model,'XYData',sol1(:,1))
title('Time 0.5')
subplot(2,2,2)
pdeplot(model,'XYData',sol1(:,21))
title('Time 0.7')
subplot(2,2,3)
pdeplot(model,'XYData',sol1(:,41))
title('Time 0.9')
subplot(2,2,4)
pdeplot(model,'XYData',sol1(:,51))
title('Time 1.0')
5-884
setInitialConditions
To use the previously obtained solution for a particular solution time instead of the last
one, specify the solution time index as a third parameter of setInitialConditions.
For example, use the solution at time 0.2, which is the 21st element in tlist.
setInitialConditions(model,results,21)
ans =
NodalInitialConditions with properties:
5-885
5 Functions — Alphabetical List
tlist2 = 0.2:0.01:1.0;
results2 = solvepde(model,tlist2);
Input Arguments
model — PDE model
PDEModel object
u0 — Initial condition
scalar | column vector of length N | function handle
• Scalar — Use it to represent a constant initial value for all solution components
throughout the domain.
• Column vector — Use it to represent a constant initial value for each of the N solution
components throughout the domain.
• Function handle — Use it to represent the initial conditions as a function of position.
The function must be of the form
u0 = initfun(location)
Solvers pass location as a structure with fields location.x, location.y, and, for
3-D problems, location.z. initfun must return a matrix u0 of size N-by-M, where M
= length(location.x).
Example: setInitialConditions(model,10)
Data Types: double | function_handle
Complex Number Support: Yes
Initial condition for time derivative, specified as a scalar, a column vector of length N, or a
function handle. N is the size of the system of PDEs. See “Equations You Can Solve Using
5-886
setInitialConditions
PDE Toolbox” on page 1-3. You must specify ut0 when there is a nonzero second-order
time-derivative coefficient m.
• Scalar — Use it to represent a constant initial value for all solution components
throughout the domain.
• Column vector — Use it to represent a constant initial value for each of the N solution
components throughout the domain.
• Function handle — Use it to represent the initial conditions as a function of position.
The function must be of the form
u0 = initfun(location)
Solvers pass location as a structure with fields location.x, location.y, and, for
3-D problems, location.z. initfun must return a matrix u0 of size N-by-M, where M
= length(location.x).
Example: setInitialConditions(model,10,@initfun)
Data Types: double | function_handle
Complex Number Support: Yes
When there are multiple initial condition assignments, solvers use the following
precedence rules for determining the initial condition.
• If there are multiple assignments to the same geometric region, solvers use the last
applied setting.
• If there are separate assignments to a geometric region and the boundaries of that
region, the solvers use the specified assignment on the region and choose the
assignment on the boundary as follows. The solvers give an 'Edge' assignment
precedence over a 'Face' assignment, even if you specify a 'Face' assignment after
an 'Edge' assignment. The precedence levels are 'Vertex (highest precedence),
'Edge', 'Face', 'Cell' (lowest precedence).
• If there is an assignment made with the results object, solvers use that assignment
instead of all previous assignments.
Example: setInitialConditions(model,10,'Face',1:4)
5-887
5 Functions — Alphabetical List
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Example: setInitialConditions(model,10,'Face',1:4)
Data Types: double
iT — Time index
positive integer
Output Arguments
ic — Handle to initial condition
object
Handle to initial condition, returned as an object. ic associates the initial condition with
the geometric region in the case of a geometric assignment or the nodes in the case of a
results-based assignment.
Tips
• To ensure that the model has the correct TimeDependent property setting, if possible
specify coefficients before setting initial conditions.
5-888
setInitialConditions
• To avoid assigning initial conditions to a wrong region, ensure that you are using the
correct geometric region IDs by plotting and visually inspecting the geometry.
See Also
PDEModel | findInitialConditions | pdegplot
Topics
“Set Initial Conditions” on page 2-113
“Solve Problems Using PDEModel Objects” on page 2-3
“Equations You Can Solve Using PDE Toolbox” on page 1-3
Introduced in R2016a
5-889
5 Functions — Alphabetical List
solve
Package: pde
Syntax
structuralStaticResults = solve(structuralStatic)
structuralModalResults = solve(structuralModal,'FrequencyRange',
[omega1,omega2])
structuralTransientResults = solve(structuralTransient,tlist)
structuralFrequencyResponseResults = solve(
structuralFrequencyResponse,flist)
structuralTransientResults = solve(structuralTransient,
tlist,'ModalResults',modalresults)
structuralFrequencyResponseResults = solve(
structuralFrequencyResponse,flist,'ModalResults',modalresults)
thermalSteadyStateResults = solve(thermalSteadyState)
thermalTransientResults = solve(thermalTransient,tlist)
Description
structuralStaticResults = solve(structuralStatic) returns the solution to
the static structural analysis model represented in structuralStatic.
structuralModalResults = solve(structuralModal,'FrequencyRange',
[omega1,omega2]) returns the solution to the modal analysis model for all modes in the
frequency range [omega1,omega2]. Define omega1 as slightly smaller than the lowest
expected frequency and omega2 as slightly larger than the highest expected frequency.
For example, if the lowest expected frequency is zero, then use a small negative value for
omega1.
5-890
solve
structuralFrequencyResponseResults = solve(
structuralFrequencyResponse,flist) returns the solution to the frequency
response model represented in structuralFrequencyResponse.
structuralTransientResults = solve(structuralTransient,
tlist,'ModalResults',modalresults) and
structuralFrequencyResponseResults = solve(
structuralFrequencyResponse,flist,'ModalResults',modalresults) solve a
transient and a frequency response structural model, respectively, by using the modal
superposition method to speed up computations. First, perform modal analysis to
compute natural frequencies and mode shapes in a particular frequency range. Then, use
this syntax to invoke the modal superposition method. The accuracy of the results
depends on the modes in the modal analysis results.
Examples
thermalmodel = createpde('thermal');
importGeometry(thermalmodel,'Block.stl');
pdegplot(thermalmodel,'FaceLabel','on','FaceAlpha',0.5)
axis equal
5-891
5 Functions — Alphabetical List
Apply a constant temperature of 100 ∘C to the left side of the block (face 1) and a constant
temperature of 300 ∘C to the right side of the block (face 3). All other faces are insulated
by default.
thermalBC(thermalmodel,'Face',1,'Temperature',100);
thermalBC(thermalmodel,'Face',3,'Temperature',300);
5-892
solve
thermalresults =
SteadyStateThermalResults with properties:
The solver finds the temperatures and temperature gradients at the nodal locations. To
access these values, use thermalresults.Temperature,
thermalresults.XGradients, and so on. For example, plot temperatures at the nodal
locations.
pdeplot3D(thermalmodel,'ColorMapData',thermalresults.Temperature)
5-893
5 Functions — Alphabetical List
5-894
solve
gd = [SQ1 D1];
sf = 'SQ1+D1';
ns = char('SQ1','D1');
ns = ns';
dl = decsg(gd,sf,ns);
geometryFromEdges(thermalmodel,dl);
pdegplot(thermalmodel,'EdgeLabels','on','FaceLabels','on')
xlim([-1.5 4.5])
ylim([-0.5 3.5])
axis equal
5-895
5 Functions — Alphabetical List
thermalProperties(thermalmodel,'ThermalConductivity',10, ...
'MassDensity',2, ...
'SpecificHeat',0.1, ...
'Face',1);
thermalProperties(thermalmodel,'ThermalConductivity',2, ...
'MassDensity',1, ...
'SpecificHeat',0.1, ...
'Face',2);
Assume that the diamond-shaped region is a heat source with a density of 4 W /m3.
internalHeatSource(thermalmodel,4,'Face',2);
The dynamics for this problem are very fast. The temperature reaches a steady state in
about 0.1 seconds. To capture the interesting part of the dynamics, set the solution time
to logspace(-2,-1,10). This command returns 10 logarithmically spaced solution
times between 0.01 and 0.1.
tlist = logspace(-2,-1,10);
5-896
solve
thermalresults = solve(thermalmodel,tlist)
thermalresults =
TransientThermalResults with properties:
T = thermalresults.Temperature;
pdeplot(thermalmodel,'XYData',T(:,10),'Contour','on','ColorMap','hot')
5-897
5 Functions — Alphabetical List
structuralmodel = createpde('structural','static-solid');
Create the geometry and include it in the model. Plot the geometry.
5-898
solve
gm = multicylinder([0.01,0.015],0.05);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','CellLabels','on','FaceAlpha',0.5)
Specify the Young's modulus and Poisson's ratio for each metal.
structuralProperties(structuralmodel,'Cell',1,'YoungsModulus',110E9, ...
'PoissonsRatio',0.28);
structuralProperties(structuralmodel,'Cell',2,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3);
structuralBC(structuralmodel,'Face',[1,4],'Constraint','fixed');
5-899
5 Functions — Alphabetical List
structuralresults =
StaticStructuralResults with properties:
The solver finds the values of displacement, stress, strain, and von Mises stress at the
nodal locations. To access these values, use structuralresults.Displacement,
structuralresults.Stress, and so on. The displacement, stress, and strain values at
the nodal locations are returned as structure arrays with fields representing their
components.
structuralresults.Displacement
structuralresults.Stress
structuralresults.Strain
5-900
solve
pdeplot3D(structuralmodel,'ColorMapData',structuralresults.Stress.szz, ...
'Deformation',structuralresults.Displacement)
5-901
5 Functions — Alphabetical List
Solve for the transient response of a thin 3-D plate under a harmonic load at the center.
Create the geometry and include it in the model. Plot the geometry.
gm = multicuboid([5,0.05],[5,0.05],0.01);
structuralmodel.Geometry=gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
5-902
solve
Zoom in to see the face labels on the small plate at the center.
figure
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.25)
axis([-0.2 0.2 -0.2 0.2 -0.1 0.1])
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9,...
'PoissonsRatio',0.3,...
'MassDensity',7800);
Specify that all faces on the periphery of the thin 3-D plate are fixed boundaries.
structuralBC(structuralmodel,'Constraint','fixed','Face',5:8);
5-903
5 Functions — Alphabetical List
Apply a sinusoidal pressure load on the small face at the center of the plate.
structuralBoundaryLoad(structuralmodel,'Face',12,'Pressure',5E7,'Frequency',25);
structuralresults =
TransientStructuralResults with properties:
The solver finds the values of the displacement, velocity, and acceleration at the nodal
locations. To access these values, use structuralresults.Displacement,
structuralresults.Velocity, and so on. The displacement, velocity, and
acceleration values are returned as structure arrays with fields representing their
components.
structuralresults.Displacement
structuralresults.Velocity
5-904
solve
structuralresults.Acceleration
Find the fundamental (lowest) mode of a 2-D cantilevered beam, assuming prevalence of
the plane-stress condition.
Specify the following geometric and structural properties of the beam, along with a unit
plane-stress thickness.
length = 5;
height = 0.1;
E = 3E7;
nu = 0.3;
rho = 0.3/386;
structuralmodel = createpde('structural','modal-planestress');
gdm = [3;4;0;length;length;0;0;0;height;height];
g = decsg(gdm,'S1',('S1')');
geometryFromEdges(structuralmodel,g);
Define a maximum element size (five elements through the beam thickness).
hmax = height/5;
msh=generateMesh(structuralmodel,'Hmax',hmax);
5-905
5 Functions — Alphabetical List
structuralProperties(structuralmodel,'YoungsModulus',E, ...
'MassDensity',rho, ...
'PoissonsRatio',nu);
structuralBC(structuralmodel,'Edge',4,'Constraint','fixed');
Compute the analytical fundamental frequency (Hz) using the beam theory.
I = height^3/12;
analyticalOmega1 = 3.516*sqrt(E*I/(length^4*(rho*height)))/(2*pi)
analyticalOmega1 = 126.9498
Specify a frequency range that includes an analytically computed frequency and solve the
model.
modalresults = solve(structuralmodel,'FrequencyRange',[0,1e6])
modalresults =
ModalStructuralResults with properties:
The solver finds natural frequencies and modal displacement values at nodal locations. To
access these values, use modalresults.NaturalFrequencies and
modalresults.ModeShapes.
modalresults.NaturalFrequencies/(2*pi)
ans = 32×1
105 ×
0.0013
0.0079
0.0222
0.0433
0.0711
0.0983
0.1055
0.1462
0.1930
0.2455
⋮
5-906
solve
modalresults.ModeShapes
pdeplot(structuralmodel,'XYData',modalresults.ModeShapes.uy(:,1))
title(['First Mode with Frequency ', ...
num2str(modalresults.NaturalFrequencies(1)/(2*pi)),' Hz'])
axis equal
5-907
5 Functions — Alphabetical List
First, create a structural model for modal analysis of a solid tuning fork.
model = createpde('structural','frequency-solid');
importGeometry(model,'TuningFork.stl');
Specify the Young's modulus, Poisson's ratio, and mass density to model linear elastic
material behavior. Specify all physical properties in consistent units.
structuralProperties(model,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',8000);
Identify faces for applying boundary constraints and loads by plotting the geometry with
the face labels.
figure('units','normalized','outerposition',[0 0 1 1])
pdegplot(model,'FaceLabels','on')
view(-50,15)
title 'Geometry with Face Labels'
5-908
solve
Impose sufficient boundary constraints to prevent rigid body motion under applied
loading. Typically, you hold a tuning fork by hand or mount it on a table. To create a
simple approximation of this boundary condition, fix a region near the intersection of
tines and the handle (faces 21 and 22).
structuralBC(model,'Face',[21,22],'Constraint','fixed');
5-909
5 Functions — Alphabetical List
Specify the pressure loading on a tine (face 11) as a short rectangular pressure pulse. In
the frequency domain, this pressure pulse is a unit load uniformly distributed across all
frequencies.
structuralBoundaryLoad(model,'Face',11,'Pressure',1);
flist = linspace(0,4000,150);
mesh = generateMesh(model,'Hmax',0.005);
R = solve(model,2*pi*flist)
R =
FrequencyStructuralResults with properties:
Plot the vibration frequency of the tine tip, which is face 12. Find nodes on the tip face
and plot the y-component of the displacement over the frequency, using one of these
nodes.
excitedTineTipNodes = findNodes(mesh,'region','Face',12);
tipDisp = R.Displacement.uy(excitedTineTipNodes(1),:);
figure
plot(flist,abs(tipDisp))
xlabel('Frequency');
ylabel('|Y-Displacement|');
5-910
solve
Find the deflection of a 3-D cantilever beam under a nonuniform thermal load. Specify the
thermal load on the structural model using the solution from a transient thermal analysis
on the same geometry and mesh.
thermalmodel = createpde('thermal','transient');
5-911
5 Functions — Alphabetical List
Generate a mesh.
mesh = generateMesh(thermalmodel);
5-912
solve
Specify the constant temperatures applied to the left and right ends on the beam.
thermalBC(thermalmodel,'Face',3,'Temperature',100);
thermalBC(thermalmodel,'Face',5,'Temperature',0);
internalHeatSource(thermalmodel,10);
thermalIC(thermalmodel,0);
tlist = [0:1e-4:2e-4];
thermalresults = solve(thermalmodel,tlist)
thermalresults =
TransientThermalResults with properties:
for n = 1:numel(thermalresults.SolutionTimes)
figure
pdeplot3D(thermalmodel,'ColorMapData',thermalresults.Temperature(:,n))
title(['Temperature at Time = ' num2str(tlist(n))])
caxis([0 100])
end
5-913
5 Functions — Alphabetical List
5-914
solve
5-915
5 Functions — Alphabetical List
Use the same mesh that you used to obtain the thermal solution.
structuralmodel.Mesh = mesh;
Specify the Young's modulus, Poisson's ratio, and coefficient of thermal expansion.
5-916
solve
structuralProperties(structuralmodel,'YoungsModulus',1e10, ...
'PoissonsRatio',0.3, ...'
'CTE',11.7e-6);
structuralBC(structuralmodel,'Face',5,'Constraint','fixed');
Apply a body load using the transient thermal model solution. By default,
structuralBodyLoad uses the solution for the last time step.
structuralBodyLoad(structuralmodel,'Temperature',thermalresults);
structuralmodel.ReferenceTemperature = 10;
thermalstressresults = solve(structuralmodel);
Plot the deformed shape of the beam corresponding to the last step of the transient
thermal model solution.
pdeplot3D(structuralmodel,'ColorMapData',thermalstressresults.Displacement.Magnitude, .
'Deformation',thermalstressresults.Displacement)
title(['Thermal Expansion at Solution Time = ' num2str(tlist(end))])
caxis([0 3e-3])
5-917
5 Functions — Alphabetical List
Now specify the body loads as the thermal model solutions for all time steps. For each
body load, solve the structural model and plot the corresponding deformed shape of the
beam.
for n = 1:numel(thermalresults.SolutionTimes)
structuralBodyLoad(structuralmodel,'Temperature',thermalresults,'TimeStep',n);
thermalstressresults = solve(structuralmodel);
figure
pdeplot3D(structuralmodel,'ColorMapData', ...
thermalstressresults.Displacement.Magnitude, ...
'Deformation', ...
thermalstressresults.Displacement)
title(['Thermal Results at Solution Time = ' num2str(tlist(n))])
5-918
solve
caxis([0 3e-3])
end
5-919
5 Functions — Alphabetical List
5-920
solve
Solve the for transient response at the center of a 3-D beam under a harmonic load on
one of its corners.
Modal Analysis
Create the geometry and include it in the model. Plot the geometry and display the edge
and vertex labels.
5-921
5 Functions — Alphabetical List
gm = multicuboid(0.05,0.003,0.003);
modelM.Geometry = gm;
pdegplot(modelM,'EdgeLabels','on','VertexLabels','on');
view([95 5])
Generate a mesh.
msh = generateMesh(modelM);
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(modelM,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
5-922
solve
Specify minimal constraints on one end of the beam to prevent rigid body modes. For
example, specify that edge 4 and vertex 7 are fixed boundaries.
structuralBC(modelM,'Edge',4,'Constraint','fixed');
structuralBC(modelM,'Vertex',7,'Constraint','fixed');
Solve the problem for the frequency range from 0 to 500,000. The recommended
approach is to use a value that is slightly smaller than the expected lowest frequency.
Thus, use -0.1 instead of 0.
Rm = solve(modelM,'FrequencyRange',[-0.1,500000]);
Transient Analysis
modelD = createpde('structural','transient-solid');
Use the same geometry and mesh as for the modal analysis.
modelD.Geometry = gm;
modelD.Mesh = msh;
Specify the same values for the Young's modulus, Poisson's ratio, and mass density of the
material.
structuralProperties(modelD,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
Specify the same minimal constraints on one end of the beam to prevent rigid body
modes.
structuralBC(modelD,'Edge',4,'Constraint','fixed');
structuralBC(modelD,'Vertex',7,'Constraint','fixed');
Apply a sinusoidal force on the corner opposite to the constrained edge and vertex.
structuralBoundaryLoad(modelD,'Vertex',5,'Force',[0,0,10],'Frequency',7600);
structuralIC(modelD,'Velocity',[0;0;0],'Displacement',[0;0;0]);
5-923
5 Functions — Alphabetical List
modelD.SolverOptions.RelativeTolerance = 1E-5;
modelD.SolverOptions.AbsoluteTolerance = 1E-9;
tlist = linspace(0,0.004,120);
Rdm = solve(modelD,tlist,'ModalResults',Rm)
Rdm =
TransientStructuralResults with properties:
intrpUdm = interpolateDisplacement(Rdm,0,0,0.0015);
plot(Rdm.SolutionTimes,intrpUdm.uz)
grid on
xlabel('Time');
ylabel('Center of beam displacement')
5-924
solve
Input Arguments
structuralStatic — Static structural analysis model
StructuralModel object
5-925
5 Functions — Alphabetical List
5-926
solve
Frequency range, specified as a vector of two elements. Define omega1 as slightly smaller
than the lowest expected frequency and omega2 as slightly larger than the highest
expected frequency. For example, if the lowest expected frequency is zero, then use a
small negative value for omega1.
Example: [-0.1,1000]
Data Types: double
5-927
5 Functions — Alphabetical List
Output Arguments
structuralStaticResults — Static structural analysis results
StaticStructuralResults object
Tips
• When you use modal analysis results to solve a transient structural dynamics model,
the modalresults argument must be created in Partial Differential Equation Toolbox
version R2019a or newer.
5-928
solve
• For a frequency response model with damping, the results are complex. Use functions
such as abs and angle to obtain real-valued results, such as the magnitude and
phase.
See Also
geometryFromEdges | PDEModel | StructuralModel | ThermalModel |
geometryFromMesh | importGeometry | reduce
Introduced in R2017a
5-929
5 Functions — Alphabetical List
solvepde
Package: pde
Syntax
result = solvepde(model)
result = solvepde(model,tlist)
Description
result = solvepde(model) returns the solution to the stationary PDE represented in
model. A stationary PDE has the property model.IsTimeDependent = false. That is,
the time-derivative coefficients m and d in model.EquationCoefficients must be 0.
Examples
Create a PDE model, and include the geometry of the L-shaped membrane.
model = createpde();
geometryFromEdges(model,@lshapeg);
pdegplot(model,'EdgeLabels','on')
ylim([-1.1,1.1])
axis equal
5-930
solvepde
Poisson's equation is
− ∇ ⋅ ∇u = 1 .
∂2 u ∂u
m +d − ∇ c ∇u + au = f .
∂t2 ∂t
5-931
5 Functions — Alphabetical List
specifyCoefficients(model,'m',0,...
'd',0,...
'c',1,...
'a',0,...
'f',1);
5-932
solvepde
model = createpde();
importGeometry(model,'Block.stl');
Suppose that radiative cooling causes the solution to decrease as the cube of temperature
on the surface of the block.
gfun = @(region,state)-state.u.^3*1e-6;
applyBoundaryCondition(model,'neumann','Face',1:model.Geometry.NumFaces,'g',gfun);
specifyCoefficients(model,'m',0,...
'd',1,...
'c',1,...
'a',0,...
'f',0);
setInitialConditions(model,350);
Mesh the geometry and solve the model for times 0 through 20.
generateMesh(model);
tlist = 0:20;
results = solvepde(model,tlist);
Plot the solution on the surface of the block at times 1 and 20.
pdeplot3D(model,'ColorMapData',results.NodalSolution(:,2))
5-933
5 Functions — Alphabetical List
figure
pdeplot3D(model,'ColorMapData',results.NodalSolution(:,21))
5-934
solvepde
Input Arguments
model — PDE model
PDEModel object
PDE model, specified as a PDEModel object. The model contains the geometry, mesh, and
problem coefficients.
Example: model = createpde(1)
5-935
5 Functions — Alphabetical List
Solution times, specified as a real vector. tlist must be a monotone vector (increasing
or decreasing).
Example: 0:20
Data Types: double
Output Arguments
result — PDE results
StationaryResults object | TimeDependentResults object
Tips
• If the Newton iteration does not converge, solvepde displays the error message Too
many iterations or Stepsize too small.
• If the initial guess produces matrices containing NaN or Inf elements, solvepde
displays the error message Unsuitable initial guess U0 (default: U0 =
0).
• If you have very small coefficients, or very small geometric dimensions, solvepde can
fail to converge, or can converge to an incorrect solution. In this case, you might
obtain better results by scaling the coefficients or geometry dimensions to be of order
one.
See Also
PDEModel | applyBoundaryCondition | setInitialConditions | solvepdeeig |
specifyCoefficients
Topics
“Solve Problems Using PDEModel Objects” on page 2-3
5-936
solvepde
Introduced in R2016a
5-937
5 Functions — Alphabetical List
solvepdeeig
Package: pde
Syntax
result = solvepdeeig(model,evr)
Description
result = solvepdeeig(model,evr) solves the PDE eigenvalue problem in model for
eigenvalues in the range evr. If the range does not contain any eigenvalues,
solvepdeeig returns an EigenResults object with the empty EigenVectors,
EigenValues, and Mesh properties.
Examples
The equations of elasticity have three components. Therefore, create a PDE model that
has three components. Import and view the BracketTwoHoles geometry.
model = createpde(3);
importGeometry(model,'BracketTwoHoles.stl');
pdegplot(model,'FaceLabels','on','FaceAlpha',0.5)
5-938
solvepdeeig
applyBoundaryCondition(model,'dirichlet','Face',1,'u',[0;0;0]);
Set the model coefficients to represent a steel bracket. For details, see “Linear Elasticity
Equations” on page 3-150.
5-939
5 Functions — Alphabetical List
evr = [-Inf,1e7];
generateMesh(model);
results = solvepdeeig(model,evr);
length(results.Eigenvalues)
ans = 3
Plot the solution on the geometry boundary for the lowest eigenvalue.
V = results.Eigenvectors;
subplot(2,2,1)
pdeplot3D(model,'ColorMapData',V(:,1,1))
title('x Deflection, Mode 1')
subplot(2,2,2)
pdeplot3D(model,'ColorMapData',V(:,2,1))
title('y Deflection, Mode 1')
subplot(2,2,3)
pdeplot3D(model,'ColorMapData',V(:,3,1))
title('z Deflection, Mode 1')
5-940
solvepdeeig
figure
subplot(2,2,1)
pdeplot3D(model,'ColorMapData',V(:,1,3))
title('x Deflection, Mode 3')
subplot(2,2,2)
pdeplot3D(model,'ColorMapData',V(:,2,3))
title('y Deflection, Mode 3')
subplot(2,2,3)
pdeplot3D(model,'ColorMapData',V(:,3,3))
title('z Deflection, Mode 3')
5-941
5 Functions — Alphabetical List
Input Arguments
model — PDE model
PDEModel object
PDE model, specified as a PDEModel object. The model contains the geometry, mesh, and
problem coefficients.
Example: model = createpde(1)
5-942
solvepdeeig
Eigenvalue range, specified as a two-element real vector. evr(1) specifies the lower limit
of the range of the real part of the eigenvalues, and may be -Inf. evr(2) specifies the
upper limit of the range, and must be finite.
Example: [-Inf;100]
Data Types: double
Output Arguments
result — Eigenvalue results
EigenResults object
Eigenvalue results, returned as an EigenResults object. If the range env does not
contain any eigenvalues, the returned EigenResults object has the empty
EigenVectors, EigenValues, and Mesh properties.
Tips
• The equation coefficients cannot depend on the solution u or its gradient.
See Also
PDEModel | applyBoundaryCondition | solvepde | specifyCoefficients
Topics
“Eigenvalues and Eigenmodes of L-Shaped Membrane” on page 3-287
“Eigenvalues and Eigenmodes of Square” on page 3-299
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2016a
5-943
5 Functions — Alphabetical List
specifyCoefficients
Package: pde
Syntax
specifyCoefficients(model,Name,Value)
specifyCoefficients(model,Name,Value,RegionType,RegionID)
CA = specifyCoefficients( ___ )
Description
Coefficients of a PDE
∂2 u ∂u
m +d − ∇ · c ∇u + au = f
∂t 2 ∂t
− ∇ · c ∇u + au = λdu
or
2
− ∇ · c ∇u + au = λ mu
5-944
specifyCoefficients
specifyCoefficients(model,Name,Value,RegionType,RegionID) assigns
coefficients for a specified geometry region.
Examples
∂2 u ∂u
m +d − ∇ ⋅ c ∇u + au = f .
∂t 2 ∂t
model = createpde();
geometryFromEdges(model,@lshapeg);
specifyCoefficients(model,'m',0,...
'd',0,...
'c',1,...
'a',0,...
'f',1);
Specify zero Dirichlet boundary conditions, mesh the model, and solve the PDE.
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
generateMesh(model,'Hmax',0.25);
results = solvepde(model);
pdeplot(model,'XYData',results.NodalSolution)
5-945
5 Functions — Alphabetical List
Specify coefficients for Poisson's equation in 3-D with a nonconstant source term, and
obtain the coefficient object.
5-946
specifyCoefficients
model = createpde();
importGeometry(model,'Block.stl');
CA = specifyCoefficients(model,'m',0,...
'd',0,...
'c',1,...
'a',0,...
'f',f)
CA =
CoefficientAssignment with properties:
RegionType: 'cell'
RegionID: 1
m: 0
d: 0
c: 1
a: 0
f: @(location,state)location.y.^2.*tanh(location.z)/1000
Set zero Dirichlet conditions on face 1, mesh the geometry, and solve the PDE.
applyBoundaryCondition(model,'dirichlet','Face',1,'u',0);
generateMesh(model);
results = solvepde(model);
pdeplot3D(model,'ColorMapData',results.NodalSolution)
5-947
5 Functions — Alphabetical List
Create a scalar PDE model with the L-shaped membrane as the geometry. Plot the
geometry and subdomain labels.
model = createpde();
geometryFromEdges(model,@lshapeg);
pdegplot(model,'FaceLabels','on')
axis equal
ylim([-1.1,1.1])
5-948
specifyCoefficients
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',1,'Face',1);
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',5,'Face',2);
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',-8,'Face',3);
Set zero Dirichlet boundary conditions to all edges. Create a mesh, solve the PDE, and
plot the result.
applyBoundaryCondition(model,'dirichlet','Edge',1:model.Geometry.NumEdges,'u',0);
generateMesh(model,'Hmax',0.25);
results = solvepde(model);
pdeplot(model,'XYData',results.NodalSolution)
5-949
5 Functions — Alphabetical List
Input Arguments
model — PDE model
PDEModel object
5-950
specifyCoefficients
Example:
specifyCoefficients(model,'m',0,'d',0,'c',1,'a',0,'f',@fcoeff)
Note If the m coefficient is nonzero, d must be 0 or a matrix, and not a function handle.
See “d Coefficient When m is Nonzero” on page 5-953.
5-951
5 Functions — Alphabetical List
Solution multiplier coefficient, specified as a scalar, column vector, or function handle. For
details on the sizes, and for details of the function handle form of the coefficient, see “m,
d, or a Coefficient for specifyCoefficients” on page 2-104.
f — Source coefficient
scalar | column vector | function handle
Source coefficient, specified as a scalar, column vector, or function handle. For details on
the sizes, and for details of the function handle form of the coefficient, see “f Coefficient
for specifyCoefficients” on page 2-79.
5-952
specifyCoefficients
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Example:
specifyCoefficients('m',0,'d',0,'c',1,'a',0,'f',10,'Cell',1:3)
Data Types: double
Output Arguments
CA — Coefficient assignment
CoefficientAssignment object
More About
d Coefficient When m is Nonzero
The d coefficient takes a special matrix form when m is nonzero. You must specify d as a
matrix of a particular size, and not as a function handle.
5-953
5 Functions — Alphabetical List
Tips
• For eigenvalue equations, the coefficients cannot depend on the solution u or its
gradient.
See Also
PDEModel | findCoefficients
Topics
“Solve Problems Using PDEModel Objects” on page 2-3
Introduced in R2016a
5-954
sptarn
sptarn
(Not recommended) Solve generalized sparse eigenvalue problem
Syntax
[xv,lmb,iresult] = sptarn(A,B,lb,ub)
[xv,lmb,iresult] = sptarn(A,B,lb,ub,spd)
[xv,lmb,iresult] = sptarn(A,B,lb,ub,spd,tolconv)
[xv,lmb,iresult] = sptarn(A,B,lb,ub,spd,tolconv,jmax)
[xv,lmb,iresult] = sptarn(A,B,lb,ub,spd,tolconv,jmax,maxmul)
Description
[xv,lmb,iresult] = sptarn(A,B,lb,ub,spd,tolconv,jmax,maxmul) finds
eigenvalues of the pencil (A – λB)x = 0 in interval [lb,ub]. (A matrix of linear polynomials
Aij – λBij, A – λB, is called a pencil.)
A and B are sparse matrices. lb and ub are lower and upper bounds for eigenvalues to be
sought. We may have lb = -inf if all eigenvalues to the left of ub are sought, and rb =
inf if all eigenvalues to the right of lb are sought. One of lb and ub must be finite. A
narrower interval makes the algorithm faster. In the complex case, the real parts of lmb
are compared to lb and ub.
5-955
5 Functions — Alphabetical List
tolconv is the expected relative accuracy. Default is 100*eps, where eps is the machine
precision.
jmax is the maximum number of basis vectors. The algorithm needs jmax*n working
space so a small value may be justified on a small computer, otherwise let it be the default
value jmax = 100. Normally the algorithm stops earlier when enough eigenvalues have
converged.
maxmul is the number of Arnoldi runs tried. Must at least be as large as maximum
multiplicity of any eigenvalue. If a small value of jmax is given, many Arnoldi runs are
necessary. The default value is maxmul = n, which is needed when all the eigenvalues of
the unit matrix are sought.
Algorithms
The Arnoldi algorithm with spectral transformation is used. The shift is chosen at ub, lb,
or at a random point in interval (lb,ub) when both bounds are finite. The number of steps
j in the Arnoldi run depends on how many eigenvalues there are in the interval, but it
stops at j = min(jmax,n). After a stop, the algorithm restarts to find more Schur
vectors in orthogonal complement to all those already found. When no more eigenvalues
are found in lb < lmb <= ub, the algorithm stops. For small values of jmax, several
restarts may be needed before a certain eigenvalue has converged. The algorithm works
when jmax is at least one larger than the number of eigenvalues in the interval, but then
many restarts are needed. For large values of jmax, which is the preferred choice, mul+1
runs are needed. mul is the maximum multiplicity of an eigenvalue in the interval.
Note The algorithm works on nonsymmetric as well as symmetric pencils, but then
accuracy is approximately tol times the Henrici departure from normality. The
parameter spd is used only to choose between symamd and colamd when factorizing, the
former being marginally better for symmetric matrices close to the lower end of the
spectrum.
In case of trouble,
5-956
sptarn
• a larger maxmul
If factorization fails, try again with lb or ub finite. Then shift is chosen at random and
hopefully not at an eigenvalue. If it fails again, check whether pencil may be singular.
If it goes on forever, there may be too many eigenvalues in the strip. Try with a small
value maxmul = 2 and see which eigenvalues you get. Those you get are some of the
eigenvalues, but a negative iresult tells you that you have not gotten them all.
The algorithm is designed for eigenvalues close to the real axis. If you want those close to
the imaginary axis, try A = i*A.
When spd = 1, the shift is at lb so that advantage is taken of the faster factorization for
symmetric positive definite matrices. No harm is done, but the execution is slower if lb is
above the lowest eigenvalue.
References
[1] Golub, Gene H., and Charles F. Van Loan, Matrix Computations, 2nd edition, Johns
Hopkins University Press, Baltimore, MD, 1989.
[2] Saad, Yousef, “Variations on Arnoldi's Method for Computing Eigenelements of Large
Unsymmetric Matrices,” Linear Algebra and its Applications, Vol. 34, 1980, pp.
269–295.
See Also
solvepdeeig
5-957
5 Functions — Alphabetical List
StaticStructuralResults
Static structural solution and its derived quantities
Description
A StaticStructuralResults object contains the displacement, stress, strain, and von
Mises stress in a form convenient for plotting and postprocessing.
Displacements, stresses, and strains are reported for the nodes of the triangular or
tetrahedral mesh generated by generateMesh. Displacement values at the nodes appear
as a structure array in the Displacement property. The fields of the structure array
contain components of displacement at nodal locations.
Stress and strain values at the nodes appear as structure arrays in the Stress and
Strain properties, respectively.
von Mises stress at the nodes appears as a vector in the VonMisesStress property.
To interpolate the displacement, stress, strain, and von Mises stress to a custom grid,
such as the one specified by meshgrid, use interpolateDisplacement,
interpolateStress, interpolateStrain, and interpolateVonMisesStress,
respectively.
Creation
Solve a static linear elasticity problem by using the solve function. This function returns
a static structural solution as a StaticStructuralResults object.
5-958
StaticStructuralResults
Properties
Displacement — Displacement values at nodes
structure array
Displacement values at the nodes, returned as a structure array. The fields of the
structure array contain components of displacement at nodal locations.
Data Types: struct
Stress values at the nodes, returned as a structure array. The fields of the structure array
contain components of stress at nodal locations.
Data Types: struct
Strain values at the nodes, returned as a structure array. The fields of the structure array
contain components of strain at nodal locations.
Data Types: struct
Finite element mesh, returned as a FEMesh object. For details, see FEMesh.
Object Functions
interpolateDisplacement Interpolate displacement at arbitrary spatial locations
interpolateStress Interpolate stress at arbitrary spatial locations
5-959
5 Functions — Alphabetical List
Examples
structuralmodel = createpde('structural','static-solid');
Create the geometry and include it in the model. Plot the geometry.
gm = multicylinder([0.01,0.015],0.05);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','CellLabels','on','FaceAlpha',0.5)
5-960
StaticStructuralResults
Specify the Young's modulus and Poisson's ratio for each metal.
structuralProperties(structuralmodel,'Cell',1,'YoungsModulus',110E9, ...
'PoissonsRatio',0.28);
structuralProperties(structuralmodel,'Cell',2,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3);
structuralBC(structuralmodel,'Face',[1,4],'Constraint','fixed');
structuralBoundaryLoad(structuralmodel,'Face',[2,5],'SurfaceTraction',[0;0;100]);
5-961
5 Functions — Alphabetical List
generateMesh(structuralmodel);
structuralresults = solve(structuralmodel)
structuralresults =
StaticStructuralResults with properties:
The solver finds the values of displacement, stress, strain, and von Mises stress at the
nodal locations. To access these values, use structuralresults.Displacement,
structuralresults.Stress, and so on. The displacement, stress, and strain values at
the nodal locations are returned as structure arrays with fields representing their
components.
structuralresults.Displacement
structuralresults.Stress
structuralresults.Strain
5-962
StaticStructuralResults
pdeplot3D(structuralmodel,'ColorMapData',structuralresults.Stress.szz, ...
'Deformation',structuralresults.Displacement)
5-963
5 Functions — Alphabetical List
See Also
ModalStructuralResults | StructuralModel | TransientStructuralResults |
solve
Introduced in R2017b
5-964
ModalStructuralResults
ModalStructuralResults
Structural modal analysis solution
Description
A ModalStructuralResults object contains the natural frequencies and modal
displacement in a form convenient for plotting and postprocessing.
Modal displacement is reported for the nodes of the triangular or tetrahedral mesh
generated by generateMesh. The modal displacement values at the nodes appear as a
structure array in the ModeShapes property. The fields of the structure array contain the
components of the displacement at the nodal locations.
Creation
Solve a modal analysis problem by using the solve function. This function returns a
modal structural solution as a ModalStructuralResults object.
Properties
NaturalFrequencies — Natural frequencies
column vector
Modal displacement values at the nodes, returned as a structure array. The fields of the
structure array contain components of modal displacement at nodal locations.
5-965
5 Functions — Alphabetical List
Finite element mesh, returned as a FEMesh object. For details, see FEMesh.
Examples
Solution to Modal Analysis Structural Model
Find the fundamental (lowest) mode of a 2-D cantilevered beam, assuming prevalence of
the plane-stress condition.
Specify the following geometric and structural properties of the beam, along with a unit
plane-stress thickness.
length = 5;
height = 0.1;
E = 3E7;
nu = 0.3;
rho = 0.3/386;
Define a maximum element size (five elements through the beam thickness).
hmax = height/5;
msh=generateMesh(structuralmodel,'Hmax',hmax);
Compute the analytical fundamental frequency (Hz) using the beam theory.
5-966
ModalStructuralResults
I = height^3/12;
analyticalOmega1 = 3.516*sqrt(E*I/(length^4*(rho*height)))/(2*pi)
analyticalOmega1 = 126.9498
Specify a frequency range that includes an analytically computed frequency and solve the
model.
modalresults = solve(structuralmodel,'FrequencyRange',[0,1e6])
modalresults =
ModalStructuralResults with properties:
The solver finds natural frequencies and modal displacement values at nodal locations. To
access these values, use modalresults.NaturalFrequencies and
modalresults.ModeShapes.
modalresults.NaturalFrequencies/(2*pi)
ans = 32×1
105 ×
0.0013
0.0079
0.0222
0.0433
0.0711
0.0983
0.1055
0.1462
0.1930
0.2455
⋮
modalresults.ModeShapes
5-967
5 Functions — Alphabetical List
pdeplot(structuralmodel,'XYData',modalresults.ModeShapes.uy(:,1))
title(['First Mode with Frequency ', ...
num2str(modalresults.NaturalFrequencies(1)/(2*pi)),' Hz'])
axis equal
See Also
StaticStructuralResults | StructuralModel | TransientStructuralResults |
solve
5-968
ModalStructuralResults
Introduced in R2018a
5-969
5 Functions — Alphabetical List
FrequencyStructuralResults
Frequency response structural solution and its derived quantities
Description
A FrequencyStructuralResults object contains the displacement, velocity, and
acceleration in a form convenient for plotting and postprocessing.
Displacement, velocity, and acceleration are reported for the nodes of the triangular or
tetrahedral mesh generated by generateMesh. The displacement, velocity, and
acceleration values at the nodes appear as structure arrays in the Displacement,
Velocity, and Acceleration properties. The fields of the structure arrays contain the
components of the displacement, velocity, and acceleration at the nodal locations.
To evaluate the stress, strain, von Mises stress, principal stress, and principal strain at
the nodal locations, use evaluateStress, evaluateStrain,
evaluateVonMisesStress, evaluatePrincipalStress, and
evaluatePrincipalStrain, respectively.
To interpolate the displacement, velocity, acceleration, stress, strain, and von Mises stress
to a custom grid, such as the one specified by meshgrid, use
interpolateDisplacement, interpolateVelocity, interpolateAcceleration,
interpolateStress, interpolateStrain, and interpolateVonMisesStress,
respectively.
For a frequency response model with damping, the results are complex. Use functions
such as abs and angle to obtain real-valued results, such as the magnitude and phase.
See “Solution to Frequency Response Structural Model with Damping” on page 5-972.
Creation
Solve a frequency response problem by using the solve function. This function returns a
frequency response structural solution as a FrequencyStructuralResults object.
5-970
FrequencyStructuralResults
Properties
Displacement — Displacement values at nodes
structure array
Displacement values at the nodes, returned as a structure array. The fields of the
structure array contain the components of the displacement at the nodal locations.
Data Types: struct
Velocity values at the nodes, returned as a structure array. The fields of the structure
array contain the components of the velocity at the nodal locations.
Data Types: struct
Acceleration values at the nodes, returned as a structure array. The fields of the structure
array contain the components of the acceleration at the nodal locations.
Data Types: struct
Finite element mesh, returned as a FEMesh object. For details, see FEMesh.
Object Functions
evaluateStress Evaluate stress for dynamic structural analysis problem
5-971
5 Functions — Alphabetical List
Examples
Solve a frequency response problem with damping. The resulting displacement values are
complex. To obtain the magnitude and phase of displacement, use the abs and angle
functions, respectively.
Solve the problem by using the direct integration approach and by using the results of
modal analysis.
Modal Analysis
modelM = createpde('structural','modal-solid');
gm = multicuboid(10,10,0.025);
modelM.Geometry = gm;
Generate a mesh.
msh = generateMesh(modelM);
5-972
FrequencyStructuralResults
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(modelM,'YoungsModulus',2E11, ...
'PoissonsRatio',0.3, ...
'MassDensity',8000);
Identify faces for applying boundary constraints and loads by plotting the geometry with
the face and edge labels.
pdegplot(gm,'FaceLabels','on','FaceAlpha',0.5)
figure
pdegplot(gm,'EdgeLabels','on','FaceAlpha',0.5)
5-973
5 Functions — Alphabetical List
Specify constraints on the sides of the plate (faces 3, 4, 5, and 6) to prevent rigid body
motions.
structuralBC(modelM,'Face',[3,4,5,6],'Constraint','fixed');
Solve the problem for the frequency range from -Inf to 12*pi.
Rm = solve(modelM,'FrequencyRange',[-Inf,12*pi]);
modelFR = createpde('structural','frequency-solid');
5-974
FrequencyStructuralResults
Use the same geometry and mesh as for the modal analysis.
modelFR.Geometry = gm;
modelFR.Mesh = msh;
Specify the same values for the Young's modulus, Poisson's ratio, and mass density of the
material.
structuralProperties(modelFR,'YoungsModulus',2E11,'PoissonsRatio',0.3,'MassDensity',800
Specify the same constraints on the midsection of the geometry to prevent rigid body
modes.
structuralBC(modelFR,'Face',[3,4,5,6],'Constraint','fixed');
Specify the pressure loading on top of the plate (face 2) as a short rectangular pressure
pulse. In the frequency domain, this pressure pulse is a unit load uniformly distributed
across all frequencies.
structuralBoundaryLoad(modelFR,'Face',2,'Pressure',1E2);
Specify the Rayleigh damping parameters. For typical damping of 2%, only one mode is
1 α
active. The equation ζi = 2 ωi
+ βωi for ωi ≈ 15 and β = 0 yields α ≈ 0 . 6.
structuralDamping(modelFR,'proportional','Alpha',0.6);
flist = [0,1,1.5,linspace(2,3,100),3.5,4,5,6]*2*pi;
Rfr = solve(modelFR,flist);
Interpolate the displacement at the center of the top surface of the plate.
iDisp = interpolateDisplacement(Rfr,[0;0;0.025]);
Plot the results. For a model with damping, the resulting displacement values are
complex. To obtain the magnitude and phase, use the abs and angle functions,
respectively.
figure
subplot(2,1,1)
plot(Rfr.SolutionFrequencies/2/pi,abs(iDisp.Magnitude));
title('Magnitude')
subplot(2,1,2)
5-975
5 Functions — Alphabetical List
plot(Rfr.SolutionFrequencies/2/pi,angle(iDisp.Magnitude));
title('Phase')
Interpolate the displacement at the center of the top surface of the plate.
iDisp = interpolateDisplacement(RfrModal,[0;0;0.025]);
5-976
FrequencyStructuralResults
plot(RfrModal.SolutionFrequencies/2/pi,abs(iDisp.Magnitude));
title('Magnitude')
subplot(2,1,2)
plot(RfrModal.SolutionFrequencies/2/pi,angle(iDisp.Magnitude));
title('Phase')
See Also
ModalStructuralResults | StaticStructuralResults | StructuralModel |
TransientStructuralResults | solve
Introduced in R2019b
5-977
5 Functions — Alphabetical List
TransientStructuralResults
Transient structural solution and its derived quantities
Description
A TransientStructuralResults object contains the displacement, velocity, and
acceleration in a form convenient for plotting and postprocessing.
Displacement, velocity, and acceleration are reported for the nodes of the triangular or
tetrahedral mesh generated by generateMesh. The displacement, velocity, and
acceleration values at the nodes appear as structure arrays in the Displacement,
Velocity, and Acceleration properties. The fields of the structure arrays contain the
components of the displacement, velocity, and acceleration at the nodal locations.
To evaluate the stress, strain, von Mises stress, principal stress, and principal strain at
the nodal locations, use evaluateStress, evaluateStrain,
evaluateVonMisesStress, evaluatePrincipalStress, and
evaluatePrincipalStrain, respectively.
To interpolate the displacement, velocity, acceleration, stress, strain, and von Mises stress
to a custom grid, such as the one specified by meshgrid, use
interpolateDisplacement, interpolateVelocity, interpolateAcceleration,
interpolateStress, interpolateStrain, and interpolateVonMisesStress,
respectively.
Creation
Solve a dynamic linear elasticity problem by using the solve function. This function
returns a transient structural solution as a TransientStructuralResults object.
5-978
TransientStructuralResults
Properties
Displacement — Displacement values at nodes
structure array
Displacement values at the nodes, returned as a structure array. The fields of the
structure array contain components of displacement at nodal locations.
Data Types: struct
Velocity values at the nodes, returned as a structure array. The fields of the structure
array contain components of velocity at nodal locations.
Data Types: struct
Acceleration values at the nodes, returned as a structure array. The fields of the structure
array contain components of acceleration at nodal locations.
Data Types: struct
Solution times, returned as a real vector. SolutionTimes is the same as the tlist input
to solve.
Data Types: double
Finite element mesh, returned as a FEMesh object. For details, see FEMesh.
Object Functions
evaluateStress Evaluate stress for dynamic structural analysis problem
5-979
5 Functions — Alphabetical List
Examples
Solution to Transient Structural Model
Solve for the transient response of a thin 3-D plate under a harmonic load at the center.
structuralmodel = createpde('structural','transient-solid');
Create the geometry and include it in the model. Plot the geometry.
gm = multicuboid([5,0.05],[5,0.05],0.01);
structuralmodel.Geometry=gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
5-980
TransientStructuralResults
Zoom in to see the face labels on the small plate at the center.
figure
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.25)
axis([-0.2 0.2 -0.2 0.2 -0.1 0.1])
5-981
5 Functions — Alphabetical List
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9,...
'PoissonsRatio',0.3,...
'MassDensity',7800);
Specify that all faces on the periphery of the thin 3-D plate are fixed boundaries.
structuralBC(structuralmodel,'Constraint','fixed','Face',5:8);
Apply a sinusoidal pressure load on the small face at the center of the plate.
structuralBoundaryLoad(structuralmodel,'Face',12,'Pressure',5E7,'Frequency',25);
5-982
TransientStructuralResults
generateMesh(structuralmodel,'GeometricOrder','linear','Hmax',0.2);
structuralresults =
TransientStructuralResults with properties:
The solver finds the values of the displacement, velocity, and acceleration at the nodal
locations. To access these values, use structuralresults.Displacement,
structuralresults.Velocity, and so on. The displacement, velocity, and
acceleration values are returned as structure arrays with fields representing their
components.
structuralresults.Displacement
structuralresults.Velocity
structuralresults.Acceleration
5-983
5 Functions — Alphabetical List
See Also
ModalStructuralResults | StaticStructuralResults | StructuralModel |
solve
Introduced in R2018a
5-984
structuralBC
structuralBC
Package: pde
Syntax
structuralBC(structuralmodel,RegionType,RegionID,'Constraint',Cval)
structuralBC(structuralmodel,RegionType,RegionID,'Displacement',
Dval)
structuralBC(structuralmodel,RegionType,RegionID,'XDisplacement',
XDval,'YDisplacement',YDval,'ZDisplacement',ZDval)
structuralBC(structuralmodel,RegionType,RegionID,'XDisplacement',
XDval,Name,Value)
structuralBC(structuralmodel,RegionType,RegionID,'YDisplacement',
YDval,Name,Value)
structuralBC(structuralmodel,RegionType,RegionID,'ZDisplacement',
ZDval,Name,Value)
structuralBC(structuralmodel,RegionType,RegionID,'Constraint',
'multipoint')
structuralBC(structuralmodel,RegionType,
RegionID,'Constraint','multipoint','Reference',Coords)
structuralBC(structuralmodel,RegionType,
RegionID,'Constraint','multipoint','Reference',Coords,'Radius',R)
Description
structuralBC(structuralmodel,RegionType,RegionID,'Constraint',Cval)
specifies one of the standard structural boundary constraints. Here, Cval can be
'fixed', 'free', 'roller', or 'symmetric'. The default value is 'free'.
5-985
5 Functions — Alphabetical List
Avoid using 'symmetric' for transient and modal analysis, since the symmetric
constraint can prevent the participation of some structural modes.
structuralBC(structuralmodel,RegionType,RegionID,'Displacement',
Dval) enforces displacement on the boundary of type RegionType with RegionID ID
numbers.
structuralBC(structuralmodel,RegionType,RegionID,'XDisplacement',
XDval,'YDisplacement',YDval,'ZDisplacement',ZDval) specifies the x-, y-, and
z-components of the enforced displacement.
structuralBC does not require you to specify all three components. Depending on your
structural analysis problem, you can specify one or more components by picking the
corresponding arguments and omitting others.
structuralBC(structuralmodel,RegionType,RegionID,'XDisplacement',
XDval,Name,Value)specifies the form and duration of the time-varying value of the x-
component of the enforced displacement.
structuralBC(structuralmodel,RegionType,RegionID,'YDisplacement',
YDval,Name,Value) specifies the form and duration of the time-varying value of the y-
component of the enforced displacement.
structuralBC(structuralmodel,RegionType,RegionID,'ZDisplacement',
ZDval,Name,Value) specifies the form and duration of the time-varying value of the z-
component of the enforced displacement.
structuralBC(structuralmodel,RegionType,RegionID,'Constraint',
'multipoint') sets the multipoint constraint using all degrees of freedom on the
combination of geometric regions specified by RegionType and RegionID. The
reference location for the constraint is the geometric center of all nodes on the
combination of all specified geometric regions.
This syntax is required if you intend to use results obtained with the model order
reduction technique in the Simscape Multibody™ Reduced Order Flexible Solid
block. Simscape models expect the connections at all joints to have six degrees of
freedom, while Partial Differential Equation Toolbox uses two or three degrees of freedom
at each node. Setting a multipoint constraint ensures that all nodes and all degrees of
freedom for the specified geometric regions have a rigid constraint with the geometric
center of all specified geometric regions altogether as the reference point. The reference
location has six degrees of freedom.
5-986
structuralBC
For better performance, specify geometric regions with a minimal number of nodes. For
example, use a set of edges instead of using a face, and a set of vertices instead of using
an edge.
structuralBC(structuralmodel,RegionType,
RegionID,'Constraint','multipoint','Reference',Coords) specifies the
reference point for the multipoint constraint instead of using the geometric center of all
specified regions as a reference point.
structuralBC(structuralmodel,RegionType,
RegionID,'Constraint','multipoint','Reference',Coords,'Radius',R)
restricts the region for multipoint constraint to nodes within the circle (for a 2-D
geometry) or sphere (for a 3-D geometry) of radius R around the reference point.
Use this syntax with any of the input arguments from previous syntaxes.
bc = structuralBC( ___ ) returns the structural boundary condition object using any
of the input arguments from previous syntaxes.
Examples
structuralModel = createpde('structural','static-solid');
gm = multicylinder([0.01,0.015],0.05);
Assign the geometry to the structural model and plot the geometry.
5-987
5 Functions — Alphabetical List
structuralModel.Geometry = gm;
pdegplot(structuralModel,'CellLabels','on','FaceLabels','on','FaceAlpha',0.4)
For each metal, specify the Young's modulus and Poisson's ratio.
structuralProperties(structuralModel,'Cell',1,'YoungsModulus',110E9, ...
'PoissonsRatio',0.28);
structuralProperties(structuralModel,'Cell',2,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3);
structuralBC(structuralModel,'Face',[1,4],'Constraint','fixed')
5-988
structuralBC
ans =
StructuralBC with properties:
RegionType: 'Face'
RegionID: [1 4]
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: []
Pressure: []
TranslationalStiffness: []
structuralBoundaryLoad(structuralModel,'Face',[2,5],'SurfaceTraction',[0;0;100])
ans =
StructuralBC with properties:
RegionType: 'Face'
RegionID: [2 5]
Vectorized: 'off'
Boundary Loads
Force: []
5-989
5 Functions — Alphabetical List
Specify Displacements
structuralModel = createpde('structural','static-solid');
gm = multicuboid(0.2,0.1,0.05);
Assign the geometry to the structural model and plot the geometry.
structuralModel.Geometry = gm;
pdegplot(structuralModel,'FaceLabels','on','FaceAlpha',0.5)
5-990
structuralBC
structuralProperties(structuralModel,'YoungsModulus',74e9,...
'PoissonsRatio',0.42,...
'MassDensity',19.29e3);
structuralBodyLoad(structuralModel,'GravitationalAcceleration',[0;0;-9.8]);
structuralBC(structuralModel,'Face',5,'Constraint','fixed');
5-991
5 Functions — Alphabetical List
structuralBC(structuralModel,'Face',3,'ZDisplacement',0.0001);
generateMesh(structuralModel);
R = solve(structuralModel);
pdeplot3D(structuralModel,'ColorMapData',R.Stress.sxx,'Deformation',R.Displacement)
5-992
structuralBC
Now specify all three displacements on the same face. Here, the z-displacement is the
same, but the x- and y-displacements are both zero. Face 3 cannot move in the x- and y-
directions.
structuralBC(structuralModel,'Face',3,'Displacement',[0;0;0.0001]);
R = solve(structuralModel);
pdeplot3D(structuralModel,'ColorMapData',R.Stress.sxx,'Deformation',R.Displacement)
structuralBC(structuralModel,'Face',3,'XDisplacement',0, ...
'YDisplacement',0, ...
'ZDisplacement',0.0001);
5-993
5 Functions — Alphabetical List
R = solve(structuralModel);
pdeplot3D(structuralModel,'ColorMapData',R.Stress.sxx,'Deformation',R.Displacement)
5-994
structuralBC
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
structuralBC(structuralmodel,'Face',5,'Constraint','fixed');
5-995
5 Functions — Alphabetical List
Apply a sinusoidal displacement along the y-direction on the end opposite to the fixed end
of the beam.
yDisplacementFunc = @(location,state) ones(size(location.y))*1E-4*sin(50*state.time);
structuralBC(structuralmodel,'Face',3,'YDisplacement',yDisplacementFunc)
ans =
StructuralBC with properties:
RegionType: 'Face'
RegionID: 3
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: []
Pressure: []
TranslationalStiffness: []
5-996
structuralBC
structuralmodel = createpde('structural','transient-solid');
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
5-997
5 Functions — Alphabetical List
structuralProperties(structuralmodel,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
structuralBC(structuralmodel,'Face',5,'Constraint','fixed');
Apply a sinusoidal displacement along the y-direction on the end opposite to the fixed end
of the beam.
structuralBC(structuralmodel,'Face',3,'YDisplacement',1E-4,'Frequency',50);
Fix one corner of a rectangular plate to restrain all rigid body motions of the model.
model = createpde('structural','static-planestress');
length = 1;
width = 0.5;
radius = 0.1;
R1 = [3 4 -length length length -length ...
-width -width width width]';
C1 = [1 0 0 radius 0 0 0 0 0 0]';
gdm = [R1 C1];
ns = char('R1','C1');
g = decsg(gdm,'R1- C1',ns');
geometryFromEdges(model,g);
figure
pdegplot(model,'EdgeLabels','on');
axis([-1.2*length 1.2*length ...
-1.2*width 1.2*width])
5-998
structuralBC
figure
pdegplot(model,'VertexLabels','on');
axis([-1.2*length 1.2*length ...
-1.2*width 1.2*width])
5-999
5 Functions — Alphabetical List
Set the x-component of displacement on the left edge of the plate to zero to resist the
applied load.
structuralBC(model,'Edge',3,'XDisplacement',0);
Apply the surface traction with a nonzero x-component on the right edge of the plate.
structuralBoundaryLoad(model,'Edge',1,'SurfaceTraction',[100000 0]);
5-1000
structuralBC
structuralBC(model,'Vertex',3,'YDisplacement',0);
Generate the mesh, using Hmax to control the mesh size. A fine mesh lets you capture the
gradation in the solution accurately.
generateMesh(model,'Hmax',radius/6);
R = solve(model);
pdeplot(model,'XYData',R.Stress.sxx);
axis equal
colormap jet
title 'Normal Stress Along x-Direction';
5-1001
5 Functions — Alphabetical List
Set Multipoint Constraint and Obtain ROM Results Compatible with Simscape
Multibody™
structuralmodel = createpde('structural','transient-solid');
5-1002
structuralBC
gm = multicuboid(0.1,0.01,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'EdgeLabels','on','FaceAlpha',0.5)
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',70E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',2700);
Generate a mesh.
generateMesh(structuralmodel);
5-1003
5 Functions — Alphabetical List
Set the multipoint constraint on the right side of the beam. For better performance, set
the constraint on the set of edges bounding the right side of the beam instead of setting it
on the entire face.
structuralBC(structuralmodel,'Edge',[4,6,9,10],'Constraint','multipoint')
ans =
StructuralBC with properties:
RegionType: 'Edge'
RegionID: [4 6 9 10]
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: []
Pressure: []
TranslationalStiffness: []
Using the same approach, set the multipoint constraint on the left side of the beam.
structuralBC(structuralmodel,'Edge',[2,8,11,12],'Constraint','multipoint')
ans =
StructuralBC with properties:
5-1004
structuralBC
RegionType: 'Edge'
RegionID: [2 8 11 12]
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: []
Pressure: []
TranslationalStiffness: []
Reduce the model to all modes in the frequency range [-Inf,500000] and the interface
degrees of freedom.
R = reduce(structuralmodel,'FrequencyRange',[-Inf,500000])
R =
ReducedStructuralModel with properties:
K: [34x34 double]
M: [34x34 double]
NumModes: 22
RetainedDoF: [1x144 double]
ReferenceLocations: [3x2 double]
5-1005
5 Functions — Alphabetical List
Input Arguments
structuralmodel — Structural model
StructuralModel object
Geometric region type, specified as 'Vertex', 'Edge', or, for a 3-D model, 'Face'.
You cannot use the following geometric region types if you specify the 'roller' or
'symmetric' value for the boundary constraint Cval:
Example: structuralBC(structuralmodel,'Face',
[2,5],'XDisplacement',0.1)
Data Types: char | string
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Example: structuralBC(structuralmodel,'Face',
[2,5],'XDisplacement',0.01)
Data Types: double
5-1006
structuralBC
5-1007
5 Functions — Alphabetical List
You cannot use the 'roller' and 'symmetric' values with the following geometric
region types:
Example: structuralBC(structuralmodel,'Face',
[2,5],'Constraint','fixed')
Data Types: char | string
Reference point location for the multipoint constraint, specified as a 2-by-1 (for a 2-D
geometry) or 3-by-1 (for a 3-D geometry) numeric vector.
Example: structuralBC(structuralmodel,'Vertex',
[1,3,5:10],'Constraint','multipoint','Reference',[0;0;1])
Data Types: double
R — Radius of circle (for 2-D geometry) or sphere (for 3-D geometry) around
reference point location for multipoint constraint
positive number
Radius of a circle (for a 2-D geometry) or a sphere (for a 3-D geometry) around the
reference point location for the multipoint constraint, specified as a positive number.
5-1008
structuralBC
Example: structuralBC(structuralmodel,'Vertex',
[1,3,5:10],'Constraint','multipoint','Reference',
[0;0;1],'Radius',0.2)
Data Types: double
You can model rectangular, triangular, and trapezoidal displacement pulses. If the start
time is 0, you do not need to specify it.
5-1009
5 Functions — Alphabetical List
You can model a harmonic displacement by specifying its frequency and initial phase. If
the initial phase is 0, you do not need to specify it.
5-1010
structuralBC
Example: structuralBC(structuralmodel,'Face',
[2,5],'XDisplacement',0.01,'RiseTime',0.5,'FallTime',0.5,'EndTime',3
)
Start time for the displacement component, specified as 0 or a positive number. Specify
this argument only for transient structural models.
Example: structuralBC(structuralmodel,'Face',
[2,5],'XDisplacement',0.01,'StartTime',1,'EndTime',3)
Data Types: double
5-1011
5 Functions — Alphabetical List
End time for the displacement component, specified as a positive number equal or greater
than the start time value. Specify this argument only for transient structural models.
Example: structuralBC(structuralmodel,'Face',
[2,5],'XDisplacement',0.01,'StartTime',1,'EndTime',3)
Data Types: double
Rise time for the displacement component, specified as a positive number. Specify this
argument only for transient structural models.
Example: structuralBC(structuralmodel,'Face',
[2,5],'XDisplacement',0.01,'RiseTime',0.5,'FallTime',0.5,'EndTime',3
)
Data Types: double
Fall time for the displacement component, specified as a positive number. Specify this
argument only for transient structural models.
Example: structuralBC(structuralmodel,'Face',
[2,5],'XDisplacement',0.01,'RiseTime',0.5,'FallTime',0.5,'EndTime',3
)
Data Types: double
Harmonic Displacement
5-1012
structuralBC
Output Arguments
bc — Handle to boundary condition
StructuralBC object
More About
Degrees of Freedom (DoFs)
In Partial Differential Equation Toolbox, each node of a 2-D or 3-D geometry has two or
three degrees of freedom (DoFs), respectively. DoFs correspond to translational
displacements. If the number of mesh points in a model is NumNodes, then the toolbox
assigns the IDs to the degrees of freedom as follows:
Tips
• Restrain all rigid body motions by specifying as many boundary conditions as needed.
If you do not restrain all rigid body motions, the entire geometry can freely rotate or
5-1013
5 Functions — Alphabetical List
move. The resulting linear system of equations is singular. The system can take a long
time to converge, or it might not converge at all. If the system converges, the solution
includes a large rigid body motion in addition to deformation.
See Also
StructuralModel | reconstructSolution | reduce | solve |
structuralBodyLoad | structuralBoundaryLoad | structuralDamping |
structuralProperties | structuralSEInterface
Introduced in R2017b
5-1014
StructuralBC Properties
StructuralBC Properties
Boundary condition or boundary load for structural analysis model
Description
A StructuralBC object specifies the type of PDE boundary condition or boundary load
on a set of geometry boundaries. A StructuralModel object contains a vector of
StructuralBC objects in its BoundaryConditions.StructuralBCAssignments
property.
To specify boundary conditions for your model, use the structuralBC function. To
specify boundary loads, use structuralBoundaryLoad.
Properties
Properties of StructuralBC
Geometric region type, returned as 'Face' for a 3-D geometry or 'Edge' for a 2-D
geometry.
Data Types: char | string
Geometric region ID, returned as a vector of positive integers. Find the region IDs by
using pdegplot with 'FaceLabels' (3-D) or 'EdgeLabels' (2-D) set to 'on'.
Data Types: double
Vectorized function evaluation, returned as 'off' or 'on'. This evaluation applies when
you pass a function handle as an argument. To save time in the function handle
5-1015
5 Functions — Alphabetical List
evaluation, specify 'on', assuming that your function handle computes in a vectorized
fashion. See “Vectorization” (MATLAB). For details on this evaluation, see “Nonconstant
Boundary Conditions” on page 2-129.
Data Types: char
5-1016
StructuralBC Properties
Radius — Radius of circle (for 2-D geometry) or sphere (for 3-D geometry)
around reference point location for multipoint constraint
positive number
Radius of a circle (for a 2-D geometry) or a sphere (for a 3-D geometry) around the
reference point location for the multipoint constraint, returned as a positive number.
Data Types: double
Reference point location for the multipoint constraint, returned as a 2-by-1 (for a 2-D
geometry) or 3-by-1 (for a 3-D geometry) numeric vector.
Data Types: double
Boundary Loads
Normal and tangential distributed forces on the boundary (in the global Cartesian
coordinates system), returned as a numeric vector or function handle. The numeric vector
must contain two elements for a 2-D model and three elements for a 3-D model. The
5-1017
5 Functions — Alphabetical List
function must return a two-row matrix for a 2-D model and a three-row matrix for a 3-D
model. Each column of the matrix must correspond to the surface traction vector at the
boundary coordinates provided by the solver.
Data Types: double | function_handle
Pressure normal to the boundary, returned as a number or function handle. The function
must return a row vector in which each column corresponds to the value of pressure at
the boundary coordinates provided by the solver. A positive value of pressure acts in the
direction of the outward normal to the boundary.
Data Types: double | function_handle
Distributed spring stiffness for each translational direction used to model an elastic
foundation, returned as a numeric vector or function handle. The numeric vector must
contain two elements for a 2-D model and three elements for a 3-D model. The custom
function must return a two-row matrix for a 2-D model and a three-row matrix for a 3-D
model. Each column of this matrix corresponds to the stiffness vector at the boundary
coordinates provided by the solver.
Data Types: double | function_handle
Start time for a displacement component, the pressure, or the concentrated force load,
returned as a nonnegative number.
Data Types: double
5-1018
StructuralBC Properties
End time for a displacement component, the pressure, or the concentrated force load,
returned as a nonnegative number.
Data Types: double
Rise time for a displacement component, the pressure, or the concentrated force load,
returned as a nonnegative number.
Data Types: double
Fall time for a displacement component, the pressure, or the concentrated force load,
returned as a nonnegative number.
Data Types: double
5-1019
5 Functions — Alphabetical List
See Also
StructuralSEIAssignment Properties | findStructuralBC | structuralBC |
structuralBoundaryLoad | structuralSEInterface
Introduced in R2017b
5-1020
structuralIC
structuralIC
Package: pde
Syntax
structuralIC(structuralmodel,'Displacement',u0,'Velocity',v0)
structuralIC( ___ RegionType,RegionID)
structuralIC(structuralmodel,Sresults)
structuralIC(structuralmodel,Sresults,iT)
struct_ic = structuralIC( ___ )
Description
structuralIC(structuralmodel,'Displacement',u0,'Velocity',v0) sets
initial displacement and velocity for the entire geometry.
Examples
5-1021
5 Functions — Alphabetical List
Specify initial velocity values for the entire geometry and for a particular face.
structuralmodel = createpde('structural','transient-solid');
Create a geometry and include it into the model. Plot the geometry.
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
5-1022
structuralIC
Specify the zero initial velocity on the entire geometry. When you specify only the initial
velocity or initial displacement, structuralIC assumes that the omitted parameter is
zero. For example, here the initial displacement is also zero.
structuralIC(structuralmodel,'Velocity',[0;0;0])
ans =
GeometricStructuralICs with properties:
RegionType: 'Cell'
RegionID: 1
InitialDisplacement: []
InitialVelocity: [3x1 double]
structuralIC(structuralmodel,'Face',2,'Velocity',[0;60;0])
ans =
GeometricStructuralICs with properties:
RegionType: 'Face'
RegionID: 2
InitialDisplacement: []
InitialVelocity: [3x1 double]
structuralmodel = createpde('structural','transient-solid');
Create the geometry and include it into the model. Plot the geometry.
gm = multicuboid(0.06,0.005,0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
5-1023
5 Functions — Alphabetical List
structuralIC(structuralmodel,'Displacement',[0;0;0])
ans =
GeometricStructuralICs with properties:
RegionType: 'Cell'
RegionID: 1
InitialDisplacement: [3x1 double]
InitialVelocity: []
5-1024
structuralIC
Now change the initial displacement in the z-direction on face 2 to a function of the
coordinates x and y:
0
u0 = 0
x2 + y2
Write the following function file. Save it to a location on your MATLAB® path.
M = length(location.x);
uinit = zeros(3,M);
ans =
GeometricStructuralICs with properties:
RegionType: 'Face'
RegionID: 2
InitialDisplacement: @initdisp
InitialVelocity: []
Create the geometry and include it in the model. Plot the geometry.
gm = multicuboid(0.06,0.005,0.01);
staticmodel.Geometry = gm;
5-1025
5 Functions — Alphabetical List
pdegplot(staticmodel,'FaceLabels','on','FaceAlpha',0.5)
view(50,20)
5-1026
structuralIC
generateMesh(staticmodel,'Hmax',0.02);
Rstatic = solve(staticmodel);
dynamicmodel = createpde('structural','transient-solid');
gm = multicuboid(0.06,0.005,0.01);
dynamicmodel.Geometry = gm;
structuralBC(dynamicmodel,'Face',5,'Constraint','fixed');
Generate a mesh.
generateMesh(dynamicmodel,'Hmax',0.02);
structuralIC(dynamicmodel,Rstatic)
ans =
NodalStructuralICs with properties:
Input Arguments
structuralmodel — Transient structural model
StructuralModel object
u0 — Initial displacement
numeric vector | function handle
5-1027
5 Functions — Alphabetical List
The function must return a two-row matrix for a 2-D model and a three-row matrix for a 3-
D model. Each column of the matrix corresponds to the initial displacement at the
coordinates provided by the solver. The approaches for using function handles to specify
initial conditions for StructuralModel and PDEModel are the same. For details about
nonconstant initial conditions for a PDEModel object, see “Nonconstant Initial
Conditions” on page 2-113.
Example: structuralIC(structuralmodel,'Face',[2,5],'Displacement',
[0;0;0.01])
Data Types: double | function_handle
v0 — Initial velocity
numeric vector | function handle
Initial velocity, specified as a numeric vector or function handle. A numeric vector must
contain two elements for a 2-D model and three elements for a 3-D model. The elements
represent the components of initial velocity.
The function must return a two-row matrix for a 2-D model and a three-row matrix for a 3-
D model. Each column of the matrix corresponds to the initial velocity at the coordinates
provided by the solver. The approaches for using function handles to specify initial
conditions for StructuralModel and PDEModel are the same. For details about
nonconstant initial conditions for a PDEModel object, see “Nonconstant Initial
Conditions” on page 2-113.
Example: structuralIC(structuralmodel,'Face',[2,5],'Displacement',
[0;0;0.01],'Velocity',[0;60;0])
Data Types: double | function_handle
When you apply multiple initial condition assignments, the solver uses these precedence
rules for determining the initial condition.
5-1028
structuralIC
• For multiple assignments to the same geometric region, the solver uses the last
applied setting.
• For separate assignments to a geometric region and the boundaries of that region, the
solver uses the specified assignment on the region and chooses the assignment on the
boundary as follows. The solver gives an 'Edge' assignment precedence over a
'Face' assignment, even if you specify a 'Face' assignment after an 'Edge'
assignment. The precedence levels are 'Vertex (highest precedence), 'Edge',
'Face', 'Cell' (lowest precedence).
• For an assignment made with the results object, the solver uses that assignment
instead of all previous assignments.
Example: structuralIC(structuralmodel,'Face',[2,5],'Displacement',
[0;0;0.01],'Velocity',[0;60;0])
Data Types: char
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Example: structuralIC(structuralmodel,'Face',[2,5],'Displacement',
[0;0;0.01],'Velocity',[0;60;0])
Data Types: double
iT — Time index
positive integer
5-1029
5 Functions — Alphabetical List
Output Arguments
struct_ic — Handle to initial conditions
object
See Also
GeometricStructuralICs Properties | NodalStructuralICs Properties | StructuralModel |
findStructuralIC | reduce | solve | structuralBC | structuralBodyLoad |
structuralBoundaryLoad | structuralDamping | structuralProperties |
structuralSEInterface
Introduced in R2018a
5-1030
structuralDamping
structuralDamping
Specify damping parameters for transient or frequency response structural model
Syntax
structuralDamping(structuralmodel,'proportional','Alpha',a,'Beta',b)
ab = structuralDamping( ___ )
Description
structuralDamping(structuralmodel,'proportional','Alpha',a,'Beta',b)
specifies proportional (Rayleigh) damping parameters a and b for structuralmodel.
The second argument must be 'proportional'.
For a frequency response model with damping, the results are complex. Use functions
such as abs and angle to obtain real-valued results such as magnitude and phase.
Examples
structuralModel = createpde('structural','transient-solid');
gm = importGeometry(structuralModel,'SquareBeam.STL');
pdegplot(structuralModel,'FaceAlpha',0.5)
5-1031
5 Functions — Alphabetical List
ans =
StructuralDampingAssignment with properties:
RegionType: 'Cell'
RegionID: 1
5-1032
structuralDamping
DampingModel: 'proportional'
Alpha: 10
Beta: 2
Input Arguments
structuralmodel — Transient or frequency response structural model
StructuralModel object
Output Arguments
ab — Handle to damping parameters
StructuralDampingAssignment object
5-1033
5 Functions — Alphabetical List
See Also
StructuralModel | solve | structuralBC | structuralBodyLoad |
structuralBoundaryLoad | structuralProperties
Introduced in R2018a
5-1034
findStructuralDamping
findStructuralDamping
Package: pde
Syntax
dma = findStructuralDamping(structuralmodel.DampingModels)
Description
dma = findStructuralDamping(structuralmodel.DampingModels) returns the
damping model and its parameters assigned to the structural dynamics model. The
toolbox supports the proportional (Rayleigh) damping model. The parameters of this
damping model are the mass and stiffness proportional damping parameters.
Examples
structuralModel = createpde('structural','transient-solid');
importGeometry(structuralModel,'Block.stl');
pdegplot(structuralModel,'CellLabels','on')
5-1035
5 Functions — Alphabetical List
Check the damping parameter assignment for structuralModel. Notice that the Beta
parameter is empty.
findStructuralDamping(structuralModel.DampingModels)
ans =
StructuralDampingAssignment with properties:
5-1036
findStructuralDamping
RegionType: 'Cell'
RegionID: 1
DampingModel: 'proportional'
Alpha: 10
Beta: []
structuralDamping(structuralModel,'proportional','Alpha',10,'Beta',40);
findStructuralDamping(structuralModel.DampingModels)
ans =
StructuralDampingAssignment with properties:
RegionType: 'Cell'
RegionID: 1
DampingModel: 'proportional'
Alpha: 10
Beta: 40
Input Arguments
structuralmodel.DampingModels — Damping model
DampingModels property of StructuralModel object
5-1037
5 Functions — Alphabetical List
Output Arguments
dma — Damping model assignment
StructuralDampingAssignment object
See Also
StructuralDampingAssignment Properties | structuralDamping
Introduced in R2018a
5-1038
StructuralDampingAssignment Properties
StructuralDampingAssignment Properties
Damping assignment for a structural analysis model
Description
A StructuralDampingAssignment object contains the damping model and its
parameters for a structural analysis model. A StructuralModel container has a vector
of StructuralDampingAssignment objects in its
DampingModels.StructuralDampingAssignments property.
To set damping parameters for your structural model, use the structuralDamping
function.
Properties
Properties of StructuralDampingAssignment
Region type, returned as 'Face' for a 2-D region, or 'Cell' for a 3-D region.
Data Types: char | string
RegionID — Region ID
positive integer
Region ID, returned as a positive integer. The toolbox defines damping parameters for the
entire geometry.
Data Types: double
5-1039
5 Functions — Alphabetical List
See Also
findStructuralDamping | structuralDamping
Introduced in R2018a
5-1040
StructuralMaterialAssignment Properties
StructuralMaterialAssignment Properties
Structural material property assignments
Description
A StructuralMaterialAssignment object contains the description of material
properties of a structural analysis model. A StructuralModel container has a vector of
StructuralMaterialAssignment objects in its
MaterialProperties.MaterialAssignments property.
To create the material properties assignments for your structural analysis model, use the
structuralProperties function.
Properties
Properties of StructuralMaterialAssignment
Region type, returned as 'Face' for a 2-D region, or 'Cell' for a 3-D region.
Data Types: char | string
RegionID — Region ID
vector of positive integers
5-1041
5 Functions — Alphabetical List
Mass density of the material, returned as a positive number. This property is required
when modeling gravitational effects.
Data Types: double
See Also
findStructuralProperties | structuralProperties
Introduced in R2017b
5-1042
structuralBodyLoad
structuralBodyLoad
Package: pde
Syntax
structuralBodyLoad(structuralmodel,'GravitationalAcceleration',
GAval)
structuralBodyLoad(structuralmodel,'Temperature',Tval)
structuralBodyLoad(structuralmodel,'Temperature',Tresults)
structuralBodyLoad(structuralmodel,'Temperature',
Tresults,'TimeStep',iT)
Description
structuralBodyLoad(structuralmodel,'GravitationalAcceleration',
GAval) specifies acceleration due to gravity as a body load for a static or transient
structural model. Structural models for modal analysis cannot have body loads.
structuralBodyLoad(structuralmodel,'Temperature',Tval) specifies a
thermal load on a static structural analysis model.
Tip If Tval is the temperature itself, and not a change in temperature, you also must
specify a reference temperature. To specify it, assign the reference temperature value to
structuralmodel.ReferenceTemperature. For details, see StructuralModel.
5-1043
5 Functions — Alphabetical List
structuralBodyLoad(structuralmodel,'Temperature',
Tresults,'TimeStep',iT) uses the transient thermal analysis results Tresults and
the time step index iT to specify a thermal load on a static structural analysis model.
bodyLoad = structuralBodyLoad( ___ ) returns the body load object, using the
input arguments from any of the previous syntaxes.
Examples
structuralModel = createpde('structural','static-solid');
gm = multicuboid(0.5,0.1,0.1);
structuralModel.Geometry = gm;
pdegplot(structuralModel,'FaceAlpha',0.5)
5-1044
structuralBodyLoad
Specify the Young's modulus, Poisson's ratio, and mass density. The mass density value is
required for modeling gravitational effects.
structuralProperties(structuralModel,'YoungsModulus',210E3, ...
'PoissonsRatio',0.3, ...
'MassDensity',2.7E-6);
structuralBodyLoad(structuralModel,'GravitationalAcceleration',[0;0;-9.8])
ans =
BodyLoadAssignment with properties:
5-1045
5 Functions — Alphabetical List
RegionType: 'Cell'
RegionID: 1
GravitationalAcceleration: [3x1 double]
Temperature: []
TimeStep: []
Specify a constant temperature rise for a thermal stress analysis of a bimetallic cantilever
beam.
structuralmodel = createpde('structural','static-solid');
gm = multicuboid(0.5,0.04,[0.03,0.03],'Zoffset',[0,0.03]);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'CellLabels','on')
5-1046
structuralBodyLoad
Set the reference temperature. This temperature corresponds to the state of zero thermal
stress of the model.
structuralmodel.ReferenceTemperature = 20
structuralmodel =
StructuralModel with properties:
AnalysisType: 'static-solid'
Geometry: [1x1 DiscreteGeometry]
MaterialProperties: []
BodyLoads: []
BoundaryConditions: []
ReferenceTemperature: 20
5-1047
5 Functions — Alphabetical List
SuperelementInterfaces: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
structuralBodyLoad(structuralmodel,'Temperature',300)
ans =
BodyLoadAssignment with properties:
RegionType: 'Cell'
RegionID: [1 2]
GravitationalAcceleration: []
Temperature: 300
TimeStep: []
Specify a thermal load using the solution from a steady-state thermal analysis on the
same geometry and mesh.
thermalmodel = createpde('thermal','steadystate');
gm = multicuboid(0.5,0.1,0.05);
thermalmodel.Geometry = gm;
pdegplot(thermalmodel,'FaceLabels','on','FaceAlpha',0.5)
5-1048
structuralBodyLoad
Generate a mesh.
generateMesh(thermalmodel);
thermalProperties(thermalmodel,'ThermalConductivity',5e-3);
Specify constant temperatures on the left and right ends on the beam.
thermalBC(thermalmodel,'Face',3,'Temperature',100);
thermalBC(thermalmodel,'Face',5,'Temperature',0);
5-1049
5 Functions — Alphabetical List
internalHeatSource(thermalmodel,10);
thermalresults = solve(thermalmodel)
thermalresults =
SteadyStateThermalResults with properties:
pdeplot3D(thermalmodel,'ColorMapData',thermalresults.Temperature)
5-1050
structuralBodyLoad
Apply the solution of the thermal model analysis as a body load for the structural model.
structuralBodyLoad(structuralmodel,'Temperature',thermalresults)
ans =
BodyLoadAssignment with properties:
5-1051
5 Functions — Alphabetical List
RegionType: 'Cell'
RegionID: 1
GravitationalAcceleration: []
Temperature: [1x1 pde.SteadyStateThermalResults]
TimeStep: []
Specify a thermal load using the solution from a transient thermal analysis on the same
geometry and mesh.
thermalmodel = createpde('thermal','transient');
gm = multicuboid(0.5,0.1,0.05);
thermalmodel.Geometry = gm;
pdegplot(thermalmodel,'FaceLabels','on','FaceAlpha',0.5)
5-1052
structuralBodyLoad
Generate a mesh.
generateMesh(thermalmodel);
thermalProperties(thermalmodel,'ThermalConductivity',5e-3, ...
'MassDensity',2.7*10^(-6), ...
'SpecificHeat',10);
Specify the constant temperatures on the left and right ends on the beam.
thermalBC(thermalmodel,'Face',3,'Temperature',100);
thermalBC(thermalmodel,'Face',5,'Temperature',0);
5-1053
5 Functions — Alphabetical List
internalHeatSource(thermalmodel,10);
thermalIC(thermalmodel,0);
tlist = [0:1e-4:2e-4];
thermalresults = solve(thermalmodel,tlist)
thermalresults =
TransientThermalResults with properties:
for n = 1:numel(thermalresults.SolutionTimes)
figure
pdeplot3D(thermalmodel,'ColorMapData',thermalresults.Temperature(:,n))
title(['Time = ' num2str(tlist(n))])
caxis([0 100])
end
5-1054
structuralBodyLoad
5-1055
5 Functions — Alphabetical List
5-1056
structuralBodyLoad
structuralmodel = createpde('structural','static-solid');
structuralmodel.Geometry = gm;
Apply the solution of the thermal model analysis as a body load for the structural model.
By default, structuralBodyLoad uses the thermal model solution for the last time step.
structuralBodyLoad(structuralmodel,'Temperature',thermalresults);
5-1057
5 Functions — Alphabetical List
You also can specify the time step you want to use. For example, apply the thermal model
solution for the second time step as a body load for the structural model.
structuralBodyLoad(structuralmodel,'Temperature',thermalresults, ...
'TimeStep',2);
Input Arguments
structuralmodel — Static or transient structural model
StructuralModel object
Constant thermal load on a static structural model, specified as a real number. Tval must
be specified in units consistent with the geometry and material properties units.
Example: structuralBodyLoad(structuralmodel,'Temperature',300)
Data Types: double
5-1058
structuralBodyLoad
Thermal model solution applied as a body load on a static structural model, specified as a
StaticThermalResults or TransientThermalResults object. Create Tresults by
using solve.
Example: Tresults = solve(thermalmodel);
structuralBodyLoad(structuralmodel,'Temperature',Tresults)
iT — Time index
positive integer
Output Arguments
bodyLoad — Handle to body load
BodyLoadAssignment object
See Also
StructuralModel | structuralBC | structuralBoundaryLoad |
structuralDamping | structuralProperties
Introduced in R2017b
5-1059
5 Functions — Alphabetical List
structuralBoundaryLoad
Package: pde
Syntax
structuralBoundaryLoad(structuralmodel,RegionType,
RegionID,'SurfaceTraction',STval,'Pressure',
Pval,'TranslationalStiffness',TSval)
structuralBoundaryLoad(structuralmodel,'Vertex',VertexID,'Force',
Fval)
Description
structuralBoundaryLoad(structuralmodel,RegionType,
RegionID,'SurfaceTraction',STval,'Pressure',
Pval,'TranslationalStiffness',TSval) specifies the surface traction, pressure,
and translational stiffness on the boundary of type RegionType with RegionID ID
numbers.
5-1060
structuralBoundaryLoad
structuralBoundaryLoad does not require you to specify all three boundary loads.
Depending on your structural analysis problem, you can specify one or more boundary
loads by picking the corresponding arguments and omitting others. You can specify
translational stiffness for any structural model. To specify pressure or surface traction,
structuralmodel must be a static, transient, or frequency response model. Structural
models for modal analysis cannot have pressure or surface traction.
structuralBoundaryLoad(structuralmodel,'Vertex',VertexID,'Force',
Fval) specifies concentrated force at a vertex with the VertexID number. You can
specify force only if structuralmodel is a static, transient, or frequency response
model. Structural models for modal analysis cannot have concentrated force.
Use this syntax with any of the input arguments from previous syntaxes.
structuralBoundaryLoad(structuralmodel,'Vertex',VertexID,'Force',
Fval,Name,Value) lets you specify the form and duration of a nonconstant
concentrated force and harmonic excitation for a transient structural model without
creating a function handle.
Examples
5-1061
5 Functions — Alphabetical List
structuralModel = createpde('structural','static-solid');
gm = multicylinder([0.01,0.015],0.05);
Assign the geometry to the structural model and plot the geometry.
structuralModel.Geometry = gm;
pdegplot(structuralModel,'CellLabels','on','FaceLabels','on','FaceAlpha',0.4)
5-1062
structuralBoundaryLoad
For each metal, specify the Young's modulus and Poisson's ratio.
structuralProperties(structuralModel,'Cell',1,'YoungsModulus',110E9, ...
'PoissonsRatio',0.28);
structuralProperties(structuralModel,'Cell',2,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3);
ans =
StructuralBC with properties:
RegionType: 'Face'
5-1063
5 Functions — Alphabetical List
RegionID: [1 4]
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: []
Pressure: []
TranslationalStiffness: []
structuralBoundaryLoad(structuralModel,'Face',[2,5],'SurfaceTraction',[0;0;100])
ans =
StructuralBC with properties:
RegionType: 'Face'
RegionID: [2 5]
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: [3x1 double]
Pressure: []
TranslationalStiffness: []
5-1064
structuralBoundaryLoad
structuralModel = createpde('structural','static-solid');
gm = multicuboid(20,10,5);
Assign the geometry to the structural model and plot the geometry.
structuralModel.Geometry = gm;
pdegplot(structuralModel,'FaceLabels','on','FaceAlpha',0.5)
5-1065
5 Functions — Alphabetical List
structuralProperties(structuralModel,'YoungsModulus',30, ...
'PoissonsRatio',0.3);
The bottom face of the block rests on an elastic foundation (a spring). To model this
foundation, specify the translational stiffness.
structuralBoundaryLoad(structuralModel,'Face',1,'TranslationalStiffness',[0;0;30])
ans =
StructuralBC with properties:
RegionType: 'Face'
5-1066
structuralBoundaryLoad
RegionID: 1
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: []
Pressure: []
TranslationalStiffness: [3x1 double]
model = createpde('structural','static-solid');
Create the geometry, which consists of two cuboids stacked on top of each other.
model.Geometry = gm;
Plot the geometry and display the face labels. Rotate the geometry so that you can see the
face labels on the left side.
figure
pdegplot(model,'FaceLabels','on');
view([-67 5])
5-1067
5 Functions — Alphabetical List
Plot the geometry and display the vertex labels. Rotate the geometry so that you can see
the vertex labels on the right side.
figure
pdegplot(model,'VertexLabels','on','FaceAlpha',0.5)
xlim([-0.01 0.1])
zlim([-0.01 0.02])
view([60 5])
5-1068
structuralBoundaryLoad
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(model,'YoungsModulus',201E9,'PoissonsRatio',0.3);
ans =
StructuralBC with properties:
5-1069
5 Functions — Alphabetical List
RegionType: 'Vertex'
RegionID: 6
Vectorized: 'off'
Boundary Loads
Force: [3x1 double]
SurfaceTraction: []
Pressure: []
TranslationalStiffness: []
fmodel = createpde('structural','frequency-solid');
importGeometry(fmodel,'TuningFork.stl');
figure
pdegplot(fmodel,'FaceLabels','on')
5-1070
structuralBoundaryLoad
Specify the pressure loading on a tine (face 11) as a short rectangular pressure pulse. In
the frequency domain, this pressure pulse is a unit load uniformly distributed across all
frequencies.
structuralBoundaryLoad(fmodel,'Face',11,'Pressure',1);
2
Now specify a frequency-dependent pressure load, for example, p = e− ω − 1000 /100000.
5-1071
5 Functions — Alphabetical List
Use a function handle to specify a harmonically varying pressure at the center of a thin 3-
D plate.
Create a geometry consisting of a thin 3-D plate with a small plate at the center. Include
the geometry in the model and plot it.
gm = multicuboid([5,0.05],[5,0.05],0.01);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
5-1072
structuralBoundaryLoad
Zoom in to see the face labels on the small plate at the center.
figure
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.25)
axis([-0.2 0.2 -0.2 0.2 -0.1 0.1])
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9,...
'PoissonsRatio',0.3,...
'MassDensity',7800);
Specify that all faces on the periphery of the thin 3-D plate are fixed boundaries.
structuralBC(structuralmodel,'Constraint','fixed','Face',5:8);
5-1073
5 Functions — Alphabetical List
Apply a harmonically varying pressure load on the small face at the center of the plate.
plungerLoad = @(location,state)5E7.*sin(25.*state.time);
structuralBoundaryLoad(structuralmodel,'Face',12,'Pressure',plungerLoad)
ans =
StructuralBC with properties:
RegionType: 'Face'
RegionID: 12
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: []
Pressure: @(location,state)5E7.*sin(25.*state.time)
TranslationalStiffness: []
Specify a harmonically varying pressure at the center of a thin 3-D plate by specifying its
frequency.
5-1074
structuralBoundaryLoad
structuralmodel = createpde('structural','transient-solid');
Create a geometry consisting of a thin 3-D plate with a small plate at the center. Include
the geometry in the model and plot it.
gm = multicuboid([5,0.05],[5,0.05],0.01);
structuralmodel.Geometry=gm;
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.5)
Zoom in to see the face labels on the small plate at the center.
5-1075
5 Functions — Alphabetical List
figure
pdegplot(structuralmodel,'FaceLabels','on','FaceAlpha',0.25)
axis([-0.2 0.2 -0.2 0.2 -0.1 0.1])
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',210E9,...
'PoissonsRatio',0.3,...
'MassDensity',7800);
Specify that all faces on the periphery of the thin 3-D plate are fixed boundaries.
structuralBC(structuralmodel,'Constraint','fixed','Face',5:8);
Apply a harmonically varying pressure load on the small face at the center of the plate.
5-1076
structuralBoundaryLoad
structuralBoundaryLoad(structuralmodel,'Face',12,'Pressure',5E7,'Frequency',25)
ans =
StructuralBC with properties:
RegionType: 'Face'
RegionID: 12
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: []
Pressure: 50000000
TranslationalStiffness: []
structuralModel = createpde('structural','transient-solid');
5-1077
5 Functions — Alphabetical List
importGeometry(structuralModel,'BracketWithHole.stl');
pdegplot(structuralModel,'FaceLabels','on')
view(-20,10)
Apply a rectangular pressure pulse on face 7 in the direction normal to the face.
5-1078
structuralBoundaryLoad
structuralBoundaryLoad(structuralModel,'Face',7,'Pressure',10^5,...
'StartTime',0.1,'EndTime',0.5)
ans =
StructuralBC with properties:
RegionType: 'Face'
RegionID: 7
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: []
Pressure: 100000
TranslationalStiffness: []
5-1079
5 Functions — Alphabetical List
Create the geometry, which consists of two cuboids stacked on top of each other.
structuralmodel.Geometry = gm;
Plot the geometry and display the face labels. Rotate the geometry so that you can see the
face labels on the left side.
figure
pdegplot(structuralmodel,'FaceLabels','on');
view([-67 5])
5-1080
structuralBoundaryLoad
Plot the geometry and display the vertex labels. Rotate the geometry so that you can see
the vertex labels on the right side.
figure
pdegplot(structuralmodel,'VertexLabels','on','FaceAlpha',0.5)
xlim([-0.01 0.1])
zlim([-0.01 0.02])
view([60 5])
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',201E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800);
5-1081
5 Functions — Alphabetical List
structuralBC(structuralmodel,'Face',[5 10],'Constraint','fixed');
structuralBoundaryLoad(structuralmodel,'Vertex',6,'Force',[0;1000;0], ...
'StartTime',1,'EndTime',1.05)
ans =
StructuralBC with properties:
RegionType: 'Vertex'
RegionID: 6
Vectorized: 'off'
Boundary Loads
Force: [3×1 double]
SurfaceTraction: []
Pressure: []
TranslationalStiffness: []
structuralIC(structuralmodel,'Displacement',[0;0;0],'Velocity',[0;0;0])
5-1082
structuralBoundaryLoad
ans =
GeometricStructuralICs with properties:
RegionType: 'Cell'
RegionID: [1 2]
InitialDisplacement: [3×1 double]
InitialVelocity: [3×1 double]
generateMesh(structuralmodel,'Hmax',0.02);
Because the load is zero for the initial time span and is applied for only a short time, solve
the model for two time spans. Use the first time span to find the solution before the force
pulse.
structuralresults1 = solve(structuralmodel,0:1E-2:1);
Use the second time span to find the solution during and after the force pulse.
structuralIC(structuralmodel,structuralresults1)
ans =
NodalStructuralICs with properties:
Plot the displacement value at the node corresponding to vertex 6, where you applied the
concentrated force pulse.
loadedNd = findNodes(structuralmodel.Mesh,'region','Vertex',6);
plot(structuralresults2.SolutionTimes,structuralresults2.Displacement.uy(loadedNd,:))
5-1083
5 Functions — Alphabetical List
Input Arguments
structuralmodel — Structural model
StructuralModel object
5-1084
structuralBoundaryLoad
Geometric region type, specified as 'Edge' for a 2-D model or 'Face' for a 3-D model.
Example: structuralBoundaryLoad(structuralmodel,'Face',
[2,5],'SurfaceTraction',[0,0,100])
Data Types: char | string
Geometric region ID, specified as a positive integer or vector of positive integers. Find the
region IDs by using pdegplot.
Example: structuralBoundaryLoad(structuralmodel,'Face',
[2,5],'SurfaceTraction',[0,0,100])
Data Types: double
VertexID — Vertex ID
positive integer | vector of positive integers
Vertex ID, specified as a positive integer or vector of positive integers. Find the vertex IDs
using pdegplot.
Example: structuralBoundaryLoad(structuralmodel,'Vertex',6,'Force',
[0;10^4;0])
Data Types: double
Distributed normal and tangential forces on the boundary, resolved along the global
Cartesian coordinate system, specified as a numeric vector or function handle. A numeric
vector must contain two elements for a 2-D model and three elements for a 3-D model.
The function must return a two-row matrix for a 2-D model and a three-row matrix for a 3-
D model. Each column of the matrix must correspond to the surface traction vector at the
boundary coordinates provided by the solver. In case of a transient structural model,
STval also can be a function of time.
Example: structuralBoundaryLoad(structuralmodel,'Face',
[2,5],'SurfaceTraction',[0;0;100])
5-1085
5 Functions — Alphabetical List
Pressure normal to the boundary, specified as a number or function handle. The function
must return a row vector where each column corresponds to the value of pressure at the
boundary coordinates provided by the solver. A positive-value pressure acts into the
boundary (for example, compression), while a negative-value pressure acts away from the
boundary (for example, suction).
In case of a transient structural model, Pval also can be a function of time. In case of a
frequency response structural model, Pval can be a function of frequency (when
specified as a function handle) or a constant pressure with the same magnitude for a
broad frequency spectrum.
Example: structuralBoundaryLoad(structuralmodel,'Face',
[2,5],'Pressure',10^5)
Data Types: double | function_handle
Distributed spring stiffness for each translational direction used to model elastic
foundation, specified as a numeric vector or function handle. A numeric vector must
contain two elements for a 2-D model and three elements for a 3-D model. The custom
function must return a two-row matrix for a 2-D model and a three-row matrix for a 3-D
model. Each column of this matrix corresponds to the stiffness vector at the boundary
coordinates provided by the solver. In case of a transient structural model, TSval also
can be a function of time.
Example: structuralBoundaryLoad(structuralmodel,'Edge',
[2,5],'TranslationalStiffness',[0;5500])
Data Types: double | function_handle
5-1086
structuralBoundaryLoad
You can model rectangular, triangular, and trapezoidal pressure or concentrated force
pulses. If the start time is 0, you can omit specifying it.
5-1087
5 Functions — Alphabetical List
You can model a harmonic pressure or concentrated force load by specifying its frequency
and initial phase. If the initial phase is 0, you can omit specifying it.
5-1088
structuralBoundaryLoad
Example: structuralBoundaryLoad(structuralmodel,'Face',
[2,5],'Pressure',10^5,'RiseTime',0.5,'FallTime',0.5,'EndTime',3)
Start time for pressure or concentrated force load, specified as a nonnegative number.
Specify this argument only for transient structural models.
Example: structuralBoundaryLoad(structuralmodel,'Face',
[2,5],'Pressure',10^5,'StartTime',1,'EndTime',3)
Data Types: double
5-1089
5 Functions — Alphabetical List
End time for pressure or concentrated force load, specified as a nonnegative number
equal or greater than the start time value. Specify this argument only for transient
structural models.
Example: structuralBoundaryLoad(structuralmodel,'Face',
[2,5],'Pressure',10^5,'StartTime',1,'EndTime',3)
Data Types: double
Rise time for pressure or concentrated force load, specified as a nonnegative number.
Specify this argument only for transient structural models.
Example: structuralBoundaryLoad(structuralmodel,'Face',
[2,5],'Pressure',10^5,'RiseTime',0.5,'FallTime',0.5,'EndTime',3)
Data Types: double
Fall time for pressure or concentrated force load, specified as a nonnegative number.
Specify this argument only for transient structural models.
Example: structuralBoundaryLoad(structuralmodel,'Face',
[2,5],'Pressure',10^5,'RiseTime',0.5,'FallTime',0.5,'EndTime',3)
Data Types: double
Harmonic Pressure or Force
5-1090
structuralBoundaryLoad
Output Arguments
boundaryLoad — Handle to boundary load
StructuralBC object
See Also
StructuralModel | structuralBC | structuralBodyLoad | structuralDamping |
structuralProperties
Introduced in R2017b
5-1091
5 Functions — Alphabetical List
StructuralModel
Structural model object
Description
A StructuralModel object contains information about a structural analysis problem:
the geometry, material properties, damping parameters, body loads, boundary loads,
boundary constraints, superelement interfaces, initial displacement and velocity, and
mesh.
Creation
To create a StructuralModel object, use createpde and specify 'structural' as its
first argument .
Properties
AnalysisType — Type of structural analysis
'static-solid' | 'static-planestress' | 'static-planestrain' |
'transient-solid' | 'transient-planestress' | 'transient-planestrain' |
'modal-solid' | 'modal-planestress' | 'frequency-solid' | 'frequency-
planestress' | 'frequency-planestrain'
Static analysis:
Transient analysis:
5-1092
StructuralModel
Modal analysis:
5-1093
5 Functions — Alphabetical List
To create the material properties assignments for your structural analysis model, use the
structuralProperties function.
To create body load assignments for your structural analysis model, use the
structuralBodyLoad function.
To specify boundary conditions for your model, use the structuralBC function. To
specify boundary loads, use structuralBoundaryLoad.
To set damping parameters for your structural model, use the structuralDamping
function.
To specify the reference temperature for a thermal load in your static structural model,
assign the property value directly, for example,
5-1094
StructuralModel
To set initial conditions for your transient structural model, use the structuralIC
function.
To specify superelement interfaces for your frequency response structural model, use the
structuralSEInterface function.
Mesh for solution, returned as a FEMesh object. For property details, see FEMesh.
Algorithm options for the PDE solvers, returned as a PDESolverOptions object. The
properties of PDESolverOptions include absolute and relative tolerances for internal
ODE solvers, maximum solver iterations, and so on.
5-1095
5 Functions — Alphabetical List
Object Functions
geometryFromEdges Create 2-D geometry from decomposed geometry matrix
geometryFromMesh Create 2-D or 3-D geometry from mesh
importGeometry Import 2-D or 3-D geometry from STL data
structuralBC Specify boundary conditions for structural model
structuralSEInterface Specify structural superelement interface for component mode
synthesis
structuralBodyLoad Specify body load for structural model
structuralBoundaryLoad Specify boundary loads for structural model
structuralIC Set initial conditions for a transient structural model
structuralProperties Assign structural properties of material for structural model
solve Solve heat transfer or structural analysis problem
reduce Reduce structural model
Examples
structuralModel = createpde('structural','static-solid')
structuralModel =
StructuralModel with properties:
AnalysisType: 'static-solid'
Geometry: []
MaterialProperties: []
BodyLoads: []
BoundaryConditions: []
ReferenceTemperature: []
SuperelementInterfaces: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
5-1096
StructuralModel
gm = multicuboid(0.5,0.1,0.1);
structuralModel.Geometry = gm;
pdegplot(structuralModel,'FaceAlpha',0.5)
ans =
StructuralMaterialAssignment with properties:
RegionType: 'Cell'
RegionID: 1
5-1097
5 Functions — Alphabetical List
YoungsModulus: 210000
PoissonsRatio: 0.3000
MassDensity: 2.7000e-06
CTE: []
ans =
BodyLoadAssignment with properties:
RegionType: 'Cell'
RegionID: 1
GravitationalAcceleration: [3x1 double]
Temperature: []
TimeStep: []
ans =
StructuralBC with properties:
RegionType: 'Face'
RegionID: 6
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: []
Pressure: []
TranslationalStiffness: []
5-1098
StructuralModel
structuralBoundaryLoad(structuralModel,'Face',5,'SurfaceTraction',[0;0;100])
ans =
StructuralBC with properties:
RegionType: 'Face'
RegionID: 5
Vectorized: 'off'
Boundary Loads
Force: []
SurfaceTraction: [3x1 double]
Pressure: []
TranslationalStiffness: []
Generate a mesh.
generateMesh(structuralModel)
ans =
FEMesh with properties:
structuralModel
5-1099
5 Functions — Alphabetical List
structuralModel =
StructuralModel with properties:
AnalysisType: 'static-solid'
Geometry: [1x1 DiscreteGeometry]
MaterialProperties: [1x1 StructuralMaterialAssignmentRecords]
BodyLoads: [1x1 BodyLoadAssignmentRecords]
BoundaryConditions: [1x1 StructuralBCRecords]
ReferenceTemperature: []
SuperelementInterfaces: []
Mesh: [1x1 FEMesh]
SolverOptions: [1x1 pde.PDESolverOptions]
See Also
createpde | generateMesh | geometryFromEdges | geometryFromMesh |
importGeometry | pdegplot | pdeplot | pdeplot3D | reduce | solve |
structuralBC | structuralBodyLoad | structuralBoundaryLoad |
structuralProperties | structuralSEInterface
Introduced in R2017b
5-1100
structuralProperties
structuralProperties
Package: pde
Syntax
structuralProperties(structuralmodel,'YoungsModulus',
YMval,'PoissonsRatio',PRval)
structuralProperties( ___ ,'MassDensity',MDval)
structuralProperties( ___ ,'CTE',CTEval)
structuralProperties( ___ ,RegionType,RegionID)
mtl = structuralProperties( ___ )
Description
structuralProperties(structuralmodel,'YoungsModulus',
YMval,'PoissonsRatio',PRval) assigns the Young's modulus and Poisson's ratio for
the entire geometry. Use this syntax if your model is static and does not account for
gravitational and thermal effects.
Tip A structural model supports only homogeneous isotropic materials. Therefore, all
material properties must be numeric scalars.
5-1101
5 Functions — Alphabetical List
Examples
structuralModel = createpde('structural','static-solid');
importGeometry(structuralModel,'BracketWithHole.stl');
pdegplot(structuralModel,'FaceAlpha',0.5)
5-1102
structuralProperties
structuralProperties(structuralModel,'YoungsModulus',200e9, ...
'PoissonsRatio',0.3, ...
'MassDensity',7800)
ans =
StructuralMaterialAssignment with properties:
RegionType: 'Cell'
RegionID: 1
YoungsModulus: 2.0000e+11
PoissonsRatio: 0.3000
MassDensity: 7800
5-1103
5 Functions — Alphabetical List
CTE: []
structuralModel = createpde('structural','modal-solid');
gm = multicuboid(0.5,0.1,0.1);
structuralModel.Geometry = gm;
pdegplot(structuralModel,'FaceAlpha',0.5)
5-1104
structuralProperties
structuralProperties(structuralModel,'YoungsModulus',210E3, ...
'PoissonsRatio',0.3, ...
'MassDensity',2.7E-6)
ans =
StructuralMaterialAssignment with properties:
RegionType: 'Cell'
RegionID: 1
YoungsModulus: 210000
PoissonsRatio: 0.3000
MassDensity: 2.7000e-06
5-1105
5 Functions — Alphabetical List
CTE: []
Specify the coefficients of thermal expansion for a bimetallic cantilever beam. The bottom
layer is steel. The top layer is copper.
structuralmodel = createpde('structural','static-solid');
gm = multicuboid(0.5,0.04,[0.03,0.03],'Zoffset',[0,0.03]);
structuralmodel.Geometry = gm;
pdegplot(structuralmodel,'CellLabels','on')
5-1106
structuralProperties
Specify the Young's modulus, Poisson's ratio, and coefficient of thermal expansion for the
bottom cell C1.
structuralProperties(structuralmodel,'Cell',1','YoungsModulus',210e9, ...
'PoissonsRatio',0.28, ...
'CTE',1.3e-5)
ans =
StructuralMaterialAssignment with properties:
RegionType: 'Cell'
RegionID: 1
YoungsModulus: 2.1000e+11
PoissonsRatio: 0.2800
5-1107
5 Functions — Alphabetical List
MassDensity: []
CTE: 1.3000e-05
Specify the Young's modulus, Poisson's ratio, and coefficient of thermal expansion for the
top cell C2.
structuralProperties(structuralmodel,'Cell',2','YoungsModulus',110e9, ...
'PoissonsRatio',0.37, ...
'CTE',2.4e-5)
ans =
StructuralMaterialAssignment with properties:
RegionType: 'Cell'
RegionID: 2
YoungsModulus: 1.1000e+11
PoissonsRatio: 0.3700
MassDensity: []
CTE: 2.4000e-05
structuralModel = createpde('structural','static-solid');
gm = multicylinder([0.01,0.015],0.05);
Assign the geometry to the structural model and plot the geometry.
structuralModel.Geometry = gm;
pdegplot(structuralModel,'CellLabels','on','FaceAlpha',0.4)
5-1108
structuralProperties
Specify the Young's modulus and Poisson's ratio for each metal.
structuralProperties(structuralModel,'Cell',1,'YoungsModulus',110E9, ...
'PoissonsRatio',0.28)
ans =
StructuralMaterialAssignment with properties:
RegionType: 'Cell'
RegionID: 1
YoungsModulus: 1.1000e+11
PoissonsRatio: 0.2800
MassDensity: []
5-1109
5 Functions — Alphabetical List
CTE: []
structuralProperties(structuralModel,'Cell',2,'YoungsModulus',210E9, ...
'PoissonsRatio',0.3)
ans =
StructuralMaterialAssignment with properties:
RegionType: 'Cell'
RegionID: 2
YoungsModulus: 2.1000e+11
PoissonsRatio: 0.3000
MassDensity: []
CTE: []
Input Arguments
structuralmodel — Structural model
StructuralModel object
Poisson's ratio of the material, specified as a number greater than 0 and less than 0.5.
5-1110
structuralProperties
Example:
structuralProperties(structuralmodel,'YoungsModulus',210e3,'Poissons
Ratio',0.3)
Data Types: double
Mass density of the material, specified as a positive number. This argument is required
for transient and modal models. MDval is also required when modeling gravitational
effects.
Example:
structuralProperties(structuralmodel,'YoungsModulus',210e3,'Poissons
Ratio',0.3,'MassDensity',11.7e-6)
Data Types: double
Geometric region type, specified as 'Face' for a 2-D model or 'Cell' for a 3-D model.
Example:
structuralProperties(structuralmodel,'Cell',1,'YoungsModulus',110E9,
'PoissonsRatio',0.3)
Data Types: char | string
5-1111
5 Functions — Alphabetical List
Geometric region ID, specified as a vector of positive integers. Find the region IDs using
pdegplot with the 'FaceLabels' (3-D) or 'EdgeLabels' (2-D) value set to 'on'.
Example:
structuralProperties(structuralmodel,'Cell',1:3,'YoungsModulus',110E
9,'PoissonsRatio',0.3)
Data Types: double
Output Arguments
mtl — Handle to material properties
StructuralMaterialAssignment object
See Also
StructuralModel | createpde | structuralBC | structuralBodyLoad |
structuralBoundaryLoad | structuralDamping
Introduced in R2017b
5-1112
structuralSEInterface
structuralSEInterface
Package: pde
Syntax
structuralSEInterface(structuralmodel,RegionType,RegionID)
sei = structuralSEInterface( ___ )
Description
structuralSEInterface(structuralmodel,RegionType,RegionID) defines the
specified geometric region RegionType, RegionID as a superelement interface for
component mode synthesis. For better performance, specify geometric regions with a
minimal number of nodes. For example, use a set of edges instead of a face, or a set of
vertices instead of an edge.
Examples
Define the two ends of the beam as structural superelement interfaces. The reduced-
order modeling technique retains the degrees of freedom on these boundaries while
condensing all other degrees of freedom.
5-1113
5 Functions — Alphabetical List
structuralmodel = createpde('structural','modal-solid');
Specify the Young's modulus, Poisson's ratio, and mass density of the material.
structuralProperties(structuralmodel,'YoungsModulus',70E9, ...
'PoissonsRatio',0.3, ...
'MassDensity',2700);
Generate a mesh.
5-1114
structuralSEInterface
generateMesh(structuralmodel);
Specify the ends of the beam as structural superelement interfaces. For better
performance, use the set of edges bounding each side of the beam instead of using the
entire face.
structuralSEInterface(structuralmodel,'Edge',[4,6,9,10]);
structuralSEInterface(structuralmodel,'Edge',[2,8,11,12]);
Reduce the model to all modes in the frequency range [-Inf,500000] and the interface
degrees of freedom.
R = reduce(structuralmodel,'FrequencyRange',[-Inf,500000])
R =
ReducedStructuralModel with properties:
K: [166x166 double]
M: [166x166 double]
NumModes: 22
RetainedDoF: [144x1 double]
ReferenceLocations: []
Mesh: [1x1 FEMesh]
Input Arguments
structuralmodel — Structural model
StructuralModel object
Geometric region type, specified as 'Vertex', 'Edge', or, for a 3-D model, 'Face'.
Example: structuralSEInterface(structuralmodel,'Face',[2,5])
5-1115
5 Functions — Alphabetical List
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Example: structuralSEInterface(structuralmodel,'Face',[2,5])
Data Types: double
Output Arguments
sei — Handle to superelement interface
StructuralSEIAssignment object
See Also
ReducedStructuralModel | StructuralModel | StructuralSEIAssignment Properties |
reconstructSolution | reduce | solve | structuralBC
Introduced in R2019b
5-1116
StructuralSEIAssignment Properties
StructuralSEIAssignment Properties
Superelement interface assignment for structural model
Description
A StructuralSEIAssignment object contains a description of the superelement
interfaces for a structural analysis model. A StructuralModel container has a vector of
StructuralSEIAssignment objects in its
SuperelementInterfaces.StructuralSEIAssignments property.
Properties
Properties of StructuralSEIAssignment
Region type, returned as 'Vertex', 'Edge', or, for a 3-D model, 'Face'.
Data Types: char | string
RegionID — Region ID
positive integer
Geometric region ID, returned as a positive integer. Find the region IDs by using
pdegplot.
Data Types: double
See Also
ReducedStructuralModel | StructuralBC Properties | StructuralModel |
reconstructSolution | reduce | solve | structuralBC |
structuralSEInterface
Introduced in R2019b
5-1117
5 Functions — Alphabetical List
StationaryResults
Time-independent PDE solution and derived quantities
Description
A StationaryResults object contains the solution of a PDE and its gradients in a form
convenient for plotting and postprocessing.
• A StationaryResults object contains the solution and its gradient calculated at the
nodes of the triangular or tetrahedral mesh, generated by generateMesh.
• Solution values at the nodes appear in the NodalSolution property.
• The three components of the gradient of the solution values at the nodes appear in the
XGradients, YGradients, and ZGradients properties.
• The array dimensions of NodalSolution, XGradients, YGradients, and
ZGradients enable you to extract solution and gradient values for specified equation
indices in a PDE system.
To interpolate the solution or its gradient to a custom grid (for example, specified by
meshgrid), use interpolateSolution or evaluateGradient.
Creation
There are several ways to create a StationaryResults object:
• Solve a time-independent problem using the solvepde function. This function returns
a PDE solution as a StationaryResults object. This is the recommended approach.
• Solve a time-independent problem using the assempde or pdenonlin function. Then
use the createPDEResults function to obtain a StationaryResults object from a
PDE solution returned by assempde or pdenonlin. Note that assempde and
pdenonlin are legacy functions. They are not recommended for solving PDE
problems.
5-1118
StationaryResults
Properties
Mesh — Finite element mesh
FEMesh object
Solution values at the nodes, returned as a vector or array. For details about the
dimensions of NodalSolution, see “Dimensions of Solutions, Gradients, and Fluxes” on
page 3-347.
Data Types: double
x-component of the gradient at the nodes, returned as a vector or array. For details about
the dimensions of XGradients, see “Dimensions of Solutions, Gradients, and Fluxes” on
page 3-347.
Data Types: double
y-component of the gradient at the nodes, returned as a vector or array. For details about
the dimensions of YGradients, see “Dimensions of Solutions, Gradients, and Fluxes” on
page 3-347.
Data Types: double
z-component of the gradient at the nodes, returned as a vector or array. For details about
the dimensions of ZGradients, see “Dimensions of Solutions, Gradients, and Fluxes” on
page 3-347.
Data Types: double
5-1119
5 Functions — Alphabetical List
Object Functions
evaluateCGradient Evaluate flux of PDE solution
evaluateGradient Evaluate gradients of PDE solutions at arbitrary points
interpolateSolution Interpolate PDE solution to arbitrary points
Examples
Create a PDE model for a system of three equations. Import the geometry of a bracket
and plot the face labels.
model = createpde(3);
importGeometry(model,'BracketWithHole.stl');
figure
pdegplot(model,'FaceLabels','on')
view(30,30)
title('Bracket with Face Labels')
5-1120
StationaryResults
figure
pdegplot(model,'FaceLabels','on')
view(-134,-32)
title('Bracket with Face Labels, Rear View')
5-1121
5 Functions — Alphabetical List
Set boundary conditions such that face 4 is immobile, and face 8 has a force in the
negative z direction.
applyBoundaryCondition(model,'dirichlet','Face',4,'u',[0,0,0]);
applyBoundaryCondition(model,'neumann','Face',8,'g',[0,0,-1e4]);
Set coefficients that represent the equations of linear elasticity. See “Linear Elasticity
Equations” on page 3-150.
E = 200e9;
nu = 0.3;
specifyCoefficients(model,'m',0,...
'd',0,...
'c',elasticityC3D(E,nu),...
5-1122
StationaryResults
'a',0,...
'f',[0;0;0]);
Create a mesh.
generateMesh(model,'Hmax',1e-2);
results = solvepde(model)
results =
StationaryResults with properties:
u = results.NodalSolution;
pdeplot3D(model,'ColorMapData',u(:,3))
5-1123
5 Functions — Alphabetical List
Create a PDE model for a system of three equations. Import the geometry of a bracket
and plot the face labels.
model = createpde(3);
importGeometry(model,'BracketWithHole.stl');
5-1124
StationaryResults
figure
pdegplot(model,'FaceLabels','on')
view(30,30)
title('Bracket with Face Labels')
figure
pdegplot(model,'FaceLabels','on')
view(-134,-32)
title('Bracket with Face Labels, Rear View')
5-1125
5 Functions — Alphabetical List
Set boundary conditions such that F4 is immobile, and F8 has a force in the negative z
direction.
applyBoundaryCondition(model,'dirichlet','Face',4,'u',[0,0,0]);
applyBoundaryCondition(model,'neumann','Face',8,'g',[0,0,-1e4]);
Set coefficients for a legacy solver that represent the equations of linear elasticity. See
“Linear Elasticity Equations” on page 3-150.
E = 200e9;
nu = 0.3;
c = elasticityC3D(E,nu);
a = 0;
f = [0;0;0];
5-1126
StationaryResults
Create a mesh.
generateMesh(model,'Hmax',1e-2);
u = assempde(model,c,a,f);
results = createPDEResults(model,u)
results =
StationaryResults with properties:
u = results.NodalSolution;
pdeplot3D(model,'ColorMapData',u(:,3))
5-1127
5 Functions — Alphabetical List
See Also
EigenResults | TimeDependentResults | evaluateCGradient |
evaluateGradient | interpolateSolution | solvepde
Topics
“Poisson's Equation on Unit Disk” on page 3-205
“Minimal Surface Problem”
“Solve Problems Using PDEModel Objects” on page 2-3
5-1128
StationaryResults
Introduced in R2016a
5-1129
5 Functions — Alphabetical List
SteadyStateThermalResults
Steady-state thermal solution and derived quantities
Description
A SteadyStateThermalResults object contains the temperature and temperature
gradient values in a form convenient for plotting and postprocessing.
The temperature and its gradients are calculated at the nodes of the triangular or
tetrahedral mesh generated by generateMesh. Temperature values at the nodes appear
in the Temperature property. The three components of the temperature gradient at the
nodes appear in the XGradients, YGradients, and ZGradients properties.
To interpolate the temperature or its gradients to a custom grid (for example, specified by
meshgrid), use interpolateTemperature or evaluateTemperatureGradient.
To evaluate heat flux of a thermal solution at nodal or arbitrary spatial locations, use
evaluateHeatFlux. To evaluate integrated heat flow rate normal to specified boundary,
use evaluateHeatRate.
Creation
Solve a steady-state thermal problem using the solve function. This function returns a
steady-state thermal solution as a SteadyStateThermalResults object.
Properties
Mesh — Finite element mesh
FEMesh object
5-1130
SteadyStateThermalResults
Object Functions
evaluateHeatFlux Evaluate heat flux of a thermal solution at nodal or
arbitrary spatial locations
evaluateHeatRate Evaluate integrated heat flow rate normal to specified
boundary
evaluateTemperatureGradient Evaluate temperature gradient of a thermal solution at
arbitrary spatial locations
interpolateTemperature Interpolate temperature in a thermal result at arbitrary
spatial locations
Examples
5-1131
5 Functions — Alphabetical List
thermalmodel = createpde('thermal');
importGeometry(thermalmodel,'Block.stl');
pdegplot(thermalmodel,'FaceLabel','on','FaceAlpha',0.5)
axis equal
thermalProperties(thermalmodel,'ThermalConductivity',80);
5-1132
SteadyStateThermalResults
Apply a constant temperature of 100 ∘C to the left side of the block (face 1) and a constant
temperature of 300 ∘C to the right side of the block (face 3). All other faces are insulated
by default.
thermalBC(thermalmodel,'Face',1,'Temperature',100);
thermalBC(thermalmodel,'Face',3,'Temperature',300);
generateMesh(thermalmodel);
thermalresults = solve(thermalmodel)
thermalresults =
SteadyStateThermalResults with properties:
The solver finds the temperatures and temperature gradients at the nodal locations. To
access these values, use thermalresults.Temperature,
thermalresults.XGradients, and so on. For example, plot temperatures at the nodal
locations.
pdeplot3D(thermalmodel,'ColorMapData',thermalresults.Temperature)
5-1133
5 Functions — Alphabetical List
See Also
TransientThermalResults | evaluateHeatFlux | evaluateHeatRate |
evaluateTemperatureGradient | interpolateTemperature
Introduced in R2017a
5-1134
ThermalBC Properties
ThermalBC Properties
Boundary condition for thermal model
Description
A ThermalBC object specifies the type of PDE boundary condition on a set of geometry
boundaries. A ThermalModel object contains a vector of ThermalBC objects in its
BoundaryConditions.ThermalBCAssignments property.
Specify boundary conditions for your model using the thermalBC function.
Properties
Properties
Geometric region type, returned as 'Face' for 3-D geometry or 'Edge' for 2-D
geometry.
Data Types: char | string
Geometric region ID, returned as a vector of positive integers. Find the region IDs by
using pdegplot with the 'FaceLabels' (3-D) or 'EdgeLabels' (2-D) value set to
'on'.
Data Types: double
5-1135
5 Functions — Alphabetical List
Heat flux boundary condition, returned as a number or a function handle. Use a function
handle to specify a spatially or temporally varying heat flux or a nonlinear heat flux.
Data Types: double | function_handle
Radiation emissivity coefficient, returned as a number in the range (0,1). Use a function
handle to specify spatially or temporally varying emissivity or nonlinear emissivity.
Specify ambient temperature using the AmbientTemperature argument and the Stefan-
Boltzmann constant using the thermal model properties.
Data Types: double | function_handle
Vectorized function evaluation, returned as 'on' or 'off'. This evaluation applies when
you pass a function handle as an argument. To save time in function handle evaluation,
5-1136
ThermalBC Properties
specify 'on', assuming that your function handle computes in a vectorized fashion. See
“Vectorization” (MATLAB). For details of this evaluation, see “Nonconstant Boundary
Conditions” on page 2-129.
Data Types: char
See Also
ThermalModel | findThermalBC | thermalBC
Introduced in R2017a
5-1137
5 Functions — Alphabetical List
ThermalMaterialAssignment Properties
Thermal material properties assignments
Description
A ThermalMaterialAssignment object contains the description of a thermal model’s
material properties. A ThermalModel container has a vector of
ThermalMaterialAssignment objects in its
MaterialProperties.MaterialAssignments property.
Create material properties assignments for your thermal model using the
thermalProperties function.
Properties
Properties
Region type, returned as 'Face' for a 2-D region, or 'Cell' for a 3-D region.
Data Types: char | string
RegionID — Region ID
vector of positive integers
5-1138
ThermalMaterialAssignment Properties
See Also
findThermalProperties | thermalProperties
Introduced in R2017a
5-1139
5 Functions — Alphabetical List
ThermalModel
Thermal model object
Description
A ThermalModel object contains information about a heat transfer problem: the
geometry, material properties, internal heat sources, temperature on the boundaries, heat
fluxes through the boundaries, mesh, and initial conditions.
Creation
Create a ThermalModel object using createpde with the first argument 'thermal'.
Properties
AnalysisType — Type of thermal analysis
'steadystate' | 'transient'
• AnalyticGeometry object for 2-D geometry. Create this geometry using the
geometryFromEdges function.
• DiscreteGeometry object for 3-D geometry. Create this geometry using the
importGeometry function or the geometryFromMesh function.
Material properties within the domain, returned as an object containing the material
property assignments.
5-1140
ThermalModel
Heat source within the domain or subdomain, returned as an object containing heat
source assignments.
Mesh for solution, returned as a FEMesh object. You create the mesh using the
generateMesh function.
• SI – 5.670367e-8 W/(m2·K4)
• CGS – 5.6704e-5 erg/(cm2·s·K4)
• US customary – 1.714e-9 BTU/(hr·ft2·R4)
Algorithm options for the PDE solvers, returned as a PDESolverOptions object. The
properties of PDESolverOptions include absolute and relative tolerances for internal
ODE solvers, maximum solver iterations, and so on.
5-1141
5 Functions — Alphabetical List
Object Functions
geometryFromEdges Create 2-D geometry from decomposed geometry matrix
geometryFromMesh Create 2-D or 3-D geometry from mesh
importGeometry Import 2-D or 3-D geometry from STL data
thermalProperties Assign thermal properties of a material for a thermal model
internalHeatSource Specify internal heat source for a thermal model
thermalBC Specify boundary conditions for a thermal model
thermalIC Set initial conditions or initial guess for a thermal model
generateMesh Create triangular or tetrahedral mesh
solve Solve heat transfer or structural analysis problem
Examples
thermalmodel = createpde('thermal','transient')
thermalmodel =
ThermalModel with properties:
AnalysisType: 'transient'
Geometry: []
MaterialProperties: []
HeatSources: []
StefanBoltzmannConstant: []
BoundaryConditions: []
InitialConditions: []
Mesh: []
SolverOptions: [1x1 pde.PDESolverOptions]
g = @squareg;
geometryFromEdges(thermalmodel,g)
ans =
AnalyticGeometry with properties:
5-1142
ThermalModel
NumCells: 0
NumFaces: 1
NumEdges: 4
NumVertices: 4
ans =
ThermalMaterialAssignment with properties:
RegionType: 'face'
RegionID: 1
ThermalConductivity: 79.5000
MassDensity: 7850
SpecificHeat: 450
Specify that the entire geometry generates heat at the rate 25 W/m^3.
internalHeatSource(thermalmodel,25)
ans =
HeatSourceAssignment with properties:
RegionType: 'face'
RegionID: 1
HeatSource: 25
Apply insulated boundary conditions on three edges and the free convection boundary
condition on the right edge.
thermalBC(thermalmodel,'Edge',[1,3,4],'HeatFlux',0);
thermalBC(thermalmodel,'Edge',2,...
'ConvectionCoefficient',5000,...
'AmbientTemperature',25)
ans =
ThermalBC with properties:
5-1143
5 Functions — Alphabetical List
RegionType: 'Edge'
RegionID: 2
Temperature: []
HeatFlux: []
ConvectionCoefficient: 5000
Emissivity: []
AmbientTemperature: 25
Vectorized: 'off'
Set the initial conditions: uniform room temperature across domain and higher
temperature on the left edge.
thermalIC(thermalmodel,25);
thermalIC(thermalmodel,100,'Edge',4)
ans =
GeometricThermalICs with properties:
RegionType: 'edge'
RegionID: 4
InitialTemperature: 100
thermalmodel.StefanBoltzmannConstant = 5.670367e-8;
Generate mesh.
generateMesh(thermalmodel)
ans =
FEMesh with properties:
5-1144
ThermalModel
thermalmodel
thermalmodel =
ThermalModel with properties:
AnalysisType: 'transient'
Geometry: [1x1 AnalyticGeometry]
MaterialProperties: [1x1 MaterialAssignmentRecords]
HeatSources: [1x1 HeatSourceAssignmentRecords]
StefanBoltzmannConstant: 5.6704e-08
BoundaryConditions: [1x1 ThermalBCRecords]
InitialConditions: [1x1 ThermalICRecords]
Mesh: [1x1 FEMesh]
SolverOptions: [1x1 pde.PDESolverOptions]
See Also
createpde | generateMesh | geometryFromEdges | geometryFromMesh |
importGeometry | internalHeatSource | pdegplot | pdeplot | pdeplot3D |
thermalBC | thermalIC | thermalProperties
Introduced in R2017a
5-1145
5 Functions — Alphabetical List
thermalProperties
Package: pde
Syntax
thermalProperties(thermalmodel,'ThermalConductivity',
TCval,'MassDensity',MDval,'SpecificHeat',SHval)
thermalProperties( ___ ,RegionType,RegionID)
mtl = thermalProperties( ___ )
Description
thermalProperties(thermalmodel,'ThermalConductivity',
TCval,'MassDensity',MDval,'SpecificHeat',SHval) assigns material properties,
such as thermal conductivity, mass density, and specific heat. For transient analysis,
specify all three properties. For steady-state analysis, specifying thermal conductivity is
enough. This syntax sets material properties for the entire geometry.
For a nonconstant or nonlinear material, specify TCval, MDval, and SHval as function
handles.
Examples
5-1146
thermalProperties
model = createpde('thermal','steadystate');
gm = importGeometry(model,'SquareBeam.STL');
thermalProperties(model,'ThermalConductivity',0.08)
ans =
ThermalMaterialAssignment with properties:
RegionType: 'cell'
RegionID: 1
ThermalConductivity: 0.0800
MassDensity: []
SpecificHeat: []
thermalmodel = createpde('thermal','transient');
gm = importGeometry(thermalmodel,'SquareBeam.STL');
thermalProperties(thermalmodel,'ThermalConductivity',0.2,...
'MassDensity',2.7*10^(-6),...
'SpecificHeat',920)
ans =
ThermalMaterialAssignment with properties:
RegionType: 'cell'
RegionID: 1
ThermalConductivity: 0.2000
MassDensity: 2.7000e-06
SpecificHeat: 920
thermalModel = createpde('thermal');
5-1147
5 Functions — Alphabetical List
Create nested cylinders to model a two-layered insulated pipe section, consisting of inner
metal pipe surrounded by insulated material.
gm = multicylinder([20,25,35],20,'Void',[1,0,0]);
thermalModel.Geometry = gm;
pdegplot(thermalModel,'CellLabels','on','FaceAlpha',0.5)
thermalProperties(thermalModel,'Cell',1,'ThermalConductivity',0.4)
5-1148
thermalProperties
ans =
ThermalMaterialAssignment with properties:
RegionType: 'cell'
RegionID: 1
ThermalConductivity: 0.4000
MassDensity: []
SpecificHeat: []
thermalProperties(thermalModel,'Cell',2,'ThermalConductivity',0.0015)
ans =
ThermalMaterialAssignment with properties:
RegionType: 'cell'
RegionID: 2
ThermalConductivity: 0.0015
MassDensity: []
SpecificHeat: []
Use function handles to specify a thermal conductivity that depends on temperature and
specific heat that depends on coordinates.
Create a thermal model for transient analysis and include the geometry. The geometry is
a rod with a circular cross section. The 2-D model is a rectangular strip whose y-
dimension extends from the axis of symmetry to the outer surface, and whose x-dimension
extends over the actual length of the rod.
thermalmodel = createpde('thermal','transient');
k = @(location,state)40 + 0.003*state.u;
5-1149
5 Functions — Alphabetical List
cp = @(location,state)500*location.y;
Specify the thermal conductivity, mass density, and specific heat of the material.
thermalProperties(thermalmodel,'ThermalConductivity',k,...
'MassDensity',2.7*10^(-6),...
'SpecificHeat',cp)
ans =
ThermalMaterialAssignment with properties:
RegionType: 'face'
RegionID: 1
ThermalConductivity: @(location,state)40+0.003*state.u
MassDensity: 2.7000e-06
SpecificHeat: @(location,state)500*location.y
Input Arguments
thermalmodel — Thermal model
ThermalModel object
Thermal model, specified as a ThermalModel object. The model contains the geometry,
mesh, thermal properties of the material, internal heat source, boundary conditions, and
initial conditions.
Example: thermalmodel = createpde('thermal','steadystate')
5-1150
thermalProperties
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Example:
thermalProperties(thermalmodel,'Cell',1:3,'ThermalConductivity',100)
Data Types: double
Use a function handle to specify the thermal conductivity that depends on space, time, or
temperature. The function must be of the form
TCval = TCfun(location,state)
The solver passes location data as a structure array with the fields location.x,
location.y, and, for 3-D problems, location.z. The state data is a structure array
with the fields state.u, state.ux, state.uy, state.uz (for 3-D problems), and
state.time (for transient problems). The state.u field contains the solution vector.
The state.ux, state.uy, state.uz fields are estimates of the solution’s partial
derivatives at the corresponding points of the location structure. The state.time field
contains time at evaluation points.
TCfun must return a matrix TCval with number of rows equal to 1, Ndim, Ndim*(Ndim
+1)/2, or Ndim*Ndim, where Ndim is 2 for 2-D problems and 3 for 3-D problems. The
number of columns must equal the number of evaluation points, M =
length(location.x). For details about dimensions of the matrix, see “c Coefficient for
specifyCoefficients” on page 2-82.
Example:
thermalProperties(thermalmodel,'Cell',1,'ThermalConductivity',100) or
thermalProperties(thermalmodel,'ThermalConductivity',[80;10;80]) for
orthotropic thermal conductivity
Data Types: double | function_handle
5-1151
5 Functions — Alphabetical List
Mass density of the material, specified as a positive number or a function handle. Specify
this property for a transient thermal conduction analysis model.
Use a function handle to specify the mass density that depends on space, time, or
temperature. The function must be of the form
MDval = MDfun(location,state)
The solver passes location data as a structure array with the fields location.x,
location.y, and, for 3-D problems, location.z. The state data is a structure array
with the fields state.u, state.ux, state.uy, state.uz (for 3-D problems), and
state.time (for transient problems). The state.u field contains the solution vector.
The state.ux, state.uy, state.uz fields are estimates of the solution’s partial
derivatives at the corresponding points of the location structure. The state.time field
contains time at evaluation points.
MDfun must return a row vector MDval with the number of columns equal to the number
of evaluation points, M = length(location.x).
Example:
thermalProperties(thermalmodel,'Cell',1,'ThermalConductivity',100,'M
assDensity',2730e-9,'SpecificHeat',910)
Data Types: double | function_handle
Specific heat of the material, specified as a positive number or a function handle. Specify
this property for a transient thermal conduction analysis model.
Use a function handle to specify the specific heat that depends on space, time, or
temperature. The function must be of the form
SHval = SHfun(location,state)
The solver passes location data as a structure array with the fields location.x,
location.y, and, for 3-D problems, location.z. The state data is a structure array
with the fields state.u, state.ux, state.uy, state.uz (for 3-D problems), and
state.time (for transient problems). The state.u field contains the solution vector.
The state.ux, state.uy, state.uz fields are estimates of the solution’s partial
derivatives at the corresponding points of the location structure. The state.time field
contains time at evaluation points.
5-1152
thermalProperties
SHfun must return a row vector SHval with the number of columns equal to the number
of evaluation points, M = length(location.x).
Example:
thermalProperties(thermalmodel,'Cell',1,'ThermalConductivity',100,'M
assDensity',2730e-9,'SpecificHeat',910)
Data Types: double | function_handle
Output Arguments
mtl — Handle to material properties
object
See Also
internalHeatSource | specifyCoefficients
Topics
“Heat Conduction in Multidomain Geometry with Nonuniform Heat Flux”
Introduced in R2017a
5-1153
5 Functions — Alphabetical List
TimeDependentResults
Time-dependent PDE solution and derived quantities
Description
A TimeDependentResults object contains the solution of a PDE and its gradients in a
form convenient for plotting and postprocessing.
To interpolate the solution or its gradient to a custom grid (for example, specified by
meshgrid), use interpolateSolution or evaluateGradient.
Creation
There are several ways to create a TimeDependentResults object:
• Solve a time-dependent problem using the solvepde function. This function returns a
PDE solution as a TimeDependentResults object. This is the recommended
approach.
• Solve a time-dependent problem using the parabolic or hyperbolic function. Then
use the createPDEResults function to obtain a TimeDependentResults object
from a PDE solution returned by parabolic or hyperbolic. Note that parabolic
and hyperbolic are legacy functions. They are not recommended for solving PDE
problems.
5-1154
TimeDependentResults
Properties
Mesh — Finite element mesh
FEMesh object
Solution values at the nodes, returned as a vector or array. For details about the
dimensions of NodalSolution, see “Dimensions of Solutions, Gradients, and Fluxes” on
page 3-347.
Data Types: double
Complex Number Support: Yes
Solution times, returned as a real vector. SolutionTimes is the same as the tlist input
to solvepde, or the tlist input to the legacy parabolic or hyperbolic solvers.
Data Types: double
x-component of the gradient at the nodes, returned as a vector or array. For details about
the dimensions of XGradients, see “Dimensions of Solutions, Gradients, and Fluxes” on
page 3-347.
Data Types: double
Complex Number Support: Yes
y-component of the gradient at the nodes, returned as a vector or array. For details about
the dimensions of YGradients, see “Dimensions of Solutions, Gradients, and Fluxes” on
page 3-347.
Data Types: double
5-1155
5 Functions — Alphabetical List
z-component of the gradient at the nodes, returned as a vector or array. For details about
the dimensions of ZGradients, see “Dimensions of Solutions, Gradients, and Fluxes” on
page 3-347.
Data Types: double
Object Functions
evaluateCGradient Evaluate flux of PDE solution
evaluateGradient Evaluate gradients of PDE solutions at arbitrary points
interpolateSolution Interpolate PDE solution to arbitrary points
Examples
5-1156
TimeDependentResults
model = createpde();
geometryFromEdges(model,dl);
Set boundary conditions that the upper and left edges are at temperature 10.
applyBoundaryCondition(model,'dirichlet','Edge',[2,3],'u',10);
Set initial conditions that the square region is at temperature 0, and the circle is at
temperature 100.
setInitialConditions(model,0);
setInitialConditions(model,100,'Face',2);
5-1157
5 Functions — Alphabetical List
specifyCoefficients(model,'m',0,'d',1,'c',1,'a',0,'f',0);
generateMesh(model,'Hmax',0.05);
tlist = 0:0.01:0.5;
results = solvepde(model,tlist);
Plot the solution for times 0.02, 0.04, 0.1, and 0.5.
sol = results.NodalSolution;
subplot(2,2,1)
pdeplot(model,'XYData',sol(:,3))
title('Time 0.02')
subplot(2,2,2)
pdeplot(model,'XYData',sol(:,5))
title('Time 0.04')
subplot(2,2,3)
pdeplot(model,'XYData',sol(:,11))
title('Time 0.1')
subplot(2,2,4)
pdeplot(model,'XYData',sol(:,51))
title('Time 0.5')
5-1158
TimeDependentResults
See Also
EigenResults | StationaryResults | evaluateCGradient | evaluateGradient |
interpolateSolution
Topics
“Heat Transfer in Block with Cavity” on page 3-238
“Wave Equation on Square Domain”
“Solve Problems Using PDEModel Objects” on page 2-3
5-1159
5 Functions — Alphabetical List
Introduced in R2016a
5-1160
TransientThermalResults
TransientThermalResults
Transient thermal solution and derived quantities
Description
A TransientThermalResults object contains the temperature and gradients values in
a form convenient for plotting and postprocessing.
The temperature and its gradient are calculated at the nodes of the triangular or
tetrahedral mesh generated by generateMesh. Temperature values at the nodes appear
in the Temperature property. The solution times appear in the SolutionTimes
property. The three components of the temperature gradient at the nodes appear in the
XGradients, YGradients, and ZGradients properties. The array dimensions of
Temperature, XGradients, YGradients, and ZGradients let you extract solution and
gradient values for specified time indices.
To interpolate the temperature or its gradient to a custom grid (for example, specified by
meshgrid), use interpolateTemperature or evaluateTemperatureGradient.
To evaluate heat flux of a thermal solution at nodal or arbitrary spatial locations, use
evaluateHeatFlux. To evaluate integrated heat flow rate normal to specified boundary,
use evaluateHeatRate.
Creation
Solve a transient thermal problem using the solve function. This function returns a
transient thermal solution as a TransientThermalResults object.
Properties
Mesh — Finite element mesh
FEMesh object
5-1161
5 Functions — Alphabetical List
Solution times, returned as a real vector. SolutionTimes is the same as the tlist input
to solve.
Data Types: double
Object Functions
evaluateHeatFlux Evaluate heat flux of a thermal solution at nodal or
arbitrary spatial locations
evaluateHeatRate Evaluate integrated heat flow rate normal to specified
boundary
evaluateTemperatureGradient Evaluate temperature gradient of a thermal solution at
arbitrary spatial locations
5-1162
TransientThermalResults
Examples
thermalmodel = createpde('thermal','transient');
5-1163
5 Functions — Alphabetical List
thermalProperties(thermalmodel,'ThermalConductivity',10, ...
'MassDensity',2, ...
'SpecificHeat',0.1, ...
'Face',1);
5-1164
TransientThermalResults
thermalProperties(thermalmodel,'ThermalConductivity',2, ...
'MassDensity',1, ...
'SpecificHeat',0.1, ...
'Face',2);
Assume that the diamond-shaped region is a heat source with a density of 4 W /m3.
internalHeatSource(thermalmodel,4,'Face',2);
thermalBC(thermalmodel,'Temperature',0,'Edge',[1 2 7 8]);
thermalIC(thermalmodel,0);
generateMesh(thermalmodel);
The dynamics for this problem are very fast. The temperature reaches a steady state in
about 0.1 seconds. To capture the interesting part of the dynamics, set the solution time
to logspace(-2,-1,10). This command returns 10 logarithmically spaced solution
times between 0.01 and 0.1.
tlist = logspace(-2,-1,10);
thermalresults = solve(thermalmodel,tlist)
thermalresults =
TransientThermalResults with properties:
5-1165
5 Functions — Alphabetical List
ZGradients: []
Mesh: [1x1 FEMesh]
See Also
SteadyStateThermalResults | evaluateHeatFlux | evaluateHeatRate |
evaluateTemperatureGradient | interpolateTemperature
5-1166
TransientThermalResults
Introduced in R2017a
5-1167
5 Functions — Alphabetical List
thermalBC
Package: pde
Syntax
thermalBC(thermalmodel,RegionType,RegionID,'Temperature',Tval)
thermalBC(thermalmodel,RegionType,RegionID,'HeatFlux,HFval)
thermalBC(thermalmodel,RegionType,RegionID,'ConvectionCoefficient',
CCval,'AmbientTemperature',ATval)
thermalBC(thermalmodel,RegionType,RegionID,'Emissivity',
REval,'AmbientTemperature',ATval)
thermalBC = thermalBC( ___ )
Description
thermalBC(thermalmodel,RegionType,RegionID,'Temperature',Tval) adds a
temperature boundary condition to thermalmodel. The boundary condition applies to
regions of type RegionType with ID numbers in RegionID.
Note Use thermalBC with the HeatFlux parameter to specify a heat flux to or from an
external source. To specify internal heat generation, that is, heat sources that belong to
the geometry of the model, use internalHeatSource.
thermalBC(thermalmodel,RegionType,RegionID,'ConvectionCoefficient',
CCval,'AmbientTemperature',ATval) adds a convection boundary condition to
thermalmodel. The boundary condition applies to regions of type RegionType with ID
numbers in RegionID.
5-1168
thermalBC
thermalBC(thermalmodel,RegionType,RegionID,'Emissivity',
REval,'AmbientTemperature',ATval) adds a radiation boundary condition to
thermalmodel. The boundary condition applies to regions of type RegionType with ID
numbers in RegionID.
Examples
ans =
ThermalBC with properties:
RegionType: 'Edge'
RegionID: [1 3]
Temperature: 100
HeatFlux: []
ConvectionCoefficient: []
Emissivity: []
AmbientTemperature: []
Vectorized: 'off'
ans =
ThermalBC with properties:
5-1169
5 Functions — Alphabetical List
RegionType: 'Face'
RegionID: [1 3]
Temperature: []
HeatFlux: 20
ConvectionCoefficient: []
Emissivity: []
AmbientTemperature: []
Vectorized: 'off'
ans =
ThermalBC with properties:
RegionType: 'Face'
RegionID: [2 4 5 6]
Temperature: []
HeatFlux: []
ConvectionCoefficient: 5
Emissivity: []
AmbientTemperature: 27
Vectorized: 'off'
5-1170
thermalBC
thermalmodel.StefanBoltzmannConstant = 5.670373E-8;
thermalBC(thermalmodel,'Face',[2,4,5,6],...
'Emissivity',0.1,...
'AmbientTemperature',300)
ans =
ThermalBC with properties:
RegionType: 'Face'
RegionID: [2 4 5 6]
Temperature: []
HeatFlux: []
ConvectionCoefficient: []
Emissivity: 0.1000
AmbientTemperature: 300
Vectorized: 'off'
Use function handles to specify thermal boundary conditions that depend on coordinates.
Create a thermal model for transient analysis and include the geometry. The geometry is
a rod with a circular cross section. The 2-D model is a rectangular strip whose y-
dimension extends from the axis of symmetry to the outer surface, and whose x-dimension
extends over the actual length of the rod.
thermalmodel = createpde('thermal','transient');
g = decsg([3 4 -1.5 1.5 1.5 -1.5 0 0 .2 .2]');
geometryFromEdges(thermalmodel,g);
figure
pdegplot(thermalmodel,'EdgeLabels','on');
xlim([-2 2]);
ylim([-2 2]);
title 'Rod Section Geometry with Edge Labels';
5-1171
5 Functions — Alphabetical List
Assume that there is a heat source at the left end of the rod and a fixed temperature at
the right end. The outer surface of the rod exchanges heat with the environment due to
convection.
Define the boundary conditions for the model. The edge at y = 0 (edge 1) is along the axis
of symmetry. No heat is transferred in the direction normal to this edge. This boundary is
modeled as an insulated boundary, by default.
The temperature at the right end of the rod (edge 2) is a fixed temperature, T = 100 C.
Specify the boundary condition for edge 2 as follows.
thermalBC(thermalmodel,'Edge',2,'Temperature',100)
5-1172
thermalBC
ans =
ThermalBC with properties:
RegionType: 'Edge'
RegionID: 2
Temperature: 100
HeatFlux: []
ConvectionCoefficient: []
Emissivity: []
AmbientTemperature: []
Vectorized: 'off'
The convection coefficient for the outer surface of the rod (edge 3) depends on the y-
coordinate, 50y. Specify the boundary condition for this edge as follows.
ans =
ThermalBC with properties:
RegionType: 'Edge'
RegionID: 3
Temperature: []
HeatFlux: []
ConvectionCoefficient: @(location,~)50*location.y
Emissivity: []
AmbientTemperature: 100
Vectorized: 'off'
The heat flux at the left end of the rod (edge 4) is also a function of the y-coordinate,
5000y. Specify the boundary condition for this edge as follows.
ans =
ThermalBC with properties:
RegionType: 'Edge'
5-1173
5 Functions — Alphabetical List
RegionID: 4
Temperature: []
HeatFlux: @(location,~)5000*location.y
ConvectionCoefficient: []
Emissivity: []
AmbientTemperature: []
Vectorized: 'off'
Input Arguments
thermalmodel — Thermal model
ThermalModel object
Thermal model, specified as a ThermalModel object. The model contains the geometry,
mesh, thermal properties of the material, internal heat source, boundary conditions, and
initial conditions.
Example: thermalmodel = createpde('thermal','steadystate')
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot with the 'FaceLabels' (3-D) or 'EdgeLabels' (2-D) value set to
'on'.
Example: thermalBC(thermalmodel,'Edge',2:5,'Temperature',72)
Data Types: double
5-1174
thermalBC
The solver passes location data as a structure array with the fields location.x,
location.y, and, for 3-D problems, location.z. The state data is a structure array
with the fields state.u, state.ux, state.uy, state.uz (for 3-D problems), and
state.time (for transient problems). The state.u field contains the solution vector.
The state.ux, state.uy, state.uz fields are estimates of the solution’s partial
derivatives at the corresponding points of the location structure. The state.time field
contains time at evaluation points.
Tfun must return a row vector Tval with the number of columns equal to the number of
evaluation points, M = length(location.x).
Example: thermalBC(thermalmodel,'Face',1,'Temperature',72)
Data Types: double | function_handle
Heat flux boundary condition, specified as a number or a function handle. Use a function
handle to specify the heat flux that depends on space, time, or temperature. The function
must be of the form
HFval = HFfun(location,state)
The solver passes location data as a structure array with the fields location.x,
location.y, and, for 3-D problems, location.z. The state data is a structure array
with the fields state.u, state.ux, state.uy, state.uz (for 3-D problems), and
state.time (for transient problems). The state.u field contains the solution vector.
The state.ux, state.uy, state.uz fields are estimates of the solution’s partial
derivatives at the corresponding points of the location structure. The state.time field
contains time at evaluation points.
HFfun must return a row vector HFval with the number of columns equal to the number
of evaluation points, M = length(location.x).
Example: thermalBC(thermalmodel,'Face',[1,3],'HeatFlux',20)
Data Types: double | function_handle
5-1175
5 Functions — Alphabetical List
The solver passes location data as a structure array with the fields location.x,
location.y, and, for 3-D problems, location.z. The state data is a structure array
with the fields state.u, state.ux, state.uy, state.uz (for 3-D problems), and
state.time (for transient problems). The state.u field contains the solution vector.
The state.ux, state.uy, state.uz fields are estimates of the solution’s partial
derivatives at the corresponding points of the location structure. The state.time field
contains time at evaluation points.
CCfun must return a row vector CCval with the number of columns equal to the number
of evaluation points, M = length(location.x).
Radiation emissivity coefficient, specified as a number in the range (0,1). Use a function
handle to specify the radiation emissivity that depends on space, time, or temperature.
The function must be of the form
REval = REfun(location,state)
The solver passes location data as a structure array with the fields location.x,
location.y, and, for 3-D problems, location.z. The state data is a structure array
with the fields state.u, state.ux, state.uy, state.uz (for 3-D problems), and
state.time (for transient problems). The state.u field contains the solution vector.
The state.ux, state.uy, state.uz fields are estimates of the solution’s partial
derivatives at the corresponding points of the location structure. The state.time field
contains time at evaluation points.
5-1176
thermalBC
REfun must return a row vector REval with the number of columns equal to the number
of evaluation points, M = length(location.x).
Specify ambient temperature using the AmbientTemperature argument and the Stefan-
Boltzmann constant using the thermal model properties. The value of Emissivity is
positive for heat radiation into the ambient environment.
Example: thermalmodel.StefanBoltzmannConstant = 5.670373E-8;
thermalBC(thermalmodel,'Edge',
[2,4,5,6],'Emissivity',0.1,'AmbientTemperature',300)
Data Types: double | function_handle
Output Arguments
thermalBC — Handle to thermal boundary condition
object
See Also
applyBoundaryCondition | internalHeatSource | thermalIC |
thermalProperties
Topics
“Heat Conduction in Multidomain Geometry with Nonuniform Heat Flux”
Introduced in R2017a
5-1177
5 Functions — Alphabetical List
thermalIC
Package: pde
Syntax
thermalIC(thermalmodel,T0)
thermalIC(thermalmodel,T0,RegionType,RegionID)
thermalIC(thermalmodel,Tresults)
thermalIC(thermalmodel,Tresults,iT)
thermalIC = thermalIC( ___ )
Description
thermalIC(thermalmodel,T0) sets initial temperature or initial guess for temperature
to the entire geometry.
thermalIC = thermalIC( ___ ), for any previous syntax, returns a handle to the
thermal initial conditions object.
Examples
5-1178
thermalIC
Create a thermal model, import geometry, and set the initial temperature to 0 on the
entire geometry.
thermalModel = createpde('thermal','transient');
geometryFromEdges(thermalModel,@lshapeg);
thermalIC(thermalModel,0)
ans =
GeometricThermalICs with properties:
RegionType: 'face'
RegionID: [1 2 3]
InitialTemperature: 0
Set different initial conditions on each portion of the L-shaped membrane geometry.
thermalModel = createpde('thermal','transient');
geometryFromEdges(thermalModel,@lshapeg);
pdegplot(thermalModel,'FaceLabels','on')
axis equal
ylim([-1.1 1.1])
5-1179
5 Functions — Alphabetical List
thermalIC(thermalModel,0,'Face',1)
ans =
GeometricThermalICs with properties:
RegionType: 'face'
RegionID: 1
InitialTemperature: 0
thermalIC(thermalModel,10,'Face',2)
5-1180
thermalIC
ans =
GeometricThermalICs with properties:
RegionType: 'face'
RegionID: 2
InitialTemperature: 10
thermalIC(thermalModel,75,'Face',3)
ans =
GeometricThermalICs with properties:
RegionType: 'face'
RegionID: 3
InitialTemperature: 75
Create a thermal model for transient analysis and include the geometry. The geometry is
a rod with a circular cross section. The 2-D model is a rectangular strip whose y-
dimension extends from the axis of symmetry to the outer surface, and whose x-dimension
extends over the actual length of the rod.
thermalmodel = createpde('thermal','transient');
g = decsg([3 4 -1.5 1.5 1.5 -1.5 0 0 .2 .2]');
geometryFromEdges(thermalmodel,g);
Set the initial temperature in the rod to be dependent on the y-coordinate, for example,
3
10 0 . 2 − y2 .
T0 = @(location)10^3*(0.2 - location.y.^2);
thermalIC(thermalmodel,T0)
ans =
GeometricThermalICs with properties:
RegionType: 'face'
RegionID: 1
5-1181
5 Functions — Alphabetical List
InitialTemperature: @(location)10^3*(0.2-location.y.^2)
5-1182
thermalIC
Specify material properties and internal heat source, and set boundary conditions and
initial conditions.
thermalProperties(thermalmodel,'ThermalConductivity',500,...
'MassDensity',200,...
'SpecificHeat',100);
internalHeatSource(thermalmodel,2);
thermalBC(thermalmodel,'Edge',[1,3],'Temperature',100);
thermalIC(thermalmodel,0);
generateMesh(thermalmodel);
tlist = 0:0.5:10;
result1 = solve(thermalmodel,tlist)
result1 =
TransientThermalResults with properties:
pdeplot(thermalmodel,'XYData',result1.Temperature(:,end))
5-1183
5 Functions — Alphabetical List
Now, resume the analysis and solve the problem for times from 10 to 15 seconds. Use the
previously obtained solution for 10 seconds as an initial condition. Since 10 seconds is the
last element in tlist, you do not need to specify the solution time index. By default,
thermalIC uses the last solution index.
thermalIC(thermalmodel,result1)
ans =
NodalThermalICs with properties:
5-1184
thermalIC
result2 = solve(thermalmodel,10:0.5:15)
result2 =
TransientThermalResults with properties:
pdeplot(thermalmodel,'XYData',result2.Temperature(:,end))
5-1185
5 Functions — Alphabetical List
To use the previously obtained solution for a particular solution time instead of the last
one, specify the solution time index as a third parameter of thermalIC. For example, use
the solution at time 5 seconds, which is the 11th element in tlist.
tlist(11)
ans = 5
thermalIC(thermalmodel,result1,11);
result2 = solve(thermalmodel,5:0.5:15)
result2 =
TransientThermalResults with properties:
pdeplot(thermalmodel,'XYData',result2.Temperature(:,end))
5-1186
thermalIC
Input Arguments
thermalmodel — Thermal model
ThermalModel object
Thermal model, specified as a ThermalModel object. The model contains the geometry,
mesh, thermal properties of the material, internal heat source, boundary conditions, and
initial conditions.
Example: thermalmodel = createpde('thermal','steadystate')
5-1187
5 Functions — Alphabetical List
The solver passes location as a structure with fields location.x, location.y, and,
for 3-D problems, location.z. T0fun must return a row vector T0 with the number of
columns equal to M = length(location.x).
Data Types: double | function_handle
Geometric region type, specified as 'Vertex', 'Edge', 'Face', or 'Cell' for a 3-D
model. For a 2-D model, use 'Vertex', 'Edge', or 'Face'.
Example: thermalIC(thermalmodel,10,'Face',1)
Data Types: char | string
Geometric region ID, specified as a vector of positive integers. Find the region IDs by
using pdegplot.
Example: thermalIC(thermalmodel,10,'Edge',2:5)
Data Types: double
iT — Time index
positive integer
5-1188
thermalIC
Example: thermalIC(thermalmodel,Tresults,21)
Data Types: double
Output Arguments
thermalIC — Handle to initial condition
object
See Also
internalHeatSource | setInitialConditions | thermalBC | thermalProperties
Introduced in R2017a
5-1189
5 Functions — Alphabetical List
tri2grid
(Not recommended) Interpolate from PDE triangular mesh to rectangular grid
Syntax
uxy = tri2grid(p,t,u,x,y)
[uxy,tn,a2,a3] = tri2grid(p,t,u,x,y)
uxy = tri2grid(p,t,u,tn,a2,a3)
Description
uxy = tri2grid(p,t,u,x,y) computes the function values uxy over the grid defined
by the vectors x and y, from the function u with values on the triangular mesh defined by
p and t. Values are computed using linear interpolation in the triangle containing the grid
point. The vectors x and y must be increasing. u must be a vector. For systems of
equations, uxy interpolates only the first component. For solutions returned by
hyperbolic or parabolic, pass u as the vector of values at one time, u(:,k).
All tri2grid output arguments are ny-by-nx matrices, where nx and ny are the lengths
of the vectors x and y respectively. At grid points outside of the triangular mesh, all
tri2grid output arguments are NaN.
See Also
interpolateSolution | solvepde
5-1190
tri2grid
5-1191
5 Functions — Alphabetical List
volume
Package: pde
Syntax
V = volume(mesh)
[V,VE] = volume(mesh)
V = volume(mesh,elements)
Description
V = volume(mesh) returns the volume V of the entire mesh.
Examples
5-1192
volume
mesh = generateMesh(model);
figure
pdemesh(model)
5-1193
5 Functions — Alphabetical List
mv = volume(mesh)
mv = 8.0295e-04
5-1194
volume
model = createpde;
importGeometry(model,'BracketWithHole.stl');
pdegplot(model)
mesh = generateMesh(model);
figure
pdemesh(model)
5-1195
5 Functions — Alphabetical List
Compute the volume of the entire mesh and the volume of each individual element of the
mesh. Display the volumes of the first 5 elements.
[va,vi] = volume(mesh);
vi(1:5)
ans = 1×5
10-6 ×
5-1196
volume
model = createpde;
importGeometry(model,'BracketWithHole.stl');
pdegplot(model)
5-1197
5 Functions — Alphabetical List
mesh = generateMesh(model);
figure
pdemesh(model)
Evaluate the shape quality of the mesh elements and find the elements with the quality
values less than 0.5.
Q = meshQuality(mesh);
elemIDs = find(Q < 0.5);
mv05 = 4.2568e-06
5-1198
volume
Find how much of the total mesh volume belongs to these elements. Return the result as a
percentage.
mv05_percent = mv05/volume(mesh)*100
mv05_percent = 0.5301
Input Arguments
mesh — Mesh object
Mesh property of a PDEModel object | output of generateMesh
Mesh object, specified as the Mesh property of a PDEModel object or as the output of
generateMesh.
Example: model.Mesh
Output Arguments
V — Volume
positive number
Volume of the entire mesh or the combined volume of the specified elements of the mesh,
returned as a positive number.
See Also
FEMesh Properties | area | findElements | findNodes | meshQuality
5-1199
5 Functions — Alphabetical List
Topics
“Finite Element Method Basics” on page 1-13
Introduced in R2018a
5-1200
wbound
wbound
(Not recommended) Write boundary condition specification file
Syntax
fid = wbound(bl,mn)
Description
fid = wbound(bl,mn) writes a Boundary file with the name [mn,'.m']. The Boundary
file is equivalent to the Boundary Condition matrix bl. The output fid is -1 if the file
could not be written.
See Also
decsg | wgeom
5-1201
5 Functions — Alphabetical List
wgeom
Write geometry specification function
Note This page describes the legacy workflow. New features might not be compatible
with the legacy workflow.
Syntax
fid = wgeom(dl,mn)
Description
fid = wgeom(dl,mn) writes a Geometry file with the name [mn,'.m']. The Geometry
file is equivalent to the Decomposed Geometry matrix dl. fid returns -1 if the file could
not be written.
The output file [mn,'.m'] is the name of a Geometry file. For a description of the
Geometry file format, see “Parametrized Function for 2-D Geometry Creation” on page 2-
12.
See Also
decsg
5-1202