polishing

This commit is contained in:
Martin Diehl 2021-06-15 19:38:01 +02:00
parent 218e6a79a8
commit 1bfbd30ae2
4 changed files with 41 additions and 38 deletions

View File

@ -3,6 +3,7 @@ stages:
- prepare - prepare
- python - python
- compile - compile
- setup
- fortran - fortran
- performance - performance
- deploy - deploy
@ -161,8 +162,10 @@ compile_Marc:
- master - master
- release - release
###################################################################################################
setup_grid: setup_grid:
stage: compile stage: setup
script: script:
- module load $IntelCompiler $MPI_Intel $PETSc_Intel - module load $IntelCompiler $MPI_Intel $PETSc_Intel
- BUILD_DIR=$(mktemp -d) - BUILD_DIR=$(mktemp -d)
@ -174,7 +177,7 @@ setup_grid:
- release - release
setup_mesh: setup_mesh:
stage: compile stage: setup
script: script:
- module load $IntelCompiler $MPI_Intel $PETSc_Intel - module load $IntelCompiler $MPI_Intel $PETSc_Intel
- BUILD_DIR=$(mktemp -d) - BUILD_DIR=$(mktemp -d)

View File

@ -1,8 +1,8 @@
import os
import copy import copy
import warnings
import multiprocessing as mp import multiprocessing as mp
from functools import partial from functools import partial
import os
import warnings
import numpy as np import numpy as np
import pandas as pd import pandas as pd
@ -20,7 +20,7 @@ class Grid:
Geometry definition for grid solvers. Geometry definition for grid solvers.
Create and manipulate geometry definitions for storage as VTK Create and manipulate geometry definitions for storage as VTK
image data files ('.vit' extension). A grid contains the image data files ('.vti' extension). A grid contains the
material ID (referring to the entry in 'material.yaml') and material ID (referring to the entry in 'material.yaml') and
the physical size. the physical size.
""" """
@ -166,9 +166,7 @@ class Grid:
Grid-based geometry from file. Grid-based geometry from file.
""" """
if str(fname).endswith('.vtr'): v = VTK.load(fname if str(fname).endswith('.vti') else str(fname)+'.vti')
warnings.warn('Support for vtr files will be removed in DAMASK 3.1.0', DeprecationWarning,2)
v = VTK.load(fname)
comments = v.get_comments() comments = v.get_comments()
cells = np.array(v.vtk_data.GetDimensions())-1 cells = np.array(v.vtk_data.GetDimensions())-1
bbox = np.array(v.vtk_data.GetBounds()).reshape(3,2).T bbox = np.array(v.vtk_data.GetBounds()).reshape(3,2).T

View File

