ฉันพยายามที่จะแก้สมการปัวซอง 2D โดยใช้วิธีไม่ต่อเนื่อง Galerkin (DG) และการแยกประเภทต่อไปนี้ (ฉันมีไฟล์ png แต่ฉันไม่ได้รับอนุญาตให้อัปโหลดขออภัย):
สมการ:
สมการใหม่:
รูปแบบที่อ่อนแอพร้อมฟลักซ์ตัวเลขและ : Q
ฟลักซ์เชิงตัวเลข (วิธี IP):
ด้วย
ฉันเขียนสคริปต์หลาม fenics ง่าย ๆ เพื่อแก้สมการ ทางออกที่ฉันได้รับไม่ดี ฉันจะขอบคุณจริง ๆ ถ้ามีคนคุ้นเคยกับวิธีการของ DG อาจดูสคริปต์ด้านล่างอย่างรวดเร็วและบอกฉันว่าฉันทำอะไรผิด
สูตรกาแลคคินอย่างต่อเนื่องที่ฉันเพิ่มเข้าไปในสคริปต์ให้ทางออกที่ดี
ขอบคุณมากในล่วงหน้า.
from dolfin import *
method = "DG" # CG / DG
# Create mesh and define function space
mesh = UnitSquare(32, 32)
V_q = VectorFunctionSpace(mesh, method, 2)
V_T = FunctionSpace (mesh, method, 1)
W = V_q * V_T
# Define test and trial functions
(q, T) = TrialFunctions(W)
(w, v) = TestFunctions(W)
# Define mehs quantities: normal component, mesh size
n = FacetNormal(mesh)
# define right-hand side
f = Expression("500.0*exp(-(pow(x[0] - 0.5, 2) + pow(x[1] - 0.5, 2)) / 0.02)")
# Define parameters
kappa = 1.0
# Define variational problem
if method == 'CG':
a = dot(q,w)*dx \
+ T*div(kappa*w)*dx \
+ div(q)*v*dx
elif method == 'DG':
#modele = "IP"
C11 = 1.
a = dot(q,w)*dx + T*div(kappa*w)*dx \
- kappa*avg(T)*dot(n('-'),w('-'))*dS \
\
+ dot(q,grad(v))*dx \
- dot( avg(grad(T)) - C11 * jump(T,n) ,n('-'))*v('-')*dS
L = -v*f*dx
# Compute solution
qT = Function(W)
solve(a == L, qT)
# Project solution to piecewise linears
(q , T) = qT.split()
# Save solution to file
file = File("poisson.pvd")
file << T
# Plot solution
plot(T); plot(q)
interactive()