|
|
@ -0,0 +1,191 @@ |
|
|
|
|
|
|
|
|
|
|
|
```python |
|
|
|
#1 Loading functions and modules |
|
|
|
from fenics import * |
|
|
|
import matplotlib.pyplot as plt |
|
|
|
T = 2.0 |
|
|
|
num_steps = 20 |
|
|
|
dt = T/num_steps |
|
|
|
rho = 7500 |
|
|
|
Cp = 500 |
|
|
|
k = 50 |
|
|
|
alpha = k/(rho*Cp) |
|
|
|
``` |
|
|
|
|
|
|
|
|
|
|
|
```python |
|
|
|
#2 Create mesh and define function space |
|
|
|
nx = 0.008 |
|
|
|
ny = 0.003 |
|
|
|
mesh = RectangleMesh(Point(0,0),Point(nx,ny),30, 30,'left') |
|
|
|
V = FunctionSpace(mesh, 'Lagrange', 1) #Lagrange are triangular elements |
|
|
|
plot(mesh) |
|
|
|
plt.show() |
|
|
|
|
|
|
|
``` |
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b1242/b12429b42da68bdd0837d29ba5c275900ad9fa4b" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
```python |
|
|
|
# Boundary conditions |
|
|
|
u0 = Constant(100) |
|
|
|
def boundary(x, on_boundary): |
|
|
|
return on_boundary |
|
|
|
|
|
|
|
bc = DirichletBC(V,u0, boundary) |
|
|
|
``` |
|
|
|
|
|
|
|
|
|
|
|
```python |
|
|
|
u_n = project(1, V) |
|
|
|
u = TrialFunction(V) |
|
|
|
v = TestFunction(V) |
|
|
|
f = Constant(0.0) |
|
|
|
F = u*v*dx + alpha*dt*dot(grad(u), grad(v))*dx-u_n*v*dx |
|
|
|
a, L = lhs(F), rhs(F) |
|
|
|
``` |
|
|
|
|
|
|
|
Calling FFC just-in-time (JIT) compiler, this may take some time. |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
```python |
|
|
|
u = Function(V) |
|
|
|
t = 0 |
|
|
|
for n in range(num_steps): |
|
|
|
t += dt |
|
|
|
#u0.t = t |
|
|
|
solve(a == L, u, bc) |
|
|
|
c = plot(u,) |
|
|
|
plt.colorbar(c) |
|
|
|
plt.show() |
|
|
|
u_n.assign(u) |
|
|
|
``` |
|
|
|
|
|
|
|
Calling FFC just-in-time (JIT) compiler, this may take some time. |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/aa75d/aa75d690c7011716c5a830f3e943c56f03cf6cba" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/eca9e/eca9e8a0e5a5fa956290d988a0027e4259078123" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4e8d6/4e8d6a64db90333339a6f32affdb41aa71353d69" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ad31f/ad31f366e2a2c6d1f76a599d102d030aafab1cd4" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a8b3a/a8b3a4aadf9aab38756a3c6dcecd47a7f4164761" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/03d67/03d677e959c2bb7d29c0b60127dc874754d55a9b" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ced46/ced4602806c776ed1c8583e29b815a7819df07fd" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1044c/1044cd458fdfd1056bcd7ffe20df586630449f06" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b1fa1/b1fa1733ef523bacf5723c15ff7be067a3b6c8c7" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/2ea83/2ea83bbbddccde30720f2de7c094129440130061" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4bdfd/4bdfdd28fbd27c7949f5c62ed24525f2645a96a9" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/50745/50745b79355ecc2a1fabe60d7b4c503a39ee3a1e" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4e4a9/4e4a9ff0393e08a66e3441221f2b720d45df88a1" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/16645/1664570398a481ae7e5cbdd4d8975e13366f072c" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/72605/726051ad4cc7b25ef270ccd76d9ef09df8d84e5e" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ad665/ad665efdfa6695f05f1a31d5015c489c4dd8e7df" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f8115/f811568c0cc602100d09c7fc0f31deccd026d472" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/516c6/516c611c7b761a9163981ba1f2e741c0ac78df01" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/6ccb2/6ccb2fe54dc94c0883f477f58ba6fc1a8d1531bb" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5a05e/5a05ea573a35314bfb8abff74313e17dc09a94b4" alt="png" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
```python |
|
|
|
1E-7 |
|
|
|
``` |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1e-07 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
```python |
|
|
|
1e2 |
|
|
|
``` |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
100.0 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
```python |
|
|
|
1E-7+1e2 |
|
|
|
``` |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
100.0000001 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
```python |
|
|
|
|
|
|
|
``` |