Skip to content

Commit

Permalink
Added the option to save the Gmsh background mesh in .pos ( point clo…
Browse files Browse the repository at this point in the history
…ud) format.
  • Loading branch information
tapegoji committed Oct 25, 2024
1 parent f89cdc5 commit 93d7a3b
Showing 1 changed file with 62 additions and 16 deletions.
78 changes: 62 additions & 16 deletions fem/src/Adaptive.F90
Original file line number Diff line number Diff line change
Expand Up @@ -116,14 +116,17 @@ END FUNCTION InsideResidual

LOGICAL :: BandwidthOptimize, Found, Coarsening, GlobalBubbles, &
MeshNumbering, DoFinalRef
INTEGER :: MaxDepth, MinDepth, NLen
INTEGER :: MaxDepth, MinDepth, NLen, MeshDim
CHARACTER(:), ALLOCATABLE :: Path, VarName
REAL(KIND=dp), POINTER :: Time(:), NodalError(:), PrevValues(:), &
Hvalue(:), HValue1(:), PrevNodalError(:), PrevHValue(:), hConvergence(:), ptr(:), tt(:)
REAL(KIND=dp), POINTER :: ErrorIndicator(:), eRef(:), hRef(:), Work(:)
LOGICAL :: NoInterp, Parallel, AdaptiveOutput, AdaptInit
TYPE(ValueList_t), POINTER :: Params
CHARACTER(*), PARAMETER :: Caller = 'RefineMesh'
REAL(KIND=dp), POINTER :: Wrk(:,:)
REAL(KIND=dp) :: CoordScale(3)



SAVE DoFinalRef
Expand Down Expand Up @@ -1285,6 +1288,7 @@ FUNCTION External_ReMesh( RefMesh, ErrorLimit, HValue, NodalError, &
REAL(KIND=dp), POINTER :: HValueF(:)
CHARACTER(:), ALLOCATABLE :: MeshCommand, Name, MeshInputFile
LOGICAL :: GmshFormat
LOGICAL :: GmshPosFormat
!------------------------------------------------------------------------------

dim = CoordinateSystemDimension()
Expand Down Expand Up @@ -1329,23 +1333,63 @@ FUNCTION External_ReMesh( RefMesh, ErrorLimit, HValue, NodalError, &
GmshFormat = ListGetLogical( Params,'Adaptive Remesh Use Gmsh', Found )

IF( GmshFormat ) THEN
CALL Info( Caller,'Saving background mesh density in gmsh 2.0 (.msh) format' )

! A cludge to change the pointer and save results in Gmsh format.
BLOCK
REAL(KIND=dp), POINTER :: PtoHvalue(:)
TYPE(Variable_t), POINTER :: HVar
HVar => VariableGet( RefMesh % Variables,'Hvalue')
pToHvalue => HVar % Values
HVar % Values => HvalueF
CALL ListAddString(Solver % Values,'Scalar Field 1','Hvalue')
CALL ListAddLogical(Solver % Values,'File Append',.FALSE.)
CALL ListAddLogical(Solver % Values,'Alter Topology',.TRUE.)
CALL ListAddNewString(Solver % Values, 'Output File Name', 'gmsh_bgmesh.msh')
CALL SaveGmshOutput( Model,Solver,0.0_dp,.FALSE.)
HVar % Values => PtoHvalue
END BLOCK
GmshPosFormat = ListGetLogical( Params,'Adaptive Remesh Gmsh Use Pos Format', Found )
! write the bacground mesh in .pos format if user requested it.
IF( GmshPosFormat) THEN

! Get the coordinate scaling. This is used to scale the background mesh coordinates according to the original mesh.
MeshDim = RefMesh % MaxDim

Wrk => ListGetConstRealArray( Model % Simulation,'Coordinate Scaling',Found )
CoordScale = 1.0_dp
IF( Found ) THEN
DO i=1, MeshDim
j = MIN( i, SIZE(Wrk,1) )
CoordScale(i) = Wrk(j,1)
END DO
WRITE(Message,'(A,3ES10.3)') 'Scaling the background mesh coordinates:',CoordScale(1:3)
CALL Info(Caller ,Message, Level=10)
END IF

! write the bacground mesh in .pos format
CALL Info( Caller,'Saving background mesh density in gmsh .pos format' )
OPEN( 11, STATUS='UNKNOWN',FILE='gmsh_bgmesh.pos' )
WRITE( 11,* ) 'View "mesh size field" {'
DO i=1,RefMesh % NumberOfNodes
IF(.NOT. (HValueF(i) > 0.0_dp )) CYCLE
IF (dim == 2 ) THEN
WRITE( 11,* ) 'SP(', (RefMesh % Nodes % x(i)) / CoordScale(1), &
', ', (RefMesh % Nodes % y(i)) / CoordScale(2), ') {', &
HValueF(i) / MIN(CoordScale(1), CoordScale(2)), '};'
ELSE
WRITE( 11,* ) 'SP(', (RefMesh % Nodes % x(i)) / CoordScale(1), &
', ', (RefMesh % Nodes % y(i)) / CoordScale(2), &
', ', (RefMesh % Nodes % z(i)) / CoordScale(3), ') {', &
HValueF(i) / MIN(CoordScale(1), MIN(CoordScale(2), CoordScale(3))), '};'
END IF
END DO
WRITE( 11,* ) '};'
CLOSE(11)
ELSE

CALL Info( Caller,'Saving background mesh density in gmsh 2.0 (.msh) format' )

! A cludge to change the pointer and save results in Gmsh format.
BLOCK
REAL(KIND=dp), POINTER :: PtoHvalue(:)
TYPE(Variable_t), POINTER :: HVar
HVar => VariableGet( RefMesh % Variables,'Hvalue')
pToHvalue => HVar % Values
HVar % Values => HvalueF
CALL ListAddString(Solver % Values,'Scalar Field 1','Hvalue')
CALL ListAddLogical(Solver % Values,'File Append',.FALSE.)
CALL ListAddLogical(Solver % Values,'Alter Topology',.TRUE.)
CALL ListAddNewString(Solver % Values, 'Output File Name', 'gmsh_bgmesh.msh')
CALL SaveGmshOutput( Model,Solver,0.0_dp,.FALSE.)
HVar % Values => PtoHvalue
END BLOCK
END IF
ELSE
CALL Info( Caller,'Saving background mesh density in point cloud format' )

Expand Down Expand Up @@ -1405,6 +1449,8 @@ FUNCTION External_ReMesh( RefMesh, ErrorLimit, HValue, NodalError, &
! Check if also conversion command is given.
MeshCommand = ListGetString( Solver % Values,'Mesh Conversion Command',Found)
IF( Found ) THEN
! add the output path to the command.
MeshCommand = MeshCommand // ' -out ' // TRIM(Path)
CALL Info('ReMesh','Conversion command: '//TRIM(MeshCommand),Level=10)
CALL SystemCommand( MeshCommand )
END IF
Expand Down

0 comments on commit 93d7a3b

Please sign in to comment.