Note
Go to the end to download the full example code.
Heat transfer through a wall
This problem demonstrates the use of prescribed temperature on both sides of the wall.
Using
mesher.PatchMesher
(see PatchMesher class)diffusion.Triangle
(see Triangle class for Diffusion)materials.Thermal
(see Diffusion Material classes)
Theory
We shall consider a stationary heat transfer problem within a wall. The inner surface of the wall, \(x=0~m\), is heated to \(200~K\), the outer surface of the wall, \(x=10~m\), to \(300~K\).
The thermal equation for the uni-directional problem can be expressed as
where \(\Delta\) is the Laplace operator.
The analytic solution follows as
This solution will be compared against the finite element solution in the last figure.
import matplotlib.pyplot as plt
import math
import sys
import numpy as np
from femedu.examples.Example import *
from femedu.domain import *
from femedu.mesher import PatchMesher
from femedu.elements.diffusion import Triangle
from femedu.materials import Thermal
class ExampleThermal02(Example):
def problem(self):
# ========== setting mesh parameters ==============
Nx = 4 # number of elements through the wall
Ny = 3 # number of elements parallel to the wall
Lx = 10.00 # wall thickness in m
Ly = 5.00 # wall thickness in m
# ========== setting material parameters ==============
params = dict(
E=20000., # Young's modulus
nu=0.250, # Poisson's ratio
t=1.00 # thickness of the plate
)
# ========== setting load parameters ==============
qn = 1.00 # uniform flux normal to x=const
# ========== setting analysis parameters ==============
target_load_level = 1.00 # reference load
max_steps = 2 # number of load steps: 2 -> [0.0, 1.0]
# define a list of target load levels
load_levels = np.linspace(0, target_load_level, max_steps)
#
# ==== Build the system model ====
#
model = System()
# create nodes
# 2 -------- 3
# | |
# | |
# | | |
# 0 -------- 1
pts = (
( 0, 0), # 0
(Lx, 0), # 1
( 0, Ly), # 2
(Lx, Ly), # 3
(0.67*Lx, 0), # 4
(0.33*Lx, Ly), # 5
)
mesher = PatchMesher(model, pts[0], pts[1], pts[3], pts[2], pts[4], None, pts[5], None)
nodes, elements = mesher.triangleMesh(Nx, Ny, Triangle, Thermal(params))
model.plot(factor=0.0,
title='Uni-directional diffusion',
show_reactions=0, show_bc=0, show_loads=0)
model.report()
# boundary condition(s)
## find nodes at y==0 and x==0
for node in nodes:
X = node.getPos()
if math.isclose(X[0], 0.0):
node.setDOF(['T'],[200.]) # prescribed temperature at x=0.0
if math.isclose(X[0], Lx):
node.setDOF(['T'],[300.]) # prescribed temperature at x=0.0
# perform the analysis
model.setLoadFactor(1.0)
model.solve()
model.report()
model.valuePlot('T', show_mesh=True)
model.valuePlot('Tx', show_mesh=True)
model.valuePlot('qx', show_mesh=True)
# creating a path plot
R_list = []
T_list = []
for node in nodes:
X = node.getPos()
T = node.getDisp('T')
R_list.append(X[0])
T_list.append(T)
# the analytic solution for comparison
x = np.linspace(0, Lx, 21)
T = 200. * (1 - x/Lx) + 300. * x/Lx
fig, axs = plt.subplots()
axs.plot(x,T,'-b',label="analytic solution")
axs.plot(R_list,T_list,'ro',label="FEM")
axs.set_title('Nodal Temperature for ALL Nodes')
axs.set_xlabel("X distance")
axs.set_ylabel('T')
axs.legend()
axs.grid(True)
plt.show()
Run the example by creating an instance of the problem and executing it by calling Example.run()
if __name__ == "__main__":
ex = ExampleThermal02()
ex.run()
System Analysis Report
=======================
Nodes:
---------------------
Node_236:
x: [0.000 0.000]
u: [0.000]
Node_237:
x: [3.775 0.000]
u: [0.000]
Node_238:
x: [6.700 0.000]
u: [0.000]
Node_239:
x: [8.775 0.000]
u: [0.000]
Node_240:
x: [10.000 0.000]
u: [0.000]
Node_241:
x: [0.000 1.667]
u: [0.000]
Node_242:
x: [2.925 1.667]
u: [0.000]
Node_243:
x: [5.567 1.667]
u: [0.000]
Node_244:
x: [7.925 1.667]
u: [0.000]
Node_245:
x: [10.000 1.667]
u: [0.000]
Node_246:
x: [0.000 3.333]
u: [0.000]
Node_247:
x: [2.075 3.333]
u: [0.000]
Node_248:
x: [4.433 3.333]
u: [0.000]
Node_249:
x: [7.075 3.333]
u: [0.000]
Node_250:
x: [10.000 3.333]
u: [0.000]
Node_251:
x: [0.000 5.000]
u: [0.000]
Node_252:
x: [1.225 5.000]
u: [0.000]
Node_253:
x: [3.300 5.000]
u: [0.000]
Node_254:
x: [6.225 5.000]
u: [0.000]
Node_255:
x: [10.000 5.000]
u: [0.000]
Elements:
---------------------
Triangle_351: nodes ( Node_236 Node_237 Node_241 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_352: nodes ( Node_242 Node_241 Node_237 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_353: nodes ( Node_237 Node_238 Node_242 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_354: nodes ( Node_243 Node_242 Node_238 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_355: nodes ( Node_238 Node_239 Node_243 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_356: nodes ( Node_244 Node_243 Node_239 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_357: nodes ( Node_239 Node_240 Node_244 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_358: nodes ( Node_245 Node_244 Node_240 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_359: nodes ( Node_241 Node_242 Node_246 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_360: nodes ( Node_247 Node_246 Node_242 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_361: nodes ( Node_242 Node_243 Node_247 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_362: nodes ( Node_248 Node_247 Node_243 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_363: nodes ( Node_243 Node_244 Node_248 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_364: nodes ( Node_249 Node_248 Node_244 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_365: nodes ( Node_244 Node_245 Node_249 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_366: nodes ( Node_250 Node_249 Node_245 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_367: nodes ( Node_246 Node_247 Node_251 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_368: nodes ( Node_252 Node_251 Node_247 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_369: nodes ( Node_247 Node_248 Node_252 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_370: nodes ( Node_253 Node_252 Node_248 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_371: nodes ( Node_248 Node_249 Node_253 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_372: nodes ( Node_254 Node_253 Node_249 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_373: nodes ( Node_249 Node_250 Node_254 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
Triangle_374: nodes ( Node_255 Node_254 Node_250 )
material: Thermal
grad phi: x=0.000e+00 y=0.000e+00
flux: x=0.000e+00 y=0.000e+00
System Analysis Report
=======================
Nodes:
---------------------
Node_236:
x: [0.000 0.000]
fix: ['T']
u: [200.000]
Node_237:
x: [3.775 0.000]
u: [237.750]
Node_238:
x: [6.700 0.000]
u: [267.000]
Node_239:
x: [8.775 0.000]
u: [287.750]
Node_240:
x: [10.000 0.000]
fix: ['T']
u: [300.000]
Node_241:
x: [0.000 1.667]
fix: ['T']
u: [200.000]
Node_242:
x: [2.925 1.667]
u: [229.250]
Node_243:
x: [5.567 1.667]
u: [255.667]
Node_244:
x: [7.925 1.667]
u: [279.250]
Node_245:
x: [10.000 1.667]
fix: ['T']
u: [300.000]
Node_246:
x: [0.000 3.333]
fix: ['T']
u: [200.000]
Node_247:
x: [2.075 3.333]
u: [220.750]
Node_248:
x: [4.433 3.333]
u: [244.333]
Node_249:
x: [7.075 3.333]
u: [270.750]
Node_250:
x: [10.000 3.333]
fix: ['T']
u: [300.000]
Node_251:
x: [0.000 5.000]
fix: ['T']
u: [200.000]
Node_252:
x: [1.225 5.000]
u: [212.250]
Node_253:
x: [3.300 5.000]
u: [233.000]
Node_254:
x: [6.225 5.000]
u: [262.250]
Node_255:
x: [10.000 5.000]
fix: ['T']
u: [300.000]
Elements:
---------------------
Triangle_351: nodes ( Node_236 Node_237 Node_241 )
material: Thermal
grad phi: x=1.000e+01 y=0.000e+00
flux: x=-1.000e+01 y=-0.000e+00
Triangle_352: nodes ( Node_242 Node_241 Node_237 )
material: Thermal
grad phi: x=1.000e+01 y=5.684e-14
flux: x=-1.000e+01 y=-5.684e-14
Triangle_353: nodes ( Node_237 Node_238 Node_242 )
material: Thermal
grad phi: x=1.000e+01 y=2.842e-14
flux: x=-1.000e+01 y=-2.842e-14
Triangle_354: nodes ( Node_243 Node_242 Node_238 )
material: Thermal
grad phi: x=1.000e+01 y=2.842e-14
flux: x=-1.000e+01 y=-2.842e-14
Triangle_355: nodes ( Node_238 Node_239 Node_243 )
material: Thermal
grad phi: x=1.000e+01 y=2.842e-14
flux: x=-1.000e+01 y=-2.842e-14
Triangle_356: nodes ( Node_244 Node_243 Node_239 )
material: Thermal
grad phi: x=1.000e+01 y=-2.842e-14
flux: x=-1.000e+01 y=2.842e-14
Triangle_357: nodes ( Node_239 Node_240 Node_244 )
material: Thermal
grad phi: x=1.000e+01 y=-2.842e-14
flux: x=-1.000e+01 y=2.842e-14
Triangle_358: nodes ( Node_245 Node_244 Node_240 )
material: Thermal
grad phi: x=1.000e+01 y=0.000e+00
flux: x=-1.000e+01 y=-0.000e+00
Triangle_359: nodes ( Node_241 Node_242 Node_246 )
material: Thermal
grad phi: x=1.000e+01 y=0.000e+00
flux: x=-1.000e+01 y=-0.000e+00
Triangle_360: nodes ( Node_247 Node_246 Node_242 )
material: Thermal
grad phi: x=1.000e+01 y=2.842e-14
flux: x=-1.000e+01 y=-2.842e-14
Triangle_361: nodes ( Node_242 Node_243 Node_247 )
material: Thermal
grad phi: x=1.000e+01 y=0.000e+00
flux: x=-1.000e+01 y=-0.000e+00
Triangle_362: nodes ( Node_248 Node_247 Node_243 )
material: Thermal
grad phi: x=1.000e+01 y=2.842e-14
flux: x=-1.000e+01 y=-2.842e-14
Triangle_363: nodes ( Node_243 Node_244 Node_248 )
material: Thermal
grad phi: x=1.000e+01 y=0.000e+00
flux: x=-1.000e+01 y=-0.000e+00
Triangle_364: nodes ( Node_249 Node_248 Node_244 )
material: Thermal
grad phi: x=1.000e+01 y=-1.137e-13
flux: x=-1.000e+01 y=1.137e-13
Triangle_365: nodes ( Node_244 Node_245 Node_249 )
material: Thermal
grad phi: x=1.000e+01 y=-1.137e-13
flux: x=-1.000e+01 y=1.137e-13
Triangle_366: nodes ( Node_250 Node_249 Node_245 )
material: Thermal
grad phi: x=1.000e+01 y=0.000e+00
flux: x=-1.000e+01 y=-0.000e+00
Triangle_367: nodes ( Node_246 Node_247 Node_251 )
material: Thermal
grad phi: x=1.000e+01 y=0.000e+00
flux: x=-1.000e+01 y=-0.000e+00
Triangle_368: nodes ( Node_252 Node_251 Node_247 )
material: Thermal
grad phi: x=1.000e+01 y=0.000e+00
flux: x=-1.000e+01 y=-0.000e+00
Triangle_369: nodes ( Node_247 Node_248 Node_252 )
material: Thermal
grad phi: x=1.000e+01 y=-5.684e-14
flux: x=-1.000e+01 y=5.684e-14
Triangle_370: nodes ( Node_253 Node_252 Node_248 )
material: Thermal
grad phi: x=1.000e+01 y=-2.842e-14
flux: x=-1.000e+01 y=2.842e-14
Triangle_371: nodes ( Node_248 Node_249 Node_253 )
material: Thermal
grad phi: x=1.000e+01 y=-8.527e-14
flux: x=-1.000e+01 y=8.527e-14
Triangle_372: nodes ( Node_254 Node_253 Node_249 )
material: Thermal
grad phi: x=1.000e+01 y=0.000e+00
flux: x=-1.000e+01 y=-0.000e+00
Triangle_373: nodes ( Node_249 Node_250 Node_254 )
material: Thermal
grad phi: x=1.000e+01 y=2.842e-14
flux: x=-1.000e+01 y=-2.842e-14
Triangle_374: nodes ( Node_255 Node_254 Node_250 )
material: Thermal
grad phi: x=1.000e+01 y=0.000e+00
flux: x=-1.000e+01 y=-0.000e+00
Total running time of the script: (0 minutes 0.490 seconds)