Skip to content

Commit

Permalink
Documentation for validation cases 1-3 idaholab#12
Browse files Browse the repository at this point in the history
  • Loading branch information
singhgp4321 committed Mar 28, 2022
1 parent bdf9e6c commit a38ea6a
Show file tree
Hide file tree
Showing 20 changed files with 3,468 additions and 146 deletions.
4 changes: 4 additions & 0 deletions doc/content/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -27,3 +27,7 @@ effectively changing the concentration of the trapped specie from being measured
in #/volume to k#/volume where 'k' indicates kilo. After this transformation,
the numerical concentrations of the trapped and mobile species are on the same
order of magnitude.

## [Verification](verification/val-1c.md)

!content location=verification level=5
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.
48 changes: 48 additions & 0 deletions doc/content/verification/val-1a.md
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
70 changes: 70 additions & 0 deletions doc/content/verification/val-1b.md
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`.
37 changes: 37 additions & 0 deletions doc/content/verification/val-1c.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
# val-1c

# Diffusion Problem with Partially Preloaded Slab

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
25 changes: 0 additions & 25 deletions doc/content/verification/val-1d.md

This file was deleted.

47 changes: 47 additions & 0 deletions test/tests/val-1a/analytical.csv
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
36 changes: 36 additions & 0 deletions test/tests/val-1a/comparison.py
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)
102 changes: 102 additions & 0 deletions test/tests/val-1b/comparison_val-1b.py
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)
Loading

0 comments on commit a38ea6a

Please sign in to comment.