forked from idaholab/TMAP8
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Documentation for validation cases 1-3 idaholab#12
- Loading branch information
1 parent
bdf9e6c
commit 503c81d
Showing
18 changed files
with
1,466 additions
and
146 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
# val-1a | ||
|
||
# Depleting Source Problem | ||
|
||
## Test Description | ||
|
||
This model consists of an enclosure containing a finite concentration of atoms which are allowed to diffuse into a SiC layer over time. No solubility or trapping effects are included. The fractional release from the outside of the shell in a depleting source model in a slab geometry is given by: | ||
|
||
\begin{equation} | ||
FR = 1.0 - \sum_{n=1}^{\infty} \frac{2\ L sec \ \alpha_{n} - \exp\left(\frac{-\alpha_{n}^2 D T}{l^{2}}\right)}{L(L+1) + \alpha_n^{2}} | ||
\end{equation} | ||
|
||
where | ||
|
||
\begin{equation} | ||
L = \frac{lA}{V \phi} | ||
\end{equation} | ||
|
||
\begin{equation} | ||
\phi = \frac{source \ concentration}{layer \ concentration} | ||
\end{equation} | ||
|
||
where the layer concentration is that at the interface with the source ($\phi$ is constant in time), | ||
|
||
$A$ = surface area | ||
|
||
$V$ = source volume | ||
|
||
$l$ = layer thickness | ||
|
||
and the $\alpha_n$ are the roots of | ||
|
||
\begin{equation} | ||
\alpha_n = \frac{L}{tan \ \alpha_n} | ||
\end{equation} | ||
|
||
## Results | ||
|
||
|
||
[val-1a_comparison] shows the comparison of the TMAP8 calculation and the analytical solution. There is good agreement between the two plots. | ||
|
||
|
||
!media figures/val-1a_comparison.png | ||
style=width:50%;margin-bottom:2% | ||
id=val-1a_comparison | ||
caption=Comparison of TMAP8 calculation with the analytical solution | ||
|
||
!bibtex bibliography |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,70 @@ | ||
# val-1b | ||
|
||
# Diffusion Problem with Constant Source Boundary Condition | ||
|
||
Diffusion of tritium through a semi-infinite SiC layer is modeled with a constant | ||
source located on one boundary. No solubility or traping is included. The | ||
concentration as a function of time and position is given by: | ||
|
||
\begin{equation} | ||
C = C_o \; erfc \left(\frac{x}{2\sqrt{Dt}}\right) | ||
\end{equation} | ||
|
||
Comparison of the TMAP8 results and the analytical solution is shown in | ||
[val-1b_comparison_time] as a function of time at | ||
x = 0.2 mm. For simplicity, both the diffusion coefficient and the initial | ||
concentration were set to unity. The TMAP8 code predictions match very well with | ||
the analytical solution. | ||
|
||
!media figures/val-1b_comparison_time.png | ||
style=width:50%;margin-bottom:2% | ||
id=val-1b_comparison_time | ||
caption=Comparison of concentration as function of time at x\=0.2m calculated | ||
through TMAP8 and analytically | ||
|
||
As a second check, the concentration as a function of position at a given time | ||
t = 25s, from TMAP8 was compared with the analytical solution as shown in | ||
[val-1b_comparison_dist]. The predicted concentration profile from TMAP8 is in | ||
good agreement with the analytical solution. | ||
|
||
!media figures/val-1b_comparison_dist.png | ||
style=width:50%;margin-bottom:2% | ||
id=val-1b_comparison_dist | ||
caption=Comparison of concentration as function of distance from the source | ||
at t\=25sec calculated through TMAP8 and analytically | ||
|
||
Finally, the diffusive flux ($J$) was compared with the analytic solution where the | ||
flux is proportional to the derivative of the concentration with respect to x and | ||
is given by: | ||
|
||
\begin{equation} | ||
J = C_o \; \sqrt{\frac{D}{t\pi}} \; exp \left(\frac{x}{2\sqrt{Dt}}\right) | ||
\end{equation} | ||
|
||
The flux as given by Equation (?) is compared with values calculated by TMAP8 in | ||
Table ?. The diffusivity, D, and the initial concentration, C$_o$, were both | ||
taken as unity, and the distance, x, was taken as 0.5 in this comparison. | ||
TMAP8 initially under predicts but the results match well subsequently. Comparison | ||
results are shown in [] | ||
|
||
!media figures/val-1b_comparison_flux.png | ||
style=width:50%;margin-bottom:2% | ||
id=val-1b_comparison_flux | ||
caption=Comparison of flux as function of time at x\=0.5m calculated through | ||
TMAP8 and analytically | ||
|
||
### Notes | ||
|
||
The trapping test features some oscillations in the solution for whatever | ||
reason. In order for the oscillations to not take over the simulation, it seems | ||
that the ratio of the **inverse of the Fourier number** must be kept | ||
sufficiently high, e.g. `h^2 / (D * dt)`. Included in this directory are three | ||
`png` files that show the permeation for different `h` and `dt` values. They are | ||
summarized below: | ||
|
||
- `nx-80.png`: `nx = 80` and `dt = .0625` | ||
- `nx-40.png`: `nx = 40` and `dt = .25` | ||
- `nx-20.png`: `nx = 20` and `dt = 1` | ||
|
||
The oscillations in the permeation graph go away with increasing fineness in the | ||
mesh and in `dt`. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
# val-1c | ||
|
||
# Diffusion Problem with Partially Preloaded Slab$^2$ | ||
|
||
Diffusion of tritium through a semi-infinite SiC layer is modeled with an initial | ||
loading of 1 atom/m{^3} in the first 10 m of a 2275-m slab. Solubility is unity | ||
and no traping is included. The analytical solution is given by: | ||
|
||
\begin{equation} | ||
C = \frac{C_o}{2} \left( erf \left( \frac{h-x}{2} \sqrt{Dt} \right) + erf \left( \frac{h+x}{2\sqrt{Dt}}) \right) \right) | ||
\end{equation} | ||
|
||
|
||
where h is the thickness of the pre-loaded portion of the layer. | ||
|
||
At the surface (x = 0) the concentration is given by: | ||
|
||
\begin{equation} | ||
C = \frac{C_o}{2} \; erf \left( \frac{h}{2\sqrt{Dt}} \right) | ||
\end{equation} | ||
|
||
while at x = h its value is described by | ||
|
||
\begin{equation} | ||
C = \frac{C_o}{2} \; erf \left( \frac{h}{\sqrt{Dt}} \right) | ||
\end{equation} | ||
|
||
A comparison of the mobile species concentration values at x = 0 m, 10 m and | ||
12.5 m calculated through TMAP8 and analytically is shown in | ||
[val-1c_comparison_time]. The TMAP8 calculations are found to be in good agreement | ||
with the analytical solution. | ||
|
||
!media figures/val-1c_comparison_time.png | ||
style=width:50%;margin-bottom:2% | ||
id=val-1c_comparison_time | ||
caption=Comparison of concentration as function of time at x\=0 m, 10 m and 12 m | ||
calculated through TMAP8 and analytically |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
time(s),frac_rel | ||
0,0 | ||
1,6.00E-07 | ||
2,0.000262 | ||
3,0.002399 | ||
4,0.007873 | ||
5,0.016781 | ||
6,0.028554 | ||
7,0.042499 | ||
8,0.06218 | ||
9,0.074568 | ||
10,0.091823 | ||
11,0.109482 | ||
12,0.127337 | ||
13,0.145233 | ||
14,0.163059 | ||
15,0.180733 | ||
16,0.198197 | ||
17,0.21541 | ||
18,0.232343 | ||
19,0.248977 | ||
20,0.265301 | ||
21,0.281307 | ||
22,0.296991 | ||
23,0.312353 | ||
24,0.327395 | ||
25,0.342119 | ||
26,0.356529 | ||
27,0.37063 | ||
28,0.384426 | ||
29,0.397923 | ||
30,0.411126 | ||
31,0.424042 | ||
32,0.436677 | ||
33,0.449035 | ||
34,0.461122 | ||
35,0.472945 | ||
36,0.484509 | ||
37,0.49582 | ||
38,0.506883 | ||
39,0.517703 | ||
40,0.528286 | ||
41,0.538637 | ||
42,0.54876 | ||
43,0.558662 | ||
44,0.568346 | ||
45,0.577818 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
#import editorial_settings | ||
|
||
import csv | ||
import matplotlib.pyplot as plt | ||
import numpy as np | ||
from matplotlib import gridspec | ||
import pandas as pd | ||
|
||
#=============================================================================== | ||
|
||
fig = plt.figure(figsize=[6.5,5.5]) | ||
gs = gridspec.GridSpec(1,1) | ||
ax = fig.add_subplot(gs[0]) | ||
|
||
tmap_sol = pd.read_csv("./val-1a_csv.csv") | ||
analytical_sol = pd.read_csv("./analytical.csv") | ||
tmap_time = tmap_sol['time'] | ||
tmap_fr = tmap_sol['rhs_release'] | ||
analytical_time = analytical_sol['time(s)'] | ||
analytical_fr = analytical_sol['frac_rel'] | ||
|
||
ax.plot(tmap_time,tmap_fr,label=r"TMAP8",c='tab:gray') | ||
ax.plot(analytical_time,analytical_fr,label=r"Analytical",c='k', linestyle='--') | ||
|
||
|
||
ax.set_xlabel(u'Time(s)') | ||
ax.set_ylabel(r"Fractional release") | ||
ax.legend(loc="best") | ||
ax.set_xlim(left=0) | ||
ax.set_xlim(right=45) | ||
ax.set_ylim(bottom=0) | ||
plt.grid(b=True, which='major', color='0.65', linestyle='--', alpha=0.3) | ||
|
||
ax.minorticks_on() | ||
plt.savefig('comparison.png', bbox_inches='tight'); | ||
plt.close(fig) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,102 @@ | ||
#import editorial_settings | ||
|
||
import csv | ||
import matplotlib.pyplot as plt | ||
import numpy as np | ||
from matplotlib import gridspec | ||
import pandas as pd | ||
from scipy import special | ||
|
||
#========= Comparison of concentration as a function of time =================== | ||
|
||
fig = plt.figure(figsize=[6.5,5.5]) | ||
gs = gridspec.GridSpec(1,1) | ||
ax = fig.add_subplot(gs[0]) | ||
|
||
tmap_sol = pd.read_csv("./gold/u_vs_t.csv") | ||
tmap_time = tmap_sol['time'] | ||
tmap_conc = tmap_sol['conc_point1'] | ||
|
||
analytical_time = tmap_time | ||
x = 0.2 | ||
C_o = 1 | ||
D = 1 | ||
analytical_conc = C_o * special.erfc( x / (2 * np.sqrt(D*analytical_time))) | ||
ax.plot(tmap_time,tmap_conc,label=r"TMAP8",c='tab:gray') | ||
ax.plot(analytical_time,analytical_conc,label=r"Analytical",c='k', linestyle='--') | ||
|
||
|
||
ax.set_xlabel(u'Time(s)') | ||
ax.set_ylabel(r"Normalized specie concentration") | ||
ax.legend(loc="best") | ||
ax.set_xlim(left=0) | ||
ax.set_xlim(right=45) | ||
ax.set_ylim(bottom=0) | ||
plt.grid(b=True, which='major', color='0.65', linestyle='--', alpha=0.3) | ||
|
||
ax.minorticks_on() | ||
plt.savefig('val-1b_comparison_time.png', bbox_inches='tight'); | ||
plt.close(fig) | ||
|
||
|
||
#============ Comparison of concentration as a function of distance ============ | ||
|
||
fig = plt.figure(figsize=[6.5,5.5]) | ||
gs = gridspec.GridSpec(1,1) | ||
ax = fig.add_subplot(gs[0]) | ||
|
||
tmap_sol = pd.read_csv("./gold/u_vs_x.csv") | ||
tmap_distance = tmap_sol['x'] | ||
tmap_conc = tmap_sol['u'] | ||
|
||
analytical_distance = tmap_distance | ||
time = 25 | ||
C_o = 1 | ||
D = 1 | ||
analytical_conc = C_o * special.erfc( analytical_distance / (2 * np.sqrt(D * time))) | ||
|
||
ax.plot(tmap_distance,tmap_conc,label=r"TMAP8",c='tab:gray') | ||
ax.plot(analytical_distance,analytical_conc,label=r"Analytical",c='k', linestyle='--') | ||
|
||
ax.set_xlabel(u'Distance (m)') | ||
ax.set_ylabel(r"Normalized specie concentration") | ||
ax.legend(loc="best") | ||
ax.set_xlim(left=0) | ||
ax.set_xlim(right=50) | ||
ax.set_ylim(bottom=0) | ||
plt.grid(b=True, which='major', color='0.65', linestyle='--', alpha=0.3) | ||
|
||
ax.minorticks_on() | ||
plt.savefig('val-1b_comparison_dist.png', bbox_inches='tight'); | ||
plt.close(fig) | ||
#================== Comparison of flux as a function of time =================== | ||
|
||
fig = plt.figure(figsize=[6.5,5.5]) | ||
gs = gridspec.GridSpec(1,1) | ||
ax = fig.add_subplot(gs[0]) | ||
|
||
tmap_sol = pd.read_csv("./gold/u_vs_t.csv") | ||
tmap_time = tmap_sol['time'] | ||
tmap_flux = tmap_sol['flux_point2'] | ||
|
||
analytical_time = tmap_time | ||
x = 0.5 | ||
C_o = 1 | ||
D = 1 | ||
analytical_flux = C_o * np.sqrt(D/(np.pi * analytical_time)) * \ | ||
np.exp( x / (2 * np.sqrt(D * analytical_time))) | ||
ax.plot(tmap_time,tmap_flux,label=r"TMAP8",c='tab:gray') | ||
ax.plot(analytical_time,analytical_flux,label=r"Analytical",c='k', linestyle='--') | ||
|
||
|
||
ax.set_xlabel(u'Time(s)') | ||
ax.set_ylabel(r"Diffusive flux") | ||
ax.legend(loc="best") | ||
ax.set_xlim(left=0) | ||
ax.set_xlim(right=45) | ||
ax.set_ylim(bottom=0) | ||
plt.grid(b=True, which='major', color='0.65', linestyle='--', alpha=0.3) | ||
|
||
ax.minorticks_on() | ||
plt.savefig('val-1b_comparison_flux.png', bbox_inches='tight'); | ||
plt.close(fig) |
Oops, something went wrong.