Skip to content

Commit

Permalink
Merge pull request #485 from easifem/dev
Browse files Browse the repository at this point in the history
EASIFEM v23.10.05 release
  • Loading branch information
vickysharma0812 authored Apr 3, 2024
2 parents 7a00086 + 6037c34 commit 0c50932
Show file tree
Hide file tree
Showing 80 changed files with 5,921 additions and 5,307 deletions.
36 changes: 29 additions & 7 deletions src/modules/AbstractKernel/src/AbstractKernel_Class.F90
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ MODULE AbstractKernel_Class
USE SolidMaterial_Class
USE Field
USE TxtFile_Class
USE PVDFile_Class
USE KernelUtility
USE UserFunction_Class

Expand Down Expand Up @@ -100,6 +101,8 @@ MODULE AbstractKernel_Class

!> authors: Vikas Sharma, Ph. D.
! date: 27 April 2022
!> author: Shion Shimizu
! update: 2024-02-10
! summary: Abstract class for kernel

TYPE, ABSTRACT :: AbstractKernel_
Expand Down Expand Up @@ -146,6 +149,8 @@ MODULE AbstractKernel_Class
!! solid material id
INTEGER(I4B) :: algorithm = 0
!! algorithm
INTEGER(I4B) :: vtkOutputFreq = 0
!! frequency of output with WriteData_vtk
TYPE(String) :: name
!! This is the name of the kernel. It can be anything you want.
TYPE(String) :: engine
Expand All @@ -159,6 +164,14 @@ MODULE AbstractKernel_Class
TYPE(String) :: outputPath
!! Path to put output files
!! Default is results
LOGICAL(LGT) :: unifyVTK = .FALSE.
!! if it is true all data are exported into one vtu file
!! in WriteData_vtk method
LOGICAL(LGT) :: createPVD = .FALSE.
!! if true paraview data file is created
!! in WriteData_vtk method
TYPE(PVDFile_) :: pvdFile
!! instance of pvd file class
INTEGER(I4B) :: coordinateSystem = DEFAULT_coordinateSystem
!! Spatial coordinate system type. It can take following values
!! `KERNEL_CARTESIAN` for Cartesian coordinates
Expand Down Expand Up @@ -753,6 +766,8 @@ MODULE AbstractKernel_Class

!> authors: Vikas Sharma, Ph. D.
! date: 25 Aug 2021
!> author: Shion Shimizu
! update: 2024-02-10
! summary: Set kernel parameters