@ -1,4 +1,5 @@
import os import os
import warnings
import multiprocessing as mp import multiprocessing as mp
from pathlib import Path from pathlib import Path
@ -69,8 +70,6 @@ class VTK:
""" """
Create VTK of type vtk.vtkRectilinearGrid. Create VTK of type vtk.vtkRectilinearGrid.
This is the common type for grid solver results.
Parameters Parameters
---------- ----------
grid : iterable of int, len (3) grid : iterable of int, len (3)
@ -86,6 +85,7 @@ class VTK:
VTK-based geometry without nodal or cell data. VTK-based geometry without nodal or cell data.
""" """
warnings.warn('Support for vtr files will be removed in DAMASK 3.1.0', DeprecationWarning,2)
vtk_data = vtk.vtkRectilinearGrid() vtk_data = vtk.vtkRectilinearGrid()
vtk_data.SetDimensions(*(np.array(grid)+1)) vtk_data.SetDimensions(*(np.array(grid)+1))
coord = [np_to_vtk(np.linspace(origin[i],origin[i]+size[i],grid[i]+1),deep=True) for i in [0,1,2]] coord = [np_to_vtk(np.linspace(origin[i],origin[i]+size[i],grid[i]+1),deep=True) for i in [0,1,2]]
@ -179,8 +179,8 @@ class VTK:
Parameters Parameters
---------- ----------
fname : str or pathlib.Path fname : str or pathlib.Path
Filename for reading. Valid extensions are .vtr, .vtu, .vtp, and .vtk. Filename for reading. Valid extensions are .vti, .vtr, .vtu, .vtp, and .vtk.
dataset_type : {'vtkRectilinearGrid', 'vtkUnstructuredGrid', 'vtkPolyData'}, optional dataset_type : {'vtkImageData', ''vtkRectilinearGrid', 'vtkUnstructuredGrid', 'vtkPolyData'}, optional
Name of the vtk.vtkDataSet subclass when opening a .vtk file. Name of the vtk.vtkDataSet subclass when opening a .vtk file.
Returns Returns

View File

@ -164,9 +164,9 @@ subroutine readVTI(grid,geomSize,origin,material)
integer, dimension(:), intent(out), allocatable :: & integer, dimension(:), intent(out), allocatable :: &
material material
character(len=:), allocatable :: fileContent, dataType, headerType, temp character(len=:), allocatable :: fileContent, dataType, headerType
logical :: inFile,inGrid,gotCoordinates,gotCellData,compressed logical :: inFile,inImage,gotCellData,compressed
integer :: fileUnit, myStat, coord integer :: fileUnit, myStat
integer(pI64) :: & integer(pI64) :: &
fileLength, & !< length of the geom file (in characters) fileLength, & !< length of the geom file (in characters)
startPos, endPos, & startPos, endPos, &
@ -186,39 +186,37 @@ subroutine readVTI(grid,geomSize,origin,material)
close(fileUnit) close(fileUnit)
inFile = .false. inFile = .false.
inGrid = .false. inImage = .false.
gotCoordinates = .false.
gotCelldata = .false. gotCelldata = .false.
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
! interpret XML file ! parse XML file
startPos = 1_pI64 startPos = 1_pI64
do while (startPos < len(fileContent,kind=pI64)) do while (startPos < len(fileContent,kind=pI64))
endPos = startPos + index(fileContent(startPos:),IO_EOL,kind=pI64) - 2_pI64 endPos = startPos + index(fileContent(startPos:),IO_EOL,kind=pI64) - 2_pI64
if (endPos < startPos) endPos = len(fileContent,kind=pI64) ! end of file without new line if (endPos < startPos) endPos = len(fileContent,kind=pI64) ! end of file without new line
if(.not. inFile) then if (.not. inFile) then
if(index(fileContent(startPos:endPos),'<VTKFile',kind=pI64) /= 0_pI64) then if(index(fileContent(startPos:endPos),'<VTKFile',kind=pI64) /= 0_pI64) then
inFile = .true. inFile = .true.
if(.not. fileFormatOk(fileContent(startPos:endPos))) call IO_error(error_ID = 844, ext_msg='file format') if (.not. fileFormatOk(fileContent(startPos:endPos))) call IO_error(error_ID = 844, ext_msg='file format')
headerType = merge('UInt64','UInt32',getXMLValue(fileContent(startPos:endPos),'header_type')=='UInt64') headerType = merge('UInt64','UInt32',getXMLValue(fileContent(startPos:endPos),'header_type')=='UInt64')
compressed = getXMLValue(fileContent(startPos:endPos),'compressor') == 'vtkZLibDataCompressor' compressed = getXMLValue(fileContent(startPos:endPos),'compressor') == 'vtkZLibDataCompressor'
endif endif
else else
if (.not. inGrid) then if (.not. inImage) then
if (index(fileContent(startPos:endPos),'<ImageData',kind=pI64) /= 0_pI64) then if (index(fileContent(startPos:endPos),'<ImageData',kind=pI64) /= 0_pI64) then
inGrid = .true. inImage = .true.
print*, 'x' call cellsSizeOrigin(grid,geomSize,origin,fileContent(startPos:endPos))
call cellsSizeOrigin(fileContent(startPos:endPos))
endif endif
else else
if(index(fileContent(startPos:endPos),'<CellData>',kind=pI64) /= 0_pI64) then if (index(fileContent(startPos:endPos),'<CellData>',kind=pI64) /= 0_pI64) then
gotCellData = .true. gotCellData = .true.
do while (index(fileContent(startPos:endPos),'</CellData>',kind=pI64) == 0_pI64) do while (index(fileContent(startPos:endPos),'</CellData>',kind=pI64) == 0_pI64)
if(index(fileContent(startPos:endPos),'<DataArray',kind=pI64) /= 0_pI64 .and. & if (index(fileContent(startPos:endPos),'<DataArray',kind=pI64) /= 0_pI64 .and. &
getXMLValue(fileContent(startPos:endPos),'Name') == 'material' ) then getXMLValue(fileContent(startPos:endPos),'Name') == 'material' ) then
if(getXMLValue(fileContent(startPos:endPos),'format') /= 'binary') & if (getXMLValue(fileContent(startPos:endPos),'format') /= 'binary') &
call IO_error(error_ID = 844, ext_msg='format (material)') call IO_error(error_ID = 844, ext_msg='format (material)')
dataType = getXMLValue(fileContent(startPos:endPos),'type') dataType = getXMLValue(fileContent(startPos:endPos),'type')
@ -235,7 +233,7 @@ subroutine readVTI(grid,geomSize,origin,material)
endif endif
endif endif
if(gotCellData .and. gotCoordinates) exit if (gotCellData) exit
startPos = endPos + 2_pI64 startPos = endPos + 2_pI64
end do end do
@ -245,19 +243,21 @@ subroutine readVTI(grid,geomSize,origin,material)
if(any(geomSize<=0)) call IO_error(error_ID = 844, ext_msg='size') if(any(geomSize<=0)) call IO_error(error_ID = 844, ext_msg='size')
if(any(grid<1)) call IO_error(error_ID = 844, ext_msg='grid') if(any(grid<1)) call IO_error(error_ID = 844, ext_msg='grid')
material = material + 1 material = material + 1
if(any(material<0)) call IO_error(error_ID = 844, ext_msg='material ID < 0') if(any(material<1)) call IO_error(error_ID = 844, ext_msg='material ID < 0')
contains contains
!------------------------------------------------------------------------------------------------ !------------------------------------------------------------------------------------------------
!> @brief determine size and origin from coordinates !> @brief determine size and origin from coordinates
!------------------------------------------------------------------------------------------------ !------------------------------------------------------------------------------------------------
subroutine cellsSizeOrigin(header) subroutine cellsSizeOrigin(c,s,o,header)
character(len=*), intent(in) :: header integer, dimension(3), intent(out) :: c
real(pReal), dimension(3), intent(out) :: s,o
character(len=*), intent(in) :: header
character(len=:), allocatable :: temp character(len=:), allocatable :: temp
real(pReal), dimension(:), allocatable :: coords,delta,origin real(pReal), dimension(:), allocatable :: delta
integer, dimension(:), allocatable :: stringPos integer, dimension(:), allocatable :: stringPos
integer :: i integer :: i
@ -265,15 +265,17 @@ subroutine readVTI(grid,geomSize,origin,material)
if (getXMLValue(header,'Direction') /= '1 0 0 0 1 0 0 0 1') & if (getXMLValue(header,'Direction') /= '1 0 0 0 1 0 0 0 1') &
call IO_error(error_ID = 844, ext_msg = 'coordinate order') call IO_error(error_ID = 844, ext_msg = 'coordinate order')
temp = getXMLValue(header,'Origin') temp = getXMLValue(header,'WholeExtent')
origin = [(IO_floatValue(temp,IO_stringPos(temp),i),i=1,3)] if (any([(IO_floatValue(temp,IO_stringPos(temp),i),i=1,5,2)] /= 0)) &
call IO_error(error_ID = 844, ext_msg = 'coordinate start')
c = [(IO_floatValue(temp,IO_stringPos(temp),i),i=2,6,2)]
temp = getXMLValue(header,'Spacing') temp = getXMLValue(header,'Spacing')
delta = [(IO_floatValue(temp,IO_stringPos(temp),i),i=1,3)] delta = [(IO_floatValue(temp,IO_stringPos(temp),i),i=1,3)]
temp = getXMLValue(header,'WholeExtent') s = delta * real(c,pReal)
grid = [(IO_floatValue(temp,IO_stringPos(temp),i),i=2,6,2)]
temp = getXMLValue(header,'Origin')
geomSize = delta * real(grid,pReal) o = [(IO_floatValue(temp,IO_stringPos(temp),i),i=1,3)]
end subroutine end subroutine