INTERFACE
Expand All @@ -764,17 +779,18 @@ MODULE SUBROUTINE SetAbstractKernelParam( &
& baseInterpolationForSpace, baseContinuityForSpace, &
& quadratureTypeForSpace, ipTypeForSpace, &
& basisTypeForSpace, alphaForSpace, &
& betaForSpace, lambdaForSpace, &
& baseInterpolationForTime, baseContinuityForTime, &
& quadratureTypeForTime, ipTypeForTime, &
& betaForSpace, lambdaForSpace, baseInterpolationForTime, &
& baseContinuityForTime, quadratureTypeForTime, ipTypeForTime, &
& basisTypeForTime, alphaForTime, betaForTime, lambdaForTime, &
& postProcessOpt, tDirichletBC, tNeumannBC, tWeakDirichletBC, &
& isSymNitsche, nitscheAlpha, materialInterfaces, isConstantMatProp, &
& tSolidMaterials, algorithm, isIsotropic, isIncompressible, &
& rtoleranceForDisplacement, atoleranceForDisplacement, &
& isSymNitsche, nitscheAlpha, &
& materialInterfaces, isConstantMatProp, tSolidMaterials, &
& algorithm, vtkOutputFreq, isIsotropic, isIncompressible, &
& rtoleranceForDisplacement, atoleranceForDisplacement, &
& rtoleranceForVelocity, atoleranceForVelocity, &
& rtoleranceForResidual, atoleranceForResidual, tanmatProp, &
& tOverlappedMaterials, outputPath, tPointSource, showTime)
& tOverlappedMaterials, outputPath, tPointSource, showTime, &
& unifyVTK, createPVD)
CHARACTER(*), INTENT(IN) :: prefix
INTEGER(I4B), INTENT(IN) :: problemType
!! Kernel problem type. Problem can be scalar, vector, or multi-physics
Expand Down Expand Up @@ -890,6 +906,8 @@ MODULE SUBROUTINE SetAbstractKernelParam( &
!! It is true if the material properties are constant
INTEGER(I4B), OPTIONAL, INTENT(IN) :: algorithm
!! algorithm
INTEGER(I4B), OPTIONAL, INTENT(IN) :: vtkOutputFreq
!! frequency of output with WriteData_vtk
LOGICAL(LGT), OPTIONAL, INTENT(IN) :: isIsotropic
!! It is true if the material is isotropic
LOGICAL(LGT), OPTIONAL, INTENT(IN) :: isIncompressible
Expand All @@ -916,6 +934,10 @@ MODULE SUBROUTINE SetAbstractKernelParam( &
!! total number of point sources, size of nbcPointSource
LOGICAL(LGT), OPTIONAL, INTENT(IN) :: showTime
!! Show time of each steps
LOGICAL(LGT), OPTIONAL, INTENT(IN) :: unifyVTK
!! unified write data to vtk file
LOGICAL(LGT), OPTIONAL, INTENT(IN) :: createPVD
!! create the paraview data file
END SUBROUTINE SetAbstractKernelParam
END INTERFACE

Expand Down
176 changes: 174 additions & 2 deletions src/modules/AbstractKernel/src/SDAlgorithms.F90
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,7 @@ MODULE SDAlgorithms

REAL(DFP) :: dis(4) = 0.0_DFP
!! dis coefficient for velocity update
!! displacement = vel(1)*u / dt + vel(2) * v + vel(3) * a *dt + vel(4)*sol/dt
!! displacement = dis(1)*u+dis(2)*v*dt+dis(3)*a*dt*dt+dis(4)*sol
!! dis(1) coefficient of displacement
!! dis(2) coefficient of velocity
!! dis(3) coefficient of acceleration
Expand All @@ -104,13 +104,19 @@ MODULE SDAlgorithms
!! acc(4) coefficient of solution
LOGICAL(LGT) :: acc_zero(4) = .TRUE.

REAL(DFP) :: alpha = 0.0_DFP
!! only in case of HHT-alpha method it can be less than 0.0

CONTAINS
PRIVATE

PROCEDURE, PUBLIC, PASS(obj) :: DEALLOCATE => obj_Deallocate
PROCEDURE, PUBLIC, PASS(obj) :: Display => obj_Display
PROCEDURE, PUBLIC, PASS(obj) :: MakeZeros => obj_MakeZeros
PROCEDURE, PUBLIC, PASS(obj) :: NewmarkBeta => obj_NewmarkBeta
PROCEDURE, PUBLIC, PASS(obj) :: HHTAlpha => obj_HHTAlpha
PROCEDURE, PUBLIC, PASS(obj) :: Collocation => obj_Collocation
! PROCEDURE, PUBLIC, PASS(obj) :: Houbolt => obj_Houbolt
PROCEDURE, PASS(obj) :: ImportFromToml1 => obj_ImportFromToml1
PROCEDURE, PASS(obj) :: ImportFromToml2 => obj_ImportFromToml2
GENERIC, PUBLIC :: ImportFromToml => ImportFromToml1, ImportFromToml2
Expand Down Expand Up @@ -159,6 +165,8 @@ SUBROUTINE obj_NewmarkBeta(obj, beta, gamma)
obj%rhs_a1(1) = -(beta0 - 0.5_DFP)
obj%rhs_a1(2) = -(beta0 - gamma0 * 0.5_DFP)

obj%dis(4) = 1.0_DFP

obj%vel(1) = -gamma0 * beta_inv
obj%vel(2) = 1.0_DFP - gamma0 * beta_inv
obj%vel(3) = 1.0_DFP - gamma0 * beta_inv * 0.5_DFP
Expand All @@ -173,6 +181,116 @@ SUBROUTINE obj_NewmarkBeta(obj, beta, gamma)

END SUBROUTINE obj_NewmarkBeta

!----------------------------------------------------------------------------
! HHTAlpha
!----------------------------------------------------------------------------

SUBROUTINE obj_HHTAlpha(obj, alpha, beta, gamma)
CLASS(SDAlgoParam_), INTENT(INOUT) :: obj
REAL(DFP), OPTIONAL, INTENT(IN) :: alpha
!! Default -0.30
REAL(DFP), OPTIONAL, INTENT(IN) :: beta
!! Default is (1-alpha)**2/4
REAL(DFP), OPTIONAL, INTENT(IN) :: gamma
!! Default is (1-2alpha)/2

! internal varibales
REAL(DFP) :: alpha0, beta0, gamma0, areal

CALL obj%DEALLOCATE()

alpha0 = Input(default=-0.30_DFP, option=alpha)
areal = (1.0_DFP - alpha0)**2 * 0.25_DFP
beta0 = Input(default=areal, option=beta)
areal = (1.0_DFP - 2.0_DFP * alpha0) * 0.50_DFP
gamma0 = Input(default=areal, option=gamma)

obj%alpha = alpha0

CALL obj%NewmarkBeta(beta=beta0, gamma=gamma0)

obj%tanmat(2) = obj%tanmat(2) * (1.0_DFP + alpha0)
obj%tanmat(3) = obj%tanmat(3) * (1.0_DFP + alpha0)

obj%rhs_u1(2) = obj%rhs_u1(2) * (1.0_DFP + alpha0)
obj%rhs_u1(3) = alpha0 * beta0

obj%rhs_v1(2) = obj%rhs_v1(2) * (1.0_DFP + alpha0) &
& + alpha0 * beta0

obj%rhs_a1(2) = obj%rhs_a1(2) * (1.0_DFP + alpha0)

CALL obj%MakeZeros()

END SUBROUTINE obj_HHTAlpha

!----------------------------------------------------------------------------
! Collocation
!----------------------------------------------------------------------------

SUBROUTINE obj_Collocation(obj, beta, gamma, theta)
CLASS(SDAlgoParam_), INTENT(INOUT) :: obj
REAL(DFP), OPTIONAL, INTENT(IN) :: beta
!! Default is 1/6
REAL(DFP), OPTIONAL, INTENT(IN) :: gamma
!! Default is 0.50
REAL(DFP), OPTIONAL, INTENT(IN) :: theta
!! Default is 1.4 (Wilson theta)

! internal varibales
REAL(DFP) :: theta0, beta0, gamma0, areal

CALL obj%DEALLOCATE()

beta0 = Input(default=1.0_DFP / 6.0_DFP, option=beta)
gamma0 = Input(default=0.50_DFP, option=gamma)
theta0 = Input(default=1.4_DFP, option=theta)

CALL obj%NewmarkBeta(beta=beta0, gamma=gamma0)

obj%tanmat(2) = obj%tanmat(2) * theta0
obj%tanmat(3) = obj%tanmat(3) * theta0**2

obj%rhs_f2 = obj%rhs_f2 * theta0**2

obj%rhs_u1(2) = obj%rhs_u1(2) * theta0

obj%rhs_v1(1) = obj%rhs_v1(1) * theta0
obj%rhs_v1(2) = obj%rhs_v1(2) * theta0**2

obj%rhs_a1(1) = obj%rhs_a1(1) * theta0**2
obj%rhs_a1(2) = obj%rhs_a1(2) * theta0**3

obj%dis(1) = 1.0_DFP - 1.0_DFP / theta0**3
obj%dis(2) = 1.0_DFP - 1.0_DFP / theta0**2
obj%dis(3) = (1.0_DFP - 1.0_DFP / theta0) * 0.50_DFP
obj%dis(4) = 1.0_DFP / theta0**3

obj%vel(1) = obj%vel(1) / theta0**3
obj%vel(2) = 1.0_DFP - gamma0 / (theta0**2 * beta0)
obj%vel(3) = 1.0_DFP - gamma0 / (2.0_DFP * theta0 * beta0)
obj%vel(4) = obj%vel(4) / theta0**3

obj%acc(1) = obj%acc(1) / theta0**3
obj%acc(2) = obj%acc(2) / theta0**2
obj%acc(3) = 1.0_DFP - 1.0_DFP / (2.0_DFP * theta0 * beta0)
obj%acc(4) = obj%acc(4) / theta0**3

CALL obj%MakeZeros()

END SUBROUTINE obj_Collocation

!----------------------------------------------------------------------------
! Houbolt
!----------------------------------------------------------------------------

SUBROUTINE obj_Houbolt(obj)
CLASS(SDAlgoParam_), INTENT(INOUT) :: obj
CHARACTER(*), PARAMETER :: myName = "Houbolt"
CALL e%RaiseError(modName//'::'//myName//' - '// &
& '[WIP] not implemented yet')
END SUBROUTINE obj_Houbolt

!----------------------------------------------------------------------------
!
!----------------------------------------------------------------------------
Expand Down Expand Up @@ -229,6 +347,9 @@ SUBROUTINE obj_Display(obj, msg, unitno)
CALL Display(obj%rhs_f2, "rhs_f2: ", unitno=unitno, advance="NO")
CALL Display(obj%rhs_f2_zero, "rhs_f2_zero: ", unitno=unitno)

CALL BlankLines(unitno=unitno)
CALL Display(obj%alpha, "alpha: ", unitno=unitno, advance="NO")

CALL BlankLines(unitno=unitno)
CALL Display(obj%dis, "dis: ", unitno=unitno, advance="NO")
CALL Display(obj%dis_zero, "dis_zero: ", unitno=unitno)
Expand Down Expand Up @@ -274,6 +395,8 @@ SUBROUTINE obj_Deallocate(obj)
obj%vel_zero = .TRUE.
obj%acc_zero = .TRUE.

obj%alpha = 0.0_DFP

END SUBROUTINE obj_Deallocate

!----------------------------------------------------------------------------
Expand All @@ -287,7 +410,7 @@ SUBROUTINE obj_ImportFromToml1(obj, table)
CHARACTER(*), PARAMETER :: myName = "obj_ImportFromToml1()"
TYPE(toml_table), POINTER :: node, node2
INTEGER(I4B) :: origin, stat
REAL(DFP) :: beta, gamma
REAL(DFP) :: alpha, beta, gamma, theta, areal
CHARACTER(:), ALLOCATABLE :: str1, algorithm
LOGICAL(LGT) :: problem

Expand Down Expand Up @@ -330,6 +453,48 @@ SUBROUTINE obj_ImportFromToml1(obj, table)
END IF
CALL obj%NewmarkBeta(beta=beta, gamma=gamma)

CASE ("HHTALPHA")

CALL toml_get(table, algorithm, node, origin=origin, requested=.FALSE., &
& stat=stat)

IF (.NOT. ASSOCIATED(node)) THEN
alpha = -0.30_DFP
beta = (1.0_DFP - alpha)**2 * 0.25_DFP
gamma = (1.0_DFP - 2.0_DFP * alpha) * 0.50_DFP
ELSE
CALL toml_get(node, "alpha", alpha, -0.30_DFP, &
& origin=origin, stat=stat)
areal = (1.0_DFP - alpha)**2 * 0.25_DFP
CALL toml_get(node, "beta", beta, areal, &
& origin=origin, stat=stat)
areal = (1.0_DFP - 2.0_DFP * alpha) * 0.50_DFP
CALL toml_get(node, "gamma", gamma, areal, &
& origin=origin, stat=stat)
END IF

CALL obj%HHTAlpha(alpha=alpha, beta=beta, gamma=gamma)

CASE ("COLLOCATION")

CALL toml_get(table, algorithm, node, origin=origin, requested=.FALSE., &
& stat=stat)

IF (.NOT. ASSOCIATED(node)) THEN
beta = 1.0_DFP / 6.0_DFP
gamma = 0.50_DFP
theta = 1.4_DFP
ELSE
CALL toml_get(node, "beta", beta, 1.0_DFP / 6.0_DFP, &
& origin=origin, stat=stat)
CALL toml_get(node, "gamma", gamma, 0.50_DFP, &
& origin=origin, stat=stat)
CALL toml_get(node, "theta", theta, 1.4_DFP, &
& origin=origin, stat=stat)
END IF

CALL obj%Collocation(beta=beta, gamma=gamma, theta=theta)

CASE DEFAULT
node => NULL()
CALL toml_get(table, algorithm, node, origin=origin, requested=.FALSE., &
Expand Down Expand Up @@ -361,6 +526,10 @@ SUBROUTINE obj_ImportFromToml1(obj, table)

IF (.NOT. ASSOCIATED(node2)) THEN
obj%rhs_u1 = 0.0_DFP
obj%rhs_v1 = 0.0_DFP
obj%rhs_a1 = 0.0_DFP
obj%rhs_f1 = 0.0_DFP
obj%rhs_f2 = 0.0_DFP
ELSE

CALL toml_get(node2, "MU", obj%rhs_u1(1), 0.0_DFP, origin=origin, &
Expand Down Expand Up @@ -397,6 +566,9 @@ SUBROUTINE obj_ImportFromToml1(obj, table)
& stat=stat)
END IF

CALL toml_get(node, "alpha", obj%alpha, 0.0_DFP, origin=origin, &
& stat=stat)

CALL toml_get(node, "dis", node2, origin=origin, requested=.FALSE., &
& stat=stat)

Expand Down
8 changes: 8 additions & 0 deletions src/modules/AbstractMesh/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,14 @@ target_sources(
${src_path}/NodeData_Class.F90
${src_path}/NodeDataList_Class.F90
${src_path}/NodeDataBinaryTree_Class.F90
${src_path}/EdgeData_Class.F90
${src_path}/EdgeDataList_Class.F90
${src_path}/EdgeDataBinaryTree_Class.F90
${src_path}/EdgeDataBinaryTreeUtility.F90
${src_path}/FaceData_Class.F90
${src_path}/FaceDataList_Class.F90
${src_path}/FaceDataBinaryTree_Class.F90
${src_path}/FaceDataBinaryTreeUtility.F90
${src_path}/ElemData_Class.F90
${src_path}/ElemDataList_Class.F90
${src_path}/ElemDataBinaryTree_Class.F90
Expand Down
Loading

0 comments on commit 0c50932

Please sign in to comment.