From c6c1878b13be5dfff792707109584931ba2b1614 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 12 Apr 2020 15:19:32 +0200 Subject: [PATCH 001/136] asterisk is the emphasize sign for restructured text not really needed here --- python/damask/_vtk.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/python/damask/_vtk.py b/python/damask/_vtk.py index 4505a5ebc..58b43dc1f 100644 --- a/python/damask/_vtk.py +++ b/python/damask/_vtk.py @@ -120,9 +120,9 @@ class VTK: Parameters ---------- fname : str - Filename for reading. Valid extensions are *.vtr, *.vtu, *.vtp, and *.vtk. + Filename for reading. Valid extensions are .vtr, .vtu, .vtp, and .vtk. dataset_type : str, optional - Name of the vtk.vtkDataSet subclass when opening an *.vtk file. Valid types are vtkRectilinearGrid, + Name of the vtk.vtkDataSet subclass when opening an .vtk file. Valid types are vtkRectilinearGrid, vtkUnstructuredGrid, and vtkPolyData. """ From b6b98bd14f56fadaae4796fcfdbd582db1cd0497 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 12 Apr 2020 15:20:09 +0200 Subject: [PATCH 002/136] more meaningful --- python/damask/__init__.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/python/damask/__init__.py b/python/damask/__init__.py index 9a01e8e62..0f343a581 100644 --- a/python/damask/__init__.py +++ b/python/damask/__init__.py @@ -1,4 +1,4 @@ -"""Main aggregator.""" +"""Tools for pre and post processing of DAMASK simulations.""" import os as _os import re as _re From aaeec16c66b4729b3d5ddec147bccbbc29535b6a Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 12 Apr 2020 15:34:29 +0200 Subject: [PATCH 003/136] proper indentation for sphinx --- python/damask/_orientation.py | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/python/damask/_orientation.py b/python/damask/_orientation.py index 76475e057..aa1ba06ef 100644 --- a/python/damask/_orientation.py +++ b/python/damask/_orientation.py @@ -8,8 +8,8 @@ class Orientation: Crystallographic orientation. A crystallographic orientation contains a rotation and a lattice. - """ + """ __slots__ = ['rotation','lattice'] def __repr__(self): @@ -46,8 +46,10 @@ class Orientation: Disorientation between myself and given other orientation. Rotation axis falls into SST if SST == True. - (Currently requires same symmetry for both orientations. - Look into A. Heinz and P. Neumann 1991 for cases with differing sym.) + + Currently requires same symmetry for both orientations. + Look into A. Heinz and P. Neumann 1991 for cases with differing sym. + """ if self.lattice.symmetry != other.lattice.symmetry: raise NotImplementedError('disorientation between different symmetry classes not supported yet.') From 93c75cada3b872775c78b433452cd9dfd8aefd78 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 12 Apr 2020 15:38:38 +0200 Subject: [PATCH 004/136] numpydoc style --- python/damask/_rotation.py | 39 +++++++++++++++++++------------------- 1 file changed, 19 insertions(+), 20 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index bea7aa5e6..e730ed845 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -11,33 +11,32 @@ def iszero(a): class Rotation: u""" Orientation stored with functionality for conversion to different representations. + The following conventions apply: + + - coordinate frames are right-handed. + - a rotation angle ω is taken to be positive for a counterclockwise rotation + when viewing from the end point of the rotation axis towards the origin. + - rotations will be interpreted in the passive sense. + - Euler angle triplets are implemented using the Bunge convention, + with the angular ranges as [0, 2π],[0, π],[0, 2π]. + - the rotation angle ω is limited to the interval [0, π]. + - the real part of a quaternion is positive, Re(q) > 0 + - P = -1 (as default). + + Examples + -------- + Rotate vector "a" (defined in coordinate system "A") to + coordinates "b" expressed in system "B": + + - b = Q * a + - b = np.dot(Q.asMatrix(),a) References ---------- D. Rowenhorst et al., Modelling and Simulation in Materials Science and Engineering 23:083501, 2015 https://doi.org/10.1088/0965-0393/23/8/083501 - Conventions - ----------- - Convention 1: Coordinate frames are right-handed. - Convention 2: A rotation angle ω is taken to be positive for a counterclockwise rotation - when viewing from the end point of the rotation axis towards the origin. - Convention 3: Rotations will be interpreted in the passive sense. - Convention 4: Euler angle triplets are implemented using the Bunge convention, - with the angular ranges as [0, 2π],[0, π],[0, 2π]. - Convention 5: The rotation angle ω is limited to the interval [0, π]. - Convention 6: the real part of a quaternion is positive, Re(q) > 0 - Convention 7: P = -1 (as default). - - Usage - ----- - Vector "a" (defined in coordinate system "A") is passively rotated - resulting in new coordinates "b" when expressed in system "B". - b = Q * a - b = np.dot(Q.asMatrix(),a) - """ - __slots__ = ['quaternion'] def __init__(self,quaternion = np.array([1.0,0.0,0.0,0.0])): From a0b7c51bec64848e74e622d4183b341a2f170ebc Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 22 Apr 2020 23:32:34 +0200 Subject: [PATCH 005/136] less strict tolerances grid position reported by EBSD has only a few decimal places, so rounding errors occur --- python/damask/grid_filters.py | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/python/damask/grid_filters.py b/python/damask/grid_filters.py index d8b136a6b..4181cb7ec 100644 --- a/python/damask/grid_filters.py +++ b/python/damask/grid_filters.py @@ -211,12 +211,13 @@ def cell_coord0_gridSizeOrigin(coord0,ordered=True): start = origin + delta*.5 end = origin - delta*.5 + size - if not _np.allclose(coords[0],_np.linspace(start[0],end[0],grid[0])) and \ - _np.allclose(coords[1],_np.linspace(start[1],end[1],grid[1])) and \ - _np.allclose(coords[2],_np.linspace(start[2],end[2],grid[2])): + atol = 1e-4*_np.max(size) + if not _np.allclose(coords[0],_np.linspace(start[0],end[0],grid[0]),atol=atol) and \ + _np.allclose(coords[1],_np.linspace(start[1],end[1],grid[1]),atol=atol) and \ + _np.allclose(coords[2],_np.linspace(start[2],end[2],grid[2]),atol=atol): raise ValueError('Regular grid spacing violated.') - if ordered and not _np.allclose(coord0.reshape(tuple(grid[::-1])+(3,)),cell_coord0(grid,size,origin)): + if ordered and not _np.allclose(coord0.reshape(tuple(grid[::-1])+(3,)),cell_coord0(grid,size,origin),atol=atol): raise ValueError('Input data is not a regular grid.') return (grid,size,origin) @@ -357,12 +358,13 @@ def node_coord0_gridSizeOrigin(coord0,ordered=False): if (grid+1).prod() != len(coord0): raise ValueError('Data count {} does not match grid {}.'.format(len(coord0),grid)) - if not _np.allclose(coords[0],_np.linspace(mincorner[0],maxcorner[0],grid[0]+1)) and \ - _np.allclose(coords[1],_np.linspace(mincorner[1],maxcorner[1],grid[1]+1)) and \ - _np.allclose(coords[2],_np.linspace(mincorner[2],maxcorner[2],grid[2]+1)): + atol = _np.max(size) + if not _np.allclose(coords[0],_np.linspace(mincorner[0],maxcorner[0],grid[0]+1),atol=atol) and \ + _np.allclose(coords[1],_np.linspace(mincorner[1],maxcorner[1],grid[1]+1),atol=atol) and \ + _np.allclose(coords[2],_np.linspace(mincorner[2],maxcorner[2],grid[2]+1),atol=atol): raise ValueError('Regular grid spacing violated.') - if ordered and not _np.allclose(coord0.reshape(tuple((grid+1)[::-1])+(3,)),node_coord0(grid,size,origin)): + if ordered and not _np.allclose(coord0.reshape(tuple((grid+1)[::-1])+(3,)),node_coord0(grid,size,origin),atol=atol): raise ValueError('Input data is not a regular grid.') return (grid,size,origin) From cc3fa156cfd8dd077e9b02c2d54be3e6d4fcbc54 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Thu, 23 Apr 2020 16:29:20 +0200 Subject: [PATCH 006/136] support change of directory one object has been created --- python/damask/_result.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index a8181b7a1..b2ec4c8d3 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -80,7 +80,7 @@ class Result: 'con_physics': self.con_physics, 'mat_physics': self.mat_physics } - self.fname = fname + self.fname = os.path.abspath(fname) def __repr__(self): From f02c77b6d05c60276d2db0b44d1aa0ee6b905211 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Fri, 24 Apr 2020 20:01:57 +0200 Subject: [PATCH 007/136] more reasonable tolerance still relatively high because ctf files store position with constant number of digits and floating dot. Hence, the precision is very low --- python/damask/grid_filters.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/python/damask/grid_filters.py b/python/damask/grid_filters.py index 4fb1012c0..62e9147f7 100644 --- a/python/damask/grid_filters.py +++ b/python/damask/grid_filters.py @@ -237,8 +237,8 @@ def cell_coord0_gridSizeOrigin(coord0,ordered=True): start = origin + delta*.5 end = origin - delta*.5 + size - - atol = _np.max(size) + + atol = _np.max(size)*5e-2 if not (_np.allclose(coords[0],_np.linspace(start[0],end[0],grid[0]),atol=atol) and \ _np.allclose(coords[1],_np.linspace(start[1],end[1],grid[1]),atol=atol) and \ _np.allclose(coords[2],_np.linspace(start[2],end[2],grid[2]),atol=atol)): @@ -386,7 +386,7 @@ def node_coord0_gridSizeOrigin(coord0,ordered=True): if (grid+1).prod() != len(coord0): raise ValueError('Data count {} does not match grid {}.'.format(len(coord0),grid)) - atol = _np.max(size) + atol = _np.max(size)*5e-2 if not (_np.allclose(coords[0],_np.linspace(mincorner[0],maxcorner[0],grid[0]+1),atol=atol) and \ _np.allclose(coords[1],_np.linspace(mincorner[1],maxcorner[1],grid[1]+1),atol=atol) and \ _np.allclose(coords[2],_np.linspace(mincorner[2],maxcorner[2],grid[2]+1),atol=atol)): From adf5e5e99c8e9132da21bfc586192e3356cb4dc7 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 25 Apr 2020 09:39:34 +0200 Subject: [PATCH 008/136] not supported at the moment --- .../Homogenization_HydrogenFlux_CahnHilliard.config | 3 --- 1 file changed, 3 deletions(-) delete mode 100644 examples/ConfigFiles/Homogenization_HydrogenFlux_CahnHilliard.config diff --git a/examples/ConfigFiles/Homogenization_HydrogenFlux_CahnHilliard.config b/examples/ConfigFiles/Homogenization_HydrogenFlux_CahnHilliard.config deleted file mode 100644 index 62e1d2505..000000000 --- a/examples/ConfigFiles/Homogenization_HydrogenFlux_CahnHilliard.config +++ /dev/null @@ -1,3 +0,0 @@ -hydrogenflux cahnhilliard -initialHydrogenConc 0.0 -(output) hydrogenconc From 7ec1ae977ecd4f5726e59f346cba210639fd181e Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 25 Apr 2020 09:56:51 +0200 Subject: [PATCH 009/136] new names spectral => grid FEM => mesh because there are FEM solvers for both discretizations. old names will be available for a certain time --- Makefile | 4 ++++ src/CMakeLists.txt | 10 +++++----- src/grid/DAMASK_grid.f90 | 4 ++-- src/mesh/DAMASK_mesh.f90 | 4 ++-- 4 files changed, 13 insertions(+), 9 deletions(-) diff --git a/Makefile b/Makefile index 34ce18c52..60cf3b8e0 100644 --- a/Makefile +++ b/Makefile @@ -9,12 +9,16 @@ all: grid mesh processing .PHONY: grid grid: build/grid @(cd build/grid;make -j${DAMASK_NUM_THREADS} all install;) + @rm -f ${DAMASK_ROOT}/bin/DAMASK_spectral > /dev/null || true + @ln -s ${DAMASK_ROOT}/bin/DAMASK_grid ${DAMASK_ROOT}/bin/DAMASK_spectral .PHONY: spectral spectral: grid .PHONY: mesh mesh: build/mesh @(cd build/mesh; make -j${DAMASK_NUM_THREADS} all install;) + @rm -f ${DAMASK_ROOT}/bin/DAMASK_FEM > /dev/null || true + @ln -s ${DAMASK_ROOT}/bin/DAMASK_mesh ${DAMASK_ROOT}/bin/DAMASK_FEM .PHONY: FEM FEM: mesh diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 53c7ffc70..0cb697013 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -17,10 +17,10 @@ if (PROJECT_NAME STREQUAL "damask-grid") file(GLOB grid-sources grid/*.f90) if(NOT CMAKE_BUILD_TYPE STREQUAL "SYNTAXONLY") - add_executable(DAMASK_spectral ${damask-sources} ${grid-sources}) - install (TARGETS DAMASK_spectral RUNTIME DESTINATION bin) + add_executable(DAMASK_grid ${damask-sources} ${grid-sources}) + install (TARGETS DAMASK_grid RUNTIME DESTINATION bin) else() - add_library(DAMASK_spectral OBJECT ${damask-sources} ${grid-sources}) + add_library(DAMASK_grid OBJECT ${damask-sources} ${grid-sources}) exec_program (mktemp OUTPUT_VARIABLE nothing) exec_program (mktemp ARGS -d OUTPUT_VARIABLE black_hole) install (PROGRAMS ${nothing} DESTINATION ${black_hole}) @@ -30,7 +30,7 @@ elseif (PROJECT_NAME STREQUAL "damask-mesh") file(GLOB mesh-sources mesh/*.f90) - add_executable(DAMASK_FEM ${damask-sources} ${mesh-sources}) - install (TARGETS DAMASK_FEM RUNTIME DESTINATION bin) + add_executable(DAMASK_mesh ${damask-sources} ${mesh-sources}) + install (TARGETS DAMASK_mesh RUNTIME DESTINATION bin) endif() diff --git a/src/grid/DAMASK_grid.f90 b/src/grid/DAMASK_grid.f90 index 84dc7cd51..7b3265740 100644 --- a/src/grid/DAMASK_grid.f90 +++ b/src/grid/DAMASK_grid.f90 @@ -6,7 +6,7 @@ !> @details doing cutbacking, forwarding in case of restart, reporting statistics, writing !> results !-------------------------------------------------------------------------------------------------- -program DAMASK_spectral +program DAMASK_grid #include use PETScsys use prec @@ -495,4 +495,4 @@ program DAMASK_spectral call quit(0) ! no complains ;) -end program DAMASK_spectral +end program DAMASK_grid diff --git a/src/mesh/DAMASK_mesh.f90 b/src/mesh/DAMASK_mesh.f90 index 3c9613d73..d36b27c17 100644 --- a/src/mesh/DAMASK_mesh.f90 +++ b/src/mesh/DAMASK_mesh.f90 @@ -6,7 +6,7 @@ !> @details doing cutbacking, reporting statistics, writing !> results !-------------------------------------------------------------------------------------------------- -program DAMASK_FEM +program DAMASK_mesh #include use PetscDM use prec @@ -367,4 +367,4 @@ program DAMASK_FEM call quit(0) ! no complains ;) -end program DAMASK_FEM +end program DAMASK_mesh From 0effa71276ada143e3f097e12f8719b54bb60b04 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 26 Apr 2020 08:36:16 +0200 Subject: [PATCH 010/136] cleaning large alias lists complicate things --- src/DAMASK_interface.f90 | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/DAMASK_interface.f90 b/src/DAMASK_interface.f90 index 00177fb75..dceef0f7f 100644 --- a/src/DAMASK_interface.f90 +++ b/src/DAMASK_interface.f90 @@ -206,7 +206,7 @@ subroutine DAMASK_interface_init write(6,'(a,/)')' Valid command line switches:' write(6,'(a)') ' --geom (-g, --geometry)' write(6,'(a)') ' --load (-l, --loadcase)' - write(6,'(a)') ' --workingdir (-w, --wd, --workingdirectory, -d, --directory)' + write(6,'(a)') ' --workingdir (-w, --wd, --workingdirectory)' write(6,'(a)') ' --restart (-r, --rs)' write(6,'(a)') ' --help (-h)' write(6,'(/,a)')' -----------------------------------------------------------------------' @@ -223,12 +223,12 @@ subroutine DAMASK_interface_init write(6,'(a)') ' directory.' write(6,'(a)') ' For further configuration place "numerics.config"' write(6,'(a)')' and "debug.config" in that directory.' - write(6,'(/,a)')' --restart XX' - write(6,'(a)') ' Reads in increment XX and continues with calculating' - write(6,'(a)') ' increment XX+1 based on this.' + write(6,'(/,a)')' --restart N' + write(6,'(a)') ' Reads in increment N and continues with calculating' + write(6,'(a)') ' increment N+1 based on this.' write(6,'(a)') ' Appends to existing results file' - write(6,'(a)') ' "NameOfGeom_NameOfLoadFile".' - write(6,'(a)') ' Works only if the restart information for increment XX' + write(6,'(a)') ' "NameOfGeom_NameOfLoadFile.hdf5".' + write(6,'(a)') ' Works only if the restart information for increment N' write(6,'(a)') ' is available in the working directory.' write(6,'(/,a)')' -----------------------------------------------------------------------' write(6,'(a)') ' Help:' @@ -239,7 +239,7 @@ subroutine DAMASK_interface_init call get_command_argument(i+1,loadCaseArg) case ('-g', '--geom', '--geometry') call get_command_argument(i+1,geometryArg) - case ('-w', '-d', '--wd', '--directory', '--workingdir', '--workingdirectory') + case ('-w', '--wd', '--workingdir', '--workingdirectory') call get_command_argument(i+1,workingDirArg) case ('-r', '--rs', '--restart') call get_command_argument(i+1,arg) From 6864b9525da3eda1b4986ca31098e7a0fa1ab369 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 26 Apr 2020 14:52:27 +0200 Subject: [PATCH 011/136] go back to original dir as soon as possible --- python/damask/util.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/python/damask/util.py b/python/damask/util.py index d45ea366e..cb1d8757d 100644 --- a/python/damask/util.py +++ b/python/damask/util.py @@ -112,8 +112,8 @@ def execute(cmd, """ initialPath = os.getcwd() - os.chdir(wd) myEnv = os.environ if env is None else env + os.chdir(wd) process = subprocess.Popen(shlex.split(cmd), stdout = subprocess.PIPE, stderr = subprocess.PIPE, @@ -121,9 +121,9 @@ def execute(cmd, env = myEnv) out,error = [i for i in (process.communicate() if streamIn is None else process.communicate(streamIn.read().encode('utf-8')))] + os.chdir(initialPath) out = out.decode('utf-8').replace('\x08','') error = error.decode('utf-8').replace('\x08','') - os.chdir(initialPath) if process.returncode != 0: raise RuntimeError('{} failed with returncode {}'.format(cmd,process.returncode)) return out,error From 9565f15415c7b9913c1f89e334481a21be767718 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 28 Apr 2020 10:30:03 +0200 Subject: [PATCH 012/136] clearer description --- src/HDF5_utilities.f90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/HDF5_utilities.f90 b/src/HDF5_utilities.f90 index 66705cc3f..a0c3b4e81 100644 --- a/src/HDF5_utilities.f90 +++ b/src/HDF5_utilities.f90 @@ -81,7 +81,7 @@ contains !-------------------------------------------------------------------------------------------------- -!> @brief open libary and do sanity checks +!> @brief initialize HDF5 libary and do sanity checks !-------------------------------------------------------------------------------------------------- subroutine HDF5_utilities_init From d99c05860e940238e15ea1e4d154c87b011912b7 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 28 Apr 2020 10:35:43 +0200 Subject: [PATCH 013/136] FEM is now Mesh --- CMakeLists.txt | 2 +- src/CPFEM2.f90 | 6 +++--- src/numerics.f90 | 10 +++++----- 3 files changed, 9 insertions(+), 9 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index f6870137f..99807ed72 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -110,7 +110,7 @@ if (DAMASK_SOLVER STREQUAL "grid") message ("Building Grid Solver\n") elseif (DAMASK_SOLVER STREQUAL "fem" OR DAMASK_SOLVER STREQUAL "mesh") project (damask-mesh Fortran C) - add_definitions (-DFEM) + add_definitions (-DMesh) message ("Building Mesh Solver\n") else () message (FATAL_ERROR "Build target (DAMASK_SOLVER) is not defined") diff --git a/src/CPFEM2.f90 b/src/CPFEM2.f90 index 357bcce9f..dea500900 100644 --- a/src/CPFEM2.f90 +++ b/src/CPFEM2.f90 @@ -21,7 +21,7 @@ module CPFEM2 use homogenization use constitutive use crystallite -#if defined(FEM) +#if defined(Mesh) use FEM_quadrature use discretization_mesh #elif defined(Grid) @@ -42,7 +42,7 @@ subroutine CPFEM_initAll call DAMASK_interface_init ! Spectral and FEM interface to commandline call prec_init call IO_init -#ifdef FEM +#ifdef Mesh call FEM_quadrature_init #endif call numerics_init @@ -53,7 +53,7 @@ subroutine CPFEM_initAll call lattice_init call HDF5_utilities_init call results_init -#if defined(FEM) +#if defined(Mesh) call discretization_mesh_init #elif defined(Grid) call discretization_grid_init diff --git a/src/numerics.f90 b/src/numerics.f90 index 8d242c71d..b0163aee3 100644 --- a/src/numerics.f90 +++ b/src/numerics.f90 @@ -63,8 +63,8 @@ module numerics #endif !-------------------------------------------------------------------------------------------------- -! FEM parameters: -#ifdef FEM +! Mesh parameters: +#ifdef Mesh integer, protected, public :: & integrationOrder = 2, & !< order of quadrature rule required structOrder = 2 !< order of displacement shape functions @@ -200,8 +200,8 @@ subroutine numerics_init #endif !-------------------------------------------------------------------------------------------------- -! FEM parameters -#ifdef FEM +! Mesh parameters +#ifdef Mesh case ('integrationorder') integrationorder = IO_intValue(line,chunkPos,2) case ('structorder') @@ -267,7 +267,7 @@ subroutine numerics_init !-------------------------------------------------------------------------------------------------- ! spectral parameters -#ifdef FEM +#ifdef Mesh write(6,'(a24,1x,i8)') ' integrationOrder: ',integrationOrder write(6,'(a24,1x,i8)') ' structOrder: ',structOrder write(6,'(a24,1x,L8)') ' B-Bar stabilisation: ',BBarStabilisation From 81b3dc74d559e67a53772daea63961a1945d185d Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 28 Apr 2020 19:07:17 +0200 Subject: [PATCH 014/136] default value needed (fcc/bcc) thanks to Richard (TU Delft) and Vitesh for reporting --- src/constitutive_plastic_phenopowerlaw.f90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/constitutive_plastic_phenopowerlaw.f90 b/src/constitutive_plastic_phenopowerlaw.f90 index 12a30478a..fa273cbd3 100644 --- a/src/constitutive_plastic_phenopowerlaw.f90 +++ b/src/constitutive_plastic_phenopowerlaw.f90 @@ -160,7 +160,7 @@ module subroutine plastic_phenopowerlaw_init config%getFloats('interaction_twintwin'), & config%getString('lattice_structure')) prm%gamma_twin_char = lattice_characteristicShear_twin(N_tw,config%getString('lattice_structure'),& - config%getFloat('c/a')) + config%getFloat('c/a',defaultVal=0.0_pReal)) xi_twin_0 = config%getFloats('tau0_twin',requiredSize=size(N_tw)) From 5a4a7393b9c5b647434994bc5a64a64da69b355f Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 28 Apr 2020 19:17:34 +0200 Subject: [PATCH 015/136] statements belong together --- src/lattice.f90 | 1 - 1 file changed, 1 deletion(-) diff --git a/src/lattice.f90 b/src/lattice.f90 index 120c58a15..b1e286f97 100644 --- a/src/lattice.f90 +++ b/src/lattice.f90 @@ -2304,7 +2304,6 @@ subroutine unitTest system = reshape([1.0_pReal+r(1),0.0_pReal,0.0_pReal, 0.0_pReal,1.0_pReal+r(2),0.0_pReal],[6,1]) CoSy = buildCoordinateSystem([1],[1],system,'fcc',0.0_pReal) - if(any(dNeq(CoSy(1:3,1:3,1),math_I3))) & call IO_error(0) From a24ddbab48db3546a1360a72f29b05f24f012e33 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 29 Apr 2020 11:50:43 +0200 Subject: [PATCH 016/136] python is replaced by python3 on newer systems --- Makefile | 2 +- env/DAMASK.csh | 2 +- env/DAMASK.sh | 2 +- env/DAMASK.zsh | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/Makefile b/Makefile index 60cf3b8e0..9a1a41856 100644 --- a/Makefile +++ b/Makefile @@ -2,7 +2,7 @@ SHELL = /bin/sh ######################################################################################## # Makefile for the installation of DAMASK ######################################################################################## -DAMASK_ROOT = $(shell python -c "import os,sys; print(os.path.normpath(os.path.realpath(os.path.expanduser('$(pwd)'))))") +DAMASK_ROOT = $(shell python3 -c "import os,sys; print(os.path.normpath(os.path.realpath(os.path.expanduser('$(pwd)'))))") .PHONY: all all: grid mesh processing diff --git a/env/DAMASK.csh b/env/DAMASK.csh index a669a4ea0..98693d6b2 100644 --- a/env/DAMASK.csh +++ b/env/DAMASK.csh @@ -3,7 +3,7 @@ set CALLED=($_) set ENV_ROOT=`dirname $CALLED[2]` -set DAMASK_ROOT=`python -c "import os,sys; print(os.path.realpath(os.path.expanduser(sys.argv[1])))" $ENV_ROOT"/../"` +set DAMASK_ROOT=`python3 -c "import os,sys; print(os.path.realpath(os.path.expanduser(sys.argv[1])))" $ENV_ROOT"/../"` source $ENV_ROOT/CONFIG diff --git a/env/DAMASK.sh b/env/DAMASK.sh index aed99b3bc..5c3d2ba85 100644 --- a/env/DAMASK.sh +++ b/env/DAMASK.sh @@ -2,7 +2,7 @@ # usage: source DAMASK.sh function canonicalPath { - python -c "import os,sys; print(os.path.normpath(os.path.realpath(os.path.expanduser(sys.argv[1]))))" $1 + python3 -c "import os,sys; print(os.path.normpath(os.path.realpath(os.path.expanduser(sys.argv[1]))))" $1 } function blink { diff --git a/env/DAMASK.zsh b/env/DAMASK.zsh index 8769bac34..831268a7e 100644 --- a/env/DAMASK.zsh +++ b/env/DAMASK.zsh @@ -2,7 +2,7 @@ # usage: source DAMASK.zsh function canonicalPath { - python -c "import os,sys; print(os.path.normpath(os.path.realpath(os.path.expanduser(sys.argv[1]))))" $1 + python3 -c "import os,sys; print(os.path.normpath(os.path.realpath(os.path.expanduser(sys.argv[1]))))" $1 } function blink { From 59c5fbc5fe948269fbddf9aa4d841986c484adca Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Thu, 30 Apr 2020 08:05:42 +0200 Subject: [PATCH 017/136] position independent code required for Fedora 32 --- CMakeLists.txt | 2 +- cmake/Compiler-GNU.cmake | 3 +++ 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 99807ed72..708d8aa3c 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -108,7 +108,7 @@ if (DAMASK_SOLVER STREQUAL "grid") project (damask-grid Fortran C) add_definitions (-DGrid) message ("Building Grid Solver\n") -elseif (DAMASK_SOLVER STREQUAL "fem" OR DAMASK_SOLVER STREQUAL "mesh") +elseif (DAMASK_SOLVER STREQUAL "mesh") project (damask-mesh Fortran C) add_definitions (-DMesh) message ("Building Mesh Solver\n") diff --git a/cmake/Compiler-GNU.cmake b/cmake/Compiler-GNU.cmake index 2e8e5841c..589850af6 100644 --- a/cmake/Compiler-GNU.cmake +++ b/cmake/Compiler-GNU.cmake @@ -25,6 +25,9 @@ set (LINKER_FLAGS "${LINKER_FLAGS},-undefined,dynamic_lookup" ) set (COMPILE_FLAGS "${COMPILE_FLAGS} -xf95-cpp-input") # preprocessor +set (COMPILE_FLAGS "${COMPILE_FLAGS} -fPIC -fPIE") +# position independent conde + set (COMPILE_FLAGS "${COMPILE_FLAGS} -ffree-line-length-132") # restrict line length to the standard 132 characters (lattice.f90 require more characters) From f0bb50b97d6cd9897cdeb261a14158164f9d0c30 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 2 May 2020 15:16:26 +0200 Subject: [PATCH 018/136] vectorized rotation function --- python/damask/_rotation.py | 42 ++++++++++++++++++++++++++++++++++---- 1 file changed, 38 insertions(+), 4 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 716977a79..f442561cf 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -83,7 +83,7 @@ class Rotation: Todo ---- Document details active/passive) - considere rotation of (3,3,3,3)-matrix + consider rotation of (3,3,3,3)-matrix """ if self.quaternion.shape != (4,): @@ -99,9 +99,7 @@ class Rotation: elif isinstance(other, (tuple,np.ndarray)): if isinstance(other,tuple) or other.shape == (3,): # rotate a single (3)-vector or meshgrid A = self.quaternion[0]**2.0 - np.dot(self.quaternion[1:],self.quaternion[1:]) - B = 2.0 * ( self.quaternion[1]*other[0] - + self.quaternion[2]*other[1] - + self.quaternion[3]*other[2]) + B = 2.0 * np.dot(self.quaternion[1:],other) C = 2.0 * _P*self.quaternion[0] return np.array([ @@ -119,6 +117,42 @@ class Rotation: return NotImplemented + def __matmul__(self, other): + """ + Rotation. + + details to be discussed + """ + shape = self.quaternion.shape[:-1] + + if isinstance(other, Rotation): # rotate a rotation + q_m = self.quaternion[...,0].reshape(shape+(1,)) + p_m = self.quaternion[...,1:] + q_o = other.quaternion[...,0].reshape(shape+(1,)) + p_o = other.quaternion[...,1:] + q = (q_m*q_o - np.einsum('...i,...i',p_m,p_o).reshape(shape+(1,))) + p = q_m*p_m + q_o*p_m + _P * np.cross(p_m,p_o) + return self.__class__(np.block([q,p])).standardize() + + elif isinstance(other,np.ndarray): + if shape + (3,) == other.shape: + q_m = self.quaternion[...,0] + p_m = self.quaternion[...,1:] + A = q_m**2.0 - np.einsum('...i,...i',p_m,p_m) + B = 2.0 * np.einsum('...i,...i',p_m,p_m) + C = 2.0 * _P * q_m + return np.block([(A * other[...,i]).reshape(shape+(1,)) + + (B * p_m[...,i]).reshape(shape+(1,)) + + (C * ( p_m[...,(i+1)%3]*other[...,(i+2)%3]\ + - p_m[...,(i+2)%3]*other[...,(i+1)%3])).reshape(shape+(1,)) + for i in [0,1,2]]) + if shape + (3,3) == other.shape: + R = self.asMatrix() + return np.einsum('...im,...jn,...mn',R,R,other) + if shape + (3,3,3,3) == other.shape: + R = self.asMatrix() + return np.einsum('...im,...jn,...ko,...lp,...mnop',R,R,R,R,other) + def inverse(self): """In-place inverse rotation/backward rotation.""" self.quaternion[...,1:] *= -1 From 03f671d12aec8015862c6988d7efdd490146b091 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 5 May 2020 09:35:28 +0200 Subject: [PATCH 019/136] do not report error if linking does not work required for syntax check --- Makefile | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Makefile b/Makefile index 9a1a41856..f7b783c61 100644 --- a/Makefile +++ b/Makefile @@ -10,7 +10,7 @@ all: grid mesh processing grid: build/grid @(cd build/grid;make -j${DAMASK_NUM_THREADS} all install;) @rm -f ${DAMASK_ROOT}/bin/DAMASK_spectral > /dev/null || true - @ln -s ${DAMASK_ROOT}/bin/DAMASK_grid ${DAMASK_ROOT}/bin/DAMASK_spectral + @ln -s ${DAMASK_ROOT}/bin/DAMASK_grid ${DAMASK_ROOT}/bin/DAMASK_spectral || true .PHONY: spectral spectral: grid @@ -18,7 +18,7 @@ spectral: grid mesh: build/mesh @(cd build/mesh; make -j${DAMASK_NUM_THREADS} all install;) @rm -f ${DAMASK_ROOT}/bin/DAMASK_FEM > /dev/null || true - @ln -s ${DAMASK_ROOT}/bin/DAMASK_mesh ${DAMASK_ROOT}/bin/DAMASK_FEM + @ln -s ${DAMASK_ROOT}/bin/DAMASK_mesh ${DAMASK_ROOT}/bin/DAMASK_FEM || true .PHONY: FEM FEM: mesh From 14cdc031e075c8a6f4eb8471814baea5a8cc43f5 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 5 May 2020 09:57:22 +0200 Subject: [PATCH 020/136] write XDMF files the limitation to scalar, 3-vector and 3x3-tensor comes currently from XDMF/vtk/paraview extension to multiple constituents and unstructured meshes might be possible --- python/damask/_result.py | 96 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 96 insertions(+) diff --git a/python/damask/_result.py b/python/damask/_result.py index 13a41757a..8036f1723 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -2,6 +2,8 @@ import multiprocessing import re import glob import os +import xml.etree.ElementTree as ET +import xml.dom.minidom from functools import partial import h5py @@ -1035,6 +1037,100 @@ class Result: pool.join() + def write_XMDF(self): + """ + Write XDMF file to directly visualize data in DADF5 file. + + This works only for scalar, 3-vector and 3x3-tensor data. + Selection is not taken into account. + """ + if len(self.constituents) != 1 or not self.structured: + raise NotImplementedError + + xdmf=ET.Element('Xdmf') + xdmf.attrib={'Version': '3.0', + 'xmlns:xi': 'http://www.w3.org/2001/XInclude'} + + domain=ET.SubElement(xdmf, 'Domain') + + collection = ET.SubElement(domain, 'Grid') + collection.attrib={'GridType': 'Collection', + 'CollectionType': 'Temporal'} + + time = ET.SubElement(collection, 'Time') + time.attrib={'TimeType': 'List'} + + time_data = ET.SubElement(time, 'DataItem') + time_data.attrib={'Dimensions': '{}'.format(len(self.times))} + time_data.text = ' '.join(map(str,self.times)) + + attributes = [] + data_items = [] + + for inc in self.increments: + + grid=ET.SubElement(collection,'Grid') + grid.attrib = {'GridType': 'Uniform', + 'Name': inc} + + topology=ET.SubElement(grid, 'Topology') + topology.attrib={'TopologyType': '3DCORECTMESH', + 'Dimensions': '{} {} {}'.format(*self.grid+1)} + + geometry=ET.SubElement(grid, 'Geometry') + geometry.attrib={'GeometryType':'Origin_DxDyDz'} + + origin=ET.SubElement(geometry, 'DataItem') + origin.attrib={'Format': 'XML', + 'NumberType': 'Float', + 'Dimensions': '3'} + origin.text="{} {} {}".format(*self.origin) + + delta=ET.SubElement(geometry, 'DataItem') + delta.attrib={'Format': 'XML', + 'NumberType': 'Float', + 'Dimensions': '3'} + delta.text="{} {} {}".format(*(self.size/self.grid)) + + + with h5py.File(self.fname,'r') as f: + attributes.append(ET.SubElement(grid, 'Attribute')) + attributes[-1].attrib={'Name': 'u', + 'Center': 'Node', + 'AttributeType': 'Vector'} + data_items.append(ET.SubElement(attributes[-1], 'DataItem')) + data_items[-1].attrib={'Format': 'HDF', + 'Precision': '8', + 'Dimensions': '{} {} {} 3'.format(*(self.grid+1))} + data_items[-1].text='{}:/{}/geometry/u_n'.format(self.fname,inc) + + for o,p in zip(['constituents','materialpoints'],['con_physics','mat_physics']): + for oo in getattr(self,o): + for pp in getattr(self,p): + g = '/'.join([inc,o[:-1],oo,pp]) + for l in f[g]: + name = '/'.join([g,l]) + shape = f[name].shape[1:] + dtype = f[name].dtype + prec = f[name].dtype.itemsize + + if (shape not in [(1,), (3,), (3,3)]) or dtype != np.float64: continue + + attributes.append(ET.SubElement(grid, 'Attribute')) + attributes[-1].attrib={'Name': '{}'.format(name.split('/',2)[2]), + 'Center': 'Cell', + 'AttributeType': 'Tensor'} + data_items.append(ET.SubElement(attributes[-1], 'DataItem')) + data_items[-1].attrib={'Format': 'HDF', + 'NumberType': 'Float', + 'Precision': '{}'.format(prec), + 'Dimensions': '{} {} {} {}'.format(*self.grid,np.prod(shape))} + data_items[-1].text='{}:{}'.format(self.fname,name) + + with open(os.path.splitext(self.fname)[0]+'.xdmf','w') as f: + f.write(xml.dom.minidom.parseString(ET.tostring(xdmf).decode()).toprettyxml()) + + def to_vtk(self,labels=[],mode='cell'): """ Export to vtk cell/point data. From 43442f0722313bf016f8f2665c51f0c2c7ba5cf7 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 5 May 2020 10:03:08 +0200 Subject: [PATCH 021/136] tests use new names (grid/mesh instead of spectral/FEM) --- PRIVATE | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/PRIVATE b/PRIVATE index c595994cd..c6a91e8ef 160000 --- a/PRIVATE +++ b/PRIVATE @@ -1 +1 @@ -Subproject commit c595994cd8880acadf50b5dedb79156d04d35b91 +Subproject commit c6a91e8effdb4cf1632bdd115e091a50fee4ecd1 From 31c397255d2ecd0ca74043f5d4ebd7890f244ea6 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 5 May 2020 10:18:48 +0200 Subject: [PATCH 022/136] equivalent (for a valid DADF5 file) but faster --- python/damask/_result.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index 8036f1723..28277e0ee 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -64,8 +64,8 @@ class Result: self.times = [round(f[i].attrs['time/s'],12) for i in self.increments] self.Nmaterialpoints, self.Nconstituents = np.shape(f['mapping/cellResults/constituent']) - self.materialpoints = [m.decode() for m in np.unique(f['mapping/cellResults/materialpoint']['Name'])] - self.constituents = [c.decode() for c in np.unique(f['mapping/cellResults/constituent'] ['Name'])] + self.materialpoints = [m for m in f['inc0/materialpoint']] + self.constituents = [c for c in f['inc0/constituent']] self.con_physics = [] for c in self.constituents: From eeb0df3a551e7775d5360f1246879b35cfef1ae5 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 5 May 2020 10:42:54 +0200 Subject: [PATCH 023/136] do not store absolute path --- python/damask/_result.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index 28277e0ee..d74b1fc4a 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -1102,7 +1102,7 @@ class Result: data_items[-1].attrib={'Format': 'HDF', 'Precision': '8', 'Dimensions': '{} {} {} 3'.format(*(self.grid+1))} - data_items[-1].text='{}:/{}/geometry/u_n'.format(self.fname,inc) + data_items[-1].text='{}:/{}/geometry/u_n'.format(os.path.split(self.fname)[1],inc) for o,p in zip(['constituents','materialpoints'],['con_physics','mat_physics']): for oo in getattr(self,o): @@ -1125,7 +1125,7 @@ class Result: 'NumberType': 'Float', 'Precision': '{}'.format(prec), 'Dimensions': '{} {} {} {}'.format(*self.grid,np.prod(shape))} - data_items[-1].text='{}:{}'.format(self.fname,name) + data_items[-1].text='{}:{}'.format(os.path.split(self.fname)[1],name) with open(os.path.splitext(self.fname)[0]+'.xdmf','w') as f: f.write(xml.dom.minidom.parseString(ET.tostring(xdmf).decode()).toprettyxml()) From b891fd4e4e58274a5ecf8c3bc6ffda6a3c5fe820 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 5 May 2020 10:43:06 +0200 Subject: [PATCH 024/136] adjusted test --- PRIVATE | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/PRIVATE b/PRIVATE index c6a91e8ef..038af521a 160000 --- a/PRIVATE +++ b/PRIVATE @@ -1 +1 @@ -Subproject commit c6a91e8effdb4cf1632bdd115e091a50fee4ecd1 +Subproject commit 038af521a1ef70ed77b132c426bc1a4880db01ef From ef4a4dad4af42e78f29a95cc18bcdadda6514d96 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 2 May 2020 15:50:46 +0200 Subject: [PATCH 025/136] shape property and numpy-like broadcasting this makes it easy to apply a single rotation to a field --- python/damask/_rotation.py | 39 +++++++++++++++++++++++++++----------- 1 file changed, 28 insertions(+), 11 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index f442561cf..cb5b2fbd1 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -53,6 +53,12 @@ class Rotation: """ self.quaternion = quaternion.copy() + + @property + def shape(self): + return self.quaternion.shape[:-1] + + def __copy__(self): """Copy.""" return self.__class__(self.quaternion) @@ -123,35 +129,35 @@ class Rotation: details to be discussed """ - shape = self.quaternion.shape[:-1] - if isinstance(other, Rotation): # rotate a rotation - q_m = self.quaternion[...,0].reshape(shape+(1,)) + q_m = self.quaternion[...,0].reshape(self.shape+(1,)) p_m = self.quaternion[...,1:] - q_o = other.quaternion[...,0].reshape(shape+(1,)) + q_o = other.quaternion[...,0].reshape(self.shape+(1,)) p_o = other.quaternion[...,1:] - q = (q_m*q_o - np.einsum('...i,...i',p_m,p_o).reshape(shape+(1,))) + q = (q_m*q_o - np.einsum('...i,...i',p_m,p_o).reshape(self.shape+(1,))) p = q_m*p_m + q_o*p_m + _P * np.cross(p_m,p_o) return self.__class__(np.block([q,p])).standardize() elif isinstance(other,np.ndarray): - if shape + (3,) == other.shape: + if self.shape + (3,) == other.shape: q_m = self.quaternion[...,0] p_m = self.quaternion[...,1:] A = q_m**2.0 - np.einsum('...i,...i',p_m,p_m) B = 2.0 * np.einsum('...i,...i',p_m,p_m) C = 2.0 * _P * q_m - return np.block([(A * other[...,i]).reshape(shape+(1,)) + - (B * p_m[...,i]).reshape(shape+(1,)) + + return np.block([(A * other[...,i]).reshape(self.shape+(1,)) + + (B * p_m[...,i]).reshape(self.shape+(1,)) + (C * ( p_m[...,(i+1)%3]*other[...,(i+2)%3]\ - - p_m[...,(i+2)%3]*other[...,(i+1)%3])).reshape(shape+(1,)) + - p_m[...,(i+2)%3]*other[...,(i+1)%3])).reshape(self.shape+(1,)) for i in [0,1,2]]) - if shape + (3,3) == other.shape: + if self.shape + (3,3) == other.shape: R = self.asMatrix() return np.einsum('...im,...jn,...mn',R,R,other) - if shape + (3,3,3,3) == other.shape: + if self.shape + (3,3,3,3) == other.shape: R = self.asMatrix() return np.einsum('...im,...jn,...ko,...lp,...mnop',R,R,R,R,other) + else: + raise ValueError def inverse(self): """In-place inverse rotation/backward rotation.""" @@ -186,6 +192,17 @@ class Rotation: return other*self.inversed() + def broadcast_to(self,shape): + if self.shape == (): + q = np.broadcast_to(self.quaternion,shape+(4,)) + else: + q = np.block([np.broadcast_to(self.quaternion[...,0:1],shape+(1,)), + np.broadcast_to(self.quaternion[...,1:2],shape+(1,)), + np.broadcast_to(self.quaternion[...,2:3],shape+(1,)), + np.broadcast_to(self.quaternion[...,3:4],shape+(1,))]) + return self.__class__(q) + + def average(self,other): """ Calculate the average rotation. From 9553a7838bcdd0dd02c107511ec915eba3839706 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 6 May 2020 22:15:09 +0200 Subject: [PATCH 027/136] needs to be logical --- src/mesh/discretization_mesh.f90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/mesh/discretization_mesh.f90 b/src/mesh/discretization_mesh.f90 index b98cbbfad..0880de115 100644 --- a/src/mesh/discretization_mesh.f90 +++ b/src/mesh/discretization_mesh.f90 @@ -65,7 +65,7 @@ contains !-------------------------------------------------------------------------------------------------- subroutine discretization_mesh_init(restart) - integer, intent(in) :: restart + logical, intent(in) :: restart integer, dimension(1), parameter:: FE_geomtype = [1] !< geometry type of particular element type integer, dimension(1) :: FE_Nips !< number of IPs in a specific type of element From c2b4f5516e4f6d3a8f7d88cf1cae6016de60a141 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Thu, 7 May 2020 00:14:14 +0200 Subject: [PATCH 028/136] DADF5_postResults tries to combine datasets, this does not work --- python/damask/_result.py | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index d74b1fc4a..622f38919 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -64,8 +64,12 @@ class Result: self.times = [round(f[i].attrs['time/s'],12) for i in self.increments] self.Nmaterialpoints, self.Nconstituents = np.shape(f['mapping/cellResults/constituent']) - self.materialpoints = [m for m in f['inc0/materialpoint']] - self.constituents = [c for c in f['inc0/constituent']] + self.materialpoints = [m.decode() for m in np.unique(f['mapping/cellResults/materialpoint']['Name'])] + self.constituents = [c.decode() for c in np.unique(f['mapping/cellResults/constituent'] ['Name'])] + + # faster, but does not work with (deprecated) DADF5_postResults + #self.materialpoints = [m for m in f['inc0/materialpoint']] + #self.constituents = [c for c in f['inc0/constituent']] self.con_physics = [] for c in self.constituents: @@ -428,8 +432,10 @@ class Result: """ with h5py.File(self.fname,'r') as f: shape = (self.Nmaterialpoints,) + np.shape(f[path[0]])[1:] + print(path[0]) if len(shape) == 1: shape = shape +(1,) dataset = np.full(shape,np.nan,dtype=np.dtype(f[path[0]])) + print('dataset shape', dataset.shape) for pa in path: label = pa.split('/')[2] @@ -437,12 +443,19 @@ class Result: dataset = np.array(f[pa]) continue + print(label) p = np.where(f['mapping/cellResults/constituent'][:,c]['Name'] == str.encode(label))[0] + print(len(p)) if len(p)>0: u = (f['mapping/cellResults/constituent']['Position'][p,c]) + print('pa',pa) a = np.array(f[pa]) + print(a.shape) if len(a.shape) == 1: a=a.reshape([a.shape[0],1]) + print('u',u) + print('a[u]',a[u,:].shape) + print('dataset[p]',dataset[p,:].shape) dataset[p,:] = a[u,:] p = np.where(f['mapping/cellResults/materialpoint']['Name'] == str.encode(label))[0] From b75e98ca3f01a7b56137a03bb079aa5c99d9b878 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Thu, 7 May 2020 19:12:05 +0200 Subject: [PATCH 029/136] forgotten debug statements + polishing of XDMF output --- python/damask/_result.py | 19 ++++++------------- 1 file changed, 6 insertions(+), 13 deletions(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index 622f38919..9993e90bd 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -66,7 +66,7 @@ class Result: self.Nmaterialpoints, self.Nconstituents = np.shape(f['mapping/cellResults/constituent']) self.materialpoints = [m.decode() for m in np.unique(f['mapping/cellResults/materialpoint']['Name'])] self.constituents = [c.decode() for c in np.unique(f['mapping/cellResults/constituent'] ['Name'])] - + # faster, but does not work with (deprecated) DADF5_postResults #self.materialpoints = [m for m in f['inc0/materialpoint']] #self.constituents = [c for c in f['inc0/constituent']] @@ -432,10 +432,8 @@ class Result: """ with h5py.File(self.fname,'r') as f: shape = (self.Nmaterialpoints,) + np.shape(f[path[0]])[1:] - print(path[0]) if len(shape) == 1: shape = shape +(1,) dataset = np.full(shape,np.nan,dtype=np.dtype(f[path[0]])) - print('dataset shape', dataset.shape) for pa in path: label = pa.split('/')[2] @@ -443,19 +441,12 @@ class Result: dataset = np.array(f[pa]) continue - print(label) p = np.where(f['mapping/cellResults/constituent'][:,c]['Name'] == str.encode(label))[0] - print(len(p)) if len(p)>0: u = (f['mapping/cellResults/constituent']['Position'][p,c]) - print('pa',pa) a = np.array(f[pa]) - print(a.shape) if len(a.shape) == 1: a=a.reshape([a.shape[0],1]) - print('u',u) - print('a[u]',a[u,:].shape) - print('dataset[p]',dataset[p,:].shape) dataset[p,:] = a[u,:] p = np.where(f['mapping/cellResults/materialpoint']['Name'] == str.encode(label))[0] @@ -1061,7 +1052,7 @@ class Result: raise NotImplementedError xdmf=ET.Element('Xdmf') - xdmf.attrib={'Version': '3.0', + xdmf.attrib={'Version': '2.0', 'xmlns:xi': 'http://www.w3.org/2001/XInclude'} domain=ET.SubElement(xdmf, 'Domain') @@ -1074,7 +1065,9 @@ class Result: time.attrib={'TimeType': 'List'} time_data = ET.SubElement(time, 'DataItem') - time_data.attrib={'Dimensions': '{}'.format(len(self.times))} + time_data.attrib={'Format': 'XML', + 'NumberType': 'Float', + 'Dimensions': '{}'.format(len(self.times))} time_data.text = ' '.join(map(str,self.times)) attributes = [] @@ -1087,7 +1080,7 @@ class Result: 'Name': inc} topology=ET.SubElement(grid, 'Topology') - topology.attrib={'TopologyType': '3DCORECTMESH', + topology.attrib={'TopologyType': '3DCoRectMesh', 'Dimensions': '{} {} {}'.format(*self.grid+1)} geometry=ET.SubElement(grid, 'Geometry') From 72c835a55417038718b4769fb3742583aec6a1ab Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 11 May 2020 16:00:53 +0200 Subject: [PATCH 030/136] not used --- src/mesh/mesh_mech_FEM.f90 | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/mesh/mesh_mech_FEM.f90 b/src/mesh/mesh_mech_FEM.f90 index 8206f4174..a2f4b9e70 100644 --- a/src/mesh/mesh_mech_FEM.f90 +++ b/src/mesh/mesh_mech_FEM.f90 @@ -17,11 +17,9 @@ module mesh_mech_FEM use prec use FEM_utilities use discretization_mesh - use IO use DAMASK_interface use numerics use FEM_quadrature - use FEsolving use homogenization use math From 66b928c5afce0891bd13793c42e0fafc8bba5324 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 13 May 2020 10:47:49 +0200 Subject: [PATCH 031/136] using doctest style https://docs.python.org/3/library/doctest.html https://numpy.org/doc/stable/docs/howto_document.html#sections (section 15) --- python/damask/_lattice.py | 27 ++++++++++++++------------- 1 file changed, 14 insertions(+), 13 deletions(-) diff --git a/python/damask/_lattice.py b/python/damask/_lattice.py index 42aa0e9bd..f33cc66f7 100644 --- a/python/damask/_lattice.py +++ b/python/damask/_lattice.py @@ -229,19 +229,20 @@ class Symmetry: Return inverse pole figure color if requested. Bases are computed from - basis = {'cubic' : np.linalg.inv(np.array([[0.,0.,1.], # direction of red - [1.,0.,1.]/np.sqrt(2.), # direction of green - [1.,1.,1.]/np.sqrt(3.)]).T), # direction of blue - 'hexagonal' : np.linalg.inv(np.array([[0.,0.,1.], # direction of red - [1.,0.,0.], # direction of green - [np.sqrt(3.),1.,0.]/np.sqrt(4.)]).T), # direction of blue - 'tetragonal' : np.linalg.inv(np.array([[0.,0.,1.], # direction of red - [1.,0.,0.], # direction of green - [1.,1.,0.]/np.sqrt(2.)]).T), # direction of blue - 'orthorhombic' : np.linalg.inv(np.array([[0.,0.,1.], # direction of red - [1.,0.,0.], # direction of green - [0.,1.,0.]]).T), # direction of blue - } + >>> basis = {'cubic' : np.linalg.inv(np.array([[0.,0.,1.], # direction of red + ... [1.,0.,1.]/np.sqrt(2.), # direction of green + ... [1.,1.,1.]/np.sqrt(3.)]).T), # direction of blue + ... 'hexagonal' : np.linalg.inv(np.array([[0.,0.,1.], # direction of red + ... [1.,0.,0.], # direction of green + ... [np.sqrt(3.),1.,0.]/np.sqrt(4.)]).T), # direction of blue + ... 'tetragonal' : np.linalg.inv(np.array([[0.,0.,1.], # direction of red + ... [1.,0.,0.], # direction of green + ... [1.,1.,0.]/np.sqrt(2.)]).T), # direction of blue + ... 'orthorhombic': np.linalg.inv(np.array([[0.,0.,1.], # direction of red + ... [1.,0.,0.], # direction of green + ... [0.,1.,0.]]).T), # direction of blue + ... } + """ if self.lattice == 'cubic': basis = {'improper':np.array([ [-1. , 0. , 1. ], From b5b9bfaa99d1dc676b3177c22536a1607047148c Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 13 May 2020 11:09:37 +0200 Subject: [PATCH 032/136] need space at end of definition list --- python/damask/_orientation.py | 1 + python/damask/_result.py | 7 ++++--- python/damask/_rotation.py | 2 ++ 3 files changed, 7 insertions(+), 3 deletions(-) diff --git a/python/damask/_orientation.py b/python/damask/_orientation.py index 64fb98f45..a558ec85d 100644 --- a/python/damask/_orientation.py +++ b/python/damask/_orientation.py @@ -10,6 +10,7 @@ class Orientation: A crystallographic orientation contains a rotation and a lattice. """ + __slots__ = ['rotation','lattice'] def __repr__(self): diff --git a/python/damask/_result.py b/python/damask/_result.py index 9171682ff..a660885fe 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -316,9 +316,10 @@ class Result: Return groups that contain all requested datasets. Only groups within - - inc?????/constituent/*_*/* - - inc?????/materialpoint/*_*/* - - inc?????/geometry/* + - inc*/constituent/*/* + - inc*/materialpoint/*/* + - inc*/geometry/* + are considered as they contain user-relevant data. Single strings will be treated as list with one entry. diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index a7427e1f9..162a118b9 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -16,6 +16,7 @@ def iszero(a): class Rotation: u""" Orientation stored with functionality for conversion to different representations. + The following conventions apply: - coordinate frames are right-handed. @@ -42,6 +43,7 @@ class Rotation: https://doi.org/10.1088/0965-0393/23/8/083501 """ + __slots__ = ['quaternion'] def __init__(self,quaternion = np.array([1.0,0.0,0.0,0.0])): From 661604ff94bd374db97ed846741e3c1f39145669 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Thu, 14 May 2020 06:59:30 +0200 Subject: [PATCH 033/136] more error checking --- src/DAMASK_interface.f90 | 34 ++++++++++++++++++---------------- 1 file changed, 18 insertions(+), 16 deletions(-) diff --git a/src/DAMASK_interface.f90 b/src/DAMASK_interface.f90 index dceef0f7f..56824d820 100644 --- a/src/DAMASK_interface.f90 +++ b/src/DAMASK_interface.f90 @@ -106,7 +106,7 @@ subroutine DAMASK_interface_init typeSize integer, dimension(8) :: & dateAndTime - integer :: mpi_err + integer :: err PetscErrorCode :: petsc_err external :: & quit @@ -118,8 +118,8 @@ subroutine DAMASK_interface_init #ifdef _OPENMP ! If openMP is enabled, check if the MPI libary supports it and initialize accordingly. ! Otherwise, the first call to PETSc will do the initialization. - call MPI_Init_Thread(MPI_THREAD_FUNNELED,threadLevel,mpi_err) - if (mpi_err /= 0) call quit(1) + call MPI_Init_Thread(MPI_THREAD_FUNNELED,threadLevel,err) + if (err /= 0) call quit(1) if (threadLevel Date: Fri, 15 May 2020 22:33:38 +0200 Subject: [PATCH 034/136] suppress warnings the compiler does not know that IO_error terminates the program --- src/lattice.f90 | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/lattice.f90 b/src/lattice.f90 index b1e286f97..cf985cc19 100644 --- a/src/lattice.f90 +++ b/src/lattice.f90 @@ -1436,6 +1436,7 @@ function lattice_SchmidMatrix_slip(Nslip,structure,cOverA) result(SchmidMatrix) NslipMax = BCT_NSLIPSYSTEM slipSystems = BCT_SYSTEMSLIP case default + allocate(NslipMax(0)) call IO_error(137,ext_msg='lattice_SchmidMatrix_slip: '//trim(structure)) end select @@ -1485,6 +1486,7 @@ function lattice_SchmidMatrix_twin(Ntwin,structure,cOverA) result(SchmidMatrix) NtwinMax = HEX_NTWINSYSTEM twinSystems = HEX_SYSTEMTWIN case default + allocate(NtwinMax(0)) call IO_error(137,ext_msg='lattice_SchmidMatrix_twin: '//trim(structure)) end select @@ -1564,6 +1566,7 @@ function lattice_SchmidMatrix_cleavage(Ncleavage,structure,cOverA) result(Schmid NcleavageMax = BCC_NCLEAVAGESYSTEM cleavageSystems = BCC_SYSTEMCLEAVAGE case default + allocate(NcleavageMax(0)) call IO_error(137,ext_msg='lattice_SchmidMatrix_cleavage: '//trim(structure)) end select @@ -1919,6 +1922,7 @@ function coordinateSystem_slip(Nslip,structure,cOverA) result(coordinateSystem) NslipMax = BCT_NSLIPSYSTEM slipSystems = BCT_SYSTEMSLIP case default + allocate(NslipMax(0)) call IO_error(137,ext_msg='coordinateSystem_slip: '//trim(structure)) end select From e3e70ae42469d222046f4c0db92c7bfac6cdcfb2 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Fri, 15 May 2020 22:45:22 +0200 Subject: [PATCH 035/136] check for recent standard requires Gfortran 8.1.x or later --- cmake/Compiler-GNU.cmake | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cmake/Compiler-GNU.cmake b/cmake/Compiler-GNU.cmake index 6fc669299..858e91134 100644 --- a/cmake/Compiler-GNU.cmake +++ b/cmake/Compiler-GNU.cmake @@ -14,7 +14,7 @@ elseif (OPTIMIZATION STREQUAL "AGGRESSIVE") set (OPTIMIZATION_FLAGS "-O3 -ffast-math -funroll-loops -ftree-vectorize") endif () -set (STANDARD_CHECK "-std=f2008ts -pedantic-errors" ) +set (STANDARD_CHECK "-std=f2018 -pedantic-errors" ) set (LINKER_FLAGS "${LINKER_FLAGS} -Wl") # options parsed directly to the linker set (LINKER_FLAGS "${LINKER_FLAGS},-undefined,dynamic_lookup" ) From 2dc46b783aa80812dc44957886a06f61c50660e7 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 16 May 2020 00:58:40 +0200 Subject: [PATCH 036/136] simplified and tested --- python/damask/_rotation.py | 7 ++----- python/tests/test_Rotation.py | 7 +++++++ 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 059f148a4..38294f75e 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -112,11 +112,8 @@ class Rotation: B = 2.0 * np.dot(self.quaternion[1:],other) C = 2.0 * _P*self.quaternion[0] - return np.array([ - A*other[0] + B*self.quaternion[1] + C*(self.quaternion[2]*other[2] - self.quaternion[3]*other[1]), - A*other[1] + B*self.quaternion[2] + C*(self.quaternion[3]*other[0] - self.quaternion[1]*other[2]), - A*other[2] + B*self.quaternion[3] + C*(self.quaternion[1]*other[1] - self.quaternion[2]*other[0]), - ]) + return A*other + B*self.quaternion[1:] + C * np.cross(self.quaternion[1:],other) + elif other.shape == (3,3,): # rotate a single (3x3)-matrix return np.dot(self.asMatrix(),np.dot(other,self.asMatrix().T)) elif other.shape == (3,3,3,3,): diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index b7442035f..ffa1548d7 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -300,3 +300,10 @@ class TestRotation: f = Rotation._get_pyramid_order(a,'forward') b = Rotation._get_pyramid_order(a,'backward') assert np.all(np.take_along_axis(np.take_along_axis(a,f,-1),b,-1) == a) + + + @pytest.mark.parametrize('x',[np.random.rand(3), + np.random.rand(3,3)]) + def test_rotation_identity(self,x): + R = Rotation() + assert np.allclose(x,R*x) From e2ba294b751b3606821ad6da9b4e96570e11e79d Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 16 May 2020 09:40:32 +0200 Subject: [PATCH 037/136] bugfix: wrong variable --- python/damask/_rotation.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 38294f75e..a9f11c6c2 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -131,12 +131,12 @@ class Rotation: details to be discussed """ if isinstance(other, Rotation): # rotate a rotation - q_m = self.quaternion[...,0].reshape(self.shape+(1,)) + q_m = self.quaternion[...,0:1] p_m = self.quaternion[...,1:] - q_o = other.quaternion[...,0].reshape(self.shape+(1,)) + q_o = other.quaternion[...,0:1] p_o = other.quaternion[...,1:] q = (q_m*q_o - np.einsum('...i,...i',p_m,p_o).reshape(self.shape+(1,))) - p = q_m*p_m + q_o*p_m + _P * np.cross(p_m,p_o) + p = q_m*p_o + q_o*p_m + _P * np.cross(p_m,p_o) return self.__class__(np.block([q,p])).standardize() elif isinstance(other,np.ndarray): From 347e3b8c60763f0bae1d7de0cd5496b363003e66 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 16 May 2020 09:40:44 +0200 Subject: [PATCH 038/136] using new table class + vectorized rotation --- processing/post/addOrientations.py | 133 +++++++++-------------------- processing/post/rotateData.py | 13 ++- 2 files changed, 46 insertions(+), 100 deletions(-) diff --git a/processing/post/addOrientations.py b/processing/post/addOrientations.py index e1752b0a4..b6292b18c 100755 --- a/processing/post/addOrientations.py +++ b/processing/post/addOrientations.py @@ -2,6 +2,7 @@ import os import sys +from io import StringIO from optparse import OptionParser import numpy as np @@ -24,14 +25,8 @@ Additional (globally fixed) rotations of the lab frame and/or crystal frame can """, version = scriptID) -representations = { - 'quaternion': ['qu',4], - 'rodrigues': ['ro',4], - 'Rodrigues': ['Ro',3], - 'eulers': ['eu',3], - 'matrix': ['om',9], - 'angleaxis': ['ax',4], - } +representations = ['quaternion', 'rodrigues', 'eulers', 'matrix', 'axisangle'] + parser.add_option('-o', '--output', @@ -93,10 +88,10 @@ parser.set_defaults(output = [], ) (options, filenames) = parser.parse_args() +if filenames == []: filenames = [None] -#options.output = list(map(lambda x: x.lower(), options.output)) if options.output == [] or (not set(options.output).issubset(set(representations))): - parser.error('output must be chosen from {}.'.format(', '.join(representations))) + parser.error('output must be chosen from {}.'.format(', '.join(representations))) input = [options.eulers is not None, options.rodrigues is not None, @@ -109,95 +104,47 @@ input = [options.eulers is not None, if np.sum(input) != 1: parser.error('needs exactly one input format.') -(label,dim,inputtype) = [(options.eulers,representations['eulers'][1],'eulers'), - (options.rodrigues,representations['rodrigues'][1],'rodrigues'), - ([options.x,options.y,options.z],[3,3,3],'frame'), - (options.matrix,representations['matrix'][1],'matrix'), - (options.quaternion,representations['quaternion'][1],'quaternion'), - ][np.where(input)[0][0]] # select input label that was requested - -r = damask.Rotation.fromAxisAngle(np.array(options.crystalrotation),options.degrees,normalise=True) -R = damask.Rotation.fromAxisAngle(np.array(options.labrotation),options.degrees,normalise=True) - - -# --- loop over input files ------------------------------------------------------------------------ - -if filenames == []: filenames = [None] +r = damask.Rotation.from_axis_angle(np.array(options.crystalrotation),options.degrees,normalise=True) +R = damask.Rotation.from_axis_angle(np.array(options.labrotation),options.degrees,normalise=True) for name in filenames: - try: - table = damask.ASCIItable(name = name) - except IOError: - continue - damask.util.report(scriptName,name) + damask.util.report(scriptName,name) -# ------------------------------------------ read header ------------------------------------------ + table = damask.Table.from_ASCII(StringIO(''.join(sys.stdin.read())) if name is None else name) - table.head_read() + if options.eulers is not None: + label = options.eulers + print(np.max(table.get(options.eulers),axis=0)) + o = damask.Rotation.from_Eulers(table.get(options.eulers), options.degrees) + elif options.rodrigues is not None: + label = options.rodrigues + o = damask.Rotation.from_Rodrigues(table.get(options.rodrigues)) + elif options.matrix is not None: + label = options.matrix + o = damask.Rotation.from_matrix(table.get(options.matrix).reshape(-1,3,3)) + elif options.x is not None: + label = '<{},{},{}>'.format(options.x,options.y,options.z) + M = np.block([table.get(options.x),table.get(options.y),table.get(options.z)]).reshape(-1,3,3) + o = damask.Rotation.from_matrix(M/np.linalg.norm(M,axis=0)) + elif options.quaternion is not None: + label = options.quaternion + o = damask.Rotation.from_quaternion(table.get(options.quaternion)) -# ------------------------------------------ sanity checks ----------------------------------------- + o = r.broadcast_to(o.shape) @ o @ R.broadcast_to(o.shape) - errors = [] - remarks = [] - - if not np.all(table.label_dimension(label) == dim): errors.append('input {} does not have dimension {}.'.format(label,dim)) - else: column = table.label_index(label) + #if options.lattice is not None: + # o = damask.Orientation(rotation = o,lattice = options.lattice).reduced().rotation - if remarks != []: damask.util.croak(remarks) - if errors != []: - damask.util.croak(errors) - table.close(dismiss = True) - continue -# ------------------------------------------ assemble header --------------------------------------- + if 'rodrigues' in options.output: + table.add('ro({})'.format(label),o.as_rodrigues(), scriptID+' '+' '.join(sys.argv[1:])) + if 'eulers' in options.output: + table.add('eu({})'.format(label),o.as_Eulers(options.degrees), scriptID+' '+' '.join(sys.argv[1:])) + if 'quaternion' in options.output: + table.add('qu({})'.format(label),o.as_quaternion(), scriptID+' '+' '.join(sys.argv[1:])) + if 'matrix' in options.output: + table.add('om({})'.format(label),o.as_matrix(), scriptID+' '+' '.join(sys.argv[1:])) + if 'axisangle' in options.output: + table.add('om({})'.format(label),o.as_axisangle(options.degrees), scriptID+' '+' '.join(sys.argv[1:])) - table.info_append(scriptID + '\t' + ' '.join(sys.argv[1:])) - for output in options.output: - if output in representations: - table.labels_append(['{}_{}({})'.format(i+1,representations[output][0],label) \ - for i in range(representations[output][1])]) - table.head_write() - -# ------------------------------------------ process data ------------------------------------------ - - outputAlive = True - while outputAlive and table.data_read(): # read next data line of ASCII table - if inputtype == 'eulers': - d = representations['eulers'][1] - o = damask.Rotation.fromEulers(list(map(float,table.data[column:column+d])),options.degrees) - - elif inputtype == 'rodrigues': - d = representations['rodrigues'][1] - o = damask.Rotation.fromRodrigues(list(map(float,table.data[column:column+d]))) - - elif inputtype == 'matrix': - d = representations['matrix'][1] - o = damask.Rotation.fromMatrix(np.array(list(map(float,table.data[column:column+d]))).reshape(3,3)) - - elif inputtype == 'frame': - M = np.array(list(map(float,table.data[column[0]:column[0]+3] + \ - table.data[column[1]:column[1]+3] + \ - table.data[column[2]:column[2]+3]))).reshape(3,3).T - o = damask.Rotation.fromMatrix(M/np.linalg.norm(M,axis=0)) - - elif inputtype == 'quaternion': - d = representations['quaternion'][1] - o = damask.Rotation.fromQuaternion(list(map(float,table.data[column:column+d]))) - - o = r*o*R # apply additional lab and crystal frame rotations - - if options.lattice is not None: - o = damask.Orientation(rotation = o,lattice = options.lattice).reduced().rotation - - for output in options.output: - if output == 'quaternion': table.data_append(o.asQuaternion()) - elif output == 'rodrigues': table.data_append(o.asRodrigues()) - elif output == 'Rodrigues': table.data_append(o.asRodrigues(vector=True)) - elif output == 'eulers': table.data_append(o.asEulers(degrees=options.degrees)) - elif output == 'matrix': table.data_append(o.asMatrix()) - elif output == 'angleaxis': table.data_append(o.asAxisAngle(degrees=options.degrees)) - outputAlive = table.data_write() # output processed line - -# ------------------------------------------ output finalization ----------------------------------- - - table.close() # close ASCII tables + table.to_ASCII(sys.stdout if name is None else name) diff --git a/processing/post/rotateData.py b/processing/post/rotateData.py index d270eb79e..ee172c64d 100755 --- a/processing/post/rotateData.py +++ b/processing/post/rotateData.py @@ -37,27 +37,26 @@ parser.add_option('--degrees', parser.set_defaults(rotation = (1.,1.,1.,0), # no rotation about (1,1,1) degrees = False, ) - + (options,filenames) = parser.parse_args() if filenames == []: filenames = [None] if options.data is None: - parser.error('no data column specified.') + parser.error('no data column specified.') -r = damask.Rotation.fromAxisAngle(options.rotation,options.degrees,normalise=True) +r = damask.Rotation.from_axis_angle(options.rotation,options.degrees,normalise=True) for name in filenames: damask.util.report(scriptName,name) - + table = damask.Table.from_ASCII(StringIO(''.join(sys.stdin.read())) if name is None else name) for data in options.data: d = table.get(data) if table.shapes[data] == (9,): d=d.reshape(-1,3,3) - for i,l in enumerate(d): - d[i] = r*l + d = r.broadcast_to(d.shape[0:1]) @ d if table.shapes[data] == (9,): d=d.reshape(-1,9) - + table.set(data,d,scriptID+' '+' '.join(sys.argv[1:])) table.to_ASCII(sys.stdout if name is None else name) From 235f3c0df7df26bc1d42ce50dd3131b2f03edf67 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 16 May 2020 11:16:52 +0200 Subject: [PATCH 039/136] bugfix: copy and paste error --- python/damask/_rotation.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index a9f11c6c2..3a046363f 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -52,7 +52,7 @@ class Rotation: Parameters ---------- quaternion : numpy.ndarray, optional - Unit quaternion that follows the conventions. Use .fromQuaternion to perform a sanity check. + Unit quaternion that follows the conventions. Use .from_quaternion to perform a sanity check. """ self.quaternion = quaternion.copy() @@ -144,7 +144,7 @@ class Rotation: q_m = self.quaternion[...,0] p_m = self.quaternion[...,1:] A = q_m**2.0 - np.einsum('...i,...i',p_m,p_m) - B = 2.0 * np.einsum('...i,...i',p_m,p_m) + B = 2.0 * np.einsum('...i,...i',p_m,other) C = 2.0 * _P * q_m return np.block([(A * other[...,i]).reshape(self.shape+(1,)) + (B * p_m[...,i]).reshape(self.shape+(1,)) + @@ -481,7 +481,7 @@ class Rotation: else M + r.asM() * n # noqa add (multiples) of this rotation to average noqa eig, vec = np.linalg.eig(M/N) - return Rotation.fromQuaternion(np.real(vec.T[eig.argmax()]),acceptHomomorph = True) + return Rotation.from_quaternion(np.real(vec.T[eig.argmax()]),acceptHomomorph = True) @staticmethod def from_random(shape=None): From 9fa153916347d1413facbaf2d2de7f510ca0404f Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 16 May 2020 11:17:12 +0200 Subject: [PATCH 040/136] using new names --- processing/pre/geom_addPrimitive.py | 4 ++-- processing/pre/geom_fromDREAM3D.py | 4 ++-- processing/pre/geom_rotate.py | 8 ++++---- python/damask/_lattice.py | 2 +- python/damask/_orientation.py | 2 +- python/tests/test_Orientation.py | 6 +++--- 6 files changed, 13 insertions(+), 13 deletions(-) diff --git a/processing/pre/geom_addPrimitive.py b/processing/pre/geom_addPrimitive.py index f33ba27b1..c04fcf565 100755 --- a/processing/pre/geom_addPrimitive.py +++ b/processing/pre/geom_addPrimitive.py @@ -84,9 +84,9 @@ if [options.angleaxis,options.quaternion].count(None) == 0: parser.error('more than one rotation specified.') if options.angleaxis is not None: - rotation = damask.Rotation.fromAxisAngle(np.array(options.angleaxis),options.degrees,normalise=True) + rotation = damask.Rotation.from_axis_angle(np.array(options.angleaxis),options.degrees,normalise=True) elif options.quaternion is not None: - rotation = damask.Rotation.fromQuaternion(options.quaternion) + rotation = damask.Rotation.from_quaternion(options.quaternion) else: rotation = damask.Rotation() diff --git a/processing/pre/geom_fromDREAM3D.py b/processing/pre/geom_fromDREAM3D.py index 7d5b1442d..b000aa811 100755 --- a/processing/pre/geom_fromDREAM3D.py +++ b/processing/pre/geom_fromDREAM3D.py @@ -97,7 +97,7 @@ for name in filenames: dataset = os.path.join(group_pointwise,options.quaternion) try: quats = np.reshape(inFile[dataset][...],(np.product(grid),4)) - rot = [damask.Rotation.fromQuaternion(q,True,P=+1) for q in quats] + rot = [damask.Rotation.from_quaternion(q,True,P=+1) for q in quats] except KeyError: errors.append('Pointwise orientation (quaternion) data ({}) not readable'.format(dataset)) @@ -123,7 +123,7 @@ for name in filenames: dataset = os.path.join(group_average,options.quaternion) try: - rot = [damask.Rotation.fromQuaternion(q,True,P=+1) for q in inFile[dataset][...][1:]] # skip first entry (unindexed) + rot = [damask.Rotation.from_quaternion(q,True,P=+1) for q in inFile[dataset][...][1:]] # skip first entry (unindexed) except KeyError: errors.append('Average orientation data ({}) not readable'.format(dataset)) diff --git a/processing/pre/geom_rotate.py b/processing/pre/geom_rotate.py index 977e00b65..7a774200b 100755 --- a/processing/pre/geom_rotate.py +++ b/processing/pre/geom_rotate.py @@ -59,13 +59,13 @@ if [options.rotation,options.eulers,options.matrix,options.quaternion].count(Non parser.error('no rotation specified.') if options.quaternion is not None: - rot = damask.Rotation.fromQuaternion(np.array(options.quaternion)) # we might need P=+1 here, too... + rot = damask.Rotation.from_quaternion(np.array(options.quaternion)) # we might need P=+1 here, too... if options.rotation is not None: - rot = damask.Rotation.fromAxisAngle(np.array(options.rotation),degrees=options.degrees,normalise=True,P=+1) + rot = damask.Rotation.from_axis_angle(np.array(options.rotation),degrees=options.degrees,normalise=True,P=+1) if options.matrix is not None: - rot = damask.Rotation.fromMatrix(np.array(options.Matrix)) + rot = damask.Rotation.from_matrix(np.array(options.Matrix)) if options.eulers is not None: - rot = damask.Rotation.fromEulers(np.array(options.eulers),degrees=options.degrees) + rot = damask.Rotation.from_Eulers(np.array(options.eulers),degrees=options.degrees) eulers = rot.asEulers(degrees=True) diff --git a/python/damask/_lattice.py b/python/damask/_lattice.py index 42aa0e9bd..5c8166508 100644 --- a/python/damask/_lattice.py +++ b/python/damask/_lattice.py @@ -634,6 +634,6 @@ class Lattice: otherDir = miller[otherDir_id]/ np.linalg.norm(miller[otherDir_id]) otherMatrix = np.array([otherDir,np.cross(otherPlane,otherDir),otherPlane]) - r['rotations'].append(Rotation.fromMatrix(np.dot(otherMatrix.T,myMatrix))) + r['rotations'].append(Rotation.from_matrix(np.dot(otherMatrix.T,myMatrix))) return r diff --git a/python/damask/_orientation.py b/python/damask/_orientation.py index e6c732007..c145dc42b 100644 --- a/python/damask/_orientation.py +++ b/python/damask/_orientation.py @@ -36,7 +36,7 @@ class Orientation: if isinstance(rotation, Rotation): self.rotation = rotation else: - self.rotation = Rotation.fromQuaternion(rotation) # assume quaternion + self.rotation = Rotation.from_quaternion(rotation) # assume quaternion if self.rotation.quaternion.shape != (4,): raise NotImplementedError('Support for multiple rotations missing') diff --git a/python/tests/test_Orientation.py b/python/tests/test_Orientation.py index 08f060887..bb8810c49 100644 --- a/python/tests/test_Orientation.py +++ b/python/tests/test_Orientation.py @@ -14,7 +14,7 @@ n = 1000 @pytest.fixture def default(): """A set of n random rotations.""" - return [Rotation.fromRandom() for r in range(n)] + return [Rotation.from_random() for r in range(n)] @pytest.fixture def reference_dir(reference_dir_base): @@ -36,7 +36,7 @@ class TestOrientation: @pytest.mark.parametrize('lattice',Lattice.lattices) def test_IPF(self,lattice): direction = np.random.random(3)*2.0-1 - for rot in [Rotation.fromRandom() for r in range(n//100)]: + for rot in [Rotation.from_random() for r in range(n//100)]: R = damask.Orientation(rot,lattice) color = R.IPFcolor(direction) for equivalent in R.equivalentOrientations(): @@ -45,7 +45,7 @@ class TestOrientation: @pytest.mark.parametrize('model',['Bain','KS','GT','GT_prime','NW','Pitsch']) @pytest.mark.parametrize('lattice',['fcc','bcc']) def test_relationship_forward_backward(self,model,lattice): - ori = Orientation(Rotation.fromRandom(),lattice) + ori = Orientation(Rotation.from_random(),lattice) for i,r in enumerate(ori.relatedOrientations(model)): ori2 = r.relatedOrientations(model)[i] misorientation = ori.rotation.misorientation(ori2.rotation) From 19638168e63ce2fc23cd7f60e63e7c0f3230948b Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 16 May 2020 13:23:32 +0200 Subject: [PATCH 041/136] more sensible type checking and errors --- python/damask/_rotation.py | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 3a046363f..7abe06110 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -98,7 +98,7 @@ class Rotation: """ if self.quaternion.shape != (4,): raise NotImplementedError('Support for multiple rotations missing') - if isinstance(other, Rotation): # rotate a rotation + if isinstance(other, Rotation): self_q = self.quaternion[0] self_p = self.quaternion[1:] other_q = other.quaternion[0] @@ -106,22 +106,23 @@ class Rotation: R = self.__class__(np.append(self_q*other_q - np.dot(self_p,other_p), self_q*other_p + other_q*self_p + _P * np.cross(self_p,other_p))) return R.standardize() - elif isinstance(other, (tuple,np.ndarray)): - if isinstance(other,tuple) or other.shape == (3,): # rotate a single (3)-vector or meshgrid + elif isinstance(other, np.ndarray): + if other.shape == (3,): A = self.quaternion[0]**2.0 - np.dot(self.quaternion[1:],self.quaternion[1:]) B = 2.0 * np.dot(self.quaternion[1:],other) C = 2.0 * _P*self.quaternion[0] return A*other + B*self.quaternion[1:] + C * np.cross(self.quaternion[1:],other) - elif other.shape == (3,3,): # rotate a single (3x3)-matrix + elif other.shape == (3,3,): return np.dot(self.asMatrix(),np.dot(other,self.asMatrix().T)) elif other.shape == (3,3,3,3,): - raise NotImplementedError('Support for rotation of 4th order tensors missing') + R = self.asMatrix() + return np.einsum('...im,...jn,...ko,...lp,...mnop',R,R,R,R,other) else: - return NotImplemented + raise ValueError('Can only rotate vectors, 2nd order ternsors, and 4th order tensors') else: - return NotImplemented + raise TypeError('Cannot rotate {}'.format(type(other))) def __matmul__(self, other): @@ -130,7 +131,7 @@ class Rotation: details to be discussed """ - if isinstance(other, Rotation): # rotate a rotation + if isinstance(other, Rotation): q_m = self.quaternion[...,0:1] p_m = self.quaternion[...,1:] q_o = other.quaternion[...,0:1] @@ -157,8 +158,10 @@ class Rotation: if self.shape + (3,3,3,3) == other.shape: R = self.asMatrix() return np.einsum('...im,...jn,...ko,...lp,...mnop',R,R,R,R,other) + else: + raise ValueError('Can only rotate vectors, 2nd order ternsors, and 4th order tensors') else: - raise ValueError + raise TypeError('Cannot rotate {}'.format(type(other))) def inverse(self): """In-place inverse rotation/backward rotation.""" From 61ac40c259773671291f0fa7400d7eaeb73a8c45 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 16 May 2020 13:44:07 +0200 Subject: [PATCH 042/136] more tests --- python/tests/test_Orientation.py | 13 +++------- python/tests/test_Rotation.py | 44 ++++++++++++++++++++++++++++---- 2 files changed, 43 insertions(+), 14 deletions(-) diff --git a/python/tests/test_Orientation.py b/python/tests/test_Orientation.py index bb8810c49..8dc526325 100644 --- a/python/tests/test_Orientation.py +++ b/python/tests/test_Orientation.py @@ -8,13 +8,8 @@ import damask from damask import Rotation from damask import Orientation from damask import Lattice - -n = 1000 -@pytest.fixture -def default(): - """A set of n random rotations.""" - return [Rotation.from_random() for r in range(n)] +n = 1000 @pytest.fixture def reference_dir(reference_dir_base): @@ -28,10 +23,10 @@ class TestOrientation: {'label':'green','RGB':[0,1,0],'direction':[0,1,1]}, {'label':'blue', 'RGB':[0,0,1],'direction':[1,1,1]}]) @pytest.mark.parametrize('lattice',['fcc','bcc']) - def test_IPF_cubic(self,default,color,lattice): + def test_IPF_cubic(self,color,lattice): cube = damask.Orientation(damask.Rotation(),lattice) for direction in set(permutations(np.array(color['direction']))): - assert np.allclose(cube.IPFcolor(direction),np.array(color['RGB'])) + assert np.allclose(cube.IPFcolor(np.array(direction)),np.array(color['RGB'])) @pytest.mark.parametrize('lattice',Lattice.lattices) def test_IPF(self,lattice): @@ -57,7 +52,7 @@ class TestOrientation: reference = os.path.join(reference_dir,'{}_{}.txt'.format(lattice,model)) ori = Orientation(Rotation(),lattice) eu = np.array([o.rotation.asEulers(degrees=True) for o in ori.relatedOrientations(model)]) - if update: + if update: coords = np.array([(1,i+1) for i,x in enumerate(eu)]) table = damask.Table(eu,{'Eulers':(3,)}) table.add('pos',coords) diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index ffa1548d7..23ab03ff6 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -177,7 +177,7 @@ class TestRotation: (Rotation.from_Rodrigues, np.array([1,0,0,-1])), (Rotation.from_Rodrigues, np.array([1,1,0,1])), (Rotation.from_homochoric, np.array([2,2,2])) ]) - def test_invalid(self,function,invalid): + def test_invalid_value(self,function,invalid): with pytest.raises(ValueError): function(invalid) @@ -302,8 +302,42 @@ class TestRotation: assert np.all(np.take_along_axis(np.take_along_axis(a,f,-1),b,-1) == a) - @pytest.mark.parametrize('x',[np.random.rand(3), - np.random.rand(3,3)]) - def test_rotation_identity(self,x): + @pytest.mark.parametrize('data',[np.random.rand(3), + np.random.rand(3,3), + np.random.rand(3,3,3,3)]) + def test_rotate_identity(self,data): R = Rotation() - assert np.allclose(x,R*x) + assert np.allclose(data,R*data) + + @pytest.mark.parametrize('data',[np.random.rand(3), + np.random.rand(3,3), + np.random.rand(3,3,3,3)]) + def test_rotate_360deg(self,data): + phi_1 = np.random.random() * np.pi + phi_2 = 2*np.pi - phi_1 + R_1 = Rotation.from_Eulers(np.array([phi_1,0.,0.])) + R_2 = Rotation.from_Eulers(np.array([0.,0.,phi_2])) + assert np.allclose(data,R_2*(R_1*data)) + + @pytest.mark.parametrize('data',[np.random.rand(3), + np.random.rand(3,3), + np.random.rand(3,3,3,3)]) + def test_rotate_inverse(self,data): + R = Rotation.from_random() + assert np.allclose(data,R.inversed()*(R*data)) + + @pytest.mark.parametrize('data',[np.random.rand(4), + np.random.rand(3,2), + np.random.rand(3,2,3,3)]) + def test_rotate_invalid_shape(self,data): + R = Rotation.from_random() + with pytest.raises(ValueError): + R*data + + @pytest.mark.parametrize('data',['does_not_work', + (1,2), + 5]) + def test_rotate_invalid_type(self,data): + R = Rotation.from_random() + with pytest.raises(TypeError): + R*data From ae20ab8d42134f05aa41481dc69f5092f5fe20e1 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 16 May 2020 17:05:03 +0200 Subject: [PATCH 043/136] more reasonable name --- src/IO.f90 | 6 +++--- src/YAML_types.f90 | 6 +++--- src/lattice.f90 | 6 +++--- src/math.f90 | 8 ++++---- src/prec.f90 | 8 ++++---- src/quaternions.f90 | 6 +++--- src/rotations.f90 | 6 +++--- 7 files changed, 23 insertions(+), 23 deletions(-) diff --git a/src/IO.f90 b/src/IO.f90 index 1bd2df833..c49ca66d0 100644 --- a/src/IO.f90 +++ b/src/IO.f90 @@ -49,7 +49,7 @@ subroutine IO_init write(6,'(/,a)') ' <<<+- IO init -+>>>'; flush(6) - call unitTest + call selfTest end subroutine IO_init @@ -696,7 +696,7 @@ end subroutine IO_warning !-------------------------------------------------------------------------------------------------- !> @brief check correctness of some IO functions !-------------------------------------------------------------------------------------------------- -subroutine unitTest +subroutine selfTest integer, dimension(:), allocatable :: chunkPos character(len=:), allocatable :: str @@ -745,6 +745,6 @@ subroutine unitTest str = IO_rmComment(' ab #') if (str /= ' ab'.or. len(str) /= 3) call IO_error(0,ext_msg='IO_rmComment/7') -end subroutine unitTest +end subroutine selfTest end module IO diff --git a/src/YAML_types.f90 b/src/YAML_types.f90 index 07541bc1a..0282fcb98 100644 --- a/src/YAML_types.f90 +++ b/src/YAML_types.f90 @@ -180,7 +180,7 @@ subroutine YAML_types_init write(6,'(/,a)') ' <<<+- YAML_types init -+>>>' - call unitTest + call selfTest end subroutine YAML_types_init @@ -188,7 +188,7 @@ end subroutine YAML_types_init !-------------------------------------------------------------------------------------------------- !> @brief check correctness of some type bound procedures !-------------------------------------------------------------------------------------------------- -subroutine unitTest +subroutine selfTest class(tNode), pointer :: s1,s2 allocate(tScalar::s1) @@ -260,7 +260,7 @@ subroutine unitTest if(n%get_asString(1) /= 'True') call IO_error(0,ext_msg='byIndex_asString') end block -end subroutine unitTest +end subroutine selfTest !--------------------------------------------------------------------------------------------------- diff --git a/src/lattice.f90 b/src/lattice.f90 index cf985cc19..7a732d2fd 100644 --- a/src/lattice.f90 +++ b/src/lattice.f90 @@ -529,7 +529,7 @@ subroutine lattice_init lattice_DamageMobility(p) = config_phase(p)%getFloat('damage_mobility',defaultVal=0.0_pReal) ! SHOULD NOT BE PART OF LATTICE END - call unitTest + call selfTest enddo @@ -2295,7 +2295,7 @@ end function equivalent_mu !-------------------------------------------------------------------------------------------------- !> @brief check correctness of some lattice functions !-------------------------------------------------------------------------------------------------- -subroutine unitTest +subroutine selfTest real(pReal), dimension(:,:,:), allocatable :: CoSy real(pReal), dimension(:,:), allocatable :: system @@ -2324,6 +2324,6 @@ subroutine unitTest if(dNeq(lambda*0.5_pReal/(lambda+equivalent_mu(C,'reuss')),equivalent_nu(C,'reuss'),1.0e-12_pReal)) & call IO_error(0,ext_msg='equivalent_nu/reuss') -end subroutine unitTest +end subroutine selfTest end module lattice diff --git a/src/math.f90 b/src/math.f90 index 070751de8..33c7c0310 100644 --- a/src/math.f90 +++ b/src/math.f90 @@ -79,7 +79,7 @@ module math !--------------------------------------------------------------------------------------------------- private :: & - unitTest + selfTest contains @@ -113,7 +113,7 @@ subroutine math_init call random_seed(put = randInit) - call unitTest + call selfTest end subroutine math_init @@ -1192,7 +1192,7 @@ end function math_clip !-------------------------------------------------------------------------------------------------- !> @brief check correctness of some math functions !-------------------------------------------------------------------------------------------------- -subroutine unitTest +subroutine selfTest integer, dimension(2,4) :: & sort_in_ = reshape([+1,+5, +5,+6, -1,-1, +3,-2],[2,4]) @@ -1330,6 +1330,6 @@ subroutine unitTest if(dNeq0(math_LeviCivita(ijk(1),ijk(2),ijk(3))))& call IO_error(0,ext_msg='math_LeviCivita') -end subroutine unitTest +end subroutine selfTest end module math diff --git a/src/prec.f90 b/src/prec.f90 index 646f7dd69..73649f76b 100644 --- a/src/prec.f90 +++ b/src/prec.f90 @@ -75,7 +75,7 @@ module prec emptyStringArray = [character(len=pStringLen)::] private :: & - unitTest + selfTest contains @@ -94,7 +94,7 @@ subroutine prec_init write(6,'(a,e10.3)') ' Minimum value: ',tiny(0.0_pReal) write(6,'(a,i3)') ' Decimal precision: ',precision(0.0_pReal) - call unitTest + call selfTest end subroutine prec_init @@ -233,7 +233,7 @@ end function cNeq !-------------------------------------------------------------------------------------------------- !> @brief check correctness of some prec functions !-------------------------------------------------------------------------------------------------- -subroutine unitTest +subroutine selfTest integer, allocatable, dimension(:) :: realloc_lhs_test real(pReal), dimension(2) :: r @@ -249,6 +249,6 @@ subroutine unitTest realloc_lhs_test = [1,2] if (any(realloc_lhs_test/=[1,2])) call quit(9000) -end subroutine unitTest +end subroutine selfTest end module prec diff --git a/src/quaternions.f90 b/src/quaternions.f90 index 991f970ab..f5f5276e8 100644 --- a/src/quaternions.f90 +++ b/src/quaternions.f90 @@ -112,7 +112,7 @@ contains subroutine quaternions_init write(6,'(/,a)') ' <<<+- quaternions init -+>>>'; flush(6) - call unitTest + call selfTest end subroutine quaternions_init @@ -457,7 +457,7 @@ end function inverse !-------------------------------------------------------------------------------------------------- !> @brief check correctness of some quaternions functions !-------------------------------------------------------------------------------------------------- -subroutine unitTest +subroutine selfTest real(pReal), dimension(4) :: qu type(quaternion) :: q, q_2 @@ -524,7 +524,7 @@ subroutine unitTest endif #endif -end subroutine unitTest +end subroutine selfTest end module quaternions diff --git a/src/rotations.f90 b/src/rotations.f90 index fea642170..42afb48e9 100644 --- a/src/rotations.f90 +++ b/src/rotations.f90 @@ -105,7 +105,7 @@ subroutine rotations_init call quaternions_init write(6,'(/,a)') ' <<<+- rotations init -+>>>'; flush(6) - call unitTest + call selfTest end subroutine rotations_init @@ -1340,7 +1340,7 @@ end function GetPyramidOrder !-------------------------------------------------------------------------------------------------- !> @brief check correctness of some rotations functions !-------------------------------------------------------------------------------------------------- -subroutine unitTest +subroutine selfTest type(rotation) :: R real(pReal), dimension(4) :: qu, ax, ro @@ -1443,7 +1443,7 @@ subroutine unitTest enddo -end subroutine unitTest +end subroutine selfTest end module rotations From 044f069437d5b0b4a6d5a6039e803abeda22fc5b Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 16 May 2020 17:06:55 +0200 Subject: [PATCH 044/136] bugfix: selected wrong data --- python/damask/grid_filters.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/python/damask/grid_filters.py b/python/damask/grid_filters.py index 62e9147f7..76ab20872 100644 --- a/python/damask/grid_filters.py +++ b/python/damask/grid_filters.py @@ -361,7 +361,7 @@ def node_2_cell(node_data): + _np.roll(node_data,1,(0,)) + _np.roll(node_data,1,(1,)) + _np.roll(node_data,1,(2,)) + _np.roll(node_data,1,(0,1)) + _np.roll(node_data,1,(1,2)) + _np.roll(node_data,1,(2,0)))*0.125 - return c[:-1,:-1,:-1] + return c[1:,1:,1:] def node_coord0_gridSizeOrigin(coord0,ordered=True): From a4dfd7fc744e34b5ee7b6e0320c7be19c0a90b35 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 16 May 2020 17:23:05 +0200 Subject: [PATCH 045/136] missing tests --- python/tests/test_Table.py | 15 ++++++++++----- python/tests/test_grid_filters.py | 19 ++++++++++++++++--- 2 files changed, 26 insertions(+), 8 deletions(-) diff --git a/python/tests/test_Table.py b/python/tests/test_Table.py index cfcdd8813..ac7444808 100644 --- a/python/tests/test_Table.py +++ b/python/tests/test_Table.py @@ -18,7 +18,7 @@ def reference_dir(reference_dir_base): return os.path.join(reference_dir_base,'Table') class TestTable: - + def test_get_scalar(self,default): d = default.get('s') assert np.allclose(d,1.0) and d.shape[1:] == (1,) @@ -29,12 +29,12 @@ class TestTable: def test_get_tensor(self,default): d = default.get('F') - assert np.allclose(d,1.0) and d.shape[1:] == (3,3) + assert np.allclose(d,1.0) and d.shape[1:] == (3,3) def test_get_component(self,default): d = default.get('5_F') assert np.allclose(d,1.0) and d.shape[1:] == (1,) - + def test_write_read_str(self,default,tmpdir): default.to_ASCII(str(tmpdir.join('default.txt'))) new = Table.from_ASCII(str(tmpdir.join('default.txt'))) @@ -69,15 +69,20 @@ class TestTable: def test_read_strange(self,reference_dir,fname): with open(os.path.join(reference_dir,fname)) as f: Table.from_ASCII(f) - + def test_set(self,default): default.set('F',np.zeros((5,3,3)),'set to zero') d=default.get('F') assert np.allclose(d,0.0) and d.shape[1:] == (3,3) + def test_set_component(self,default): + default.set('1_F',np.zeros((5)),'set to zero') + d=default.get('F') + assert np.allclose(d[...,0,0],0.0) and d.shape[1:] == (3,3) + def test_labels(self,default): assert default.labels == ['F','v','s'] - + def test_add(self,default): d = np.random.random((5,9)) default.add('nine',d,'random data') diff --git a/python/tests/test_grid_filters.py b/python/tests/test_grid_filters.py index ab60c0446..8a343e26b 100644 --- a/python/tests/test_grid_filters.py +++ b/python/tests/test_grid_filters.py @@ -42,12 +42,25 @@ class TestGridFilters: assert np.allclose(grid_filters.node_displacement_fluct(size,F), grid_filters.cell_2_node(grid_filters.cell_displacement_fluct(size,F))) - def test_interpolation_nonperiodic(self): + def test_interpolation_to_node(self): size = np.random.random(3) grid = np.random.randint(8,32,(3)) F = np.random.random(tuple(grid)+(3,3)) - assert np.allclose(grid_filters.node_coord(size,F) [1:-1,1:-1,1:-1],grid_filters.cell_2_node( - grid_filters.cell_coord(size,F))[1:-1,1:-1,1:-1]) + assert np.allclose(grid_filters.node_coord(size,F) [1:-1,1:-1,1:-1], + grid_filters.cell_2_node(grid_filters.cell_coord(size,F))[1:-1,1:-1,1:-1]) + + def test_interpolation_to_cell(self): + grid = np.random.randint(1,30,(3)) + + node_coord_x = np.linspace(0,np.pi*2,num=grid[0]+1) + node_field_x = np.cos(node_coord_x) + node_field = np.broadcast_to(node_field_x.reshape(-1,1,1),grid+1) + + cell_coord_x = node_coord_x[:-1]+node_coord_x[1]*.5 + cell_field_x = np.interp(cell_coord_x,node_coord_x,node_field_x,period=np.pi*2.) + cell_field = np.broadcast_to(cell_field_x.reshape(-1,1,1),grid) + + assert np.allclose(cell_field,grid_filters.node_2_cell(node_field)) @pytest.mark.parametrize('mode',['cell','node']) def test_coord0_origin(self,mode): From d8764f2b8fee0ac13ecf0613b28f8a971ddbfabe Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 16 May 2020 18:32:30 +0200 Subject: [PATCH 046/136] status is not the first argument --- src/DAMASK_interface.f90 | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/DAMASK_interface.f90 b/src/DAMASK_interface.f90 index 56824d820..8e4369840 100644 --- a/src/DAMASK_interface.f90 +++ b/src/DAMASK_interface.f90 @@ -237,13 +237,13 @@ subroutine DAMASK_interface_init write(6,'(a,/)')' Prints this message and exits' call quit(0) ! normal Termination case ('-l', '--load', '--loadcase') - call get_command_argument(i+1,loadCaseArg,err) + call get_command_argument(i+1,loadCaseArg,status=err) case ('-g', '--geom', '--geometry') - call get_command_argument(i+1,geometryArg,err) + call get_command_argument(i+1,geometryArg,status=err) case ('-w', '--wd', '--workingdir', '--workingdirectory') - call get_command_argument(i+1,workingDirArg,err) + call get_command_argument(i+1,workingDirArg,status=err) case ('-r', '--rs', '--restart') - call get_command_argument(i+1,arg,err) + call get_command_argument(i+1,arg,status=err) read(arg,*,iostat=stat) interface_restartInc if (interface_restartInc < 0 .or. stat /=0) then write(6,'(/,a)') ' ERROR: Could not parse restart increment: '//trim(arg) From 2f8501dbaed9fd964bfb8d82ba63af89cbf79cb2 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 16 May 2020 20:55:05 +0200 Subject: [PATCH 047/136] current state (misc-improvements and master) --- PRIVATE | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/PRIVATE b/PRIVATE index 038af521a..72d526e57 160000 --- a/PRIVATE +++ b/PRIVATE @@ -1 +1 @@ -Subproject commit 038af521a1ef70ed77b132c426bc1a4880db01ef +Subproject commit 72d526e5750366a9efe4d1fd9d92e0d1ecd2cd38 From 74bfed96b24b23275a27e2df91ded6d0c937af02 Mon Sep 17 00:00:00 2001 From: Test User Date: Sat, 16 May 2020 23:34:38 +0200 Subject: [PATCH 048/136] [skip ci] updated version information after successful test of v2.0.3-2504-gcee9daff --- VERSION | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/VERSION b/VERSION index 29f305cbe..3ba40668a 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -v2.0.3-2464-g90f93d23 +v2.0.3-2504-gcee9daff From a90865c8777616925afedc632f0b747435415022 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 16 May 2020 21:56:30 +0200 Subject: [PATCH 049/136] non-vectorized versions not needed anymore using them only for testing purposes --- python/damask/_rotation.py | 672 +++++++++------------------- python/tests/rotation_conversion.py | 399 +++++++++++++++++ python/tests/test_Rotation.py | 127 +++--- 3 files changed, 658 insertions(+), 540 deletions(-) create mode 100644 python/tests/rotation_conversion.py diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 7abe06110..5258145e0 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -549,67 +549,42 @@ class Rotation: #---------- Quaternion ---------- @staticmethod def qu2om(qu): - if len(qu.shape) == 1: - """Quaternion to rotation matrix.""" - qq = qu[0]**2-(qu[1]**2 + qu[2]**2 + qu[3]**2) - om = np.diag(qq + 2.0*np.array([qu[1],qu[2],qu[3]])**2) - - om[0,1] = 2.0*(qu[2]*qu[1]+qu[0]*qu[3]) - om[1,0] = 2.0*(qu[1]*qu[2]-qu[0]*qu[3]) - om[1,2] = 2.0*(qu[3]*qu[2]+qu[0]*qu[1]) - om[2,1] = 2.0*(qu[2]*qu[3]-qu[0]*qu[1]) - om[2,0] = 2.0*(qu[1]*qu[3]+qu[0]*qu[2]) - om[0,2] = 2.0*(qu[3]*qu[1]-qu[0]*qu[2]) - else: - qq = qu[...,0:1]**2-(qu[...,1:2]**2 + qu[...,2:3]**2 + qu[...,3:4]**2) - om = np.block([qq + 2.0*qu[...,1:2]**2, - 2.0*(qu[...,2:3]*qu[...,1:2]+qu[...,0:1]*qu[...,3:4]), - 2.0*(qu[...,3:4]*qu[...,1:2]-qu[...,0:1]*qu[...,2:3]), - 2.0*(qu[...,1:2]*qu[...,2:3]-qu[...,0:1]*qu[...,3:4]), - qq + 2.0*qu[...,2:3]**2, - 2.0*(qu[...,3:4]*qu[...,2:3]+qu[...,0:1]*qu[...,1:2]), - 2.0*(qu[...,1:2]*qu[...,3:4]+qu[...,0:1]*qu[...,2:3]), - 2.0*(qu[...,2:3]*qu[...,3:4]-qu[...,0:1]*qu[...,1:2]), - qq + 2.0*qu[...,3:4]**2, - ]).reshape(qu.shape[:-1]+(3,3)) + qq = qu[...,0:1]**2-(qu[...,1:2]**2 + qu[...,2:3]**2 + qu[...,3:4]**2) + om = np.block([qq + 2.0*qu[...,1:2]**2, + 2.0*(qu[...,2:3]*qu[...,1:2]+qu[...,0:1]*qu[...,3:4]), + 2.0*(qu[...,3:4]*qu[...,1:2]-qu[...,0:1]*qu[...,2:3]), + 2.0*(qu[...,1:2]*qu[...,2:3]-qu[...,0:1]*qu[...,3:4]), + qq + 2.0*qu[...,2:3]**2, + 2.0*(qu[...,3:4]*qu[...,2:3]+qu[...,0:1]*qu[...,1:2]), + 2.0*(qu[...,1:2]*qu[...,3:4]+qu[...,0:1]*qu[...,2:3]), + 2.0*(qu[...,2:3]*qu[...,3:4]-qu[...,0:1]*qu[...,1:2]), + qq + 2.0*qu[...,3:4]**2, + ]).reshape(qu.shape[:-1]+(3,3)) return om if _P < 0.0 else np.swapaxes(om,(-1,-2)) @staticmethod def qu2eu(qu): """Quaternion to Bunge-Euler angles.""" - if len(qu.shape) == 1: - q03 = qu[0]**2+qu[3]**2 - q12 = qu[1]**2+qu[2]**2 - chi = np.sqrt(q03*q12) - if np.abs(q12) < 1.e-8: - eu = np.array([np.arctan2(-_P*2.0*qu[0]*qu[3],qu[0]**2-qu[3]**2), 0.0, 0.0]) - elif np.abs(q03) < 1.e-8: - eu = np.array([np.arctan2( 2.0*qu[1]*qu[2],qu[1]**2-qu[2]**2), np.pi, 0.0]) - else: - eu = np.array([np.arctan2((-_P*qu[0]*qu[2]+qu[1]*qu[3])*chi, (-_P*qu[0]*qu[1]-qu[2]*qu[3])*chi ), - np.arctan2( 2.0*chi, q03-q12 ), - np.arctan2(( _P*qu[0]*qu[2]+qu[1]*qu[3])*chi, (-_P*qu[0]*qu[1]+qu[2]*qu[3])*chi )]) - else: - q02 = qu[...,0:1]*qu[...,2:3] - q13 = qu[...,1:2]*qu[...,3:4] - q01 = qu[...,0:1]*qu[...,1:2] - q23 = qu[...,2:3]*qu[...,3:4] - q03_s = qu[...,0:1]**2+qu[...,3:4]**2 - q12_s = qu[...,1:2]**2+qu[...,2:3]**2 - chi = np.sqrt(q03_s*q12_s) + q02 = qu[...,0:1]*qu[...,2:3] + q13 = qu[...,1:2]*qu[...,3:4] + q01 = qu[...,0:1]*qu[...,1:2] + q23 = qu[...,2:3]*qu[...,3:4] + q03_s = qu[...,0:1]**2+qu[...,3:4]**2 + q12_s = qu[...,1:2]**2+qu[...,2:3]**2 + chi = np.sqrt(q03_s*q12_s) - eu = np.where(np.abs(q12_s) < 1.0e-8, - np.block([np.arctan2(-_P*2.0*qu[...,0:1]*qu[...,3:4],qu[...,0:1]**2-qu[...,3:4]**2), - np.zeros(qu.shape[:-1]+(2,))]), - np.where(np.abs(q03_s) < 1.0e-8, - np.block([np.arctan2( 2.0*qu[...,1:2]*qu[...,2:3],qu[...,1:2]**2-qu[...,2:3]**2), - np.broadcast_to(np.pi,qu.shape[:-1]+(1,)), - np.zeros(qu.shape[:-1]+(1,))]), - np.block([np.arctan2((-_P*q02+q13)*chi, (-_P*q01-q23)*chi), - np.arctan2( 2.0*chi, q03_s-q12_s ), - np.arctan2(( _P*q02+q13)*chi, (-_P*q01+q23)*chi)]) - ) - ) + eu = np.where(np.abs(q12_s) < 1.0e-8, + np.block([np.arctan2(-_P*2.0*qu[...,0:1]*qu[...,3:4],qu[...,0:1]**2-qu[...,3:4]**2), + np.zeros(qu.shape[:-1]+(2,))]), + np.where(np.abs(q03_s) < 1.0e-8, + np.block([np.arctan2( 2.0*qu[...,1:2]*qu[...,2:3],qu[...,1:2]**2-qu[...,2:3]**2), + np.broadcast_to(np.pi,qu.shape[:-1]+(1,)), + np.zeros(qu.shape[:-1]+(1,))]), + np.block([np.arctan2((-_P*q02+q13)*chi, (-_P*q01-q23)*chi), + np.arctan2( 2.0*chi, q03_s-q12_s ), + np.arctan2(( _P*q02+q13)*chi, (-_P*q01+q23)*chi)]) + ) + ) # reduce Euler angles to definition range eu[np.abs(eu)<1.e-6] = 0.0 eu = np.where(eu<0, (eu+2.0*np.pi)%np.array([2.0*np.pi,np.pi,2.0*np.pi]),eu) @@ -622,65 +597,38 @@ class Rotation: Modified version of the original formulation, should be numerically more stable """ - if len(qu.shape) == 1: - if np.abs(np.sum(qu[1:4]**2)) < 1.e-6: # set axis to [001] if the angle is 0/360 - ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) - elif qu[0] > 1.e-6: - s = np.sign(qu[0])/np.sqrt(qu[1]**2+qu[2]**2+qu[3]**2) - omega = 2.0 * np.arccos(np.clip(qu[0],-1.0,1.0)) - ax = ax = np.array([ qu[1]*s, qu[2]*s, qu[3]*s, omega ]) - else: - ax = ax = np.array([ qu[1], qu[2], qu[3], np.pi]) - else: - with np.errstate(invalid='ignore',divide='ignore'): - s = np.sign(qu[...,0:1])/np.sqrt(qu[...,1:2]**2+qu[...,2:3]**2+qu[...,3:4]**2) - omega = 2.0 * np.arccos(np.clip(qu[...,0:1],-1.0,1.0)) - ax = np.where(np.broadcast_to(qu[...,0:1] < 1.0e-6,qu.shape), - np.block([qu[...,1:4],np.broadcast_to(np.pi,qu.shape[:-1]+(1,))]), - np.block([qu[...,1:4]*s,omega])) - ax[np.sum(np.abs(qu[...,1:4])**2,axis=-1) < 1.0e-6,] = [0.0, 0.0, 1.0, 0.0] + with np.errstate(invalid='ignore',divide='ignore'): + s = np.sign(qu[...,0:1])/np.sqrt(qu[...,1:2]**2+qu[...,2:3]**2+qu[...,3:4]**2) + omega = 2.0 * np.arccos(np.clip(qu[...,0:1],-1.0,1.0)) + ax = np.where(np.broadcast_to(qu[...,0:1] < 1.0e-6,qu.shape), + np.block([qu[...,1:4],np.broadcast_to(np.pi,qu.shape[:-1]+(1,))]), + np.block([qu[...,1:4]*s,omega])) + ax[np.sum(np.abs(qu[...,1:4])**2,axis=-1) < 1.0e-6,] = [0.0, 0.0, 1.0, 0.0] return ax @staticmethod def qu2ro(qu): """Quaternion to Rodrigues-Frank vector.""" - if len(qu.shape) == 1: - if iszero(qu[0]): - ro = np.array([qu[1], qu[2], qu[3], np.inf]) - else: - s = np.linalg.norm(qu[1:4]) - ro = np.array([0.0,0.0,_P,0.0] if iszero(s) else \ - [ qu[1]/s, qu[2]/s, qu[3]/s, np.tan(np.arccos(np.clip(qu[0],-1.0,1.0)))]) - else: - with np.errstate(invalid='ignore',divide='ignore'): - s = np.linalg.norm(qu[...,1:4],axis=-1,keepdims=True) - ro = np.where(np.broadcast_to(np.abs(qu[...,0:1]) < 1.0e-12,qu.shape), - np.block([qu[...,1:2], qu[...,2:3], qu[...,3:4], np.broadcast_to(np.inf,qu.shape[:-1]+(1,))]), - np.block([qu[...,1:2]/s,qu[...,2:3]/s,qu[...,3:4]/s, - np.tan(np.arccos(np.clip(qu[...,0:1],-1.0,1.0))) - ]) - ) - ro[np.abs(s).squeeze(-1) < 1.0e-12] = [0.0,0.0,_P,0.0] + with np.errstate(invalid='ignore',divide='ignore'): + s = np.linalg.norm(qu[...,1:4],axis=-1,keepdims=True) + ro = np.where(np.broadcast_to(np.abs(qu[...,0:1]) < 1.0e-12,qu.shape), + np.block([qu[...,1:2], qu[...,2:3], qu[...,3:4], np.broadcast_to(np.inf,qu.shape[:-1]+(1,))]), + np.block([qu[...,1:2]/s,qu[...,2:3]/s,qu[...,3:4]/s, + np.tan(np.arccos(np.clip(qu[...,0:1],-1.0,1.0))) + ]) + ) + ro[np.abs(s).squeeze(-1) < 1.0e-12] = [0.0,0.0,_P,0.0] return ro @staticmethod def qu2ho(qu): """Quaternion to homochoric vector.""" - if len(qu.shape) == 1: - omega = 2.0 * np.arccos(np.clip(qu[0],-1.0,1.0)) - if np.abs(omega) < 1.0e-12: - ho = np.zeros(3) - else: - ho = np.array([qu[1], qu[2], qu[3]]) - f = 0.75 * ( omega - np.sin(omega) ) - ho = ho/np.linalg.norm(ho) * f**(1./3.) - else: - with np.errstate(invalid='ignore'): - omega = 2.0 * np.arccos(np.clip(qu[...,0:1],-1.0,1.0)) - ho = np.where(np.abs(omega) < 1.0e-12, - np.zeros(3), - qu[...,1:4]/np.linalg.norm(qu[...,1:4],axis=-1,keepdims=True) \ - * (0.75*(omega - np.sin(omega)))**(1./3.)) + with np.errstate(invalid='ignore'): + omega = 2.0 * np.arccos(np.clip(qu[...,0:1],-1.0,1.0)) + ho = np.where(np.abs(omega) < 1.0e-12, + np.zeros(3), + qu[...,1:4]/np.linalg.norm(qu[...,1:4],axis=-1,keepdims=True) \ + * (0.75*(omega - np.sin(omega)))**(1./3.)) return ho @staticmethod @@ -702,27 +650,18 @@ class Rotation: @staticmethod def om2eu(om): """Rotation matrix to Bunge-Euler angles.""" - if len(om.shape) == 2: - if not np.isclose(np.abs(om[2,2]),1.0,1.e-4): - zeta = 1.0/np.sqrt(1.0-om[2,2]**2) - eu = np.array([np.arctan2(om[2,0]*zeta,-om[2,1]*zeta), - np.arccos(om[2,2]), - np.arctan2(om[0,2]*zeta, om[1,2]*zeta)]) - else: - eu = np.array([np.arctan2( om[0,1],om[0,0]), np.pi*0.5*(1-om[2,2]),0.0]) # following the paper, not the reference implementation - else: - with np.errstate(invalid='ignore',divide='ignore'): - zeta = 1.0/np.sqrt(1.0-om[...,2,2:3]**2) - eu = np.where(np.isclose(np.abs(om[...,2,2:3]),1.0,1e-4), - np.block([np.arctan2(om[...,0,1:2],om[...,0,0:1]), - np.pi*0.5*(1-om[...,2,2:3]), - np.zeros(om.shape[:-2]+(1,)), - ]), - np.block([np.arctan2(om[...,2,0:1]*zeta,-om[...,2,1:2]*zeta), - np.arccos(om[...,2,2:3]), - np.arctan2(om[...,0,2:3]*zeta,+om[...,1,2:3]*zeta) - ]) - ) + with np.errstate(invalid='ignore',divide='ignore'): + zeta = 1.0/np.sqrt(1.0-om[...,2,2:3]**2) + eu = np.where(np.isclose(np.abs(om[...,2,2:3]),1.0,1e-4), + np.block([np.arctan2(om[...,0,1:2],om[...,0,0:1]), + np.pi*0.5*(1-om[...,2,2:3]), + np.zeros(om.shape[:-2]+(1,)), + ]), + np.block([np.arctan2(om[...,2,0:1]*zeta,-om[...,2,1:2]*zeta), + np.arccos(om[...,2,2:3]), + np.arctan2(om[...,0,2:3]*zeta,+om[...,1,2:3]*zeta) + ]) + ) eu[np.abs(eu)<1.e-6] = 0.0 eu = np.where(eu<0, (eu+2.0*np.pi)%np.array([2.0*np.pi,np.pi,2.0*np.pi]),eu) return eu @@ -731,40 +670,23 @@ class Rotation: @staticmethod def om2ax(om): """Rotation matrix to axis angle pair.""" - if len(om.shape) == 2: - ax=np.empty(4) - - # first get the rotation angle - t = 0.5*(om.trace() -1.0) - ax[3] = np.arccos(np.clip(t,-1.0,1.0)) - if np.abs(ax[3])<1.e-6: - ax = np.array([ 0.0, 0.0, 1.0, 0.0]) - else: - w,vr = np.linalg.eig(om) - # next, find the eigenvalue (1,0j) - i = np.where(np.isclose(w,1.0+0.0j))[0][0] - ax[0:3] = np.real(vr[0:3,i]) - diagDelta = -_P*np.array([om[1,2]-om[2,1],om[2,0]-om[0,2],om[0,1]-om[1,0]]) - diagDelta[np.abs(diagDelta)<1.e-6] = 1.0 - ax[0:3] = np.where(np.abs(diagDelta)<0, ax[0:3],np.abs(ax[0:3])*np.sign(diagDelta)) - else: - diag_delta = -_P*np.block([om[...,1,2:3]-om[...,2,1:2], - om[...,2,0:1]-om[...,0,2:3], - om[...,0,1:2]-om[...,1,0:1] - ]) - diag_delta[np.abs(diag_delta)<1.e-6] = 1.0 - t = 0.5*(om.trace(axis2=-2,axis1=-1) -1.0).reshape(om.shape[:-2]+(1,)) - w,vr = np.linalg.eig(om) - # mask duplicated real eigenvalues - w[np.isclose(w[...,0],1.0+0.0j),1:] = 0. - w[np.isclose(w[...,1],1.0+0.0j),2:] = 0. - vr = np.swapaxes(vr,-1,-2) - ax = np.where(np.abs(diag_delta)<0, - np.real(vr[np.isclose(w,1.0+0.0j)]).reshape(om.shape[:-2]+(3,)), - np.abs(np.real(vr[np.isclose(w,1.0+0.0j)]).reshape(om.shape[:-2]+(3,))) \ - *np.sign(diag_delta)) - ax = np.block([ax,np.arccos(np.clip(t,-1.0,1.0))]) - ax[np.abs(ax[...,3])<1.e-6] = [ 0.0, 0.0, 1.0, 0.0] + diag_delta = -_P*np.block([om[...,1,2:3]-om[...,2,1:2], + om[...,2,0:1]-om[...,0,2:3], + om[...,0,1:2]-om[...,1,0:1] + ]) + diag_delta[np.abs(diag_delta)<1.e-6] = 1.0 + t = 0.5*(om.trace(axis2=-2,axis1=-1) -1.0).reshape(om.shape[:-2]+(1,)) + w,vr = np.linalg.eig(om) + # mask duplicated real eigenvalues + w[np.isclose(w[...,0],1.0+0.0j),1:] = 0. + w[np.isclose(w[...,1],1.0+0.0j),2:] = 0. + vr = np.swapaxes(vr,-1,-2) + ax = np.where(np.abs(diag_delta)<0, + np.real(vr[np.isclose(w,1.0+0.0j)]).reshape(om.shape[:-2]+(3,)), + np.abs(np.real(vr[np.isclose(w,1.0+0.0j)]).reshape(om.shape[:-2]+(3,))) \ + *np.sign(diag_delta)) + ax = np.block([ax,np.arccos(np.clip(t,-1.0,1.0))]) + ax[np.abs(ax[...,3])<1.e-6] = [ 0.0, 0.0, 1.0, 0.0] return ax @@ -788,103 +710,61 @@ class Rotation: @staticmethod def eu2qu(eu): """Bunge-Euler angles to quaternion.""" - if len(eu.shape) == 1: - ee = 0.5*eu - cPhi = np.cos(ee[1]) - sPhi = np.sin(ee[1]) - qu = np.array([ cPhi*np.cos(ee[0]+ee[2]), - -_P*sPhi*np.cos(ee[0]-ee[2]), - -_P*sPhi*np.sin(ee[0]-ee[2]), - -_P*cPhi*np.sin(ee[0]+ee[2]) ]) - if qu[0] < 0.0: qu*=-1 - else: - ee = 0.5*eu - cPhi = np.cos(ee[...,1:2]) - sPhi = np.sin(ee[...,1:2]) - qu = np.block([ cPhi*np.cos(ee[...,0:1]+ee[...,2:3]), - -_P*sPhi*np.cos(ee[...,0:1]-ee[...,2:3]), - -_P*sPhi*np.sin(ee[...,0:1]-ee[...,2:3]), - -_P*cPhi*np.sin(ee[...,0:1]+ee[...,2:3])]) - qu[qu[...,0]<0.0]*=-1 + ee = 0.5*eu + cPhi = np.cos(ee[...,1:2]) + sPhi = np.sin(ee[...,1:2]) + qu = np.block([ cPhi*np.cos(ee[...,0:1]+ee[...,2:3]), + -_P*sPhi*np.cos(ee[...,0:1]-ee[...,2:3]), + -_P*sPhi*np.sin(ee[...,0:1]-ee[...,2:3]), + -_P*cPhi*np.sin(ee[...,0:1]+ee[...,2:3])]) + qu[qu[...,0]<0.0]*=-1 return qu @staticmethod def eu2om(eu): """Bunge-Euler angles to rotation matrix.""" - if len(eu.shape) == 1: - c = np.cos(eu) - s = np.sin(eu) - - om = np.array([[+c[0]*c[2]-s[0]*s[2]*c[1], +s[0]*c[2]+c[0]*s[2]*c[1], +s[2]*s[1]], - [-c[0]*s[2]-s[0]*c[2]*c[1], -s[0]*s[2]+c[0]*c[2]*c[1], +c[2]*s[1]], - [+s[0]*s[1], -c[0]*s[1], +c[1] ]]) - else: - c = np.cos(eu) - s = np.sin(eu) - om = np.block([+c[...,0:1]*c[...,2:3]-s[...,0:1]*s[...,2:3]*c[...,1:2], - +s[...,0:1]*c[...,2:3]+c[...,0:1]*s[...,2:3]*c[...,1:2], - +s[...,2:3]*s[...,1:2], - -c[...,0:1]*s[...,2:3]-s[...,0:1]*c[...,2:3]*c[...,1:2], - -s[...,0:1]*s[...,2:3]+c[...,0:1]*c[...,2:3]*c[...,1:2], - +c[...,2:3]*s[...,1:2], - +s[...,0:1]*s[...,1:2], - -c[...,0:1]*s[...,1:2], - +c[...,1:2] - ]).reshape(eu.shape[:-1]+(3,3)) + c = np.cos(eu) + s = np.sin(eu) + om = np.block([+c[...,0:1]*c[...,2:3]-s[...,0:1]*s[...,2:3]*c[...,1:2], + +s[...,0:1]*c[...,2:3]+c[...,0:1]*s[...,2:3]*c[...,1:2], + +s[...,2:3]*s[...,1:2], + -c[...,0:1]*s[...,2:3]-s[...,0:1]*c[...,2:3]*c[...,1:2], + -s[...,0:1]*s[...,2:3]+c[...,0:1]*c[...,2:3]*c[...,1:2], + +c[...,2:3]*s[...,1:2], + +s[...,0:1]*s[...,1:2], + -c[...,0:1]*s[...,1:2], + +c[...,1:2] + ]).reshape(eu.shape[:-1]+(3,3)) om[np.abs(om)<1.e-12] = 0.0 return om @staticmethod def eu2ax(eu): """Bunge-Euler angles to axis angle pair.""" - if len(eu.shape) == 1: - t = np.tan(eu[1]*0.5) - sigma = 0.5*(eu[0]+eu[2]) - delta = 0.5*(eu[0]-eu[2]) - tau = np.linalg.norm([t,np.sin(sigma)]) - alpha = np.pi if iszero(np.cos(sigma)) else \ - 2.0*np.arctan(tau/np.cos(sigma)) - - if np.abs(alpha)<1.e-6: - ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) - else: - ax = -_P/tau * np.array([ t*np.cos(delta), t*np.sin(delta), np.sin(sigma) ]) # passive axis angle pair so a minus sign in front - ax = np.append(ax,alpha) - if alpha < 0.0: ax *= -1.0 # ensure alpha is positive - else: - t = np.tan(eu[...,1:2]*0.5) - sigma = 0.5*(eu[...,0:1]+eu[...,2:3]) - delta = 0.5*(eu[...,0:1]-eu[...,2:3]) - tau = np.linalg.norm(np.block([t,np.sin(sigma)]),axis=-1,keepdims=True) - alpha = np.where(np.abs(np.cos(sigma))<1.e-12,np.pi,2.0*np.arctan(tau/np.cos(sigma))) - with np.errstate(invalid='ignore',divide='ignore'): - ax = np.where(np.broadcast_to(np.abs(alpha)<1.0e-12,eu.shape[:-1]+(4,)), - [0.0,0.0,1.0,0.0], - np.block([-_P/tau*t*np.cos(delta), - -_P/tau*t*np.sin(delta), - -_P/tau* np.sin(sigma), - alpha - ])) - ax[(alpha<0.0).squeeze()] *=-1 + t = np.tan(eu[...,1:2]*0.5) + sigma = 0.5*(eu[...,0:1]+eu[...,2:3]) + delta = 0.5*(eu[...,0:1]-eu[...,2:3]) + tau = np.linalg.norm(np.block([t,np.sin(sigma)]),axis=-1,keepdims=True) + alpha = np.where(np.abs(np.cos(sigma))<1.e-12,np.pi,2.0*np.arctan(tau/np.cos(sigma))) + with np.errstate(invalid='ignore',divide='ignore'): + ax = np.where(np.broadcast_to(np.abs(alpha)<1.0e-12,eu.shape[:-1]+(4,)), + [0.0,0.0,1.0,0.0], + np.block([-_P/tau*t*np.cos(delta), + -_P/tau*t*np.sin(delta), + -_P/tau* np.sin(sigma), + alpha + ])) + ax[(alpha<0.0).squeeze()] *=-1 return ax @staticmethod def eu2ro(eu): """Bunge-Euler angles to Rodrigues-Frank vector.""" - if len(eu.shape) == 1: - ro = Rotation.eu2ax(eu) # convert to axis angle pair representation - if ro[3] >= np.pi: # Differs from original implementation. check convention 5 - ro[3] = np.inf - elif iszero(ro[3]): - ro = np.array([ 0.0, 0.0, _P, 0.0 ]) - else: - ro[3] = np.tan(ro[3]*0.5) - else: - ax = Rotation.eu2ax(eu) - ro = np.block([ax[...,:3],np.tan(ax[...,3:4]*.5)]) - ro[ax[...,3]>=np.pi,3] = np.inf - ro[np.abs(ax[...,3])<1.e-16] = [ 0.0, 0.0, _P, 0.0 ] + ax = Rotation.eu2ax(eu) + ro = np.block([ax[...,:3],np.tan(ax[...,3:4]*.5)]) + ro[ax[...,3]>=np.pi,3] = np.inf + ro[np.abs(ax[...,3])<1.e-16] = [ 0.0, 0.0, _P, 0.0 ] return ro @staticmethod @@ -902,45 +782,26 @@ class Rotation: @staticmethod def ax2qu(ax): """Axis angle pair to quaternion.""" - if len(ax.shape) == 1: - if np.abs(ax[3])<1.e-6: - qu = np.array([ 1.0, 0.0, 0.0, 0.0 ]) - else: - c = np.cos(ax[3]*0.5) - s = np.sin(ax[3]*0.5) - qu = np.array([ c, ax[0]*s, ax[1]*s, ax[2]*s ]) - else: - c = np.cos(ax[...,3:4]*.5) - s = np.sin(ax[...,3:4]*.5) - qu = np.where(np.abs(ax[...,3:4])<1.e-6,[1.0, 0.0, 0.0, 0.0],np.block([c, ax[...,:3]*s])) + c = np.cos(ax[...,3:4]*.5) + s = np.sin(ax[...,3:4]*.5) + qu = np.where(np.abs(ax[...,3:4])<1.e-6,[1.0, 0.0, 0.0, 0.0],np.block([c, ax[...,:3]*s])) return qu @staticmethod def ax2om(ax): """Axis angle pair to rotation matrix.""" - if len(ax.shape) == 1: - c = np.cos(ax[3]) - s = np.sin(ax[3]) - omc = 1.0-c - om=np.diag(ax[0:3]**2*omc + c) - - for idx in [[0,1,2],[1,2,0],[2,0,1]]: - q = omc*ax[idx[0]] * ax[idx[1]] - om[idx[0],idx[1]] = q + s*ax[idx[2]] - om[idx[1],idx[0]] = q - s*ax[idx[2]] - else: - c = np.cos(ax[...,3:4]) - s = np.sin(ax[...,3:4]) - omc = 1. -c - om = np.block([c+omc*ax[...,0:1]**2, - omc*ax[...,0:1]*ax[...,1:2] + s*ax[...,2:3], - omc*ax[...,0:1]*ax[...,2:3] - s*ax[...,1:2], - omc*ax[...,0:1]*ax[...,1:2] - s*ax[...,2:3], - c+omc*ax[...,1:2]**2, - omc*ax[...,1:2]*ax[...,2:3] + s*ax[...,0:1], - omc*ax[...,0:1]*ax[...,2:3] + s*ax[...,1:2], - omc*ax[...,1:2]*ax[...,2:3] - s*ax[...,0:1], - c+omc*ax[...,2:3]**2]).reshape(ax.shape[:-1]+(3,3)) + c = np.cos(ax[...,3:4]) + s = np.sin(ax[...,3:4]) + omc = 1. -c + om = np.block([c+omc*ax[...,0:1]**2, + omc*ax[...,0:1]*ax[...,1:2] + s*ax[...,2:3], + omc*ax[...,0:1]*ax[...,2:3] - s*ax[...,1:2], + omc*ax[...,0:1]*ax[...,1:2] - s*ax[...,2:3], + c+omc*ax[...,1:2]**2, + omc*ax[...,1:2]*ax[...,2:3] + s*ax[...,0:1], + omc*ax[...,0:1]*ax[...,2:3] + s*ax[...,1:2], + omc*ax[...,1:2]*ax[...,2:3] - s*ax[...,0:1], + c+omc*ax[...,2:3]**2]).reshape(ax.shape[:-1]+(3,3)) return om if _P < 0.0 else np.swapaxes(om,(-1,-2)) @staticmethod @@ -951,33 +812,19 @@ class Rotation: @staticmethod def ax2ro(ax): """Axis angle pair to Rodrigues-Frank vector.""" - if len(ax.shape) == 1: - if np.abs(ax[3])<1.e-6: - ro = [ 0.0, 0.0, _P, 0.0 ] - else: - ro = [ax[0], ax[1], ax[2]] - # 180 degree case - ro += [np.inf] if np.isclose(ax[3],np.pi,atol=1.0e-15,rtol=0.0) else \ - [np.tan(ax[3]*0.5)] - ro = np.array(ro) - else: - ro = np.block([ax[...,:3], - np.where(np.isclose(ax[...,3:4],np.pi,atol=1.e-15,rtol=.0), - np.inf, - np.tan(ax[...,3:4]*0.5)) - ]) - ro[np.abs(ax[...,3])<1.e-6] = [.0,.0,_P,.0] + ro = np.block([ax[...,:3], + np.where(np.isclose(ax[...,3:4],np.pi,atol=1.e-15,rtol=.0), + np.inf, + np.tan(ax[...,3:4]*0.5)) + ]) + ro[np.abs(ax[...,3])<1.e-6] = [.0,.0,_P,.0] return ro @staticmethod def ax2ho(ax): """Axis angle pair to homochoric vector.""" - if len(ax.shape) == 1: - f = (0.75 * ( ax[3] - np.sin(ax[3]) ))**(1.0/3.0) - ho = ax[0:3] * f - else: - f = (0.75 * ( ax[...,3:4] - np.sin(ax[...,3:4]) ))**(1.0/3.0) - ho = ax[...,:3] * f + f = (0.75 * ( ax[...,3:4] - np.sin(ax[...,3:4]) ))**(1.0/3.0) + ho = ax[...,:3] * f return ho @staticmethod @@ -1005,36 +852,19 @@ class Rotation: @staticmethod def ro2ax(ro): """Rodrigues-Frank vector to axis angle pair.""" - if len(ro.shape) == 1: - if np.abs(ro[3]) < 1.e-6: - ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) - elif not np.isfinite(ro[3]): - ax = np.array([ ro[0], ro[1], ro[2], np.pi ]) - else: - angle = 2.0*np.arctan(ro[3]) - ta = np.linalg.norm(ro[0:3]) - ax = np.array([ ro[0]*ta, ro[1]*ta, ro[2]*ta, angle ]) - else: - with np.errstate(invalid='ignore',divide='ignore'): - ax = np.where(np.isfinite(ro[...,3:4]), - np.block([ro[...,0:3]*np.linalg.norm(ro[...,0:3],axis=-1,keepdims=True),2.*np.arctan(ro[...,3:4])]), - np.block([ro[...,0:3],np.broadcast_to(np.pi,ro[...,3:4].shape)])) - ax[np.abs(ro[...,3]) < 1.e-6] = np.array([ 0.0, 0.0, 1.0, 0.0 ]) + with np.errstate(invalid='ignore',divide='ignore'): + ax = np.where(np.isfinite(ro[...,3:4]), + np.block([ro[...,0:3]*np.linalg.norm(ro[...,0:3],axis=-1,keepdims=True),2.*np.arctan(ro[...,3:4])]), + np.block([ro[...,0:3],np.broadcast_to(np.pi,ro[...,3:4].shape)])) + ax[np.abs(ro[...,3]) < 1.e-6] = np.array([ 0.0, 0.0, 1.0, 0.0 ]) return ax @staticmethod def ro2ho(ro): """Rodrigues-Frank vector to homochoric vector.""" - if len(ro.shape) == 1: - if np.sum(ro[0:3]**2.0) < 1.e-6: - ho = np.zeros(3) - else: - f = 2.0*np.arctan(ro[3]) -np.sin(2.0*np.arctan(ro[3])) if np.isfinite(ro[3]) else np.pi - ho = ro[0:3] * (0.75*f)**(1.0/3.0) - else: - f = np.where(np.isfinite(ro[...,3:4]),2.0*np.arctan(ro[...,3:4]) -np.sin(2.0*np.arctan(ro[...,3:4])),np.pi) - ho = np.where(np.broadcast_to(np.sum(ro[...,0:3]**2.0,axis=-1,keepdims=True) < 1.e-6,ro[...,0:3].shape), - np.zeros(3), ro[...,0:3]* (0.75*f)**(1.0/3.0)) + f = np.where(np.isfinite(ro[...,3:4]),2.0*np.arctan(ro[...,3:4]) -np.sin(2.0*np.arctan(ro[...,3:4])),np.pi) + ho = np.where(np.broadcast_to(np.sum(ro[...,0:3]**2.0,axis=-1,keepdims=True) < 1.e-6,ro[...,0:3].shape), + np.zeros(3), ro[...,0:3]* (0.75*f)**(1.0/3.0)) return ho @staticmethod @@ -1070,31 +900,16 @@ class Rotation: +0.0001703481934140054, -0.00012062065004116828, +0.000059719705868660826, -0.00001980756723965647, +0.000003953714684212874, -0.00000036555001439719544]) - if len(ho.shape) == 1: - # normalize h and store the magnitude - hmag_squared = np.sum(ho**2.) - if iszero(hmag_squared): - ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) - else: - hm = hmag_squared - - # convert the magnitude to the rotation angle - s = tfit[0] + tfit[1] * hmag_squared - for i in range(2,16): - hm *= hmag_squared - s += tfit[i] * hm - ax = np.append(ho/np.sqrt(hmag_squared),2.0*np.arccos(np.clip(s,-1.0,1.0))) - else: - hmag_squared = np.sum(ho**2.,axis=-1,keepdims=True) - hm = hmag_squared.copy() - s = tfit[0] + tfit[1] * hmag_squared - for i in range(2,16): - hm *= hmag_squared - s += tfit[i] * hm - with np.errstate(invalid='ignore'): - ax = np.where(np.broadcast_to(np.abs(hmag_squared)<1.e-6,ho.shape[:-1]+(4,)), - [ 0.0, 0.0, 1.0, 0.0 ], - np.block([ho/np.sqrt(hmag_squared),2.0*np.arccos(np.clip(s,-1.0,1.0))])) + hmag_squared = np.sum(ho**2.,axis=-1,keepdims=True) + hm = hmag_squared.copy() + s = tfit[0] + tfit[1] * hmag_squared + for i in range(2,16): + hm *= hmag_squared + s += tfit[i] * hm + with np.errstate(invalid='ignore'): + ax = np.where(np.broadcast_to(np.abs(hmag_squared)<1.e-6,ho.shape[:-1]+(4,)), + [ 0.0, 0.0, 1.0, 0.0 ], + np.block([ho/np.sqrt(hmag_squared),2.0*np.arccos(np.clip(s,-1.0,1.0))])) return ax @staticmethod @@ -1113,60 +928,31 @@ class Rotation: https://doi.org/10.1088/0965-0393/22/7/075013 """ - if len(ho.shape) == 1: - rs = np.linalg.norm(ho) + rs = np.linalg.norm(ho,axis=-1,keepdims=True) - if np.allclose(ho,0.0,rtol=0.0,atol=1.0e-16): - cu = np.zeros(3) - else: - xyz3 = ho[Rotation._get_pyramid_order(ho,'forward')] + xyz3 = np.take_along_axis(ho,Rotation._get_pyramid_order(ho,'forward'),-1) - # inverse M_3 - xyz2 = xyz3[0:2] * np.sqrt( 2.0*rs/(rs+np.abs(xyz3[2])) ) + with np.errstate(invalid='ignore',divide='ignore'): + # inverse M_3 + xyz2 = xyz3[...,0:2] * np.sqrt( 2.0*rs/(rs+np.abs(xyz3[...,2:3])) ) + qxy = np.sum(xyz2**2,axis=-1,keepdims=True) - # inverse M_2 - qxy = np.sum(xyz2**2) + q2 = qxy + np.max(np.abs(xyz2),axis=-1,keepdims=True)**2 + sq2 = np.sqrt(q2) + q = (_beta/np.sqrt(2.0)/_R1) * np.sqrt(q2*qxy/(q2-np.max(np.abs(xyz2),axis=-1,keepdims=True)*sq2)) + tt = np.clip((np.min(np.abs(xyz2),axis=-1,keepdims=True)**2\ + +np.max(np.abs(xyz2),axis=-1,keepdims=True)*sq2)/np.sqrt(2.0)/qxy,-1.0,1.0) + T_inv = np.where(np.abs(xyz2[...,1:2]) <= np.abs(xyz2[...,0:1]), + np.block([np.ones_like(tt),np.arccos(tt)/np.pi*12.0]), + np.block([np.arccos(tt)/np.pi*12.0,np.ones_like(tt)]))*q + T_inv[xyz2<0.0] *= -1.0 + T_inv[np.broadcast_to(np.isclose(qxy,0.0,rtol=0.0,atol=1.0e-12),T_inv.shape)] = 0.0 + cu = np.block([T_inv, np.where(xyz3[...,2:3]<0.0,-np.ones_like(xyz3[...,2:3]),np.ones_like(xyz3[...,2:3])) \ + * rs/np.sqrt(6.0/np.pi), + ])/ _sc - if np.isclose(qxy,0.0,rtol=0.0,atol=1.0e-16): - Tinv = np.zeros(2) - else: - q2 = qxy + np.max(np.abs(xyz2))**2 - sq2 = np.sqrt(q2) - q = (_beta/np.sqrt(2.0)/_R1) * np.sqrt(q2*qxy/(q2-np.max(np.abs(xyz2))*sq2)) - tt = np.clip((np.min(np.abs(xyz2))**2+np.max(np.abs(xyz2))*sq2)/np.sqrt(2.0)/qxy,-1.0,1.0) - Tinv = np.array([1.0,np.arccos(tt)/np.pi*12.0]) if np.abs(xyz2[1]) <= np.abs(xyz2[0]) else \ - np.array([np.arccos(tt)/np.pi*12.0,1.0]) - Tinv = q * np.where(xyz2<0.0,-Tinv,Tinv) - - # inverse M_1 - cu = np.array([ Tinv[0], Tinv[1], (-1.0 if xyz3[2] < 0.0 else 1.0) * rs / np.sqrt(6.0/np.pi) ]) /_sc - cu = cu[Rotation._get_pyramid_order(ho,'backward')] - else: - rs = np.linalg.norm(ho,axis=-1,keepdims=True) - - xyz3 = np.take_along_axis(ho,Rotation._get_pyramid_order(ho,'forward'),-1) - - with np.errstate(invalid='ignore',divide='ignore'): - # inverse M_3 - xyz2 = xyz3[...,0:2] * np.sqrt( 2.0*rs/(rs+np.abs(xyz3[...,2:3])) ) - qxy = np.sum(xyz2**2,axis=-1,keepdims=True) - - q2 = qxy + np.max(np.abs(xyz2),axis=-1,keepdims=True)**2 - sq2 = np.sqrt(q2) - q = (_beta/np.sqrt(2.0)/_R1) * np.sqrt(q2*qxy/(q2-np.max(np.abs(xyz2),axis=-1,keepdims=True)*sq2)) - tt = np.clip((np.min(np.abs(xyz2),axis=-1,keepdims=True)**2\ - +np.max(np.abs(xyz2),axis=-1,keepdims=True)*sq2)/np.sqrt(2.0)/qxy,-1.0,1.0) - T_inv = np.where(np.abs(xyz2[...,1:2]) <= np.abs(xyz2[...,0:1]), - np.block([np.ones_like(tt),np.arccos(tt)/np.pi*12.0]), - np.block([np.arccos(tt)/np.pi*12.0,np.ones_like(tt)]))*q - T_inv[xyz2<0.0] *= -1.0 - T_inv[np.broadcast_to(np.isclose(qxy,0.0,rtol=0.0,atol=1.0e-12),T_inv.shape)] = 0.0 - cu = np.block([T_inv, np.where(xyz3[...,2:3]<0.0,-np.ones_like(xyz3[...,2:3]),np.ones_like(xyz3[...,2:3])) \ - * rs/np.sqrt(6.0/np.pi), - ])/ _sc - - cu[np.isclose(np.sum(np.abs(ho),axis=-1),0.0,rtol=0.0,atol=1.0e-16)] = 0.0 - cu = np.take_along_axis(cu,Rotation._get_pyramid_order(ho,'backward'),-1) + cu[np.isclose(np.sum(np.abs(ho),axis=-1),0.0,rtol=0.0,atol=1.0e-16)] = 0.0 + cu = np.take_along_axis(cu,Rotation._get_pyramid_order(ho,'backward'),-1) return cu @@ -1207,64 +993,34 @@ class Rotation: https://doi.org/10.1088/0965-0393/22/7/075013 """ - if len(cu.shape) == 1: - # transform to the sphere grid via the curved square, and intercept the zero point - if np.allclose(cu,0.0,rtol=0.0,atol=1.0e-16): - ho = np.zeros(3) - else: - # get pyramide and scale by grid parameter ratio - XYZ = cu[Rotation._get_pyramid_order(cu,'forward')] * _sc + with np.errstate(invalid='ignore',divide='ignore'): + # get pyramide and scale by grid parameter ratio + XYZ = np.take_along_axis(cu,Rotation._get_pyramid_order(cu,'forward'),-1) * _sc + order = np.abs(XYZ[...,1:2]) <= np.abs(XYZ[...,0:1]) + q = np.pi/12.0 * np.where(order,XYZ[...,1:2],XYZ[...,0:1]) \ + / np.where(order,XYZ[...,0:1],XYZ[...,1:2]) + c = np.cos(q) + s = np.sin(q) + q = _R1*2.0**0.25/_beta/ np.sqrt(np.sqrt(2.0)-c) \ + * np.where(order,XYZ[...,0:1],XYZ[...,1:2]) - # intercept all the points along the z-axis - if np.allclose(XYZ[0:2],0.0,rtol=0.0,atol=1.0e-16): - ho = np.array([0.0, 0.0, np.sqrt(6.0/np.pi) * XYZ[2]]) - else: - order = [1,0] if np.abs(XYZ[1]) <= np.abs(XYZ[0]) else [0,1] - q = np.pi/12.0 * XYZ[order[0]]/XYZ[order[1]] - c = np.cos(q) - s = np.sin(q) - q = _R1*2.0**0.25/_beta * XYZ[order[1]] / np.sqrt(np.sqrt(2.0)-c) - T = np.array([ (np.sqrt(2.0)*c - 1.0), np.sqrt(2.0) * s]) * q + T = np.block([ (np.sqrt(2.0)*c - 1.0), np.sqrt(2.0) * s]) * q - # transform to sphere grid (inverse Lambert) - # note that there is no need to worry about dividing by zero, since XYZ[2] can not become zero - c = np.sum(T**2) - s = c * np.pi/24.0 /XYZ[2]**2 - c = c * np.sqrt(np.pi/24.0)/XYZ[2] + # transform to sphere grid (inverse Lambert) + c = np.sum(T**2,axis=-1,keepdims=True) + s = c * np.pi/24.0 /XYZ[...,2:3]**2 + c = c * np.sqrt(np.pi/24.0)/XYZ[...,2:3] + q = np.sqrt( 1.0 - s) - q = np.sqrt( 1.0 - s ) - ho = np.array([ T[order[1]] * q, T[order[0]] * q, np.sqrt(6.0/np.pi) * XYZ[2] - c ]) + ho = np.where(np.isclose(np.sum(np.abs(XYZ[...,0:2]),axis=-1,keepdims=True),0.0,rtol=0.0,atol=1.0e-16), + np.block([np.zeros_like(XYZ[...,0:2]),np.sqrt(6.0/np.pi) *XYZ[...,2:3]]), + np.block([np.where(order,T[...,0:1],T[...,1:2])*q, + np.where(order,T[...,1:2],T[...,0:1])*q, + np.sqrt(6.0/np.pi) * XYZ[...,2:3] - c]) + ) - ho = ho[Rotation._get_pyramid_order(cu,'backward')] - else: - with np.errstate(invalid='ignore',divide='ignore'): - # get pyramide and scale by grid parameter ratio - XYZ = np.take_along_axis(cu,Rotation._get_pyramid_order(cu,'forward'),-1) * _sc - order = np.abs(XYZ[...,1:2]) <= np.abs(XYZ[...,0:1]) - q = np.pi/12.0 * np.where(order,XYZ[...,1:2],XYZ[...,0:1]) \ - / np.where(order,XYZ[...,0:1],XYZ[...,1:2]) - c = np.cos(q) - s = np.sin(q) - q = _R1*2.0**0.25/_beta/ np.sqrt(np.sqrt(2.0)-c) \ - * np.where(order,XYZ[...,0:1],XYZ[...,1:2]) - - T = np.block([ (np.sqrt(2.0)*c - 1.0), np.sqrt(2.0) * s]) * q - - # transform to sphere grid (inverse Lambert) - c = np.sum(T**2,axis=-1,keepdims=True) - s = c * np.pi/24.0 /XYZ[...,2:3]**2 - c = c * np.sqrt(np.pi/24.0)/XYZ[...,2:3] - q = np.sqrt( 1.0 - s) - - ho = np.where(np.isclose(np.sum(np.abs(XYZ[...,0:2]),axis=-1,keepdims=True),0.0,rtol=0.0,atol=1.0e-16), - np.block([np.zeros_like(XYZ[...,0:2]),np.sqrt(6.0/np.pi) *XYZ[...,2:3]]), - np.block([np.where(order,T[...,0:1],T[...,1:2])*q, - np.where(order,T[...,1:2],T[...,0:1])*q, - np.sqrt(6.0/np.pi) * XYZ[...,2:3] - c]) - ) - - ho[np.isclose(np.sum(np.abs(cu),axis=-1),0.0,rtol=0.0,atol=1.0e-16)] = 0.0 - ho = np.take_along_axis(ho,Rotation._get_pyramid_order(cu,'backward'),-1) + ho[np.isclose(np.sum(np.abs(cu),axis=-1),0.0,rtol=0.0,atol=1.0e-16)] = 0.0 + ho = np.take_along_axis(ho,Rotation._get_pyramid_order(cu,'backward'),-1) return ho @@ -1288,20 +1044,10 @@ class Rotation: https://doi.org/10.1088/0965-0393/22/7/075013 """ - order = {'forward':np.array([[0,1,2],[1,2,0],[2,0,1]]), + order = {'forward': np.array([[0,1,2],[1,2,0],[2,0,1]]), 'backward':np.array([[0,1,2],[2,0,1],[1,2,0]])} - if len(xyz.shape) == 1: - if np.maximum(abs(xyz[0]),abs(xyz[1])) <= xyz[2] or \ - np.maximum(abs(xyz[0]),abs(xyz[1])) <=-xyz[2]: - p = 0 - elif np.maximum(abs(xyz[1]),abs(xyz[2])) <= xyz[0] or \ - np.maximum(abs(xyz[1]),abs(xyz[2])) <=-xyz[0]: - p = 1 - elif np.maximum(abs(xyz[2]),abs(xyz[0])) <= xyz[1] or \ - np.maximum(abs(xyz[2]),abs(xyz[0])) <=-xyz[1]: - p = 2 - else: - p = np.where(np.maximum(np.abs(xyz[...,0]),np.abs(xyz[...,1])) <= np.abs(xyz[...,2]),0, - np.where(np.maximum(np.abs(xyz[...,1]),np.abs(xyz[...,2])) <= np.abs(xyz[...,0]),1,2)) + + p = np.where(np.maximum(np.abs(xyz[...,0]),np.abs(xyz[...,1])) <= np.abs(xyz[...,2]),0, + np.where(np.maximum(np.abs(xyz[...,1]),np.abs(xyz[...,2])) <= np.abs(xyz[...,0]),1,2)) return order[direction][p] diff --git a/python/tests/rotation_conversion.py b/python/tests/rotation_conversion.py new file mode 100644 index 000000000..5ca10f443 --- /dev/null +++ b/python/tests/rotation_conversion.py @@ -0,0 +1,399 @@ +#################################################################################################### +# Code below available according to the following conditions on https://github.com/MarDiehl/3Drotations +#################################################################################################### +# Copyright (c) 2017-2019, Martin Diehl/Max-Planck-Institut für Eisenforschung GmbH +# Copyright (c) 2013-2014, Marc De Graef/Carnegie Mellon University +# All rights reserved. +# +# Redistribution and use in source and binary forms, with or without modification, are +# permitted provided that the following conditions are met: +# +# - Redistributions of source code must retain the above copyright notice, this list +# of conditions and the following disclaimer. +# - Redistributions in binary form must reproduce the above copyright notice, this +# list of conditions and the following disclaimer in the documentation and/or +# other materials provided with the distribution. +# - Neither the names of Marc De Graef, Carnegie Mellon University nor the names +# of its contributors may be used to endorse or promote products derived from +# this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE +# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR +# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, +# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE +# USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +#################################################################################################### + +import numpy as np + +_P = -1 + +# parameters for conversion from/to cubochoric +_sc = np.pi**(1./6.)/6.**(1./6.) +_beta = np.pi**(5./6.)/6.**(1./6.)/2. +_R1 = (3.*np.pi/4.)**(1./3.) + +def iszero(a): + return np.isclose(a,0.0,atol=1.0e-12,rtol=0.0) + +#---------- Quaternion ---------- +def qu2om(qu): + """Quaternion to rotation matrix.""" + qq = qu[0]**2-(qu[1]**2 + qu[2]**2 + qu[3]**2) + om = np.diag(qq + 2.0*np.array([qu[1],qu[2],qu[3]])**2) + + om[0,1] = 2.0*(qu[2]*qu[1]+qu[0]*qu[3]) + om[1,0] = 2.0*(qu[1]*qu[2]-qu[0]*qu[3]) + om[1,2] = 2.0*(qu[3]*qu[2]+qu[0]*qu[1]) + om[2,1] = 2.0*(qu[2]*qu[3]-qu[0]*qu[1]) + om[2,0] = 2.0*(qu[1]*qu[3]+qu[0]*qu[2]) + om[0,2] = 2.0*(qu[3]*qu[1]-qu[0]*qu[2]) + return om if _P < 0.0 else np.swapaxes(om,(-1,-2)) + +def qu2eu(qu): + """Quaternion to Bunge-Euler angles.""" + q03 = qu[0]**2+qu[3]**2 + q12 = qu[1]**2+qu[2]**2 + chi = np.sqrt(q03*q12) + if np.abs(q12) < 1.e-8: + eu = np.array([np.arctan2(-_P*2.0*qu[0]*qu[3],qu[0]**2-qu[3]**2), 0.0, 0.0]) + elif np.abs(q03) < 1.e-8: + eu = np.array([np.arctan2( 2.0*qu[1]*qu[2],qu[1]**2-qu[2]**2), np.pi, 0.0]) + else: + eu = np.array([np.arctan2((-_P*qu[0]*qu[2]+qu[1]*qu[3])*chi, (-_P*qu[0]*qu[1]-qu[2]*qu[3])*chi ), + np.arctan2( 2.0*chi, q03-q12 ), + np.arctan2(( _P*qu[0]*qu[2]+qu[1]*qu[3])*chi, (-_P*qu[0]*qu[1]+qu[2]*qu[3])*chi )]) + # reduce Euler angles to definition range + eu[np.abs(eu)<1.e-6] = 0.0 + eu = np.where(eu<0, (eu+2.0*np.pi)%np.array([2.0*np.pi,np.pi,2.0*np.pi]),eu) + return eu + +def qu2ax(qu): + """ + Quaternion to axis angle pair. + + Modified version of the original formulation, should be numerically more stable + """ + if np.abs(np.sum(qu[1:4]**2)) < 1.e-6: # set axis to [001] if the angle is 0/360 + ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) + elif qu[0] > 1.e-6: + s = np.sign(qu[0])/np.sqrt(qu[1]**2+qu[2]**2+qu[3]**2) + omega = 2.0 * np.arccos(np.clip(qu[0],-1.0,1.0)) + ax = ax = np.array([ qu[1]*s, qu[2]*s, qu[3]*s, omega ]) + else: + ax = ax = np.array([ qu[1], qu[2], qu[3], np.pi]) + return ax + +def qu2ro(qu): + """Quaternion to Rodrigues-Frank vector.""" + if iszero(qu[0]): + ro = np.array([qu[1], qu[2], qu[3], np.inf]) + else: + s = np.linalg.norm(qu[1:4]) + ro = np.array([0.0,0.0,_P,0.0] if iszero(s) else \ + [ qu[1]/s, qu[2]/s, qu[3]/s, np.tan(np.arccos(np.clip(qu[0],-1.0,1.0)))]) + return ro + +def qu2ho(qu): + """Quaternion to homochoric vector.""" + omega = 2.0 * np.arccos(np.clip(qu[0],-1.0,1.0)) + if np.abs(omega) < 1.0e-12: + ho = np.zeros(3) + else: + ho = np.array([qu[1], qu[2], qu[3]]) + f = 0.75 * ( omega - np.sin(omega) ) + ho = ho/np.linalg.norm(ho) * f**(1./3.) + return ho + + +#---------- Rotation matrix ---------- +def om2eu(om): + """Rotation matrix to Bunge-Euler angles.""" + if not np.isclose(np.abs(om[2,2]),1.0,1.e-4): + zeta = 1.0/np.sqrt(1.0-om[2,2]**2) + eu = np.array([np.arctan2(om[2,0]*zeta,-om[2,1]*zeta), + np.arccos(om[2,2]), + np.arctan2(om[0,2]*zeta, om[1,2]*zeta)]) + else: + eu = np.array([np.arctan2( om[0,1],om[0,0]), np.pi*0.5*(1-om[2,2]),0.0]) # following the paper, not the reference implementation + eu[np.abs(eu)<1.e-6] = 0.0 + eu = np.where(eu<0, (eu+2.0*np.pi)%np.array([2.0*np.pi,np.pi,2.0*np.pi]),eu) + return eu + +def om2ax(om): + """Rotation matrix to axis angle pair.""" + ax=np.empty(4) + + # first get the rotation angle + t = 0.5*(om.trace() -1.0) + ax[3] = np.arccos(np.clip(t,-1.0,1.0)) + if np.abs(ax[3])<1.e-6: + ax = np.array([ 0.0, 0.0, 1.0, 0.0]) + else: + w,vr = np.linalg.eig(om) + # next, find the eigenvalue (1,0j) + i = np.where(np.isclose(w,1.0+0.0j))[0][0] + ax[0:3] = np.real(vr[0:3,i]) + diagDelta = -_P*np.array([om[1,2]-om[2,1],om[2,0]-om[0,2],om[0,1]-om[1,0]]) + diagDelta[np.abs(diagDelta)<1.e-6] = 1.0 + ax[0:3] = np.where(np.abs(diagDelta)<0, ax[0:3],np.abs(ax[0:3])*np.sign(diagDelta)) + return ax + +#---------- Bunge-Euler angles ---------- +def eu2qu(eu): + """Bunge-Euler angles to quaternion.""" + ee = 0.5*eu + cPhi = np.cos(ee[1]) + sPhi = np.sin(ee[1]) + qu = np.array([ cPhi*np.cos(ee[0]+ee[2]), + -_P*sPhi*np.cos(ee[0]-ee[2]), + -_P*sPhi*np.sin(ee[0]-ee[2]), + -_P*cPhi*np.sin(ee[0]+ee[2]) ]) + if qu[0] < 0.0: qu*=-1 + return qu + +def eu2om(eu): + """Bunge-Euler angles to rotation matrix.""" + c = np.cos(eu) + s = np.sin(eu) + + om = np.array([[+c[0]*c[2]-s[0]*s[2]*c[1], +s[0]*c[2]+c[0]*s[2]*c[1], +s[2]*s[1]], + [-c[0]*s[2]-s[0]*c[2]*c[1], -s[0]*s[2]+c[0]*c[2]*c[1], +c[2]*s[1]], + [+s[0]*s[1], -c[0]*s[1], +c[1] ]]) + om[np.abs(om)<1.e-12] = 0.0 + return om + +def eu2ax(eu): + """Bunge-Euler angles to axis angle pair.""" + t = np.tan(eu[1]*0.5) + sigma = 0.5*(eu[0]+eu[2]) + delta = 0.5*(eu[0]-eu[2]) + tau = np.linalg.norm([t,np.sin(sigma)]) + alpha = np.pi if iszero(np.cos(sigma)) else \ + 2.0*np.arctan(tau/np.cos(sigma)) + + if np.abs(alpha)<1.e-6: + ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) + else: + ax = -_P/tau * np.array([ t*np.cos(delta), t*np.sin(delta), np.sin(sigma) ]) # passive axis angle pair so a minus sign in front + ax = np.append(ax,alpha) + if alpha < 0.0: ax *= -1.0 # ensure alpha is positive + return ax + +def eu2ro(eu): + """Bunge-Euler angles to Rodrigues-Frank vector.""" + ro = eu2ax(eu) # convert to axis angle pair representation + if ro[3] >= np.pi: # Differs from original implementation. check convention 5 + ro[3] = np.inf + elif iszero(ro[3]): + ro = np.array([ 0.0, 0.0, _P, 0.0 ]) + else: + ro[3] = np.tan(ro[3]*0.5) + return ro + +#---------- Axis angle pair ---------- +def ax2qu(ax): + """Axis angle pair to quaternion.""" + if np.abs(ax[3])<1.e-6: + qu = np.array([ 1.0, 0.0, 0.0, 0.0 ]) + else: + c = np.cos(ax[3]*0.5) + s = np.sin(ax[3]*0.5) + qu = np.array([ c, ax[0]*s, ax[1]*s, ax[2]*s ]) + return qu + +def ax2om(ax): + """Axis angle pair to rotation matrix.""" + c = np.cos(ax[3]) + s = np.sin(ax[3]) + omc = 1.0-c + om=np.diag(ax[0:3]**2*omc + c) + + for idx in [[0,1,2],[1,2,0],[2,0,1]]: + q = omc*ax[idx[0]] * ax[idx[1]] + om[idx[0],idx[1]] = q + s*ax[idx[2]] + om[idx[1],idx[0]] = q - s*ax[idx[2]] + return om if _P < 0.0 else np.swapaxes(om,(-1,-2)) + +def ax2ro(ax): + """Axis angle pair to Rodrigues-Frank vector.""" + if np.abs(ax[3])<1.e-6: + ro = [ 0.0, 0.0, _P, 0.0 ] + else: + ro = [ax[0], ax[1], ax[2]] + # 180 degree case + ro += [np.inf] if np.isclose(ax[3],np.pi,atol=1.0e-15,rtol=0.0) else \ + [np.tan(ax[3]*0.5)] + ro = np.array(ro) + return ro + +def ax2ho(ax): + """Axis angle pair to homochoric vector.""" + f = (0.75 * ( ax[3] - np.sin(ax[3]) ))**(1.0/3.0) + ho = ax[0:3] * f + return ho + + +#---------- Rodrigues-Frank vector ---------- +def ro2ax(ro): + """Rodrigues-Frank vector to axis angle pair.""" + if np.abs(ro[3]) < 1.e-6: + ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) + elif not np.isfinite(ro[3]): + ax = np.array([ ro[0], ro[1], ro[2], np.pi ]) + else: + angle = 2.0*np.arctan(ro[3]) + ta = np.linalg.norm(ro[0:3]) + ax = np.array([ ro[0]*ta, ro[1]*ta, ro[2]*ta, angle ]) + return ax + +def ro2ho(ro): + """Rodrigues-Frank vector to homochoric vector.""" + if np.sum(ro[0:3]**2.0) < 1.e-6: + ho = np.zeros(3) + else: + f = 2.0*np.arctan(ro[3]) -np.sin(2.0*np.arctan(ro[3])) if np.isfinite(ro[3]) else np.pi + ho = ro[0:3] * (0.75*f)**(1.0/3.0) + return ho + +#---------- Homochoric vector---------- +def ho2ax(ho): + """Homochoric vector to axis angle pair.""" + tfit = np.array([+1.0000000000018852, -0.5000000002194847, + -0.024999992127593126, -0.003928701544781374, + -0.0008152701535450438, -0.0002009500426119712, + -0.00002397986776071756, -0.00008202868926605841, + +0.00012448715042090092, -0.0001749114214822577, + +0.0001703481934140054, -0.00012062065004116828, + +0.000059719705868660826, -0.00001980756723965647, + +0.000003953714684212874, -0.00000036555001439719544]) + # normalize h and store the magnitude + hmag_squared = np.sum(ho**2.) + if iszero(hmag_squared): + ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) + else: + hm = hmag_squared + + # convert the magnitude to the rotation angle + s = tfit[0] + tfit[1] * hmag_squared + for i in range(2,16): + hm *= hmag_squared + s += tfit[i] * hm + ax = np.append(ho/np.sqrt(hmag_squared),2.0*np.arccos(np.clip(s,-1.0,1.0))) + return ax + +def ho2cu(ho): + """ + Homochoric vector to cubochoric vector. + + References + ---------- + D. Roşca et al., Modelling and Simulation in Materials Science and Engineering 22:075013, 2014 + https://doi.org/10.1088/0965-0393/22/7/075013 + + """ + rs = np.linalg.norm(ho) + + if np.allclose(ho,0.0,rtol=0.0,atol=1.0e-16): + cu = np.zeros(3) + else: + xyz3 = ho[_get_pyramid_order(ho,'forward')] + + # inverse M_3 + xyz2 = xyz3[0:2] * np.sqrt( 2.0*rs/(rs+np.abs(xyz3[2])) ) + + # inverse M_2 + qxy = np.sum(xyz2**2) + + if np.isclose(qxy,0.0,rtol=0.0,atol=1.0e-16): + Tinv = np.zeros(2) + else: + q2 = qxy + np.max(np.abs(xyz2))**2 + sq2 = np.sqrt(q2) + q = (_beta/np.sqrt(2.0)/_R1) * np.sqrt(q2*qxy/(q2-np.max(np.abs(xyz2))*sq2)) + tt = np.clip((np.min(np.abs(xyz2))**2+np.max(np.abs(xyz2))*sq2)/np.sqrt(2.0)/qxy,-1.0,1.0) + Tinv = np.array([1.0,np.arccos(tt)/np.pi*12.0]) if np.abs(xyz2[1]) <= np.abs(xyz2[0]) else \ + np.array([np.arccos(tt)/np.pi*12.0,1.0]) + Tinv = q * np.where(xyz2<0.0,-Tinv,Tinv) + + # inverse M_1 + cu = np.array([ Tinv[0], Tinv[1], (-1.0 if xyz3[2] < 0.0 else 1.0) * rs / np.sqrt(6.0/np.pi) ]) /_sc + cu = cu[_get_pyramid_order(ho,'backward')] + return cu + +#---------- Cubochoric ---------- +def cu2ho(cu): + """ + Cubochoric vector to homochoric vector. + + References + ---------- + D. Roşca et al., Modelling and Simulation in Materials Science and Engineering 22:075013, 2014 + https://doi.org/10.1088/0965-0393/22/7/075013 + + """ + # transform to the sphere grid via the curved square, and intercept the zero point + if np.allclose(cu,0.0,rtol=0.0,atol=1.0e-16): + ho = np.zeros(3) + else: + # get pyramide and scale by grid parameter ratio + XYZ = cu[_get_pyramid_order(cu,'forward')] * _sc + + # intercept all the points along the z-axis + if np.allclose(XYZ[0:2],0.0,rtol=0.0,atol=1.0e-16): + ho = np.array([0.0, 0.0, np.sqrt(6.0/np.pi) * XYZ[2]]) + else: + order = [1,0] if np.abs(XYZ[1]) <= np.abs(XYZ[0]) else [0,1] + q = np.pi/12.0 * XYZ[order[0]]/XYZ[order[1]] + c = np.cos(q) + s = np.sin(q) + q = _R1*2.0**0.25/_beta * XYZ[order[1]] / np.sqrt(np.sqrt(2.0)-c) + T = np.array([ (np.sqrt(2.0)*c - 1.0), np.sqrt(2.0) * s]) * q + + # transform to sphere grid (inverse Lambert) + # note that there is no need to worry about dividing by zero, since XYZ[2] can not become zero + c = np.sum(T**2) + s = c * np.pi/24.0 /XYZ[2]**2 + c = c * np.sqrt(np.pi/24.0)/XYZ[2] + + q = np.sqrt( 1.0 - s ) + ho = np.array([ T[order[1]] * q, T[order[0]] * q, np.sqrt(6.0/np.pi) * XYZ[2] - c ]) + + ho = ho[_get_pyramid_order(cu,'backward')] + return ho + +def _get_pyramid_order(xyz,direction=None): + """ + Get order of the coordinates. + + Depending on the pyramid in which the point is located, the order need to be adjusted. + + Parameters + ---------- + xyz : numpy.ndarray + coordinates of a point on a uniform refinable grid on a ball or + in a uniform refinable cubical grid. + + References + ---------- + D. Roşca et al., Modelling and Simulation in Materials Science and Engineering 22:075013, 2014 + https://doi.org/10.1088/0965-0393/22/7/075013 + + """ + order = {'forward':np.array([[0,1,2],[1,2,0],[2,0,1]]), + 'backward':np.array([[0,1,2],[2,0,1],[1,2,0]])} + if np.maximum(abs(xyz[0]),abs(xyz[1])) <= xyz[2] or \ + np.maximum(abs(xyz[0]),abs(xyz[1])) <=-xyz[2]: + p = 0 + elif np.maximum(abs(xyz[1]),abs(xyz[2])) <= xyz[0] or \ + np.maximum(abs(xyz[1]),abs(xyz[2])) <=-xyz[0]: + p = 1 + elif np.maximum(abs(xyz[2]),abs(xyz[0])) <= xyz[1] or \ + np.maximum(abs(xyz[2]),abs(xyz[0])) <=-xyz[1]: + p = 2 + return order[direction][p] diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index 23ab03ff6..4a6350fda 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -4,6 +4,7 @@ import pytest import numpy as np from damask import Rotation +import rotation_conversion n = 1100 atol=1.e-4 @@ -181,111 +182,83 @@ class TestRotation: with pytest.raises(ValueError): function(invalid) - @pytest.mark.parametrize('conversion',[Rotation.qu2om, - Rotation.qu2eu, - Rotation.qu2ax, - Rotation.qu2ro, - Rotation.qu2ho, - Rotation.qu2cu - ]) - def test_quaternion_vectorization(self,default,conversion): + @pytest.mark.parametrize('vectorized, single',[(Rotation.qu2om,rotation_conversion.qu2om), + (Rotation.qu2eu,rotation_conversion.qu2eu), + (Rotation.qu2ax,rotation_conversion.qu2ax), + (Rotation.qu2ro,rotation_conversion.qu2ro), + (Rotation.qu2ho,rotation_conversion.qu2ho)]) + def test_quaternion_vectorization(self,default,vectorized,single): qu = np.array([rot.as_quaternion() for rot in default]) - conversion(qu.reshape(qu.shape[0]//2,-1,4)) - co = conversion(qu) + vectorized(qu.reshape(qu.shape[0]//2,-1,4)) + co = vectorized(qu) for q,c in zip(qu,co): print(q,c) - assert np.allclose(conversion(q),c) + assert np.allclose(single(q),c) and np.allclose(single(q),vectorized(q)) - @pytest.mark.parametrize('conversion',[Rotation.om2qu, - Rotation.om2eu, - Rotation.om2ax, - Rotation.om2ro, - Rotation.om2ho, - Rotation.om2cu - ]) - def test_matrix_vectorization(self,default,conversion): + + @pytest.mark.parametrize('vectorized, single',[(Rotation.om2eu,rotation_conversion.om2eu), + (Rotation.om2ax,rotation_conversion.om2ax)]) + def test_matrix_vectorization(self,default,vectorized,single): om = np.array([rot.as_matrix() for rot in default]) - conversion(om.reshape(om.shape[0]//2,-1,3,3)) - co = conversion(om) + vectorized(om.reshape(om.shape[0]//2,-1,3,3)) + co = vectorized(om) for o,c in zip(om,co): print(o,c) - assert np.allclose(conversion(o),c) + assert np.allclose(single(o),c) and np.allclose(single(o),vectorized(o)) - @pytest.mark.parametrize('conversion',[Rotation.eu2qu, - Rotation.eu2om, - Rotation.eu2ax, - Rotation.eu2ro, - Rotation.eu2ho, - Rotation.eu2cu - ]) - def test_Euler_vectorization(self,default,conversion): + @pytest.mark.parametrize('vectorized, single',[(Rotation.eu2qu,rotation_conversion.eu2qu), + (Rotation.eu2om,rotation_conversion.eu2om), + (Rotation.eu2ax,rotation_conversion.eu2ax), + (Rotation.eu2ro,rotation_conversion.eu2ro)]) + def test_Euler_vectorization(self,default,vectorized,single): eu = np.array([rot.as_Eulers() for rot in default]) - conversion(eu.reshape(eu.shape[0]//2,-1,3)) - co = conversion(eu) + vectorized(eu.reshape(eu.shape[0]//2,-1,3)) + co = vectorized(eu) for e,c in zip(eu,co): print(e,c) - assert np.allclose(conversion(e),c) + assert np.allclose(single(e),c) and np.allclose(single(e),vectorized(e)) - @pytest.mark.parametrize('conversion',[Rotation.ax2qu, - Rotation.ax2om, - Rotation.ax2eu, - Rotation.ax2ro, - Rotation.ax2ho, - Rotation.ax2cu - ]) - def test_axisAngle_vectorization(self,default,conversion): + @pytest.mark.parametrize('vectorized, single',[(Rotation.ax2qu,rotation_conversion.ax2qu), + (Rotation.ax2om,rotation_conversion.ax2om), + (Rotation.ax2ro,rotation_conversion.ax2ro), + (Rotation.ax2ho,rotation_conversion.ax2ho)]) + def test_axisAngle_vectorization(self,default,vectorized,single): ax = np.array([rot.as_axis_angle() for rot in default]) - conversion(ax.reshape(ax.shape[0]//2,-1,4)) - co = conversion(ax) + vectorized(ax.reshape(ax.shape[0]//2,-1,4)) + co = vectorized(ax) for a,c in zip(ax,co): print(a,c) - assert np.allclose(conversion(a),c) + assert np.allclose(single(a),c) and np.allclose(single(a),vectorized(a)) - @pytest.mark.parametrize('conversion',[Rotation.ro2qu, - Rotation.ro2om, - Rotation.ro2eu, - Rotation.ro2ax, - Rotation.ro2ho, - Rotation.ro2cu - ]) - def test_Rodrigues_vectorization(self,default,conversion): + @pytest.mark.parametrize('vectorized, single',[(Rotation.ro2ax,rotation_conversion.ro2ax), + (Rotation.ro2ho,rotation_conversion.ro2ho)]) + def test_Rodrigues_vectorization(self,default,vectorized,single): ro = np.array([rot.as_Rodrigues() for rot in default]) - conversion(ro.reshape(ro.shape[0]//2,-1,4)) - co = conversion(ro) + vectorized(ro.reshape(ro.shape[0]//2,-1,4)) + co = vectorized(ro) for r,c in zip(ro,co): print(r,c) - assert np.allclose(conversion(r),c) + assert np.allclose(single(r),c) and np.allclose(single(r),vectorized(r)) - @pytest.mark.parametrize('conversion',[Rotation.ho2qu, - Rotation.ho2om, - Rotation.ho2eu, - Rotation.ho2ax, - Rotation.ho2ro, - Rotation.ho2cu - ]) - def test_homochoric_vectorization(self,default,conversion): + @pytest.mark.parametrize('vectorized, single',[(Rotation.ho2ax,rotation_conversion.ho2ax), + (Rotation.ho2cu,rotation_conversion.ho2cu)]) + def test_homochoric_vectorization(self,default,vectorized,single): ho = np.array([rot.as_homochoric() for rot in default]) - conversion(ho.reshape(ho.shape[0]//2,-1,3)) - co = conversion(ho) + vectorized(ho.reshape(ho.shape[0]//2,-1,3)) + co = vectorized(ho) for h,c in zip(ho,co): print(h,c) - assert np.allclose(conversion(h),c) + assert np.allclose(single(h),c) and np.allclose(single(h),vectorized(h)) - @pytest.mark.parametrize('conversion',[Rotation.cu2qu, - Rotation.cu2om, - Rotation.cu2eu, - Rotation.cu2ax, - Rotation.cu2ro, - Rotation.cu2ho - ]) - def test_cubochoric_vectorization(self,default,conversion): + @pytest.mark.parametrize('vectorized, single',[(Rotation.cu2ho,rotation_conversion.cu2ho)]) + def test_cubochoric_vectorization(self,default,vectorized,single): cu = np.array([rot.as_cubochoric() for rot in default]) - conversion(cu.reshape(cu.shape[0]//2,-1,3)) - co = conversion(cu) + vectorized(cu.reshape(cu.shape[0]//2,-1,3)) + co = vectorized(cu) for u,c in zip(cu,co): print(u,c) - assert np.allclose(conversion(u),c) + assert np.allclose(single(u),c) and np.allclose(single(u),vectorized(u)) @pytest.mark.parametrize('direction',['forward', 'backward']) From 652ece6bb3c46084a2256125551d61f72d2655a4 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 17 May 2020 07:25:17 +0200 Subject: [PATCH 050/136] fix: wrong capitalization --- processing/post/addOrientations.py | 2 +- python/damask/_rotation.py | 3 --- 2 files changed, 1 insertion(+), 4 deletions(-) diff --git a/processing/post/addOrientations.py b/processing/post/addOrientations.py index b6292b18c..706a959ad 100755 --- a/processing/post/addOrientations.py +++ b/processing/post/addOrientations.py @@ -137,7 +137,7 @@ for name in filenames: if 'rodrigues' in options.output: - table.add('ro({})'.format(label),o.as_rodrigues(), scriptID+' '+' '.join(sys.argv[1:])) + table.add('ro({})'.format(label),o.as_Rodrigues(), scriptID+' '+' '.join(sys.argv[1:])) if 'eulers' in options.output: table.add('eu({})'.format(label),o.as_Eulers(options.degrees), scriptID+' '+' '.join(sys.argv[1:])) if 'quaternion' in options.output: diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 5258145e0..44484ccd9 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -9,9 +9,6 @@ _sc = np.pi**(1./6.)/6.**(1./6.) _beta = np.pi**(5./6.)/6.**(1./6.)/2. _R1 = (3.*np.pi/4.)**(1./3.) -def iszero(a): - return np.isclose(a,0.0,atol=1.0e-12,rtol=0.0) - class Rotation: u""" From 743e91a78d6f9d1509238d6886758cc2d5f8cad6 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 17 May 2020 08:01:34 +0200 Subject: [PATCH 051/136] cleaning --- processing/pre/geom_fromDREAM3D.py | 2 +- processing/pre/geom_fromTable.py | 2 +- processing/pre/geom_rotate.py | 2 +- python/damask/_rotation.py | 18 ++---------------- 4 files changed, 5 insertions(+), 19 deletions(-) diff --git a/processing/pre/geom_fromDREAM3D.py b/processing/pre/geom_fromDREAM3D.py index b000aa811..c48698e53 100755 --- a/processing/pre/geom_fromDREAM3D.py +++ b/processing/pre/geom_fromDREAM3D.py @@ -140,7 +140,7 @@ for name in filenames: config_header = [''] for i in range(np.nanmax(microstructure)): config_header += ['[{}{}]'.format(label,i+1), - '(gauss)\tphi1 {:.2f}\tPhi {:.2f}\tphi2 {:.2f}'.format(*rot[i].asEulers(degrees = True)), + '(gauss)\tphi1 {:.2f}\tPhi {:.2f}\tphi2 {:.2f}'.format(*rot[i].as_Eulers(degrees = True)), ] config_header += [''] for i in range(np.nanmax(microstructure)): diff --git a/processing/pre/geom_fromTable.py b/processing/pre/geom_fromTable.py index f6c9ba38e..be5b3a23c 100755 --- a/processing/pre/geom_fromTable.py +++ b/processing/pre/geom_fromTable.py @@ -89,7 +89,7 @@ for name in filenames: for i,data in enumerate(unique): ori = damask.Rotation(data[0:4]) config_header += ['[Grain{}]'.format(i+1), - '(gauss)\tphi1 {:.2f}\tPhi {:.2f}\tphi2 {:.2f}'.format(*ori.asEulers(degrees = True)), + '(gauss)\tphi1 {:.2f}\tPhi {:.2f}\tphi2 {:.2f}'.format(*ori.as_Eulers(degrees = True)), ] if options.axes is not None: config_header += ['axes\t{} {} {}'.format(*options.axes)] diff --git a/processing/pre/geom_rotate.py b/processing/pre/geom_rotate.py index 7a774200b..dc2e8e2a3 100755 --- a/processing/pre/geom_rotate.py +++ b/processing/pre/geom_rotate.py @@ -67,7 +67,7 @@ if options.matrix is not None: if options.eulers is not None: rot = damask.Rotation.from_Eulers(np.array(options.eulers),degrees=options.degrees) -eulers = rot.asEulers(degrees=True) +eulers = rot.as_Eulers(degrees=True) if filenames == []: filenames = [None] diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 44484ccd9..bf5a2a4f3 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -305,15 +305,6 @@ class Rotation: """ return np.einsum('...i,...j',self.quaternion,self.quaternion) - # for compatibility (old names do not follow convention) - asM = M - asQuaternion = as_quaternion - asEulers = as_Eulers - asAxisAngle = as_axis_angle - asMatrix = as_matrix - asRodrigues = as_Rodrigues - asHomochoric = as_homochoric - asCubochoric = as_cubochoric ################################################################################################ # Static constructors. The input data needs to follow the conventions, options allow to @@ -505,13 +496,8 @@ class Rotation: # for compatibility (old names do not follow convention) fromQuaternion = from_quaternion fromEulers = from_Eulers - fromAxisAngle = from_axis_angle - fromBasis = from_basis - fromMatrix = from_matrix - fromRodrigues = from_Rodrigues - fromHomochoric = from_homochoric - fromCubochoric = from_cubochoric - fromRandom = from_random + asAxisAngle = as_axis_angle + #################################################################################################### # Code below available according to the following conditions on https://github.com/MarDiehl/3Drotations From a25dd1c4389165a74237706b0e83b4964892fb1d Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 17 May 2020 08:01:34 +0200 Subject: [PATCH 052/136] cleaning --- python/damask/_rotation.py | 20 ++++++++++---------- python/tests/test_Orientation.py | 2 +- 2 files changed, 11 insertions(+), 11 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index bf5a2a4f3..e2d5963fe 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -35,8 +35,8 @@ class Rotation: ----- Vector "a" (defined in coordinate system "A") is passively rotated resulting in new coordinates "b" when expressed in system "B". - b = Q * a - b = np.dot(Q.asMatrix(),a) + b = Q @ a + b = np.dot(Q.as_matrix(),a) """ @@ -73,8 +73,8 @@ class Rotation: raise NotImplementedError('Support for multiple rotations missing') return '\n'.join([ 'Quaternion: (real={:.3f}, imag=<{:+.3f}, {:+.3f}, {:+.3f}>)'.format(*(self.quaternion)), - 'Matrix:\n{}'.format(self.asMatrix()), - 'Bunge Eulers / deg: ({:3.2f}, {:3.2f}, {:3.2f})'.format(*self.asEulers(degrees=True)), + 'Matrix:\n{}'.format(self.as_matrix()), + 'Bunge Eulers / deg: ({:3.2f}, {:3.2f}, {:3.2f})'.format(*self.as_Eulers(degrees=True)), ]) @@ -112,9 +112,9 @@ class Rotation: return A*other + B*self.quaternion[1:] + C * np.cross(self.quaternion[1:],other) elif other.shape == (3,3,): - return np.dot(self.asMatrix(),np.dot(other,self.asMatrix().T)) + return np.dot(self.as_matrix(),np.dot(other,self.as_matrix().T)) elif other.shape == (3,3,3,3,): - R = self.asMatrix() + R = self.as_matrix() return np.einsum('...im,...jn,...ko,...lp,...mnop',R,R,R,R,other) else: raise ValueError('Can only rotate vectors, 2nd order ternsors, and 4th order tensors') @@ -150,10 +150,10 @@ class Rotation: - p_m[...,(i+2)%3]*other[...,(i+1)%3])).reshape(self.shape+(1,)) for i in [0,1,2]]) if self.shape + (3,3) == other.shape: - R = self.asMatrix() + R = self.as_matrix() return np.einsum('...im,...jn,...mn',R,R,other) if self.shape + (3,3,3,3) == other.shape: - R = self.asMatrix() + R = self.as_matrix() return np.einsum('...im,...jn,...ko,...lp,...mnop',R,R,R,R,other) else: raise ValueError('Can only rotate vectors, 2nd order ternsors, and 4th order tensors') @@ -654,8 +654,8 @@ class Rotation: def om2ax(om): """Rotation matrix to axis angle pair.""" diag_delta = -_P*np.block([om[...,1,2:3]-om[...,2,1:2], - om[...,2,0:1]-om[...,0,2:3], - om[...,0,1:2]-om[...,1,0:1] + om[...,2,0:1]-om[...,0,2:3], + om[...,0,1:2]-om[...,1,0:1] ]) diag_delta[np.abs(diag_delta)<1.e-6] = 1.0 t = 0.5*(om.trace(axis2=-2,axis1=-1) -1.0).reshape(om.shape[:-2]+(1,)) diff --git a/python/tests/test_Orientation.py b/python/tests/test_Orientation.py index 8dc526325..a8b8afdac 100644 --- a/python/tests/test_Orientation.py +++ b/python/tests/test_Orientation.py @@ -51,7 +51,7 @@ class TestOrientation: def test_relationship_reference(self,update,reference_dir,model,lattice): reference = os.path.join(reference_dir,'{}_{}.txt'.format(lattice,model)) ori = Orientation(Rotation(),lattice) - eu = np.array([o.rotation.asEulers(degrees=True) for o in ori.relatedOrientations(model)]) + eu = np.array([o.rotation.as_Eulers(degrees=True) for o in ori.relatedOrientations(model)]) if update: coords = np.array([(1,i+1) for i,x in enumerate(eu)]) table = damask.Table(eu,{'Eulers':(3,)}) From 3dc90ddb943a7be8d55416031af8e0281a413d66 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 18 May 2020 15:54:58 +0200 Subject: [PATCH 053/136] use the formula from the paper, not from the reference implementation a few multiplications should be faster than a transpose --- python/damask/_rotation.py | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index e2d5963fe..032cd1ac2 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -534,16 +534,16 @@ class Rotation: def qu2om(qu): qq = qu[...,0:1]**2-(qu[...,1:2]**2 + qu[...,2:3]**2 + qu[...,3:4]**2) om = np.block([qq + 2.0*qu[...,1:2]**2, - 2.0*(qu[...,2:3]*qu[...,1:2]+qu[...,0:1]*qu[...,3:4]), - 2.0*(qu[...,3:4]*qu[...,1:2]-qu[...,0:1]*qu[...,2:3]), - 2.0*(qu[...,1:2]*qu[...,2:3]-qu[...,0:1]*qu[...,3:4]), + 2.0*(qu[...,2:3]*qu[...,1:2]+_P*qu[...,0:1]*qu[...,3:4]), + 2.0*(qu[...,3:4]*qu[...,1:2]-_P*qu[...,0:1]*qu[...,2:3]), + 2.0*(qu[...,1:2]*qu[...,2:3]-_P*qu[...,0:1]*qu[...,3:4]), qq + 2.0*qu[...,2:3]**2, - 2.0*(qu[...,3:4]*qu[...,2:3]+qu[...,0:1]*qu[...,1:2]), - 2.0*(qu[...,1:2]*qu[...,3:4]+qu[...,0:1]*qu[...,2:3]), - 2.0*(qu[...,2:3]*qu[...,3:4]-qu[...,0:1]*qu[...,1:2]), + 2.0*(qu[...,3:4]*qu[...,2:3]+_P*qu[...,0:1]*qu[...,1:2]), + 2.0*(qu[...,1:2]*qu[...,3:4]+_P*qu[...,0:1]*qu[...,2:3]), + 2.0*(qu[...,2:3]*qu[...,3:4]-_P*qu[...,0:1]*qu[...,1:2]), qq + 2.0*qu[...,3:4]**2, ]).reshape(qu.shape[:-1]+(3,3)) - return om if _P < 0.0 else np.swapaxes(om,(-1,-2)) + return om @staticmethod def qu2eu(qu): @@ -641,7 +641,7 @@ class Rotation: np.zeros(om.shape[:-2]+(1,)), ]), np.block([np.arctan2(om[...,2,0:1]*zeta,-om[...,2,1:2]*zeta), - np.arccos(om[...,2,2:3]), + np.arccos( om[...,2,2:3]), np.arctan2(om[...,0,2:3]*zeta,+om[...,1,2:3]*zeta) ]) ) From b200894a40782420b624a2058ff40cbd5097e95d Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 18 May 2020 18:41:48 +0200 Subject: [PATCH 054/136] bugfix and further test --- python/damask/_rotation.py | 41 +++++++++++++++++++++-------- python/tests/rotation_conversion.py | 17 ++++++++++++ python/tests/test_Rotation.py | 3 ++- 3 files changed, 49 insertions(+), 12 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 032cd1ac2..5af3e1874 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -534,13 +534,13 @@ class Rotation: def qu2om(qu): qq = qu[...,0:1]**2-(qu[...,1:2]**2 + qu[...,2:3]**2 + qu[...,3:4]**2) om = np.block([qq + 2.0*qu[...,1:2]**2, - 2.0*(qu[...,2:3]*qu[...,1:2]+_P*qu[...,0:1]*qu[...,3:4]), - 2.0*(qu[...,3:4]*qu[...,1:2]-_P*qu[...,0:1]*qu[...,2:3]), - 2.0*(qu[...,1:2]*qu[...,2:3]-_P*qu[...,0:1]*qu[...,3:4]), + 2.0*(qu[...,2:3]*qu[...,1:2]-_P*qu[...,0:1]*qu[...,3:4]), + 2.0*(qu[...,3:4]*qu[...,1:2]+_P*qu[...,0:1]*qu[...,2:3]), + 2.0*(qu[...,1:2]*qu[...,2:3]+_P*qu[...,0:1]*qu[...,3:4]), qq + 2.0*qu[...,2:3]**2, - 2.0*(qu[...,3:4]*qu[...,2:3]+_P*qu[...,0:1]*qu[...,1:2]), - 2.0*(qu[...,1:2]*qu[...,3:4]+_P*qu[...,0:1]*qu[...,2:3]), - 2.0*(qu[...,2:3]*qu[...,3:4]-_P*qu[...,0:1]*qu[...,1:2]), + 2.0*(qu[...,3:4]*qu[...,2:3]-_P*qu[...,0:1]*qu[...,1:2]), + 2.0*(qu[...,1:2]*qu[...,3:4]-_P*qu[...,0:1]*qu[...,2:3]), + 2.0*(qu[...,2:3]*qu[...,3:4]+_P*qu[...,0:1]*qu[...,1:2]), qq + 2.0*qu[...,3:4]**2, ]).reshape(qu.shape[:-1]+(3,3)) return om @@ -626,9 +626,31 @@ class Rotation: """ Rotation matrix to quaternion. - The original formulation (direct conversion) had (numerical?) issues + This formulation is from www.euclideanspace.com/maths/geometry/rotations/conversions/matrixToQuaternion. + The original formulation had issues. """ - return Rotation.eu2qu(Rotation.om2eu(om)) + def x(a): + trace = a[0,0] + a[1,1] + a[2,2] + if trace > 0: + s = 0.5 / np.sqrt(trace+ 1.0) + qu = np.array([0.25 / s,( a[2,1] - a[1,2] ) * s,( a[0,2] - a[2,0] ) * s,( a[1,0] - a[0,1] ) * s]) + else: + if ( a[0,0] > a[1,1] and a[0,0] > a[2,2] ): + s = 2.0 * np.sqrt( 1.0 + a[0,0] - a[1,1] - a[2,2]) + qu = np.array([ (a[2,1] - a[1,2]) / s,0.25 * s,(a[0,1] + a[1,0]) / s,(a[0,2] + a[2,0]) / s]) + elif (a[1,1] > a[2,2]): + s = 2.0 * np.sqrt( 1.0 + a[1,1] - a[0,0] - a[2,2]) + qu = np.array([ (a[0,2] - a[2,0]) / s,(a[0,1] + a[1,0]) / s,0.25 * s,(a[1,2] + a[2,1]) / s]) + else: + s = 2.0 * np.sqrt( 1.0 + a[2,2] - a[0,0] - a[1,1] ) + qu = np.array([ (a[1,0] - a[0,1]) / s,(a[0,2] + a[2,0]) / s,(a[1,2] + a[2,1]) / s,0.25 * s]) + return qu + if len(om.shape) > 2: + om_ = om.reshape(-1,3,3) + qu = np.array([x(o) for o in om_]).reshape(om.shape[:-2]+(4,)) + else: + qu = x(om) + return qu*np.array([1,_P,_P,_P]) @staticmethod def om2eu(om): @@ -649,7 +671,6 @@ class Rotation: eu = np.where(eu<0, (eu+2.0*np.pi)%np.array([2.0*np.pi,np.pi,2.0*np.pi]),eu) return eu - @staticmethod def om2ax(om): """Rotation matrix to axis angle pair.""" @@ -672,7 +693,6 @@ class Rotation: ax[np.abs(ax[...,3])<1.e-6] = [ 0.0, 0.0, 1.0, 0.0] return ax - @staticmethod def om2ro(om): """Rotation matrix to Rodrigues-Frank vector.""" @@ -703,7 +723,6 @@ class Rotation: qu[qu[...,0]<0.0]*=-1 return qu - @staticmethod def eu2om(eu): """Bunge-Euler angles to rotation matrix.""" diff --git a/python/tests/rotation_conversion.py b/python/tests/rotation_conversion.py index 5ca10f443..ddd13495f 100644 --- a/python/tests/rotation_conversion.py +++ b/python/tests/rotation_conversion.py @@ -112,6 +112,23 @@ def qu2ho(qu): #---------- Rotation matrix ---------- +def om2qu(a): + trace = a[0,0] + a[1,1] + a[2,2] + if trace > 0: + s = 0.5 / np.sqrt(trace+ 1.0) + qu = np.array([0.25 / s,( a[2,1] - a[1,2] ) * s,( a[0,2] - a[2,0] ) * s,( a[1,0] - a[0,1] ) * s]) + else: + if ( a[0,0] > a[1,1] and a[0,0] > a[2,2] ): + s = 2.0 * np.sqrt( 1.0 + a[0,0] - a[1,1] - a[2,2]) + qu = np.array([ (a[2,1] - a[1,2]) / s,0.25 * s,(a[0,1] + a[1,0]) / s,(a[0,2] + a[2,0]) / s]) + elif (a[1,1] > a[2,2]): + s = 2.0 * np.sqrt( 1.0 + a[1,1] - a[0,0] - a[2,2]) + qu = np.array([ (a[0,2] - a[2,0]) / s,(a[0,1] + a[1,0]) / s,0.25 * s,(a[1,2] + a[2,1]) / s]) + else: + s = 2.0 * np.sqrt( 1.0 + a[2,2] - a[0,0] - a[1,1] ) + qu = np.array([ (a[1,0] - a[0,1]) / s,(a[0,2] + a[2,0]) / s,(a[1,2] + a[2,1]) / s,0.25 * s]) + return qu + def om2eu(om): """Rotation matrix to Bunge-Euler angles.""" if not np.isclose(np.abs(om[2,2]),1.0,1.e-4): diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index 4a6350fda..71aff04a9 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -196,7 +196,8 @@ class TestRotation: assert np.allclose(single(q),c) and np.allclose(single(q),vectorized(q)) - @pytest.mark.parametrize('vectorized, single',[(Rotation.om2eu,rotation_conversion.om2eu), + @pytest.mark.parametrize('vectorized, single',[(Rotation.om2qu,rotation_conversion.om2qu), + (Rotation.om2eu,rotation_conversion.om2eu), (Rotation.om2ax,rotation_conversion.om2ax)]) def test_matrix_vectorization(self,default,vectorized,single): om = np.array([rot.as_matrix() for rot in default]) From b6eebcd7044a2867b5b96aa97114b4a2a77cfc47 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 18 May 2020 20:16:50 +0200 Subject: [PATCH 055/136] small fixes (testing P=+1) --- python/damask/_rotation.py | 10 +++++----- python/tests/rotation_conversion.py | 16 +++++++++------- 2 files changed, 14 insertions(+), 12 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 5af3e1874..e38a2bc56 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -716,10 +716,10 @@ class Rotation: ee = 0.5*eu cPhi = np.cos(ee[...,1:2]) sPhi = np.sin(ee[...,1:2]) - qu = np.block([ cPhi*np.cos(ee[...,0:1]+ee[...,2:3]), - -_P*sPhi*np.cos(ee[...,0:1]-ee[...,2:3]), - -_P*sPhi*np.sin(ee[...,0:1]-ee[...,2:3]), - -_P*cPhi*np.sin(ee[...,0:1]+ee[...,2:3])]) + qu = np.block([ cPhi*np.cos(ee[...,0:1]+ee[...,2:3]), + -_P*sPhi*np.cos(ee[...,0:1]-ee[...,2:3]), + -_P*sPhi*np.sin(ee[...,0:1]-ee[...,2:3]), + -_P*cPhi*np.sin(ee[...,0:1]+ee[...,2:3])]) qu[qu[...,0]<0.0]*=-1 return qu @@ -804,7 +804,7 @@ class Rotation: omc*ax[...,0:1]*ax[...,2:3] + s*ax[...,1:2], omc*ax[...,1:2]*ax[...,2:3] - s*ax[...,0:1], c+omc*ax[...,2:3]**2]).reshape(ax.shape[:-1]+(3,3)) - return om if _P < 0.0 else np.swapaxes(om,(-1,-2)) + return om if _P < 0.0 else np.swapaxes(om,-1,-2) @staticmethod def ax2eu(ax): diff --git a/python/tests/rotation_conversion.py b/python/tests/rotation_conversion.py index ddd13495f..82451bd84 100644 --- a/python/tests/rotation_conversion.py +++ b/python/tests/rotation_conversion.py @@ -31,12 +31,14 @@ import numpy as np -_P = -1 +from damask import _rotation + +_P = _rotation._P # parameters for conversion from/to cubochoric -_sc = np.pi**(1./6.)/6.**(1./6.) -_beta = np.pi**(5./6.)/6.**(1./6.)/2. -_R1 = (3.*np.pi/4.)**(1./3.) +_sc = _rotation._sc +_beta = _rotation._beta +_R1 = _rotation._R1 def iszero(a): return np.isclose(a,0.0,atol=1.0e-12,rtol=0.0) @@ -53,7 +55,7 @@ def qu2om(qu): om[2,1] = 2.0*(qu[2]*qu[3]-qu[0]*qu[1]) om[2,0] = 2.0*(qu[1]*qu[3]+qu[0]*qu[2]) om[0,2] = 2.0*(qu[3]*qu[1]-qu[0]*qu[2]) - return om if _P < 0.0 else np.swapaxes(om,(-1,-2)) + return om if _P < 0.0 else np.swapaxes(om,-1,-2) def qu2eu(qu): """Quaternion to Bunge-Euler angles.""" @@ -127,7 +129,7 @@ def om2qu(a): else: s = 2.0 * np.sqrt( 1.0 + a[2,2] - a[0,0] - a[1,1] ) qu = np.array([ (a[1,0] - a[0,1]) / s,(a[0,2] + a[2,0]) / s,(a[1,2] + a[2,1]) / s,0.25 * s]) - return qu + return qu*np.array([1.,_P,_P,_P]) def om2eu(om): """Rotation matrix to Bunge-Euler angles.""" @@ -167,7 +169,7 @@ def eu2qu(eu): ee = 0.5*eu cPhi = np.cos(ee[1]) sPhi = np.sin(ee[1]) - qu = np.array([ cPhi*np.cos(ee[0]+ee[2]), + qu = np.array([ cPhi*np.cos(ee[0]+ee[2]), -_P*sPhi*np.cos(ee[0]-ee[2]), -_P*sPhi*np.sin(ee[0]-ee[2]), -_P*cPhi*np.sin(ee[0]+ee[2]) ]) From 1a3a4a800e6f6b4616eb8b76dfb18473f63945e0 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 19 May 2020 07:35:58 +0200 Subject: [PATCH 056/136] vectorized --- python/damask/_rotation.py | 54 ++++++++++++++++++++++---------------- 1 file changed, 32 insertions(+), 22 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index e38a2bc56..09921a194 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -629,28 +629,38 @@ class Rotation: This formulation is from www.euclideanspace.com/maths/geometry/rotations/conversions/matrixToQuaternion. The original formulation had issues. """ - def x(a): - trace = a[0,0] + a[1,1] + a[2,2] - if trace > 0: - s = 0.5 / np.sqrt(trace+ 1.0) - qu = np.array([0.25 / s,( a[2,1] - a[1,2] ) * s,( a[0,2] - a[2,0] ) * s,( a[1,0] - a[0,1] ) * s]) - else: - if ( a[0,0] > a[1,1] and a[0,0] > a[2,2] ): - s = 2.0 * np.sqrt( 1.0 + a[0,0] - a[1,1] - a[2,2]) - qu = np.array([ (a[2,1] - a[1,2]) / s,0.25 * s,(a[0,1] + a[1,0]) / s,(a[0,2] + a[2,0]) / s]) - elif (a[1,1] > a[2,2]): - s = 2.0 * np.sqrt( 1.0 + a[1,1] - a[0,0] - a[2,2]) - qu = np.array([ (a[0,2] - a[2,0]) / s,(a[0,1] + a[1,0]) / s,0.25 * s,(a[1,2] + a[2,1]) / s]) - else: - s = 2.0 * np.sqrt( 1.0 + a[2,2] - a[0,0] - a[1,1] ) - qu = np.array([ (a[1,0] - a[0,1]) / s,(a[0,2] + a[2,0]) / s,(a[1,2] + a[2,1]) / s,0.25 * s]) - return qu - if len(om.shape) > 2: - om_ = om.reshape(-1,3,3) - qu = np.array([x(o) for o in om_]).reshape(om.shape[:-2]+(4,)) - else: - qu = x(om) - return qu*np.array([1,_P,_P,_P]) + trace = om[...,0,0:1]+om[...,1,1:2]+om[...,2,2:3] + + with np.errstate(invalid='ignore',divide='ignore'): + s = [ + 0.5 / np.sqrt( 1.0 + trace), + 2.0 * np.sqrt( 1.0 + om[...,0,0:1] - om[...,1,1:2] - om[...,2,2:3]), + 2.0 * np.sqrt( 1.0 + om[...,1,1:2] - om[...,2,2:3] - om[...,0,0:1]), + 2.0 * np.sqrt( 1.0 + om[...,2,2:3] - om[...,0,0:1] - om[...,1,1:2] ) + ] + qu= np.where(trace>0, + np.block([0.25 / s[0], + (om[...,2,1:2] - om[...,1,2:3] ) * s[0], + (om[...,0,2:3] - om[...,2,0:1] ) * s[0], + (om[...,1,0:1] - om[...,0,1:2] ) * s[0]]), + np.where(om[...,0,0:1] > np.maximum(om[...,1,1:2],om[...,2,2:3]), + np.block([(om[...,2,1:2] - om[...,1,2:3]) / s[1], + 0.25 * s[1], + (om[...,0,1:2] + om[...,1,0:1]) / s[1], + (om[...,0,2:3] + om[...,2,0:1]) / s[1]]), + np.where(om[...,1,1:2] > om[...,2,2:3], + np.block([(om[...,0,2:3] - om[...,2,0:1]) / s[2], + (om[...,0,1:2] + om[...,1,0:1]) / s[2], + 0.25 * s[2], + (om[...,1,2:3] + om[...,2,1:2]) / s[2]]), + np.block([(om[...,1,0:1] - om[...,0,1:2]) / s[3], + (om[...,0,2:3] + om[...,2,0:1]) / s[3], + (om[...,1,2:3] + om[...,2,1:2]) / s[3], + 0.25 * s[3]]), + ) + ) + )*np.array([1,_P,_P,_P]) + return qu @staticmethod def om2eu(om): From ebf05a279eb2693a37dcce13efa590a67ab5bdc9 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 19 May 2020 08:59:03 +0200 Subject: [PATCH 057/136] standard name --- python/damask/_rotation.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 09921a194..949a6c3ab 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -311,7 +311,7 @@ class Rotation: # relax the conventions. @staticmethod def from_quaternion(quaternion, - acceptHomomorph = False, + accept_homomorph = False, P = -1): qu = np.array(quaternion,dtype=float) @@ -319,7 +319,7 @@ class Rotation: raise ValueError('Invalid shape.') if P > 0: qu[...,1:4] *= -1 # convert from P=1 to P=-1 - if acceptHomomorph: + if accept_homomorph: qu[qu[...,0] < 0.0] *= -1 else: if np.any(qu[...,0] < 0.0): @@ -472,7 +472,7 @@ class Rotation: else M + r.asM() * n # noqa add (multiples) of this rotation to average noqa eig, vec = np.linalg.eig(M/N) - return Rotation.from_quaternion(np.real(vec.T[eig.argmax()]),acceptHomomorph = True) + return Rotation.from_quaternion(np.real(vec.T[eig.argmax()]),accept_homomorph = True) @staticmethod def from_random(shape=None): From 065c624f94acdacce2fce12be0aca72c1cbe3c30 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 19 May 2020 09:10:14 +0200 Subject: [PATCH 058/136] fix for backward compatibility --- python/damask/_rotation.py | 1 + python/tests/test_Rotation.py | 36 +++++++++++++++++++++++------------ 2 files changed, 25 insertions(+), 12 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 949a6c3ab..f45e04ff4 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -494,6 +494,7 @@ class Rotation: # for compatibility (old names do not follow convention) + asM = M fromQuaternion = from_quaternion fromEulers = from_Eulers asAxisAngle = as_axis_angle diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index 71aff04a9..183fbd19e 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -91,20 +91,25 @@ def reference_dir(reference_dir_base): class TestRotation: - def test_Eulers(self,default): + @pytest.mark.parametrize('degrees',[True,False]) + def test_Eulers(self,default,degrees): for rot in default: m = rot.as_quaternion() - o = Rotation.from_Eulers(rot.as_Eulers()).as_quaternion() + o = Rotation.from_Eulers(rot.as_Eulers(degrees),degrees).as_quaternion() ok = np.allclose(m,o,atol=atol) if np.isclose(rot.as_quaternion()[0],0.0,atol=atol): ok = ok or np.allclose(m*-1.,o,atol=atol) print(m,o,rot.as_quaternion()) assert ok and np.isclose(np.linalg.norm(o),1.0) - def test_AxisAngle(self,default): + @pytest.mark.parametrize('P',[1,-1]) + @pytest.mark.parametrize('normalise',[True,False]) + @pytest.mark.parametrize('degrees',[True,False]) + def test_AxisAngle(self,default,degrees,normalise,P): + c = np.array([P*-1,P*-1,P*-1,1.]) for rot in default: m = rot.as_Eulers() - o = Rotation.from_axis_angle(rot.as_axis_angle()).as_Eulers() + o = Rotation.from_axis_angle(rot.as_axis_angle(degrees)*c,degrees,normalise,P).as_Eulers() u = np.array([np.pi*2,np.pi,np.pi*2]) ok = np.allclose(m,o,atol=atol) ok = ok or np.allclose(np.where(np.isclose(m,u),m-u,m),np.where(np.isclose(o,u),o-u,o),atol=atol) @@ -124,36 +129,43 @@ class TestRotation: print(m,o,rot.as_quaternion()) assert ok and np.isclose(np.linalg.norm(o[:3]),1.0) and o[3]<=np.pi++1.e-9 - def test_Rodrigues(self,default): + @pytest.mark.parametrize('P',[1,-1]) + @pytest.mark.parametrize('normalise',[True,False]) + def test_Rodrigues(self,default,normalise,P): + c = np.array([P*-1,P*-1,P*-1,1.]) for rot in default: m = rot.as_matrix() - o = Rotation.from_Rodrigues(rot.as_Rodrigues()).as_matrix() + o = Rotation.from_Rodrigues(rot.as_Rodrigues()*c,normalise,P).as_matrix() ok = np.allclose(m,o,atol=atol) print(m,o) assert ok and np.isclose(np.linalg.det(o),1.0) - def test_Homochoric(self,default): + @pytest.mark.parametrize('P',[1,-1]) + def test_Homochoric(self,default,P): cutoff = np.tan(np.pi*.5*(1.-1e-4)) for rot in default: m = rot.as_Rodrigues() - o = Rotation.from_homochoric(rot.as_homochoric()).as_Rodrigues() + o = Rotation.from_homochoric(rot.as_homochoric()*P*-1,P).as_Rodrigues() ok = np.allclose(np.clip(m,None,cutoff),np.clip(o,None,cutoff),atol=atol) ok = ok or np.isclose(m[3],0.0,atol=atol) print(m,o,rot.as_quaternion()) assert ok and np.isclose(np.linalg.norm(o[:3]),1.0) - def test_Cubochoric(self,default): + @pytest.mark.parametrize('P',[1,-1]) + def test_Cubochoric(self,default,P): for rot in default: m = rot.as_homochoric() - o = Rotation.from_cubochoric(rot.as_cubochoric()).as_homochoric() + o = Rotation.from_cubochoric(rot.as_cubochoric()*P*-1,P).as_homochoric() ok = np.allclose(m,o,atol=atol) print(m,o,rot.as_quaternion()) assert ok and np.linalg.norm(o) < (3.*np.pi/4.)**(1./3.) + 1.e-9 - def test_Quaternion(self,default): + @pytest.mark.parametrize('P',[1,-1]) + def test_Quaternion(self,default,P): + c = np.array([1,P*-1,P*-1,P*-1]) for rot in default: m = rot.as_cubochoric() - o = Rotation.from_quaternion(rot.as_quaternion()).as_cubochoric() + o = Rotation.from_quaternion(rot.as_quaternion()*c,False,P).as_cubochoric() ok = np.allclose(m,o,atol=atol) print(m,o,rot.as_quaternion()) assert ok and o.max() < np.pi**(2./3.)*0.5+1.e-9 From de79a5af43772629878e0bafe6f928de569e289a Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 19 May 2020 09:55:23 +0200 Subject: [PATCH 059/136] directly test the internal conversions some work to do ... --- python/damask/_rotation.py | 5 +-- python/tests/rotation_conversion.py | 1 + python/tests/test_Rotation.py | 50 +++++++++++++++++++++++++++++ 3 files changed, 54 insertions(+), 2 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index f45e04ff4..167552b68 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -468,8 +468,8 @@ class Rotation: weights = np.ones(N,dtype='i') for i,(r,n) in enumerate(zip(rotations,weights)): - M = r.asM() * n if i == 0 \ - else M + r.asM() * n # noqa add (multiples) of this rotation to average noqa + M = r.M() * n if i == 0 \ + else M + r.M() * n # noqa add (multiples) of this rotation to average noqa eig, vec = np.linalg.eig(M/N) return Rotation.from_quaternion(np.real(vec.T[eig.argmax()]),accept_homomorph = True) @@ -661,6 +661,7 @@ class Rotation: ) ) )*np.array([1,_P,_P,_P]) + qu[qu[...,0]<0] *=-1 return qu @staticmethod diff --git a/python/tests/rotation_conversion.py b/python/tests/rotation_conversion.py index 82451bd84..5219f3260 100644 --- a/python/tests/rotation_conversion.py +++ b/python/tests/rotation_conversion.py @@ -129,6 +129,7 @@ def om2qu(a): else: s = 2.0 * np.sqrt( 1.0 + a[2,2] - a[0,0] - a[1,1] ) qu = np.array([ (a[1,0] - a[0,1]) / s,(a[0,2] + a[2,0]) / s,(a[1,2] + a[2,1]) / s,0.25 * s]) + if qu[0]<0: qu*=-1 return qu*np.array([1.,_P,_P,_P]) def om2eu(om): diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index 183fbd19e..4dc98a797 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -91,6 +91,56 @@ def reference_dir(reference_dir_base): class TestRotation: + @pytest.mark.parametrize('forward,backward',[(Rotation.qu2om,Rotation.om2qu), + (Rotation.qu2eu,Rotation.eu2qu), + (Rotation.qu2ax,Rotation.ax2qu), + (Rotation.qu2ro,Rotation.ro2qu), + (Rotation.qu2ho,Rotation.ho2qu), + (Rotation.qu2cu,Rotation.cu2qu)]) + def test_quaternion_internal(self,default,forward,backward): + for rot in default: + m = rot.as_quaternion() + o = backward(forward(m)) + ok = np.allclose(m,o,atol=atol) + if np.isclose(rot.as_quaternion()[0],0.0,atol=atol): + ok = ok or np.allclose(m*-1.,o,atol=atol) + print(m,o,rot.as_quaternion()) + assert ok and np.isclose(np.linalg.norm(o),1.0) + + @pytest.mark.parametrize('forward,backward',[(Rotation.om2qu,Rotation.qu2om)]) + #(Rotation.om2eu,Rotation.eu2om), + #(Rotation.om2ax,Rotation.ax2om), + #(Rotation.om2ro,Rotation.ro2om), + #(Rotation.om2ho,Rotation.ho2om), + #(Rotation.om2cu,Rotation.cu2om)]) + def test_matrix_internal(self,default,forward,backward): + for rot in default: + m = rot.as_matrix() + o = backward(forward(m)) + ok = np.allclose(m,o,atol=atol) + print(m,o,rot.as_quaternion()) + assert ok and np.isclose(np.linalg.det(o),1.0) + + @pytest.mark.parametrize('forward,backward',[(Rotation.eu2qu,Rotation.qu2eu)]) + #(Rotation.eu2om,Rotation.om2eu), + #(Rotation.eu2ax,Rotation.ax2eu), + #(Rotation.eu2ro,Rotation.ro2eu), + #(Rotation.eu2ho,Rotation.ho2eu), + #(Rotation.eu2cu,Rotation.cu2eu)]) + def test_Eulers_internal(self,default,forward,backward): + for rot in default: + m = rot.as_Eulers() + o = backward(forward(m)) + u = np.array([np.pi*2,np.pi,np.pi*2]) + ok = np.allclose(m,o,atol=atol) + ok = ok or np.allclose(np.where(np.isclose(m,u),m-u,m),np.where(np.isclose(o,u),o-u,o),atol=atol) + if np.isclose(m[1],0.0,atol=atol) or np.isclose(m[1],np.pi,atol=atol): + sum_phi = np.unwrap([m[0]+m[2],o[0]+o[2]]) + ok = ok or np.isclose(sum_phi[0],sum_phi[1],atol=atol) + print(m,o,rot.as_quaternion()) + assert ok and (np.zeros(3)-1.e-9 <= o).all() and (o <= np.array([np.pi*2.,np.pi,np.pi*2.])+1.e-9).all() + + @pytest.mark.parametrize('degrees',[True,False]) def test_Eulers(self,default,degrees): for rot in default: From a6b0aaffbac0d1188e85f5862b0e3c7452405dc4 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 19 May 2020 19:41:50 +0200 Subject: [PATCH 060/136] more tests Hotfix needed for axis angle to matrix (not used in DAMASK, needs further investigation) --- python/damask/_rotation.py | 11 +++++---- python/tests/rotation_conversion.py | 11 +++++---- python/tests/test_Rotation.py | 38 ++++++++++++++++++++--------- 3 files changed, 39 insertions(+), 21 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 167552b68..ee497e72b 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -669,7 +669,7 @@ class Rotation: """Rotation matrix to Bunge-Euler angles.""" with np.errstate(invalid='ignore',divide='ignore'): zeta = 1.0/np.sqrt(1.0-om[...,2,2:3]**2) - eu = np.where(np.isclose(np.abs(om[...,2,2:3]),1.0,1e-4), + eu = np.where(np.isclose(np.abs(om[...,2,2:3]),1.0,1e-9), np.block([np.arctan2(om[...,0,1:2],om[...,0,0:1]), np.pi*0.5*(1-om[...,2,2:3]), np.zeros(om.shape[:-2]+(1,)), @@ -679,30 +679,30 @@ class Rotation: np.arctan2(om[...,0,2:3]*zeta,+om[...,1,2:3]*zeta) ]) ) - eu[np.abs(eu)<1.e-6] = 0.0 + eu[np.abs(eu)<1.e-8] = 0.0 eu = np.where(eu<0, (eu+2.0*np.pi)%np.array([2.0*np.pi,np.pi,2.0*np.pi]),eu) return eu @staticmethod def om2ax(om): """Rotation matrix to axis angle pair.""" + return Rotation.qu2ax(Rotation.om2qu(om)) # HOTFIX diag_delta = -_P*np.block([om[...,1,2:3]-om[...,2,1:2], om[...,2,0:1]-om[...,0,2:3], om[...,0,1:2]-om[...,1,0:1] ]) - diag_delta[np.abs(diag_delta)<1.e-6] = 1.0 t = 0.5*(om.trace(axis2=-2,axis1=-1) -1.0).reshape(om.shape[:-2]+(1,)) w,vr = np.linalg.eig(om) # mask duplicated real eigenvalues w[np.isclose(w[...,0],1.0+0.0j),1:] = 0. w[np.isclose(w[...,1],1.0+0.0j),2:] = 0. vr = np.swapaxes(vr,-1,-2) - ax = np.where(np.abs(diag_delta)<0, + ax = np.where(np.abs(diag_delta)<1e-12, np.real(vr[np.isclose(w,1.0+0.0j)]).reshape(om.shape[:-2]+(3,)), np.abs(np.real(vr[np.isclose(w,1.0+0.0j)]).reshape(om.shape[:-2]+(3,))) \ *np.sign(diag_delta)) ax = np.block([ax,np.arccos(np.clip(t,-1.0,1.0))]) - ax[np.abs(ax[...,3])<1.e-6] = [ 0.0, 0.0, 1.0, 0.0] + ax[np.abs(ax[...,3])<1.e-8] = [ 0.0, 0.0, 1.0, 0.0] return ax @staticmethod @@ -804,6 +804,7 @@ class Rotation: @staticmethod def ax2om(ax): """Axis angle pair to rotation matrix.""" + return Rotation.qu2om(Rotation.ax2qu(ax)) # HOTFIX c = np.cos(ax[...,3:4]) s = np.sin(ax[...,3:4]) omc = 1. -c diff --git a/python/tests/rotation_conversion.py b/python/tests/rotation_conversion.py index 5219f3260..ab503f402 100644 --- a/python/tests/rotation_conversion.py +++ b/python/tests/rotation_conversion.py @@ -134,25 +134,26 @@ def om2qu(a): def om2eu(om): """Rotation matrix to Bunge-Euler angles.""" - if not np.isclose(np.abs(om[2,2]),1.0,1.e-4): + if not np.isclose(np.abs(om[2,2]),1.0,1.e-9): zeta = 1.0/np.sqrt(1.0-om[2,2]**2) eu = np.array([np.arctan2(om[2,0]*zeta,-om[2,1]*zeta), np.arccos(om[2,2]), np.arctan2(om[0,2]*zeta, om[1,2]*zeta)]) else: eu = np.array([np.arctan2( om[0,1],om[0,0]), np.pi*0.5*(1-om[2,2]),0.0]) # following the paper, not the reference implementation - eu[np.abs(eu)<1.e-6] = 0.0 + eu[np.abs(eu)<1.e-8] = 0.0 eu = np.where(eu<0, (eu+2.0*np.pi)%np.array([2.0*np.pi,np.pi,2.0*np.pi]),eu) return eu def om2ax(om): """Rotation matrix to axis angle pair.""" + return qu2ax(om2qu(om)) # HOTFIX ax=np.empty(4) # first get the rotation angle t = 0.5*(om.trace() -1.0) ax[3] = np.arccos(np.clip(t,-1.0,1.0)) - if np.abs(ax[3])<1.e-6: + if np.abs(ax[3])<1.e-8: ax = np.array([ 0.0, 0.0, 1.0, 0.0]) else: w,vr = np.linalg.eig(om) @@ -160,8 +161,7 @@ def om2ax(om): i = np.where(np.isclose(w,1.0+0.0j))[0][0] ax[0:3] = np.real(vr[0:3,i]) diagDelta = -_P*np.array([om[1,2]-om[2,1],om[2,0]-om[0,2],om[0,1]-om[1,0]]) - diagDelta[np.abs(diagDelta)<1.e-6] = 1.0 - ax[0:3] = np.where(np.abs(diagDelta)<0, ax[0:3],np.abs(ax[0:3])*np.sign(diagDelta)) + ax[0:3] = np.where(np.abs(diagDelta)<1e-12, ax[0:3],np.abs(ax[0:3])*np.sign(diagDelta)) return ax #---------- Bunge-Euler angles ---------- @@ -229,6 +229,7 @@ def ax2qu(ax): def ax2om(ax): """Axis angle pair to rotation matrix.""" + return qu2om(ax2qu(ax)) # HOTFIX c = np.cos(ax[3]) s = np.sin(ax[3]) omc = 1.0-c diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index 4dc98a797..adf507e49 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -107,10 +107,10 @@ class TestRotation: print(m,o,rot.as_quaternion()) assert ok and np.isclose(np.linalg.norm(o),1.0) - @pytest.mark.parametrize('forward,backward',[(Rotation.om2qu,Rotation.qu2om)]) - #(Rotation.om2eu,Rotation.eu2om), - #(Rotation.om2ax,Rotation.ax2om), - #(Rotation.om2ro,Rotation.ro2om), + @pytest.mark.parametrize('forward,backward',[(Rotation.om2qu,Rotation.qu2om), + (Rotation.om2eu,Rotation.eu2om), + (Rotation.om2ax,Rotation.ax2om), + (Rotation.om2ro,Rotation.ro2om)]) #(Rotation.om2ho,Rotation.ho2om), #(Rotation.om2cu,Rotation.cu2om)]) def test_matrix_internal(self,default,forward,backward): @@ -121,12 +121,12 @@ class TestRotation: print(m,o,rot.as_quaternion()) assert ok and np.isclose(np.linalg.det(o),1.0) - @pytest.mark.parametrize('forward,backward',[(Rotation.eu2qu,Rotation.qu2eu)]) - #(Rotation.eu2om,Rotation.om2eu), - #(Rotation.eu2ax,Rotation.ax2eu), - #(Rotation.eu2ro,Rotation.ro2eu), - #(Rotation.eu2ho,Rotation.ho2eu), - #(Rotation.eu2cu,Rotation.cu2eu)]) + @pytest.mark.parametrize('forward,backward',[(Rotation.eu2qu,Rotation.qu2eu), + (Rotation.eu2om,Rotation.om2eu), + (Rotation.eu2ax,Rotation.ax2eu), + (Rotation.eu2ro,Rotation.ro2eu), + (Rotation.eu2ho,Rotation.ho2eu), + (Rotation.eu2cu,Rotation.cu2eu)]) def test_Eulers_internal(self,default,forward,backward): for rot in default: m = rot.as_Eulers() @@ -140,6 +140,22 @@ class TestRotation: print(m,o,rot.as_quaternion()) assert ok and (np.zeros(3)-1.e-9 <= o).all() and (o <= np.array([np.pi*2.,np.pi,np.pi*2.])+1.e-9).all() + @pytest.mark.parametrize('forward,backward',[(Rotation.ax2qu,Rotation.qu2ax), + (Rotation.ax2om,Rotation.om2ax), + (Rotation.ax2eu,Rotation.eu2ax), + (Rotation.ax2ro,Rotation.ro2ax), + (Rotation.ax2ho,Rotation.ho2ax), + (Rotation.ax2cu,Rotation.cu2ax)]) + def test_axis_angle_internal(self,default,forward,backward): + for rot in default: + m = rot.as_axis_angle() + o = backward(forward(m)) + ok = np.allclose(m,o,atol=atol) + if np.isclose(m[3],np.pi,atol=atol): + ok = ok or np.allclose(m*np.array([-1.,-1.,-1.,1.]),o,atol=atol) + print(m,o,rot.as_quaternion()) + assert ok and np.isclose(np.linalg.norm(o[:3]),1.0) and o[3]<=np.pi+1.e-7 + @pytest.mark.parametrize('degrees',[True,False]) def test_Eulers(self,default,degrees): @@ -177,7 +193,7 @@ class TestRotation: if np.isclose(m[3],np.pi,atol=atol): ok = ok or np.allclose(m*np.array([-1.,-1.,-1.,1.]),o,atol=atol) print(m,o,rot.as_quaternion()) - assert ok and np.isclose(np.linalg.norm(o[:3]),1.0) and o[3]<=np.pi++1.e-9 + assert ok and np.isclose(np.linalg.norm(o[:3]),1.0) and o[3]<=np.pi+1.e-7 @pytest.mark.parametrize('P',[1,-1]) @pytest.mark.parametrize('normalise',[True,False]) From 1c53a37de485420da8ca8fa6cbdea6612b60824d Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 19 May 2020 21:03:30 +0200 Subject: [PATCH 061/136] more tests and adjustments to tolerances --- python/damask/_rotation.py | 5 ++--- python/tests/rotation_conversion.py | 7 +++---- python/tests/test_Rotation.py | 6 +++--- 3 files changed, 8 insertions(+), 10 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index ee497e72b..0f0a081bc 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -584,10 +584,10 @@ class Rotation: with np.errstate(invalid='ignore',divide='ignore'): s = np.sign(qu[...,0:1])/np.sqrt(qu[...,1:2]**2+qu[...,2:3]**2+qu[...,3:4]**2) omega = 2.0 * np.arccos(np.clip(qu[...,0:1],-1.0,1.0)) - ax = np.where(np.broadcast_to(qu[...,0:1] < 1.0e-6,qu.shape), + ax = np.where(np.broadcast_to(qu[...,0:1] < 1.0e-8,qu.shape), np.block([qu[...,1:4],np.broadcast_to(np.pi,qu.shape[:-1]+(1,))]), np.block([qu[...,1:4]*s,omega])) - ax[np.sum(np.abs(qu[...,1:4])**2,axis=-1) < 1.0e-6,] = [0.0, 0.0, 1.0, 0.0] + ax[np.isclose(qu[...,0],1.,rtol=0.0)] = [0.0, 0.0, 1.0, 0.0] return ax @staticmethod @@ -804,7 +804,6 @@ class Rotation: @staticmethod def ax2om(ax): """Axis angle pair to rotation matrix.""" - return Rotation.qu2om(Rotation.ax2qu(ax)) # HOTFIX c = np.cos(ax[...,3:4]) s = np.sin(ax[...,3:4]) omc = 1. -c diff --git a/python/tests/rotation_conversion.py b/python/tests/rotation_conversion.py index ab503f402..3aca1a212 100644 --- a/python/tests/rotation_conversion.py +++ b/python/tests/rotation_conversion.py @@ -81,9 +81,9 @@ def qu2ax(qu): Modified version of the original formulation, should be numerically more stable """ - if np.abs(np.sum(qu[1:4]**2)) < 1.e-6: # set axis to [001] if the angle is 0/360 + if np.isclose(qu[0],1.,rtol=0.0): # set axis to [001] if the angle is 0/360 ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) - elif qu[0] > 1.e-6: + elif qu[0] > 1.e-8: s = np.sign(qu[0])/np.sqrt(qu[1]**2+qu[2]**2+qu[3]**2) omega = 2.0 * np.arccos(np.clip(qu[0],-1.0,1.0)) ax = ax = np.array([ qu[1]*s, qu[2]*s, qu[3]*s, omega ]) @@ -229,7 +229,6 @@ def ax2qu(ax): def ax2om(ax): """Axis angle pair to rotation matrix.""" - return qu2om(ax2qu(ax)) # HOTFIX c = np.cos(ax[3]) s = np.sin(ax[3]) omc = 1.0-c @@ -239,7 +238,7 @@ def ax2om(ax): q = omc*ax[idx[0]] * ax[idx[1]] om[idx[0],idx[1]] = q + s*ax[idx[2]] om[idx[1],idx[0]] = q - s*ax[idx[2]] - return om if _P < 0.0 else np.swapaxes(om,(-1,-2)) + return om if _P < 0.0 else om.T def ax2ro(ax): """Axis angle pair to Rodrigues-Frank vector.""" diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index adf507e49..f9565a5e2 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -110,9 +110,9 @@ class TestRotation: @pytest.mark.parametrize('forward,backward',[(Rotation.om2qu,Rotation.qu2om), (Rotation.om2eu,Rotation.eu2om), (Rotation.om2ax,Rotation.ax2om), - (Rotation.om2ro,Rotation.ro2om)]) - #(Rotation.om2ho,Rotation.ho2om), - #(Rotation.om2cu,Rotation.cu2om)]) + (Rotation.om2ro,Rotation.ro2om), + (Rotation.om2ho,Rotation.ho2om), + (Rotation.om2cu,Rotation.cu2om)]) def test_matrix_internal(self,default,forward,backward): for rot in default: m = rot.as_matrix() From 3e002691793b36590c6bce536cffc2a6b8d01260 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 19 May 2020 23:24:12 +0200 Subject: [PATCH 062/136] again some more tests --- python/damask/_rotation.py | 8 ++++++-- python/tests/test_Rotation.py | 33 +++++++++++++++++++++++++++++++-- 2 files changed, 37 insertions(+), 4 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 0f0a081bc..fc124f5bb 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -112,10 +112,14 @@ class Rotation: return A*other + B*self.quaternion[1:] + C * np.cross(self.quaternion[1:],other) elif other.shape == (3,3,): - return np.dot(self.as_matrix(),np.dot(other,self.as_matrix().T)) + R = self.as_matrix() + return np.dot(R,np.dot(other,R.T)) elif other.shape == (3,3,3,3,): R = self.as_matrix() - return np.einsum('...im,...jn,...ko,...lp,...mnop',R,R,R,R,other) + RR = np.outer(R, R) + RRRR = np.outer(RR, RR).reshape(4 * (3,3)) + axes = ((0, 2, 4, 6), (0, 1, 2, 3)) + return np.tensordot(RRRR, other, axes) else: raise ValueError('Can only rotate vectors, 2nd order ternsors, and 4th order tensors') else: diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index f9565a5e2..35df97f7b 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -154,8 +154,37 @@ class TestRotation: if np.isclose(m[3],np.pi,atol=atol): ok = ok or np.allclose(m*np.array([-1.,-1.,-1.,1.]),o,atol=atol) print(m,o,rot.as_quaternion()) - assert ok and np.isclose(np.linalg.norm(o[:3]),1.0) and o[3]<=np.pi+1.e-7 + assert ok and np.isclose(np.linalg.norm(o[:3]),1.0) and o[3]<=np.pi+1.e-9 + @pytest.mark.parametrize('forward,backward',[(Rotation.ro2qu,Rotation.qu2ro), + #(Rotation.ro2om,Rotation.om2ro), + #(Rotation.ro2eu,Rotation.eu2ro), + (Rotation.ro2ax,Rotation.ax2ro), + (Rotation.ro2ho,Rotation.ho2ro), + (Rotation.ro2cu,Rotation.cu2ro)]) + def test_Rodrigues_internal(self,default,forward,backward): + cutoff = np.tan(np.pi*.5*(1.-1e-4)) + for rot in default: + m = rot.as_Rodrigues() + o = backward(forward(m)) + ok = np.allclose(np.clip(m,None,cutoff),np.clip(o,None,cutoff),atol=atol) + ok = ok or np.isclose(m[3],0.0,atol=atol) + print(m,o,rot.as_quaternion()) + assert ok and np.isclose(np.linalg.norm(o[:3]),1.0) + + @pytest.mark.parametrize('forward,backward',[(Rotation.ho2qu,Rotation.qu2ho), + (Rotation.ho2om,Rotation.om2ho), + #(Rotation.ho2eu,Rotation.eu2ho), + (Rotation.ho2ax,Rotation.ax2ho), + (Rotation.ho2ro,Rotation.ro2ho), + (Rotation.ho2cu,Rotation.cu2ho)]) + def test_homochoric_internal(self,default,forward,backward): + for rot in default: + m = rot.as_homochoric() + o = backward(forward(m)) + ok = np.allclose(m,o,atol=atol) + print(m,o,rot.as_quaternion()) + assert ok and np.linalg.norm(o) < (3.*np.pi/4.)**(1./3.) + 1.e-9 @pytest.mark.parametrize('degrees',[True,False]) def test_Eulers(self,default,degrees): @@ -193,7 +222,7 @@ class TestRotation: if np.isclose(m[3],np.pi,atol=atol): ok = ok or np.allclose(m*np.array([-1.,-1.,-1.,1.]),o,atol=atol) print(m,o,rot.as_quaternion()) - assert ok and np.isclose(np.linalg.norm(o[:3]),1.0) and o[3]<=np.pi+1.e-7 + assert ok and np.isclose(np.linalg.norm(o[:3]),1.0) and o[3]<=np.pi+1.e-9 @pytest.mark.parametrize('P',[1,-1]) @pytest.mark.parametrize('normalise',[True,False]) From 1fa4a07bb857fe3f6cd2da04ae88786caaa1ca81 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 19 May 2020 23:39:01 +0200 Subject: [PATCH 063/136] for backward compatibility --- python/damask/_rotation.py | 1 + 1 file changed, 1 insertion(+) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index fc124f5bb..31732015e 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -502,6 +502,7 @@ class Rotation: fromQuaternion = from_quaternion fromEulers = from_Eulers asAxisAngle = as_axis_angle + asRodrigues = as_Rodrigues #################################################################################################### From 1d8903bb0c26f8094ac859936c9089f2985891f6 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 20 May 2020 00:17:45 +0200 Subject: [PATCH 064/136] transition code --- python/damask/_rotation.py | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 31732015e..d2698fd52 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -316,8 +316,11 @@ class Rotation: @staticmethod def from_quaternion(quaternion, accept_homomorph = False, - P = -1): + P = -1, + acceptHomomorph = None): + if acceptHomomorph is not None: + accept_homomorph = acceptHomomorph qu = np.array(quaternion,dtype=float) if qu.shape[:-2:-1] != (4,): raise ValueError('Invalid shape.') From 9694767997933e55f8ae41e08b5282ac838a6677 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 20 May 2020 09:01:38 +0200 Subject: [PATCH 065/136] all seems to work now --- python/damask/_rotation.py | 8 ++++---- python/tests/rotation_conversion.py | 6 +++--- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index d2698fd52..baa008391 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -694,7 +694,7 @@ class Rotation: @staticmethod def om2ax(om): """Rotation matrix to axis angle pair.""" - return Rotation.qu2ax(Rotation.om2qu(om)) # HOTFIX + #return Rotation.qu2ax(Rotation.om2qu(om)) # HOTFIX diag_delta = -_P*np.block([om[...,1,2:3]-om[...,2,1:2], om[...,2,0:1]-om[...,0,2:3], om[...,0,1:2]-om[...,1,0:1] @@ -878,14 +878,14 @@ class Rotation: ax = np.where(np.isfinite(ro[...,3:4]), np.block([ro[...,0:3]*np.linalg.norm(ro[...,0:3],axis=-1,keepdims=True),2.*np.arctan(ro[...,3:4])]), np.block([ro[...,0:3],np.broadcast_to(np.pi,ro[...,3:4].shape)])) - ax[np.abs(ro[...,3]) < 1.e-6] = np.array([ 0.0, 0.0, 1.0, 0.0 ]) + ax[np.abs(ro[...,3]) < 1.e-8] = np.array([ 0.0, 0.0, 1.0, 0.0 ]) return ax @staticmethod def ro2ho(ro): """Rodrigues-Frank vector to homochoric vector.""" f = np.where(np.isfinite(ro[...,3:4]),2.0*np.arctan(ro[...,3:4]) -np.sin(2.0*np.arctan(ro[...,3:4])),np.pi) - ho = np.where(np.broadcast_to(np.sum(ro[...,0:3]**2.0,axis=-1,keepdims=True) < 1.e-6,ro[...,0:3].shape), + ho = np.where(np.broadcast_to(np.sum(ro[...,0:3]**2.0,axis=-1,keepdims=True) < 1.e-8,ro[...,0:3].shape), np.zeros(3), ro[...,0:3]* (0.75*f)**(1.0/3.0)) return ho @@ -929,7 +929,7 @@ class Rotation: hm *= hmag_squared s += tfit[i] * hm with np.errstate(invalid='ignore'): - ax = np.where(np.broadcast_to(np.abs(hmag_squared)<1.e-6,ho.shape[:-1]+(4,)), + ax = np.where(np.broadcast_to(np.abs(hmag_squared)<1.e-8,ho.shape[:-1]+(4,)), [ 0.0, 0.0, 1.0, 0.0 ], np.block([ho/np.sqrt(hmag_squared),2.0*np.arccos(np.clip(s,-1.0,1.0))])) return ax diff --git a/python/tests/rotation_conversion.py b/python/tests/rotation_conversion.py index 3aca1a212..58ac9329f 100644 --- a/python/tests/rotation_conversion.py +++ b/python/tests/rotation_conversion.py @@ -147,7 +147,7 @@ def om2eu(om): def om2ax(om): """Rotation matrix to axis angle pair.""" - return qu2ax(om2qu(om)) # HOTFIX + #return qu2ax(om2qu(om)) # HOTFIX ax=np.empty(4) # first get the rotation angle @@ -262,7 +262,7 @@ def ax2ho(ax): #---------- Rodrigues-Frank vector ---------- def ro2ax(ro): """Rodrigues-Frank vector to axis angle pair.""" - if np.abs(ro[3]) < 1.e-6: + if np.abs(ro[3]) < 1.e-8: ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) elif not np.isfinite(ro[3]): ax = np.array([ ro[0], ro[1], ro[2], np.pi ]) @@ -274,7 +274,7 @@ def ro2ax(ro): def ro2ho(ro): """Rodrigues-Frank vector to homochoric vector.""" - if np.sum(ro[0:3]**2.0) < 1.e-6: + if np.sum(ro[0:3]**2.0) < 1.e-8: ho = np.zeros(3) else: f = 2.0*np.arctan(ro[3]) -np.sin(2.0*np.arctan(ro[3])) if np.isfinite(ro[3]) else np.pi From 9240dd59b22bb4bb3f7736d13ae918183b1243cd Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 20 May 2020 11:11:07 +0200 Subject: [PATCH 066/136] mark as internal all functionality (+ sanity checks) can be done with the class functionality --- python/damask/_rotation.py | 156 +++++++++++++++++----------------- python/tests/test_Rotation.py | 114 ++++++++++++------------- 2 files changed, 135 insertions(+), 135 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index baa008391..cf6eaed34 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -249,7 +249,7 @@ class Rotation: return angles in degrees. """ - eu = Rotation.qu2eu(self.quaternion) + eu = Rotation._qu2eu(self.quaternion) if degrees: eu = np.degrees(eu) return eu @@ -267,13 +267,13 @@ class Rotation: return tuple of axis and angle. """ - ax = Rotation.qu2ax(self.quaternion) + ax = Rotation._qu2ax(self.quaternion) if degrees: ax[...,3] = np.degrees(ax[...,3]) return (ax[...,:3],ax[...,3]) if pair else ax def as_matrix(self): """Rotation matrix.""" - return Rotation.qu2om(self.quaternion) + return Rotation._qu2om(self.quaternion) def as_Rodrigues(self, vector = False): @@ -286,16 +286,16 @@ class Rotation: return as actual Rodrigues--Frank vector, i.e. rotation axis scaled by tan(ω/2). """ - ro = Rotation.qu2ro(self.quaternion) + ro = Rotation._qu2ro(self.quaternion) return ro[...,:3]*ro[...,3] if vector else ro def as_homochoric(self): """Homochoric vector: (h_1, h_2, h_3).""" - return Rotation.qu2ho(self.quaternion) + return Rotation._qu2ho(self.quaternion) def as_cubochoric(self): """Cubochoric vector: (c_1, c_2, c_3).""" - return Rotation.qu2cu(self.quaternion) + return Rotation._qu2cu(self.quaternion) def M(self): # ToDo not sure about the name: as_M or M? we do not have a from_M """ @@ -348,7 +348,7 @@ class Rotation: if np.any(eu < 0.0) or np.any(eu > 2.0*np.pi) or np.any(eu[...,1] > np.pi): # ToDo: No separate check for PHI raise ValueError('Euler angles outside of [0..2π],[0..π],[0..2π].') - return Rotation(Rotation.eu2qu(eu)) + return Rotation(Rotation._eu2qu(eu)) @staticmethod def from_axis_angle(axis_angle, @@ -368,7 +368,7 @@ class Rotation: if not np.all(np.isclose(np.linalg.norm(ax[...,0:3],axis=-1), 1.0)): raise ValueError('Axis angle rotation axis is not of unit length.') - return Rotation(Rotation.ax2qu(ax)) + return Rotation(Rotation._ax2qu(ax)) @staticmethod def from_basis(basis, @@ -392,7 +392,7 @@ class Rotation: or not np.all(np.isclose(np.einsum('...i,...i',om[...,2],om[...,0]), 0.0)): raise ValueError('Orientation matrix is not orthogonal.') - return Rotation(Rotation.om2qu(om)) + return Rotation(Rotation._om2qu(om)) @staticmethod def from_matrix(om): @@ -415,7 +415,7 @@ class Rotation: if not np.all(np.isclose(np.linalg.norm(ro[...,0:3],axis=-1), 1.0)): raise ValueError('Rodrigues vector rotation axis is not of unit length.') - return Rotation(Rotation.ro2qu(ro)) + return Rotation(Rotation._ro2qu(ro)) @staticmethod def from_homochoric(homochoric, @@ -430,7 +430,7 @@ class Rotation: if np.any(np.linalg.norm(ho,axis=-1) > (3.*np.pi/4.)**(1./3.)+1e-9): raise ValueError('Homochoric coordinate outside of the sphere.') - return Rotation(Rotation.ho2qu(ho)) + return Rotation(Rotation._ho2qu(ho)) @staticmethod def from_cubochoric(cubochoric, @@ -443,10 +443,10 @@ class Rotation: if np.abs(np.max(cu))>np.pi**(2./3.) * 0.5+1e-9: raise ValueError('Cubochoric coordinate outside of the cube: {} {} {}.'.format(*cu)) - ho = Rotation.cu2ho(cu) + ho = Rotation._cu2ho(cu) if P > 0: ho *= -1 # convert from P=1 to P=-1 - return Rotation(Rotation.ho2qu(ho)) + return Rotation(Rotation._ho2qu(ho)) @staticmethod @@ -540,7 +540,7 @@ class Rotation: #################################################################################################### #---------- Quaternion ---------- @staticmethod - def qu2om(qu): + def _qu2om(qu): qq = qu[...,0:1]**2-(qu[...,1:2]**2 + qu[...,2:3]**2 + qu[...,3:4]**2) om = np.block([qq + 2.0*qu[...,1:2]**2, 2.0*(qu[...,2:3]*qu[...,1:2]-_P*qu[...,0:1]*qu[...,3:4]), @@ -555,7 +555,7 @@ class Rotation: return om @staticmethod - def qu2eu(qu): + def _qu2eu(qu): """Quaternion to Bunge-Euler angles.""" q02 = qu[...,0:1]*qu[...,2:3] q13 = qu[...,1:2]*qu[...,3:4] @@ -583,7 +583,7 @@ class Rotation: return eu @staticmethod - def qu2ax(qu): + def _qu2ax(qu): """ Quaternion to axis angle pair. @@ -599,7 +599,7 @@ class Rotation: return ax @staticmethod - def qu2ro(qu): + def _qu2ro(qu): """Quaternion to Rodrigues-Frank vector.""" with np.errstate(invalid='ignore',divide='ignore'): s = np.linalg.norm(qu[...,1:4],axis=-1,keepdims=True) @@ -613,7 +613,7 @@ class Rotation: return ro @staticmethod - def qu2ho(qu): + def _qu2ho(qu): """Quaternion to homochoric vector.""" with np.errstate(invalid='ignore'): omega = 2.0 * np.arccos(np.clip(qu[...,0:1],-1.0,1.0)) @@ -624,14 +624,14 @@ class Rotation: return ho @staticmethod - def qu2cu(qu): + def _qu2cu(qu): """Quaternion to cubochoric vector.""" - return Rotation.ho2cu(Rotation.qu2ho(qu)) + return Rotation._ho2cu(Rotation._qu2ho(qu)) #---------- Rotation matrix ---------- @staticmethod - def om2qu(om): + def _om2qu(om): """ Rotation matrix to quaternion. @@ -673,7 +673,7 @@ class Rotation: return qu @staticmethod - def om2eu(om): + def _om2eu(om): """Rotation matrix to Bunge-Euler angles.""" with np.errstate(invalid='ignore',divide='ignore'): zeta = 1.0/np.sqrt(1.0-om[...,2,2:3]**2) @@ -692,9 +692,9 @@ class Rotation: return eu @staticmethod - def om2ax(om): + def _om2ax(om): """Rotation matrix to axis angle pair.""" - #return Rotation.qu2ax(Rotation.om2qu(om)) # HOTFIX + #return Rotation._qu2ax(Rotation._om2qu(om)) # HOTFIX diag_delta = -_P*np.block([om[...,1,2:3]-om[...,2,1:2], om[...,2,0:1]-om[...,0,2:3], om[...,0,1:2]-om[...,1,0:1] @@ -714,24 +714,24 @@ class Rotation: return ax @staticmethod - def om2ro(om): + def _om2ro(om): """Rotation matrix to Rodrigues-Frank vector.""" - return Rotation.eu2ro(Rotation.om2eu(om)) + return Rotation._eu2ro(Rotation._om2eu(om)) @staticmethod - def om2ho(om): + def _om2ho(om): """Rotation matrix to homochoric vector.""" - return Rotation.ax2ho(Rotation.om2ax(om)) + return Rotation._ax2ho(Rotation._om2ax(om)) @staticmethod - def om2cu(om): + def _om2cu(om): """Rotation matrix to cubochoric vector.""" - return Rotation.ho2cu(Rotation.om2ho(om)) + return Rotation._ho2cu(Rotation._om2ho(om)) #---------- Bunge-Euler angles ---------- @staticmethod - def eu2qu(eu): + def _eu2qu(eu): """Bunge-Euler angles to quaternion.""" ee = 0.5*eu cPhi = np.cos(ee[...,1:2]) @@ -744,7 +744,7 @@ class Rotation: return qu @staticmethod - def eu2om(eu): + def _eu2om(eu): """Bunge-Euler angles to rotation matrix.""" c = np.cos(eu) s = np.sin(eu) @@ -762,7 +762,7 @@ class Rotation: return om @staticmethod - def eu2ax(eu): + def _eu2ax(eu): """Bunge-Euler angles to axis angle pair.""" t = np.tan(eu[...,1:2]*0.5) sigma = 0.5*(eu[...,0:1]+eu[...,2:3]) @@ -781,28 +781,28 @@ class Rotation: return ax @staticmethod - def eu2ro(eu): + def _eu2ro(eu): """Bunge-Euler angles to Rodrigues-Frank vector.""" - ax = Rotation.eu2ax(eu) + ax = Rotation._eu2ax(eu) ro = np.block([ax[...,:3],np.tan(ax[...,3:4]*.5)]) ro[ax[...,3]>=np.pi,3] = np.inf ro[np.abs(ax[...,3])<1.e-16] = [ 0.0, 0.0, _P, 0.0 ] return ro @staticmethod - def eu2ho(eu): + def _eu2ho(eu): """Bunge-Euler angles to homochoric vector.""" - return Rotation.ax2ho(Rotation.eu2ax(eu)) + return Rotation._ax2ho(Rotation._eu2ax(eu)) @staticmethod - def eu2cu(eu): + def _eu2cu(eu): """Bunge-Euler angles to cubochoric vector.""" - return Rotation.ho2cu(Rotation.eu2ho(eu)) + return Rotation._ho2cu(Rotation._eu2ho(eu)) #---------- Axis angle pair ---------- @staticmethod - def ax2qu(ax): + def _ax2qu(ax): """Axis angle pair to quaternion.""" c = np.cos(ax[...,3:4]*.5) s = np.sin(ax[...,3:4]*.5) @@ -810,7 +810,7 @@ class Rotation: return qu @staticmethod - def ax2om(ax): + def _ax2om(ax): """Axis angle pair to rotation matrix.""" c = np.cos(ax[...,3:4]) s = np.sin(ax[...,3:4]) @@ -827,12 +827,12 @@ class Rotation: return om if _P < 0.0 else np.swapaxes(om,-1,-2) @staticmethod - def ax2eu(ax): + def _ax2eu(ax): """Rotation matrix to Bunge Euler angles.""" - return Rotation.om2eu(Rotation.ax2om(ax)) + return Rotation._om2eu(Rotation._ax2om(ax)) @staticmethod - def ax2ro(ax): + def _ax2ro(ax): """Axis angle pair to Rodrigues-Frank vector.""" ro = np.block([ax[...,:3], np.where(np.isclose(ax[...,3:4],np.pi,atol=1.e-15,rtol=.0), @@ -843,36 +843,36 @@ class Rotation: return ro @staticmethod - def ax2ho(ax): + def _ax2ho(ax): """Axis angle pair to homochoric vector.""" f = (0.75 * ( ax[...,3:4] - np.sin(ax[...,3:4]) ))**(1.0/3.0) ho = ax[...,:3] * f return ho @staticmethod - def ax2cu(ax): + def _ax2cu(ax): """Axis angle pair to cubochoric vector.""" - return Rotation.ho2cu(Rotation.ax2ho(ax)) + return Rotation._ho2cu(Rotation._ax2ho(ax)) #---------- Rodrigues-Frank vector ---------- @staticmethod - def ro2qu(ro): + def _ro2qu(ro): """Rodrigues-Frank vector to quaternion.""" - return Rotation.ax2qu(Rotation.ro2ax(ro)) + return Rotation._ax2qu(Rotation._ro2ax(ro)) @staticmethod - def ro2om(ro): + def _ro2om(ro): """Rodgrigues-Frank vector to rotation matrix.""" - return Rotation.ax2om(Rotation.ro2ax(ro)) + return Rotation._ax2om(Rotation._ro2ax(ro)) @staticmethod - def ro2eu(ro): + def _ro2eu(ro): """Rodrigues-Frank vector to Bunge-Euler angles.""" - return Rotation.om2eu(Rotation.ro2om(ro)) + return Rotation._om2eu(Rotation._ro2om(ro)) @staticmethod - def ro2ax(ro): + def _ro2ax(ro): """Rodrigues-Frank vector to axis angle pair.""" with np.errstate(invalid='ignore',divide='ignore'): ax = np.where(np.isfinite(ro[...,3:4]), @@ -882,7 +882,7 @@ class Rotation: return ax @staticmethod - def ro2ho(ro): + def _ro2ho(ro): """Rodrigues-Frank vector to homochoric vector.""" f = np.where(np.isfinite(ro[...,3:4]),2.0*np.arctan(ro[...,3:4]) -np.sin(2.0*np.arctan(ro[...,3:4])),np.pi) ho = np.where(np.broadcast_to(np.sum(ro[...,0:3]**2.0,axis=-1,keepdims=True) < 1.e-8,ro[...,0:3].shape), @@ -890,29 +890,29 @@ class Rotation: return ho @staticmethod - def ro2cu(ro): + def _ro2cu(ro): """Rodrigues-Frank vector to cubochoric vector.""" - return Rotation.ho2cu(Rotation.ro2ho(ro)) + return Rotation._ho2cu(Rotation._ro2ho(ro)) #---------- Homochoric vector---------- @staticmethod - def ho2qu(ho): + def _ho2qu(ho): """Homochoric vector to quaternion.""" - return Rotation.ax2qu(Rotation.ho2ax(ho)) + return Rotation._ax2qu(Rotation._ho2ax(ho)) @staticmethod - def ho2om(ho): + def _ho2om(ho): """Homochoric vector to rotation matrix.""" - return Rotation.ax2om(Rotation.ho2ax(ho)) + return Rotation._ax2om(Rotation._ho2ax(ho)) @staticmethod - def ho2eu(ho): + def _ho2eu(ho): """Homochoric vector to Bunge-Euler angles.""" - return Rotation.ax2eu(Rotation.ho2ax(ho)) + return Rotation._ax2eu(Rotation._ho2ax(ho)) @staticmethod - def ho2ax(ho): + def _ho2ax(ho): """Homochoric vector to axis angle pair.""" tfit = np.array([+1.0000000000018852, -0.5000000002194847, -0.024999992127593126, -0.003928701544781374, @@ -935,12 +935,12 @@ class Rotation: return ax @staticmethod - def ho2ro(ho): + def _ho2ro(ho): """Axis angle pair to Rodrigues-Frank vector.""" - return Rotation.ax2ro(Rotation.ho2ax(ho)) + return Rotation._ax2ro(Rotation._ho2ax(ho)) @staticmethod - def ho2cu(ho): + def _ho2cu(ho): """ Homochoric vector to cubochoric vector. @@ -980,32 +980,32 @@ class Rotation: #---------- Cubochoric ---------- @staticmethod - def cu2qu(cu): + def _cu2qu(cu): """Cubochoric vector to quaternion.""" - return Rotation.ho2qu(Rotation.cu2ho(cu)) + return Rotation._ho2qu(Rotation._cu2ho(cu)) @staticmethod - def cu2om(cu): + def _cu2om(cu): """Cubochoric vector to rotation matrix.""" - return Rotation.ho2om(Rotation.cu2ho(cu)) + return Rotation._ho2om(Rotation._cu2ho(cu)) @staticmethod - def cu2eu(cu): + def _cu2eu(cu): """Cubochoric vector to Bunge-Euler angles.""" - return Rotation.ho2eu(Rotation.cu2ho(cu)) + return Rotation._ho2eu(Rotation._cu2ho(cu)) @staticmethod - def cu2ax(cu): + def _cu2ax(cu): """Cubochoric vector to axis angle pair.""" - return Rotation.ho2ax(Rotation.cu2ho(cu)) + return Rotation._ho2ax(Rotation._cu2ho(cu)) @staticmethod - def cu2ro(cu): + def _cu2ro(cu): """Cubochoric vector to Rodrigues-Frank vector.""" - return Rotation.ho2ro(Rotation.cu2ho(cu)) + return Rotation._ho2ro(Rotation._cu2ho(cu)) @staticmethod - def cu2ho(cu): + def _cu2ho(cu): """ Cubochoric vector to homochoric vector. diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index 35df97f7b..4e48fbb7c 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -91,12 +91,12 @@ def reference_dir(reference_dir_base): class TestRotation: - @pytest.mark.parametrize('forward,backward',[(Rotation.qu2om,Rotation.om2qu), - (Rotation.qu2eu,Rotation.eu2qu), - (Rotation.qu2ax,Rotation.ax2qu), - (Rotation.qu2ro,Rotation.ro2qu), - (Rotation.qu2ho,Rotation.ho2qu), - (Rotation.qu2cu,Rotation.cu2qu)]) + @pytest.mark.parametrize('forward,backward',[(Rotation._qu2om,Rotation._om2qu), + (Rotation._qu2eu,Rotation._eu2qu), + (Rotation._qu2ax,Rotation._ax2qu), + (Rotation._qu2ro,Rotation._ro2qu), + (Rotation._qu2ho,Rotation._ho2qu), + (Rotation._qu2cu,Rotation._cu2qu)]) def test_quaternion_internal(self,default,forward,backward): for rot in default: m = rot.as_quaternion() @@ -107,12 +107,12 @@ class TestRotation: print(m,o,rot.as_quaternion()) assert ok and np.isclose(np.linalg.norm(o),1.0) - @pytest.mark.parametrize('forward,backward',[(Rotation.om2qu,Rotation.qu2om), - (Rotation.om2eu,Rotation.eu2om), - (Rotation.om2ax,Rotation.ax2om), - (Rotation.om2ro,Rotation.ro2om), - (Rotation.om2ho,Rotation.ho2om), - (Rotation.om2cu,Rotation.cu2om)]) + @pytest.mark.parametrize('forward,backward',[(Rotation._om2qu,Rotation._qu2om), + (Rotation._om2eu,Rotation._eu2om), + (Rotation._om2ax,Rotation._ax2om), + (Rotation._om2ro,Rotation._ro2om), + (Rotation._om2ho,Rotation._ho2om), + (Rotation._om2cu,Rotation._cu2om)]) def test_matrix_internal(self,default,forward,backward): for rot in default: m = rot.as_matrix() @@ -121,12 +121,12 @@ class TestRotation: print(m,o,rot.as_quaternion()) assert ok and np.isclose(np.linalg.det(o),1.0) - @pytest.mark.parametrize('forward,backward',[(Rotation.eu2qu,Rotation.qu2eu), - (Rotation.eu2om,Rotation.om2eu), - (Rotation.eu2ax,Rotation.ax2eu), - (Rotation.eu2ro,Rotation.ro2eu), - (Rotation.eu2ho,Rotation.ho2eu), - (Rotation.eu2cu,Rotation.cu2eu)]) + @pytest.mark.parametrize('forward,backward',[(Rotation._eu2qu,Rotation._qu2eu), + (Rotation._eu2om,Rotation._om2eu), + (Rotation._eu2ax,Rotation._ax2eu), + (Rotation._eu2ro,Rotation._ro2eu), + (Rotation._eu2ho,Rotation._ho2eu), + (Rotation._eu2cu,Rotation._cu2eu)]) def test_Eulers_internal(self,default,forward,backward): for rot in default: m = rot.as_Eulers() @@ -140,12 +140,12 @@ class TestRotation: print(m,o,rot.as_quaternion()) assert ok and (np.zeros(3)-1.e-9 <= o).all() and (o <= np.array([np.pi*2.,np.pi,np.pi*2.])+1.e-9).all() - @pytest.mark.parametrize('forward,backward',[(Rotation.ax2qu,Rotation.qu2ax), - (Rotation.ax2om,Rotation.om2ax), - (Rotation.ax2eu,Rotation.eu2ax), - (Rotation.ax2ro,Rotation.ro2ax), - (Rotation.ax2ho,Rotation.ho2ax), - (Rotation.ax2cu,Rotation.cu2ax)]) + @pytest.mark.parametrize('forward,backward',[(Rotation._ax2qu,Rotation._qu2ax), + (Rotation._ax2om,Rotation._om2ax), + (Rotation._ax2eu,Rotation._eu2ax), + (Rotation._ax2ro,Rotation._ro2ax), + (Rotation._ax2ho,Rotation._ho2ax), + (Rotation._ax2cu,Rotation._cu2ax)]) def test_axis_angle_internal(self,default,forward,backward): for rot in default: m = rot.as_axis_angle() @@ -156,12 +156,12 @@ class TestRotation: print(m,o,rot.as_quaternion()) assert ok and np.isclose(np.linalg.norm(o[:3]),1.0) and o[3]<=np.pi+1.e-9 - @pytest.mark.parametrize('forward,backward',[(Rotation.ro2qu,Rotation.qu2ro), - #(Rotation.ro2om,Rotation.om2ro), - #(Rotation.ro2eu,Rotation.eu2ro), - (Rotation.ro2ax,Rotation.ax2ro), - (Rotation.ro2ho,Rotation.ho2ro), - (Rotation.ro2cu,Rotation.cu2ro)]) + @pytest.mark.parametrize('forward,backward',[(Rotation._ro2qu,Rotation._qu2ro), + #(Rotation._ro2om,Rotation._om2ro), + #(Rotation._ro2eu,Rotation._eu2ro), + (Rotation._ro2ax,Rotation._ax2ro), + (Rotation._ro2ho,Rotation._ho2ro), + (Rotation._ro2cu,Rotation._cu2ro)]) def test_Rodrigues_internal(self,default,forward,backward): cutoff = np.tan(np.pi*.5*(1.-1e-4)) for rot in default: @@ -172,12 +172,12 @@ class TestRotation: print(m,o,rot.as_quaternion()) assert ok and np.isclose(np.linalg.norm(o[:3]),1.0) - @pytest.mark.parametrize('forward,backward',[(Rotation.ho2qu,Rotation.qu2ho), - (Rotation.ho2om,Rotation.om2ho), - #(Rotation.ho2eu,Rotation.eu2ho), - (Rotation.ho2ax,Rotation.ax2ho), - (Rotation.ho2ro,Rotation.ro2ho), - (Rotation.ho2cu,Rotation.cu2ho)]) + @pytest.mark.parametrize('forward,backward',[(Rotation._ho2qu,Rotation._qu2ho), + (Rotation._ho2om,Rotation._om2ho), + #(Rotation._ho2eu,Rotation._eu2ho), + (Rotation._ho2ax,Rotation._ax2ho), + (Rotation._ho2ro,Rotation._ro2ho), + (Rotation._ho2cu,Rotation._cu2ho)]) def test_homochoric_internal(self,default,forward,backward): for rot in default: m = rot.as_homochoric() @@ -289,11 +289,11 @@ class TestRotation: with pytest.raises(ValueError): function(invalid) - @pytest.mark.parametrize('vectorized, single',[(Rotation.qu2om,rotation_conversion.qu2om), - (Rotation.qu2eu,rotation_conversion.qu2eu), - (Rotation.qu2ax,rotation_conversion.qu2ax), - (Rotation.qu2ro,rotation_conversion.qu2ro), - (Rotation.qu2ho,rotation_conversion.qu2ho)]) + @pytest.mark.parametrize('vectorized, single',[(Rotation._qu2om,rotation_conversion.qu2om), + (Rotation._qu2eu,rotation_conversion.qu2eu), + (Rotation._qu2ax,rotation_conversion.qu2ax), + (Rotation._qu2ro,rotation_conversion.qu2ro), + (Rotation._qu2ho,rotation_conversion.qu2ho)]) def test_quaternion_vectorization(self,default,vectorized,single): qu = np.array([rot.as_quaternion() for rot in default]) vectorized(qu.reshape(qu.shape[0]//2,-1,4)) @@ -303,9 +303,9 @@ class TestRotation: assert np.allclose(single(q),c) and np.allclose(single(q),vectorized(q)) - @pytest.mark.parametrize('vectorized, single',[(Rotation.om2qu,rotation_conversion.om2qu), - (Rotation.om2eu,rotation_conversion.om2eu), - (Rotation.om2ax,rotation_conversion.om2ax)]) + @pytest.mark.parametrize('vectorized, single',[(Rotation._om2qu,rotation_conversion.om2qu), + (Rotation._om2eu,rotation_conversion.om2eu), + (Rotation._om2ax,rotation_conversion.om2ax)]) def test_matrix_vectorization(self,default,vectorized,single): om = np.array([rot.as_matrix() for rot in default]) vectorized(om.reshape(om.shape[0]//2,-1,3,3)) @@ -314,10 +314,10 @@ class TestRotation: print(o,c) assert np.allclose(single(o),c) and np.allclose(single(o),vectorized(o)) - @pytest.mark.parametrize('vectorized, single',[(Rotation.eu2qu,rotation_conversion.eu2qu), - (Rotation.eu2om,rotation_conversion.eu2om), - (Rotation.eu2ax,rotation_conversion.eu2ax), - (Rotation.eu2ro,rotation_conversion.eu2ro)]) + @pytest.mark.parametrize('vectorized, single',[(Rotation._eu2qu,rotation_conversion.eu2qu), + (Rotation._eu2om,rotation_conversion.eu2om), + (Rotation._eu2ax,rotation_conversion.eu2ax), + (Rotation._eu2ro,rotation_conversion.eu2ro)]) def test_Euler_vectorization(self,default,vectorized,single): eu = np.array([rot.as_Eulers() for rot in default]) vectorized(eu.reshape(eu.shape[0]//2,-1,3)) @@ -326,10 +326,10 @@ class TestRotation: print(e,c) assert np.allclose(single(e),c) and np.allclose(single(e),vectorized(e)) - @pytest.mark.parametrize('vectorized, single',[(Rotation.ax2qu,rotation_conversion.ax2qu), - (Rotation.ax2om,rotation_conversion.ax2om), - (Rotation.ax2ro,rotation_conversion.ax2ro), - (Rotation.ax2ho,rotation_conversion.ax2ho)]) + @pytest.mark.parametrize('vectorized, single',[(Rotation._ax2qu,rotation_conversion.ax2qu), + (Rotation._ax2om,rotation_conversion.ax2om), + (Rotation._ax2ro,rotation_conversion.ax2ro), + (Rotation._ax2ho,rotation_conversion.ax2ho)]) def test_axisAngle_vectorization(self,default,vectorized,single): ax = np.array([rot.as_axis_angle() for rot in default]) vectorized(ax.reshape(ax.shape[0]//2,-1,4)) @@ -339,8 +339,8 @@ class TestRotation: assert np.allclose(single(a),c) and np.allclose(single(a),vectorized(a)) - @pytest.mark.parametrize('vectorized, single',[(Rotation.ro2ax,rotation_conversion.ro2ax), - (Rotation.ro2ho,rotation_conversion.ro2ho)]) + @pytest.mark.parametrize('vectorized, single',[(Rotation._ro2ax,rotation_conversion.ro2ax), + (Rotation._ro2ho,rotation_conversion.ro2ho)]) def test_Rodrigues_vectorization(self,default,vectorized,single): ro = np.array([rot.as_Rodrigues() for rot in default]) vectorized(ro.reshape(ro.shape[0]//2,-1,4)) @@ -349,8 +349,8 @@ class TestRotation: print(r,c) assert np.allclose(single(r),c) and np.allclose(single(r),vectorized(r)) - @pytest.mark.parametrize('vectorized, single',[(Rotation.ho2ax,rotation_conversion.ho2ax), - (Rotation.ho2cu,rotation_conversion.ho2cu)]) + @pytest.mark.parametrize('vectorized, single',[(Rotation._ho2ax,rotation_conversion.ho2ax), + (Rotation._ho2cu,rotation_conversion.ho2cu)]) def test_homochoric_vectorization(self,default,vectorized,single): ho = np.array([rot.as_homochoric() for rot in default]) vectorized(ho.reshape(ho.shape[0]//2,-1,3)) @@ -359,7 +359,7 @@ class TestRotation: print(h,c) assert np.allclose(single(h),c) and np.allclose(single(h),vectorized(h)) - @pytest.mark.parametrize('vectorized, single',[(Rotation.cu2ho,rotation_conversion.cu2ho)]) + @pytest.mark.parametrize('vectorized, single',[(Rotation._cu2ho,rotation_conversion.cu2ho)]) def test_cubochoric_vectorization(self,default,vectorized,single): cu = np.array([rot.as_cubochoric() for rot in default]) vectorized(cu.reshape(cu.shape[0]//2,-1,3)) From b59d773689170a14571321322ff364fbfd51baec Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 20 May 2020 15:26:49 +0200 Subject: [PATCH 067/136] store all test data together --- python/tests/rotation_conversion.py | 419 -------------------- python/tests/test_Rotation.py | 590 ++++++++++++++++++++++++---- 2 files changed, 506 insertions(+), 503 deletions(-) delete mode 100644 python/tests/rotation_conversion.py diff --git a/python/tests/rotation_conversion.py b/python/tests/rotation_conversion.py deleted file mode 100644 index 58ac9329f..000000000 --- a/python/tests/rotation_conversion.py +++ /dev/null @@ -1,419 +0,0 @@ -#################################################################################################### -# Code below available according to the following conditions on https://github.com/MarDiehl/3Drotations -#################################################################################################### -# Copyright (c) 2017-2019, Martin Diehl/Max-Planck-Institut für Eisenforschung GmbH -# Copyright (c) 2013-2014, Marc De Graef/Carnegie Mellon University -# All rights reserved. -# -# Redistribution and use in source and binary forms, with or without modification, are -# permitted provided that the following conditions are met: -# -# - Redistributions of source code must retain the above copyright notice, this list -# of conditions and the following disclaimer. -# - Redistributions in binary form must reproduce the above copyright notice, this -# list of conditions and the following disclaimer in the documentation and/or -# other materials provided with the distribution. -# - Neither the names of Marc De Graef, Carnegie Mellon University nor the names -# of its contributors may be used to endorse or promote products derived from -# this software without specific prior written permission. -# -# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE -# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL -# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR -# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, -# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE -# USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -#################################################################################################### - -import numpy as np - -from damask import _rotation - -_P = _rotation._P - -# parameters for conversion from/to cubochoric -_sc = _rotation._sc -_beta = _rotation._beta -_R1 = _rotation._R1 - -def iszero(a): - return np.isclose(a,0.0,atol=1.0e-12,rtol=0.0) - -#---------- Quaternion ---------- -def qu2om(qu): - """Quaternion to rotation matrix.""" - qq = qu[0]**2-(qu[1]**2 + qu[2]**2 + qu[3]**2) - om = np.diag(qq + 2.0*np.array([qu[1],qu[2],qu[3]])**2) - - om[0,1] = 2.0*(qu[2]*qu[1]+qu[0]*qu[3]) - om[1,0] = 2.0*(qu[1]*qu[2]-qu[0]*qu[3]) - om[1,2] = 2.0*(qu[3]*qu[2]+qu[0]*qu[1]) - om[2,1] = 2.0*(qu[2]*qu[3]-qu[0]*qu[1]) - om[2,0] = 2.0*(qu[1]*qu[3]+qu[0]*qu[2]) - om[0,2] = 2.0*(qu[3]*qu[1]-qu[0]*qu[2]) - return om if _P < 0.0 else np.swapaxes(om,-1,-2) - -def qu2eu(qu): - """Quaternion to Bunge-Euler angles.""" - q03 = qu[0]**2+qu[3]**2 - q12 = qu[1]**2+qu[2]**2 - chi = np.sqrt(q03*q12) - if np.abs(q12) < 1.e-8: - eu = np.array([np.arctan2(-_P*2.0*qu[0]*qu[3],qu[0]**2-qu[3]**2), 0.0, 0.0]) - elif np.abs(q03) < 1.e-8: - eu = np.array([np.arctan2( 2.0*qu[1]*qu[2],qu[1]**2-qu[2]**2), np.pi, 0.0]) - else: - eu = np.array([np.arctan2((-_P*qu[0]*qu[2]+qu[1]*qu[3])*chi, (-_P*qu[0]*qu[1]-qu[2]*qu[3])*chi ), - np.arctan2( 2.0*chi, q03-q12 ), - np.arctan2(( _P*qu[0]*qu[2]+qu[1]*qu[3])*chi, (-_P*qu[0]*qu[1]+qu[2]*qu[3])*chi )]) - # reduce Euler angles to definition range - eu[np.abs(eu)<1.e-6] = 0.0 - eu = np.where(eu<0, (eu+2.0*np.pi)%np.array([2.0*np.pi,np.pi,2.0*np.pi]),eu) - return eu - -def qu2ax(qu): - """ - Quaternion to axis angle pair. - - Modified version of the original formulation, should be numerically more stable - """ - if np.isclose(qu[0],1.,rtol=0.0): # set axis to [001] if the angle is 0/360 - ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) - elif qu[0] > 1.e-8: - s = np.sign(qu[0])/np.sqrt(qu[1]**2+qu[2]**2+qu[3]**2) - omega = 2.0 * np.arccos(np.clip(qu[0],-1.0,1.0)) - ax = ax = np.array([ qu[1]*s, qu[2]*s, qu[3]*s, omega ]) - else: - ax = ax = np.array([ qu[1], qu[2], qu[3], np.pi]) - return ax - -def qu2ro(qu): - """Quaternion to Rodrigues-Frank vector.""" - if iszero(qu[0]): - ro = np.array([qu[1], qu[2], qu[3], np.inf]) - else: - s = np.linalg.norm(qu[1:4]) - ro = np.array([0.0,0.0,_P,0.0] if iszero(s) else \ - [ qu[1]/s, qu[2]/s, qu[3]/s, np.tan(np.arccos(np.clip(qu[0],-1.0,1.0)))]) - return ro - -def qu2ho(qu): - """Quaternion to homochoric vector.""" - omega = 2.0 * np.arccos(np.clip(qu[0],-1.0,1.0)) - if np.abs(omega) < 1.0e-12: - ho = np.zeros(3) - else: - ho = np.array([qu[1], qu[2], qu[3]]) - f = 0.75 * ( omega - np.sin(omega) ) - ho = ho/np.linalg.norm(ho) * f**(1./3.) - return ho - - -#---------- Rotation matrix ---------- -def om2qu(a): - trace = a[0,0] + a[1,1] + a[2,2] - if trace > 0: - s = 0.5 / np.sqrt(trace+ 1.0) - qu = np.array([0.25 / s,( a[2,1] - a[1,2] ) * s,( a[0,2] - a[2,0] ) * s,( a[1,0] - a[0,1] ) * s]) - else: - if ( a[0,0] > a[1,1] and a[0,0] > a[2,2] ): - s = 2.0 * np.sqrt( 1.0 + a[0,0] - a[1,1] - a[2,2]) - qu = np.array([ (a[2,1] - a[1,2]) / s,0.25 * s,(a[0,1] + a[1,0]) / s,(a[0,2] + a[2,0]) / s]) - elif (a[1,1] > a[2,2]): - s = 2.0 * np.sqrt( 1.0 + a[1,1] - a[0,0] - a[2,2]) - qu = np.array([ (a[0,2] - a[2,0]) / s,(a[0,1] + a[1,0]) / s,0.25 * s,(a[1,2] + a[2,1]) / s]) - else: - s = 2.0 * np.sqrt( 1.0 + a[2,2] - a[0,0] - a[1,1] ) - qu = np.array([ (a[1,0] - a[0,1]) / s,(a[0,2] + a[2,0]) / s,(a[1,2] + a[2,1]) / s,0.25 * s]) - if qu[0]<0: qu*=-1 - return qu*np.array([1.,_P,_P,_P]) - -def om2eu(om): - """Rotation matrix to Bunge-Euler angles.""" - if not np.isclose(np.abs(om[2,2]),1.0,1.e-9): - zeta = 1.0/np.sqrt(1.0-om[2,2]**2) - eu = np.array([np.arctan2(om[2,0]*zeta,-om[2,1]*zeta), - np.arccos(om[2,2]), - np.arctan2(om[0,2]*zeta, om[1,2]*zeta)]) - else: - eu = np.array([np.arctan2( om[0,1],om[0,0]), np.pi*0.5*(1-om[2,2]),0.0]) # following the paper, not the reference implementation - eu[np.abs(eu)<1.e-8] = 0.0 - eu = np.where(eu<0, (eu+2.0*np.pi)%np.array([2.0*np.pi,np.pi,2.0*np.pi]),eu) - return eu - -def om2ax(om): - """Rotation matrix to axis angle pair.""" - #return qu2ax(om2qu(om)) # HOTFIX - ax=np.empty(4) - - # first get the rotation angle - t = 0.5*(om.trace() -1.0) - ax[3] = np.arccos(np.clip(t,-1.0,1.0)) - if np.abs(ax[3])<1.e-8: - ax = np.array([ 0.0, 0.0, 1.0, 0.0]) - else: - w,vr = np.linalg.eig(om) - # next, find the eigenvalue (1,0j) - i = np.where(np.isclose(w,1.0+0.0j))[0][0] - ax[0:3] = np.real(vr[0:3,i]) - diagDelta = -_P*np.array([om[1,2]-om[2,1],om[2,0]-om[0,2],om[0,1]-om[1,0]]) - ax[0:3] = np.where(np.abs(diagDelta)<1e-12, ax[0:3],np.abs(ax[0:3])*np.sign(diagDelta)) - return ax - -#---------- Bunge-Euler angles ---------- -def eu2qu(eu): - """Bunge-Euler angles to quaternion.""" - ee = 0.5*eu - cPhi = np.cos(ee[1]) - sPhi = np.sin(ee[1]) - qu = np.array([ cPhi*np.cos(ee[0]+ee[2]), - -_P*sPhi*np.cos(ee[0]-ee[2]), - -_P*sPhi*np.sin(ee[0]-ee[2]), - -_P*cPhi*np.sin(ee[0]+ee[2]) ]) - if qu[0] < 0.0: qu*=-1 - return qu - -def eu2om(eu): - """Bunge-Euler angles to rotation matrix.""" - c = np.cos(eu) - s = np.sin(eu) - - om = np.array([[+c[0]*c[2]-s[0]*s[2]*c[1], +s[0]*c[2]+c[0]*s[2]*c[1], +s[2]*s[1]], - [-c[0]*s[2]-s[0]*c[2]*c[1], -s[0]*s[2]+c[0]*c[2]*c[1], +c[2]*s[1]], - [+s[0]*s[1], -c[0]*s[1], +c[1] ]]) - om[np.abs(om)<1.e-12] = 0.0 - return om - -def eu2ax(eu): - """Bunge-Euler angles to axis angle pair.""" - t = np.tan(eu[1]*0.5) - sigma = 0.5*(eu[0]+eu[2]) - delta = 0.5*(eu[0]-eu[2]) - tau = np.linalg.norm([t,np.sin(sigma)]) - alpha = np.pi if iszero(np.cos(sigma)) else \ - 2.0*np.arctan(tau/np.cos(sigma)) - - if np.abs(alpha)<1.e-6: - ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) - else: - ax = -_P/tau * np.array([ t*np.cos(delta), t*np.sin(delta), np.sin(sigma) ]) # passive axis angle pair so a minus sign in front - ax = np.append(ax,alpha) - if alpha < 0.0: ax *= -1.0 # ensure alpha is positive - return ax - -def eu2ro(eu): - """Bunge-Euler angles to Rodrigues-Frank vector.""" - ro = eu2ax(eu) # convert to axis angle pair representation - if ro[3] >= np.pi: # Differs from original implementation. check convention 5 - ro[3] = np.inf - elif iszero(ro[3]): - ro = np.array([ 0.0, 0.0, _P, 0.0 ]) - else: - ro[3] = np.tan(ro[3]*0.5) - return ro - -#---------- Axis angle pair ---------- -def ax2qu(ax): - """Axis angle pair to quaternion.""" - if np.abs(ax[3])<1.e-6: - qu = np.array([ 1.0, 0.0, 0.0, 0.0 ]) - else: - c = np.cos(ax[3]*0.5) - s = np.sin(ax[3]*0.5) - qu = np.array([ c, ax[0]*s, ax[1]*s, ax[2]*s ]) - return qu - -def ax2om(ax): - """Axis angle pair to rotation matrix.""" - c = np.cos(ax[3]) - s = np.sin(ax[3]) - omc = 1.0-c - om=np.diag(ax[0:3]**2*omc + c) - - for idx in [[0,1,2],[1,2,0],[2,0,1]]: - q = omc*ax[idx[0]] * ax[idx[1]] - om[idx[0],idx[1]] = q + s*ax[idx[2]] - om[idx[1],idx[0]] = q - s*ax[idx[2]] - return om if _P < 0.0 else om.T - -def ax2ro(ax): - """Axis angle pair to Rodrigues-Frank vector.""" - if np.abs(ax[3])<1.e-6: - ro = [ 0.0, 0.0, _P, 0.0 ] - else: - ro = [ax[0], ax[1], ax[2]] - # 180 degree case - ro += [np.inf] if np.isclose(ax[3],np.pi,atol=1.0e-15,rtol=0.0) else \ - [np.tan(ax[3]*0.5)] - ro = np.array(ro) - return ro - -def ax2ho(ax): - """Axis angle pair to homochoric vector.""" - f = (0.75 * ( ax[3] - np.sin(ax[3]) ))**(1.0/3.0) - ho = ax[0:3] * f - return ho - - -#---------- Rodrigues-Frank vector ---------- -def ro2ax(ro): - """Rodrigues-Frank vector to axis angle pair.""" - if np.abs(ro[3]) < 1.e-8: - ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) - elif not np.isfinite(ro[3]): - ax = np.array([ ro[0], ro[1], ro[2], np.pi ]) - else: - angle = 2.0*np.arctan(ro[3]) - ta = np.linalg.norm(ro[0:3]) - ax = np.array([ ro[0]*ta, ro[1]*ta, ro[2]*ta, angle ]) - return ax - -def ro2ho(ro): - """Rodrigues-Frank vector to homochoric vector.""" - if np.sum(ro[0:3]**2.0) < 1.e-8: - ho = np.zeros(3) - else: - f = 2.0*np.arctan(ro[3]) -np.sin(2.0*np.arctan(ro[3])) if np.isfinite(ro[3]) else np.pi - ho = ro[0:3] * (0.75*f)**(1.0/3.0) - return ho - -#---------- Homochoric vector---------- -def ho2ax(ho): - """Homochoric vector to axis angle pair.""" - tfit = np.array([+1.0000000000018852, -0.5000000002194847, - -0.024999992127593126, -0.003928701544781374, - -0.0008152701535450438, -0.0002009500426119712, - -0.00002397986776071756, -0.00008202868926605841, - +0.00012448715042090092, -0.0001749114214822577, - +0.0001703481934140054, -0.00012062065004116828, - +0.000059719705868660826, -0.00001980756723965647, - +0.000003953714684212874, -0.00000036555001439719544]) - # normalize h and store the magnitude - hmag_squared = np.sum(ho**2.) - if iszero(hmag_squared): - ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) - else: - hm = hmag_squared - - # convert the magnitude to the rotation angle - s = tfit[0] + tfit[1] * hmag_squared - for i in range(2,16): - hm *= hmag_squared - s += tfit[i] * hm - ax = np.append(ho/np.sqrt(hmag_squared),2.0*np.arccos(np.clip(s,-1.0,1.0))) - return ax - -def ho2cu(ho): - """ - Homochoric vector to cubochoric vector. - - References - ---------- - D. Roşca et al., Modelling and Simulation in Materials Science and Engineering 22:075013, 2014 - https://doi.org/10.1088/0965-0393/22/7/075013 - - """ - rs = np.linalg.norm(ho) - - if np.allclose(ho,0.0,rtol=0.0,atol=1.0e-16): - cu = np.zeros(3) - else: - xyz3 = ho[_get_pyramid_order(ho,'forward')] - - # inverse M_3 - xyz2 = xyz3[0:2] * np.sqrt( 2.0*rs/(rs+np.abs(xyz3[2])) ) - - # inverse M_2 - qxy = np.sum(xyz2**2) - - if np.isclose(qxy,0.0,rtol=0.0,atol=1.0e-16): - Tinv = np.zeros(2) - else: - q2 = qxy + np.max(np.abs(xyz2))**2 - sq2 = np.sqrt(q2) - q = (_beta/np.sqrt(2.0)/_R1) * np.sqrt(q2*qxy/(q2-np.max(np.abs(xyz2))*sq2)) - tt = np.clip((np.min(np.abs(xyz2))**2+np.max(np.abs(xyz2))*sq2)/np.sqrt(2.0)/qxy,-1.0,1.0) - Tinv = np.array([1.0,np.arccos(tt)/np.pi*12.0]) if np.abs(xyz2[1]) <= np.abs(xyz2[0]) else \ - np.array([np.arccos(tt)/np.pi*12.0,1.0]) - Tinv = q * np.where(xyz2<0.0,-Tinv,Tinv) - - # inverse M_1 - cu = np.array([ Tinv[0], Tinv[1], (-1.0 if xyz3[2] < 0.0 else 1.0) * rs / np.sqrt(6.0/np.pi) ]) /_sc - cu = cu[_get_pyramid_order(ho,'backward')] - return cu - -#---------- Cubochoric ---------- -def cu2ho(cu): - """ - Cubochoric vector to homochoric vector. - - References - ---------- - D. Roşca et al., Modelling and Simulation in Materials Science and Engineering 22:075013, 2014 - https://doi.org/10.1088/0965-0393/22/7/075013 - - """ - # transform to the sphere grid via the curved square, and intercept the zero point - if np.allclose(cu,0.0,rtol=0.0,atol=1.0e-16): - ho = np.zeros(3) - else: - # get pyramide and scale by grid parameter ratio - XYZ = cu[_get_pyramid_order(cu,'forward')] * _sc - - # intercept all the points along the z-axis - if np.allclose(XYZ[0:2],0.0,rtol=0.0,atol=1.0e-16): - ho = np.array([0.0, 0.0, np.sqrt(6.0/np.pi) * XYZ[2]]) - else: - order = [1,0] if np.abs(XYZ[1]) <= np.abs(XYZ[0]) else [0,1] - q = np.pi/12.0 * XYZ[order[0]]/XYZ[order[1]] - c = np.cos(q) - s = np.sin(q) - q = _R1*2.0**0.25/_beta * XYZ[order[1]] / np.sqrt(np.sqrt(2.0)-c) - T = np.array([ (np.sqrt(2.0)*c - 1.0), np.sqrt(2.0) * s]) * q - - # transform to sphere grid (inverse Lambert) - # note that there is no need to worry about dividing by zero, since XYZ[2] can not become zero - c = np.sum(T**2) - s = c * np.pi/24.0 /XYZ[2]**2 - c = c * np.sqrt(np.pi/24.0)/XYZ[2] - - q = np.sqrt( 1.0 - s ) - ho = np.array([ T[order[1]] * q, T[order[0]] * q, np.sqrt(6.0/np.pi) * XYZ[2] - c ]) - - ho = ho[_get_pyramid_order(cu,'backward')] - return ho - -def _get_pyramid_order(xyz,direction=None): - """ - Get order of the coordinates. - - Depending on the pyramid in which the point is located, the order need to be adjusted. - - Parameters - ---------- - xyz : numpy.ndarray - coordinates of a point on a uniform refinable grid on a ball or - in a uniform refinable cubical grid. - - References - ---------- - D. Roşca et al., Modelling and Simulation in Materials Science and Engineering 22:075013, 2014 - https://doi.org/10.1088/0965-0393/22/7/075013 - - """ - order = {'forward':np.array([[0,1,2],[1,2,0],[2,0,1]]), - 'backward':np.array([[0,1,2],[2,0,1],[1,2,0]])} - if np.maximum(abs(xyz[0]),abs(xyz[1])) <= xyz[2] or \ - np.maximum(abs(xyz[0]),abs(xyz[1])) <=-xyz[2]: - p = 0 - elif np.maximum(abs(xyz[1]),abs(xyz[2])) <= xyz[0] or \ - np.maximum(abs(xyz[1]),abs(xyz[2])) <=-xyz[0]: - p = 1 - elif np.maximum(abs(xyz[2]),abs(xyz[0])) <= xyz[1] or \ - np.maximum(abs(xyz[2]),abs(xyz[0])) <=-xyz[1]: - p = 2 - return order[direction][p] diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index 4e48fbb7c..92f39b4fb 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -4,7 +4,9 @@ import pytest import numpy as np from damask import Rotation -import rotation_conversion +from damask import _rotation + + n = 1100 atol=1.e-4 @@ -13,68 +15,69 @@ scatter=1.e-2 @pytest.fixture def default(): """A set of n random rotations.""" - specials = np.array( - [np.array([ 1.0, 0.0, 0.0, 0.0]), - #----------------------------------------------- - np.array([0.0, 1.0, 0.0, 0.0]), - np.array([0.0, 0.0, 1.0, 0.0]), - np.array([0.0, 0.0, 0.0, 1.0]), - np.array([0.0,-1.0, 0.0, 0.0]), - np.array([0.0, 0.0,-1.0, 0.0]), - np.array([0.0, 0.0, 0.0,-1.0]), - #----------------------------------------------- - np.array([1.0, 1.0, 0.0, 0.0])/np.sqrt(2.), - np.array([1.0, 0.0, 1.0, 0.0])/np.sqrt(2.), - np.array([1.0, 0.0, 0.0, 1.0])/np.sqrt(2.), - np.array([0.0, 1.0, 1.0, 0.0])/np.sqrt(2.), - np.array([0.0, 1.0, 0.0, 1.0])/np.sqrt(2.), - np.array([0.0, 0.0, 1.0, 1.0])/np.sqrt(2.), - #----------------------------------------------- - np.array([1.0,-1.0, 0.0, 0.0])/np.sqrt(2.), - np.array([1.0, 0.0,-1.0, 0.0])/np.sqrt(2.), - np.array([1.0, 0.0, 0.0,-1.0])/np.sqrt(2.), - np.array([0.0, 1.0,-1.0, 0.0])/np.sqrt(2.), - np.array([0.0, 1.0, 0.0,-1.0])/np.sqrt(2.), - np.array([0.0, 0.0, 1.0,-1.0])/np.sqrt(2.), - #----------------------------------------------- - np.array([0.0, 1.0,-1.0, 0.0])/np.sqrt(2.), - np.array([0.0, 1.0, 0.0,-1.0])/np.sqrt(2.), - np.array([0.0, 0.0, 1.0,-1.0])/np.sqrt(2.), - #----------------------------------------------- - np.array([0.0,-1.0,-1.0, 0.0])/np.sqrt(2.), - np.array([0.0,-1.0, 0.0,-1.0])/np.sqrt(2.), - np.array([0.0, 0.0,-1.0,-1.0])/np.sqrt(2.), - #----------------------------------------------- - np.array([1.0, 1.0, 1.0, 0.0])/np.sqrt(3.), - np.array([1.0, 1.0, 0.0, 1.0])/np.sqrt(3.), - np.array([1.0, 0.0, 1.0, 1.0])/np.sqrt(3.), - np.array([1.0,-1.0, 1.0, 0.0])/np.sqrt(3.), - np.array([1.0,-1.0, 0.0, 1.0])/np.sqrt(3.), - np.array([1.0, 0.0,-1.0, 1.0])/np.sqrt(3.), - np.array([1.0, 1.0,-1.0, 0.0])/np.sqrt(3.), - np.array([1.0, 1.0, 0.0,-1.0])/np.sqrt(3.), - np.array([1.0, 0.0, 1.0,-1.0])/np.sqrt(3.), - np.array([1.0,-1.0,-1.0, 0.0])/np.sqrt(3.), - np.array([1.0,-1.0, 0.0,-1.0])/np.sqrt(3.), - np.array([1.0, 0.0,-1.0,-1.0])/np.sqrt(3.), - #----------------------------------------------- - np.array([0.0, 1.0, 1.0, 1.0])/np.sqrt(3.), - np.array([0.0, 1.0,-1.0, 1.0])/np.sqrt(3.), - np.array([0.0, 1.0, 1.0,-1.0])/np.sqrt(3.), - np.array([0.0,-1.0, 1.0, 1.0])/np.sqrt(3.), - np.array([0.0,-1.0,-1.0, 1.0])/np.sqrt(3.), - np.array([0.0,-1.0, 1.0,-1.0])/np.sqrt(3.), - np.array([0.0,-1.0,-1.0,-1.0])/np.sqrt(3.), - #----------------------------------------------- - np.array([1.0, 1.0, 1.0, 1.0])/2., - np.array([1.0,-1.0, 1.0, 1.0])/2., - np.array([1.0, 1.0,-1.0, 1.0])/2., - np.array([1.0, 1.0, 1.0,-1.0])/2., - np.array([1.0,-1.0,-1.0, 1.0])/2., - np.array([1.0,-1.0, 1.0,-1.0])/2., - np.array([1.0, 1.0,-1.0,-1.0])/2., - np.array([1.0,-1.0,-1.0,-1.0])/2., - ]) + specials = np.array([ + [1.0, 0.0, 0.0, 0.0], + #---------------------- + [0.0, 1.0, 0.0, 0.0], + [0.0, 0.0, 1.0, 0.0], + [0.0, 0.0, 0.0, 1.0], + [0.0,-1.0, 0.0, 0.0], + [0.0, 0.0,-1.0, 0.0], + [0.0, 0.0, 0.0,-1.0], + #---------------------- + [1.0, 1.0, 0.0, 0.0], + [1.0, 0.0, 1.0, 0.0], + [1.0, 0.0, 0.0, 1.0], + [0.0, 1.0, 1.0, 0.0], + [0.0, 1.0, 0.0, 1.0], + [0.0, 0.0, 1.0, 1.0], + #---------------------- + [1.0,-1.0, 0.0, 0.0], + [1.0, 0.0,-1.0, 0.0], + [1.0, 0.0, 0.0,-1.0], + [0.0, 1.0,-1.0, 0.0], + [0.0, 1.0, 0.0,-1.0], + [0.0, 0.0, 1.0,-1.0], + #---------------------- + [0.0, 1.0,-1.0, 0.0], + [0.0, 1.0, 0.0,-1.0], + [0.0, 0.0, 1.0,-1.0], + #---------------------- + [0.0,-1.0,-1.0, 0.0], + [0.0,-1.0, 0.0,-1.0], + [0.0, 0.0,-1.0,-1.0], + #---------------------- + [1.0, 1.0, 1.0, 0.0], + [1.0, 1.0, 0.0, 1.0], + [1.0, 0.0, 1.0, 1.0], + [1.0,-1.0, 1.0, 0.0], + [1.0,-1.0, 0.0, 1.0], + [1.0, 0.0,-1.0, 1.0], + [1.0, 1.0,-1.0, 0.0], + [1.0, 1.0, 0.0,-1.0], + [1.0, 0.0, 1.0,-1.0], + [1.0,-1.0,-1.0, 0.0], + [1.0,-1.0, 0.0,-1.0], + [1.0, 0.0,-1.0,-1.0], + #---------------------- + [0.0, 1.0, 1.0, 1.0], + [0.0, 1.0,-1.0, 1.0], + [0.0, 1.0, 1.0,-1.0], + [0.0,-1.0, 1.0, 1.0], + [0.0,-1.0,-1.0, 1.0], + [0.0,-1.0, 1.0,-1.0], + [0.0,-1.0,-1.0,-1.0], + #---------------------- + [1.0, 1.0, 1.0, 1.0], + [1.0,-1.0, 1.0, 1.0], + [1.0, 1.0,-1.0, 1.0], + [1.0, 1.0, 1.0,-1.0], + [1.0,-1.0,-1.0, 1.0], + [1.0,-1.0, 1.0,-1.0], + [1.0, 1.0,-1.0,-1.0], + [1.0,-1.0,-1.0,-1.0], + ]) + specials /= np.linalg.norm(specials,axis=1).reshape(-1,1) specials_scatter = specials + np.broadcast_to(np.random.rand(4)*scatter,specials.shape) specials_scatter /= np.linalg.norm(specials_scatter,axis=1).reshape(-1,1) specials_scatter[specials_scatter[:,0]<0]*=-1 @@ -89,6 +92,425 @@ def reference_dir(reference_dir_base): return os.path.join(reference_dir_base,'Rotation') +#################################################################################################### +# Code below available according to the following conditions on https://github.com/MarDiehl/3Drotations +#################################################################################################### +# Copyright (c) 2017-2019, Martin Diehl/Max-Planck-Institut für Eisenforschung GmbH +# Copyright (c) 2013-2014, Marc De Graef/Carnegie Mellon University +# All rights reserved. +# +# Redistribution and use in source and binary forms, with or without modification, are +# permitted provided that the following conditions are met: +# +# - Redistributions of source code must retain the above copyright notice, this list +# of conditions and the following disclaimer. +# - Redistributions in binary form must reproduce the above copyright notice, this +# list of conditions and the following disclaimer in the documentation and/or +# other materials provided with the distribution. +# - Neither the names of Marc De Graef, Carnegie Mellon University nor the names +# of its contributors may be used to endorse or promote products derived from +# this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE +# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR +# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, +# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE +# USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +#################################################################################################### +_P = _rotation._P + +# parameters for conversion from/to cubochoric +_sc = _rotation._sc +_beta = _rotation._beta +_R1 = _rotation._R1 + +def iszero(a): + return np.isclose(a,0.0,atol=1.0e-12,rtol=0.0) + +#---------- Quaternion ---------- +def qu2om(qu): + """Quaternion to rotation matrix.""" + qq = qu[0]**2-(qu[1]**2 + qu[2]**2 + qu[3]**2) + om = np.diag(qq + 2.0*np.array([qu[1],qu[2],qu[3]])**2) + + om[0,1] = 2.0*(qu[2]*qu[1]+qu[0]*qu[3]) + om[1,0] = 2.0*(qu[1]*qu[2]-qu[0]*qu[3]) + om[1,2] = 2.0*(qu[3]*qu[2]+qu[0]*qu[1]) + om[2,1] = 2.0*(qu[2]*qu[3]-qu[0]*qu[1]) + om[2,0] = 2.0*(qu[1]*qu[3]+qu[0]*qu[2]) + om[0,2] = 2.0*(qu[3]*qu[1]-qu[0]*qu[2]) + return om if _P < 0.0 else np.swapaxes(om,-1,-2) + +def qu2eu(qu): + """Quaternion to Bunge-Euler angles.""" + q03 = qu[0]**2+qu[3]**2 + q12 = qu[1]**2+qu[2]**2 + chi = np.sqrt(q03*q12) + if np.abs(q12) < 1.e-8: + eu = np.array([np.arctan2(-_P*2.0*qu[0]*qu[3],qu[0]**2-qu[3]**2), 0.0, 0.0]) + elif np.abs(q03) < 1.e-8: + eu = np.array([np.arctan2( 2.0*qu[1]*qu[2],qu[1]**2-qu[2]**2), np.pi, 0.0]) + else: + eu = np.array([np.arctan2((-_P*qu[0]*qu[2]+qu[1]*qu[3])*chi, (-_P*qu[0]*qu[1]-qu[2]*qu[3])*chi ), + np.arctan2( 2.0*chi, q03-q12 ), + np.arctan2(( _P*qu[0]*qu[2]+qu[1]*qu[3])*chi, (-_P*qu[0]*qu[1]+qu[2]*qu[3])*chi )]) + # reduce Euler angles to definition range + eu[np.abs(eu)<1.e-6] = 0.0 + eu = np.where(eu<0, (eu+2.0*np.pi)%np.array([2.0*np.pi,np.pi,2.0*np.pi]),eu) + return eu + +def qu2ax(qu): + """ + Quaternion to axis angle pair. + + Modified version of the original formulation, should be numerically more stable + """ + if np.isclose(qu[0],1.,rtol=0.0): # set axis to [001] if the angle is 0/360 + ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) + elif qu[0] > 1.e-8: + s = np.sign(qu[0])/np.sqrt(qu[1]**2+qu[2]**2+qu[3]**2) + omega = 2.0 * np.arccos(np.clip(qu[0],-1.0,1.0)) + ax = ax = np.array([ qu[1]*s, qu[2]*s, qu[3]*s, omega ]) + else: + ax = ax = np.array([ qu[1], qu[2], qu[3], np.pi]) + return ax + +def qu2ro(qu): + """Quaternion to Rodrigues-Frank vector.""" + if iszero(qu[0]): + ro = np.array([qu[1], qu[2], qu[3], np.inf]) + else: + s = np.linalg.norm(qu[1:4]) + ro = np.array([0.0,0.0,_P,0.0] if iszero(s) else \ + [ qu[1]/s, qu[2]/s, qu[3]/s, np.tan(np.arccos(np.clip(qu[0],-1.0,1.0)))]) + return ro + +def qu2ho(qu): + """Quaternion to homochoric vector.""" + omega = 2.0 * np.arccos(np.clip(qu[0],-1.0,1.0)) + if np.abs(omega) < 1.0e-12: + ho = np.zeros(3) + else: + ho = np.array([qu[1], qu[2], qu[3]]) + f = 0.75 * ( omega - np.sin(omega) ) + ho = ho/np.linalg.norm(ho) * f**(1./3.) + return ho + + +#---------- Rotation matrix ---------- +def om2qu(a): + trace = a[0,0] + a[1,1] + a[2,2] + if trace > 0: + s = 0.5 / np.sqrt(trace+ 1.0) + qu = np.array([0.25 / s,( a[2,1] - a[1,2] ) * s,( a[0,2] - a[2,0] ) * s,( a[1,0] - a[0,1] ) * s]) + else: + if ( a[0,0] > a[1,1] and a[0,0] > a[2,2] ): + s = 2.0 * np.sqrt( 1.0 + a[0,0] - a[1,1] - a[2,2]) + qu = np.array([ (a[2,1] - a[1,2]) / s,0.25 * s,(a[0,1] + a[1,0]) / s,(a[0,2] + a[2,0]) / s]) + elif (a[1,1] > a[2,2]): + s = 2.0 * np.sqrt( 1.0 + a[1,1] - a[0,0] - a[2,2]) + qu = np.array([ (a[0,2] - a[2,0]) / s,(a[0,1] + a[1,0]) / s,0.25 * s,(a[1,2] + a[2,1]) / s]) + else: + s = 2.0 * np.sqrt( 1.0 + a[2,2] - a[0,0] - a[1,1] ) + qu = np.array([ (a[1,0] - a[0,1]) / s,(a[0,2] + a[2,0]) / s,(a[1,2] + a[2,1]) / s,0.25 * s]) + if qu[0]<0: qu*=-1 + return qu*np.array([1.,_P,_P,_P]) + +def om2eu(om): + """Rotation matrix to Bunge-Euler angles.""" + if not np.isclose(np.abs(om[2,2]),1.0,1.e-9): + zeta = 1.0/np.sqrt(1.0-om[2,2]**2) + eu = np.array([np.arctan2(om[2,0]*zeta,-om[2,1]*zeta), + np.arccos(om[2,2]), + np.arctan2(om[0,2]*zeta, om[1,2]*zeta)]) + else: + eu = np.array([np.arctan2( om[0,1],om[0,0]), np.pi*0.5*(1-om[2,2]),0.0]) # following the paper, not the reference implementation + eu[np.abs(eu)<1.e-8] = 0.0 + eu = np.where(eu<0, (eu+2.0*np.pi)%np.array([2.0*np.pi,np.pi,2.0*np.pi]),eu) + return eu + +def om2ax(om): + """Rotation matrix to axis angle pair.""" + #return qu2ax(om2qu(om)) # HOTFIX + ax=np.empty(4) + + # first get the rotation angle + t = 0.5*(om.trace() -1.0) + ax[3] = np.arccos(np.clip(t,-1.0,1.0)) + if np.abs(ax[3])<1.e-8: + ax = np.array([ 0.0, 0.0, 1.0, 0.0]) + else: + w,vr = np.linalg.eig(om) + # next, find the eigenvalue (1,0j) + i = np.where(np.isclose(w,1.0+0.0j))[0][0] + ax[0:3] = np.real(vr[0:3,i]) + diagDelta = -_P*np.array([om[1,2]-om[2,1],om[2,0]-om[0,2],om[0,1]-om[1,0]]) + ax[0:3] = np.where(np.abs(diagDelta)<1e-12, ax[0:3],np.abs(ax[0:3])*np.sign(diagDelta)) + return ax + +#---------- Bunge-Euler angles ---------- +def eu2qu(eu): + """Bunge-Euler angles to quaternion.""" + ee = 0.5*eu + cPhi = np.cos(ee[1]) + sPhi = np.sin(ee[1]) + qu = np.array([ cPhi*np.cos(ee[0]+ee[2]), + -_P*sPhi*np.cos(ee[0]-ee[2]), + -_P*sPhi*np.sin(ee[0]-ee[2]), + -_P*cPhi*np.sin(ee[0]+ee[2]) ]) + if qu[0] < 0.0: qu*=-1 + return qu + +def eu2om(eu): + """Bunge-Euler angles to rotation matrix.""" + c = np.cos(eu) + s = np.sin(eu) + + om = np.array([[+c[0]*c[2]-s[0]*s[2]*c[1], +s[0]*c[2]+c[0]*s[2]*c[1], +s[2]*s[1]], + [-c[0]*s[2]-s[0]*c[2]*c[1], -s[0]*s[2]+c[0]*c[2]*c[1], +c[2]*s[1]], + [+s[0]*s[1], -c[0]*s[1], +c[1] ]]) + om[np.abs(om)<1.e-12] = 0.0 + return om + +def eu2ax(eu): + """Bunge-Euler angles to axis angle pair.""" + t = np.tan(eu[1]*0.5) + sigma = 0.5*(eu[0]+eu[2]) + delta = 0.5*(eu[0]-eu[2]) + tau = np.linalg.norm([t,np.sin(sigma)]) + alpha = np.pi if iszero(np.cos(sigma)) else \ + 2.0*np.arctan(tau/np.cos(sigma)) + + if np.abs(alpha)<1.e-6: + ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) + else: + ax = -_P/tau * np.array([ t*np.cos(delta), t*np.sin(delta), np.sin(sigma) ]) # passive axis angle pair so a minus sign in front + ax = np.append(ax,alpha) + if alpha < 0.0: ax *= -1.0 # ensure alpha is positive + return ax + +def eu2ro(eu): + """Bunge-Euler angles to Rodrigues-Frank vector.""" + ro = eu2ax(eu) # convert to axis angle pair representation + if ro[3] >= np.pi: # Differs from original implementation. check convention 5 + ro[3] = np.inf + elif iszero(ro[3]): + ro = np.array([ 0.0, 0.0, _P, 0.0 ]) + else: + ro[3] = np.tan(ro[3]*0.5) + return ro + +#---------- Axis angle pair ---------- +def ax2qu(ax): + """Axis angle pair to quaternion.""" + if np.abs(ax[3])<1.e-6: + qu = np.array([ 1.0, 0.0, 0.0, 0.0 ]) + else: + c = np.cos(ax[3]*0.5) + s = np.sin(ax[3]*0.5) + qu = np.array([ c, ax[0]*s, ax[1]*s, ax[2]*s ]) + return qu + +def ax2om(ax): + """Axis angle pair to rotation matrix.""" + c = np.cos(ax[3]) + s = np.sin(ax[3]) + omc = 1.0-c + om=np.diag(ax[0:3]**2*omc + c) + + for idx in [[0,1,2],[1,2,0],[2,0,1]]: + q = omc*ax[idx[0]] * ax[idx[1]] + om[idx[0],idx[1]] = q + s*ax[idx[2]] + om[idx[1],idx[0]] = q - s*ax[idx[2]] + return om if _P < 0.0 else om.T + +def ax2ro(ax): + """Axis angle pair to Rodrigues-Frank vector.""" + if np.abs(ax[3])<1.e-6: + ro = [ 0.0, 0.0, _P, 0.0 ] + else: + ro = [ax[0], ax[1], ax[2]] + # 180 degree case + ro += [np.inf] if np.isclose(ax[3],np.pi,atol=1.0e-15,rtol=0.0) else \ + [np.tan(ax[3]*0.5)] + ro = np.array(ro) + return ro + +def ax2ho(ax): + """Axis angle pair to homochoric vector.""" + f = (0.75 * ( ax[3] - np.sin(ax[3]) ))**(1.0/3.0) + ho = ax[0:3] * f + return ho + + +#---------- Rodrigues-Frank vector ---------- +def ro2ax(ro): + """Rodrigues-Frank vector to axis angle pair.""" + if np.abs(ro[3]) < 1.e-8: + ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) + elif not np.isfinite(ro[3]): + ax = np.array([ ro[0], ro[1], ro[2], np.pi ]) + else: + angle = 2.0*np.arctan(ro[3]) + ta = np.linalg.norm(ro[0:3]) + ax = np.array([ ro[0]*ta, ro[1]*ta, ro[2]*ta, angle ]) + return ax + +def ro2ho(ro): + """Rodrigues-Frank vector to homochoric vector.""" + if np.sum(ro[0:3]**2.0) < 1.e-8: + ho = np.zeros(3) + else: + f = 2.0*np.arctan(ro[3]) -np.sin(2.0*np.arctan(ro[3])) if np.isfinite(ro[3]) else np.pi + ho = ro[0:3] * (0.75*f)**(1.0/3.0) + return ho + +#---------- Homochoric vector---------- +def ho2ax(ho): + """Homochoric vector to axis angle pair.""" + tfit = np.array([+1.0000000000018852, -0.5000000002194847, + -0.024999992127593126, -0.003928701544781374, + -0.0008152701535450438, -0.0002009500426119712, + -0.00002397986776071756, -0.00008202868926605841, + +0.00012448715042090092, -0.0001749114214822577, + +0.0001703481934140054, -0.00012062065004116828, + +0.000059719705868660826, -0.00001980756723965647, + +0.000003953714684212874, -0.00000036555001439719544]) + # normalize h and store the magnitude + hmag_squared = np.sum(ho**2.) + if iszero(hmag_squared): + ax = np.array([ 0.0, 0.0, 1.0, 0.0 ]) + else: + hm = hmag_squared + + # convert the magnitude to the rotation angle + s = tfit[0] + tfit[1] * hmag_squared + for i in range(2,16): + hm *= hmag_squared + s += tfit[i] * hm + ax = np.append(ho/np.sqrt(hmag_squared),2.0*np.arccos(np.clip(s,-1.0,1.0))) + return ax + +def ho2cu(ho): + """ + Homochoric vector to cubochoric vector. + + References + ---------- + D. Roşca et al., Modelling and Simulation in Materials Science and Engineering 22:075013, 2014 + https://doi.org/10.1088/0965-0393/22/7/075013 + + """ + rs = np.linalg.norm(ho) + + if np.allclose(ho,0.0,rtol=0.0,atol=1.0e-16): + cu = np.zeros(3) + else: + xyz3 = ho[_get_pyramid_order(ho,'forward')] + + # inverse M_3 + xyz2 = xyz3[0:2] * np.sqrt( 2.0*rs/(rs+np.abs(xyz3[2])) ) + + # inverse M_2 + qxy = np.sum(xyz2**2) + + if np.isclose(qxy,0.0,rtol=0.0,atol=1.0e-16): + Tinv = np.zeros(2) + else: + q2 = qxy + np.max(np.abs(xyz2))**2 + sq2 = np.sqrt(q2) + q = (_beta/np.sqrt(2.0)/_R1) * np.sqrt(q2*qxy/(q2-np.max(np.abs(xyz2))*sq2)) + tt = np.clip((np.min(np.abs(xyz2))**2+np.max(np.abs(xyz2))*sq2)/np.sqrt(2.0)/qxy,-1.0,1.0) + Tinv = np.array([1.0,np.arccos(tt)/np.pi*12.0]) if np.abs(xyz2[1]) <= np.abs(xyz2[0]) else \ + np.array([np.arccos(tt)/np.pi*12.0,1.0]) + Tinv = q * np.where(xyz2<0.0,-Tinv,Tinv) + + # inverse M_1 + cu = np.array([ Tinv[0], Tinv[1], (-1.0 if xyz3[2] < 0.0 else 1.0) * rs / np.sqrt(6.0/np.pi) ]) /_sc + cu = cu[_get_pyramid_order(ho,'backward')] + return cu + +#---------- Cubochoric ---------- +def cu2ho(cu): + """ + Cubochoric vector to homochoric vector. + + References + ---------- + D. Roşca et al., Modelling and Simulation in Materials Science and Engineering 22:075013, 2014 + https://doi.org/10.1088/0965-0393/22/7/075013 + + """ + # transform to the sphere grid via the curved square, and intercept the zero point + if np.allclose(cu,0.0,rtol=0.0,atol=1.0e-16): + ho = np.zeros(3) + else: + # get pyramide and scale by grid parameter ratio + XYZ = cu[_get_pyramid_order(cu,'forward')] * _sc + + # intercept all the points along the z-axis + if np.allclose(XYZ[0:2],0.0,rtol=0.0,atol=1.0e-16): + ho = np.array([0.0, 0.0, np.sqrt(6.0/np.pi) * XYZ[2]]) + else: + order = [1,0] if np.abs(XYZ[1]) <= np.abs(XYZ[0]) else [0,1] + q = np.pi/12.0 * XYZ[order[0]]/XYZ[order[1]] + c = np.cos(q) + s = np.sin(q) + q = _R1*2.0**0.25/_beta * XYZ[order[1]] / np.sqrt(np.sqrt(2.0)-c) + T = np.array([ (np.sqrt(2.0)*c - 1.0), np.sqrt(2.0) * s]) * q + + # transform to sphere grid (inverse Lambert) + # note that there is no need to worry about dividing by zero, since XYZ[2] can not become zero + c = np.sum(T**2) + s = c * np.pi/24.0 /XYZ[2]**2 + c = c * np.sqrt(np.pi/24.0)/XYZ[2] + + q = np.sqrt( 1.0 - s ) + ho = np.array([ T[order[1]] * q, T[order[0]] * q, np.sqrt(6.0/np.pi) * XYZ[2] - c ]) + + ho = ho[_get_pyramid_order(cu,'backward')] + return ho + +def _get_pyramid_order(xyz,direction=None): + """ + Get order of the coordinates. + + Depending on the pyramid in which the point is located, the order need to be adjusted. + + Parameters + ---------- + xyz : numpy.ndarray + coordinates of a point on a uniform refinable grid on a ball or + in a uniform refinable cubical grid. + + References + ---------- + D. Roşca et al., Modelling and Simulation in Materials Science and Engineering 22:075013, 2014 + https://doi.org/10.1088/0965-0393/22/7/075013 + + """ + order = {'forward':np.array([[0,1,2],[1,2,0],[2,0,1]]), + 'backward':np.array([[0,1,2],[2,0,1],[1,2,0]])} + if np.maximum(abs(xyz[0]),abs(xyz[1])) <= xyz[2] or \ + np.maximum(abs(xyz[0]),abs(xyz[1])) <=-xyz[2]: + p = 0 + elif np.maximum(abs(xyz[1]),abs(xyz[2])) <= xyz[0] or \ + np.maximum(abs(xyz[1]),abs(xyz[2])) <=-xyz[0]: + p = 1 + elif np.maximum(abs(xyz[2]),abs(xyz[0])) <= xyz[1] or \ + np.maximum(abs(xyz[2]),abs(xyz[0])) <=-xyz[1]: + p = 2 + return order[direction][p] + +#################################################################################################### +#################################################################################################### + + class TestRotation: @pytest.mark.parametrize('forward,backward',[(Rotation._qu2om,Rotation._om2qu), @@ -289,11 +711,11 @@ class TestRotation: with pytest.raises(ValueError): function(invalid) - @pytest.mark.parametrize('vectorized, single',[(Rotation._qu2om,rotation_conversion.qu2om), - (Rotation._qu2eu,rotation_conversion.qu2eu), - (Rotation._qu2ax,rotation_conversion.qu2ax), - (Rotation._qu2ro,rotation_conversion.qu2ro), - (Rotation._qu2ho,rotation_conversion.qu2ho)]) + @pytest.mark.parametrize('vectorized, single',[(Rotation._qu2om,qu2om), + (Rotation._qu2eu,qu2eu), + (Rotation._qu2ax,qu2ax), + (Rotation._qu2ro,qu2ro), + (Rotation._qu2ho,qu2ho)]) def test_quaternion_vectorization(self,default,vectorized,single): qu = np.array([rot.as_quaternion() for rot in default]) vectorized(qu.reshape(qu.shape[0]//2,-1,4)) @@ -303,9 +725,9 @@ class TestRotation: assert np.allclose(single(q),c) and np.allclose(single(q),vectorized(q)) - @pytest.mark.parametrize('vectorized, single',[(Rotation._om2qu,rotation_conversion.om2qu), - (Rotation._om2eu,rotation_conversion.om2eu), - (Rotation._om2ax,rotation_conversion.om2ax)]) + @pytest.mark.parametrize('vectorized, single',[(Rotation._om2qu,om2qu), + (Rotation._om2eu,om2eu), + (Rotation._om2ax,om2ax)]) def test_matrix_vectorization(self,default,vectorized,single): om = np.array([rot.as_matrix() for rot in default]) vectorized(om.reshape(om.shape[0]//2,-1,3,3)) @@ -314,10 +736,10 @@ class TestRotation: print(o,c) assert np.allclose(single(o),c) and np.allclose(single(o),vectorized(o)) - @pytest.mark.parametrize('vectorized, single',[(Rotation._eu2qu,rotation_conversion.eu2qu), - (Rotation._eu2om,rotation_conversion.eu2om), - (Rotation._eu2ax,rotation_conversion.eu2ax), - (Rotation._eu2ro,rotation_conversion.eu2ro)]) + @pytest.mark.parametrize('vectorized, single',[(Rotation._eu2qu,eu2qu), + (Rotation._eu2om,eu2om), + (Rotation._eu2ax,eu2ax), + (Rotation._eu2ro,eu2ro)]) def test_Euler_vectorization(self,default,vectorized,single): eu = np.array([rot.as_Eulers() for rot in default]) vectorized(eu.reshape(eu.shape[0]//2,-1,3)) @@ -326,10 +748,10 @@ class TestRotation: print(e,c) assert np.allclose(single(e),c) and np.allclose(single(e),vectorized(e)) - @pytest.mark.parametrize('vectorized, single',[(Rotation._ax2qu,rotation_conversion.ax2qu), - (Rotation._ax2om,rotation_conversion.ax2om), - (Rotation._ax2ro,rotation_conversion.ax2ro), - (Rotation._ax2ho,rotation_conversion.ax2ho)]) + @pytest.mark.parametrize('vectorized, single',[(Rotation._ax2qu,ax2qu), + (Rotation._ax2om,ax2om), + (Rotation._ax2ro,ax2ro), + (Rotation._ax2ho,ax2ho)]) def test_axisAngle_vectorization(self,default,vectorized,single): ax = np.array([rot.as_axis_angle() for rot in default]) vectorized(ax.reshape(ax.shape[0]//2,-1,4)) @@ -339,8 +761,8 @@ class TestRotation: assert np.allclose(single(a),c) and np.allclose(single(a),vectorized(a)) - @pytest.mark.parametrize('vectorized, single',[(Rotation._ro2ax,rotation_conversion.ro2ax), - (Rotation._ro2ho,rotation_conversion.ro2ho)]) + @pytest.mark.parametrize('vectorized, single',[(Rotation._ro2ax,ro2ax), + (Rotation._ro2ho,ro2ho)]) def test_Rodrigues_vectorization(self,default,vectorized,single): ro = np.array([rot.as_Rodrigues() for rot in default]) vectorized(ro.reshape(ro.shape[0]//2,-1,4)) @@ -349,8 +771,8 @@ class TestRotation: print(r,c) assert np.allclose(single(r),c) and np.allclose(single(r),vectorized(r)) - @pytest.mark.parametrize('vectorized, single',[(Rotation._ho2ax,rotation_conversion.ho2ax), - (Rotation._ho2cu,rotation_conversion.ho2cu)]) + @pytest.mark.parametrize('vectorized, single',[(Rotation._ho2ax,ho2ax), + (Rotation._ho2cu,ho2cu)]) def test_homochoric_vectorization(self,default,vectorized,single): ho = np.array([rot.as_homochoric() for rot in default]) vectorized(ho.reshape(ho.shape[0]//2,-1,3)) @@ -359,7 +781,7 @@ class TestRotation: print(h,c) assert np.allclose(single(h),c) and np.allclose(single(h),vectorized(h)) - @pytest.mark.parametrize('vectorized, single',[(Rotation._cu2ho,rotation_conversion.cu2ho)]) + @pytest.mark.parametrize('vectorized, single',[(Rotation._cu2ho,cu2ho)]) def test_cubochoric_vectorization(self,default,vectorized,single): cu = np.array([rot.as_cubochoric() for rot in default]) vectorized(cu.reshape(cu.shape[0]//2,-1,3)) From bb419d49dfc81bb70a0a5c42a95ef587a9378461 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 20 May 2020 16:19:12 +0200 Subject: [PATCH 068/136] polishing --- python/damask/_rotation.py | 3 +- python/tests/test_Rotation.py | 198 +++++++++++++++++++--------------- 2 files changed, 114 insertions(+), 87 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index cf6eaed34..4081f2844 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -9,7 +9,6 @@ _sc = np.pi**(1./6.)/6.**(1./6.) _beta = np.pi**(5./6.)/6.**(1./6.)/2. _R1 = (3.*np.pi/4.)**(1./3.) - class Rotation: u""" Orientation stored with functionality for conversion to different representations. @@ -427,7 +426,7 @@ class Rotation: if P > 0: ho *= -1 # convert from P=1 to P=-1 - if np.any(np.linalg.norm(ho,axis=-1) > (3.*np.pi/4.)**(1./3.)+1e-9): + if np.any(np.linalg.norm(ho,axis=-1) >_R1+1e-9): raise ValueError('Homochoric coordinate outside of the sphere.') return Rotation(Rotation._ho2qu(ho)) diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index 92f39b4fb..f424fd9ab 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -520,6 +520,7 @@ class TestRotation: (Rotation._qu2ho,Rotation._ho2qu), (Rotation._qu2cu,Rotation._cu2qu)]) def test_quaternion_internal(self,default,forward,backward): + """Ensure invariance of conversion from quaternion and back.""" for rot in default: m = rot.as_quaternion() o = backward(forward(m)) @@ -536,6 +537,7 @@ class TestRotation: (Rotation._om2ho,Rotation._ho2om), (Rotation._om2cu,Rotation._cu2om)]) def test_matrix_internal(self,default,forward,backward): + """Ensure invariance of conversion from rotation matrix and back.""" for rot in default: m = rot.as_matrix() o = backward(forward(m)) @@ -550,6 +552,7 @@ class TestRotation: (Rotation._eu2ho,Rotation._ho2eu), (Rotation._eu2cu,Rotation._cu2eu)]) def test_Eulers_internal(self,default,forward,backward): + """Ensure invariance of conversion from Euler angles and back.""" for rot in default: m = rot.as_Eulers() o = backward(forward(m)) @@ -569,6 +572,7 @@ class TestRotation: (Rotation._ax2ho,Rotation._ho2ax), (Rotation._ax2cu,Rotation._cu2ax)]) def test_axis_angle_internal(self,default,forward,backward): + """Ensure invariance of conversion from axis angle angles pair and back.""" for rot in default: m = rot.as_axis_angle() o = backward(forward(m)) @@ -585,6 +589,7 @@ class TestRotation: (Rotation._ro2ho,Rotation._ho2ro), (Rotation._ro2cu,Rotation._cu2ro)]) def test_Rodrigues_internal(self,default,forward,backward): + """Ensure invariance of conversion from Rodrigues-Frank vector and back.""" cutoff = np.tan(np.pi*.5*(1.-1e-4)) for rot in default: m = rot.as_Rodrigues() @@ -601,12 +606,114 @@ class TestRotation: (Rotation._ho2ro,Rotation._ro2ho), (Rotation._ho2cu,Rotation._cu2ho)]) def test_homochoric_internal(self,default,forward,backward): + """Ensure invariance of conversion from homochoric vector and back.""" for rot in default: m = rot.as_homochoric() o = backward(forward(m)) ok = np.allclose(m,o,atol=atol) print(m,o,rot.as_quaternion()) - assert ok and np.linalg.norm(o) < (3.*np.pi/4.)**(1./3.) + 1.e-9 + assert ok and np.linalg.norm(o) < _R1 + 1.e-9 + + @pytest.mark.parametrize('forward,backward',[(Rotation._cu2qu,Rotation._qu2cu), + (Rotation._cu2om,Rotation._om2cu), + #(Rotation._cu2eu,Rotation._eu2cu), + (Rotation._cu2ax,Rotation._ax2cu), + (Rotation._cu2ro,Rotation._ro2cu), + (Rotation._cu2ho,Rotation._ho2cu)]) + def test_cubochoric_internal(self,default,forward,backward): + """Ensure invariance of conversion from cubochoric vector and back.""" + for rot in default: + m = rot.as_cubochoric() + o = backward(forward(m)) + ok = np.allclose(m,o,atol=atol) + print(m,o,rot.as_quaternion()) + assert ok and np.max(np.abs(o)) < np.pi**(2./3.) * 0.5 + 1.e-9 + + @pytest.mark.parametrize('vectorized, single',[(Rotation._qu2om,qu2om), + (Rotation._qu2eu,qu2eu), + (Rotation._qu2ax,qu2ax), + (Rotation._qu2ro,qu2ro), + (Rotation._qu2ho,qu2ho)]) + def test_quaternion_vectorization(self,default,vectorized,single): + """Check vectorized implementation for quaternion against single point calculation.""" + qu = np.array([rot.as_quaternion() for rot in default]) + vectorized(qu.reshape(qu.shape[0]//2,-1,4)) + co = vectorized(qu) + for q,c in zip(qu,co): + print(q,c) + assert np.allclose(single(q),c) and np.allclose(single(q),vectorized(q)) + + + @pytest.mark.parametrize('vectorized, single',[(Rotation._om2qu,om2qu), + (Rotation._om2eu,om2eu), + (Rotation._om2ax,om2ax)]) + def test_matrix_vectorization(self,default,vectorized,single): + """Check vectorized implementation for rotation matrix against single point calculation.""" + om = np.array([rot.as_matrix() for rot in default]) + vectorized(om.reshape(om.shape[0]//2,-1,3,3)) + co = vectorized(om) + for o,c in zip(om,co): + print(o,c) + assert np.allclose(single(o),c) and np.allclose(single(o),vectorized(o)) + + @pytest.mark.parametrize('vectorized, single',[(Rotation._eu2qu,eu2qu), + (Rotation._eu2om,eu2om), + (Rotation._eu2ax,eu2ax), + (Rotation._eu2ro,eu2ro)]) + def test_Eulers_vectorization(self,default,vectorized,single): + """Check vectorized implementation for Euler angles against single point calculation.""" + eu = np.array([rot.as_Eulers() for rot in default]) + vectorized(eu.reshape(eu.shape[0]//2,-1,3)) + co = vectorized(eu) + for e,c in zip(eu,co): + print(e,c) + assert np.allclose(single(e),c) and np.allclose(single(e),vectorized(e)) + + @pytest.mark.parametrize('vectorized, single',[(Rotation._ax2qu,ax2qu), + (Rotation._ax2om,ax2om), + (Rotation._ax2ro,ax2ro), + (Rotation._ax2ho,ax2ho)]) + def test_axis_angle_vectorization(self,default,vectorized,single): + """Check vectorized implementation for axis angle pair against single point calculation.""" + ax = np.array([rot.as_axis_angle() for rot in default]) + vectorized(ax.reshape(ax.shape[0]//2,-1,4)) + co = vectorized(ax) + for a,c in zip(ax,co): + print(a,c) + assert np.allclose(single(a),c) and np.allclose(single(a),vectorized(a)) + + + @pytest.mark.parametrize('vectorized, single',[(Rotation._ro2ax,ro2ax), + (Rotation._ro2ho,ro2ho)]) + def test_Rodrigues_vectorization(self,default,vectorized,single): + """Check vectorized implementation for Rodrigues-Frank vector against single point calculation.""" + ro = np.array([rot.as_Rodrigues() for rot in default]) + vectorized(ro.reshape(ro.shape[0]//2,-1,4)) + co = vectorized(ro) + for r,c in zip(ro,co): + print(r,c) + assert np.allclose(single(r),c) and np.allclose(single(r),vectorized(r)) + + @pytest.mark.parametrize('vectorized, single',[(Rotation._ho2ax,ho2ax), + (Rotation._ho2cu,ho2cu)]) + def test_homochoric_vectorization(self,default,vectorized,single): + """Check vectorized implementation for homochoric vector against single point calculation.""" + ho = np.array([rot.as_homochoric() for rot in default]) + vectorized(ho.reshape(ho.shape[0]//2,-1,3)) + co = vectorized(ho) + for h,c in zip(ho,co): + print(h,c) + assert np.allclose(single(h),c) and np.allclose(single(h),vectorized(h)) + + @pytest.mark.parametrize('vectorized, single',[(Rotation._cu2ho,cu2ho)]) + def test_cubochoric_vectorization(self,default,vectorized,single): + """Check vectorized implementation for cubochoric vector against single point calculation.""" + cu = np.array([rot.as_cubochoric() for rot in default]) + vectorized(cu.reshape(cu.shape[0]//2,-1,3)) + co = vectorized(cu) + for u,c in zip(cu,co): + print(u,c) + assert np.allclose(single(u),c) and np.allclose(single(u),vectorized(u)) @pytest.mark.parametrize('degrees',[True,False]) def test_Eulers(self,default,degrees): @@ -622,7 +729,7 @@ class TestRotation: @pytest.mark.parametrize('P',[1,-1]) @pytest.mark.parametrize('normalise',[True,False]) @pytest.mark.parametrize('degrees',[True,False]) - def test_AxisAngle(self,default,degrees,normalise,P): + def test_axis_angle(self,default,degrees,normalise,P): c = np.array([P*-1,P*-1,P*-1,1.]) for rot in default: m = rot.as_Eulers() @@ -636,7 +743,7 @@ class TestRotation: print(m,o,rot.as_quaternion()) assert ok and (np.zeros(3)-1.e-9 <= o).all() and (o <= np.array([np.pi*2.,np.pi,np.pi*2.])+1.e-9).all() - def test_Matrix(self,default): + def test_matrix(self,default): for rot in default: m = rot.as_axis_angle() o = Rotation.from_axis_angle(rot.as_axis_angle()).as_axis_angle() @@ -658,7 +765,7 @@ class TestRotation: assert ok and np.isclose(np.linalg.det(o),1.0) @pytest.mark.parametrize('P',[1,-1]) - def test_Homochoric(self,default,P): + def test_homochoric(self,default,P): cutoff = np.tan(np.pi*.5*(1.-1e-4)) for rot in default: m = rot.as_Rodrigues() @@ -669,7 +776,7 @@ class TestRotation: assert ok and np.isclose(np.linalg.norm(o[:3]),1.0) @pytest.mark.parametrize('P',[1,-1]) - def test_Cubochoric(self,default,P): + def test_cubochoric(self,default,P): for rot in default: m = rot.as_homochoric() o = Rotation.from_cubochoric(rot.as_cubochoric()*P*-1,P).as_homochoric() @@ -678,7 +785,7 @@ class TestRotation: assert ok and np.linalg.norm(o) < (3.*np.pi/4.)**(1./3.) + 1.e-9 @pytest.mark.parametrize('P',[1,-1]) - def test_Quaternion(self,default,P): + def test_quaternion(self,default,P): c = np.array([1,P*-1,P*-1,P*-1]) for rot in default: m = rot.as_cubochoric() @@ -711,85 +818,6 @@ class TestRotation: with pytest.raises(ValueError): function(invalid) - @pytest.mark.parametrize('vectorized, single',[(Rotation._qu2om,qu2om), - (Rotation._qu2eu,qu2eu), - (Rotation._qu2ax,qu2ax), - (Rotation._qu2ro,qu2ro), - (Rotation._qu2ho,qu2ho)]) - def test_quaternion_vectorization(self,default,vectorized,single): - qu = np.array([rot.as_quaternion() for rot in default]) - vectorized(qu.reshape(qu.shape[0]//2,-1,4)) - co = vectorized(qu) - for q,c in zip(qu,co): - print(q,c) - assert np.allclose(single(q),c) and np.allclose(single(q),vectorized(q)) - - - @pytest.mark.parametrize('vectorized, single',[(Rotation._om2qu,om2qu), - (Rotation._om2eu,om2eu), - (Rotation._om2ax,om2ax)]) - def test_matrix_vectorization(self,default,vectorized,single): - om = np.array([rot.as_matrix() for rot in default]) - vectorized(om.reshape(om.shape[0]//2,-1,3,3)) - co = vectorized(om) - for o,c in zip(om,co): - print(o,c) - assert np.allclose(single(o),c) and np.allclose(single(o),vectorized(o)) - - @pytest.mark.parametrize('vectorized, single',[(Rotation._eu2qu,eu2qu), - (Rotation._eu2om,eu2om), - (Rotation._eu2ax,eu2ax), - (Rotation._eu2ro,eu2ro)]) - def test_Euler_vectorization(self,default,vectorized,single): - eu = np.array([rot.as_Eulers() for rot in default]) - vectorized(eu.reshape(eu.shape[0]//2,-1,3)) - co = vectorized(eu) - for e,c in zip(eu,co): - print(e,c) - assert np.allclose(single(e),c) and np.allclose(single(e),vectorized(e)) - - @pytest.mark.parametrize('vectorized, single',[(Rotation._ax2qu,ax2qu), - (Rotation._ax2om,ax2om), - (Rotation._ax2ro,ax2ro), - (Rotation._ax2ho,ax2ho)]) - def test_axisAngle_vectorization(self,default,vectorized,single): - ax = np.array([rot.as_axis_angle() for rot in default]) - vectorized(ax.reshape(ax.shape[0]//2,-1,4)) - co = vectorized(ax) - for a,c in zip(ax,co): - print(a,c) - assert np.allclose(single(a),c) and np.allclose(single(a),vectorized(a)) - - - @pytest.mark.parametrize('vectorized, single',[(Rotation._ro2ax,ro2ax), - (Rotation._ro2ho,ro2ho)]) - def test_Rodrigues_vectorization(self,default,vectorized,single): - ro = np.array([rot.as_Rodrigues() for rot in default]) - vectorized(ro.reshape(ro.shape[0]//2,-1,4)) - co = vectorized(ro) - for r,c in zip(ro,co): - print(r,c) - assert np.allclose(single(r),c) and np.allclose(single(r),vectorized(r)) - - @pytest.mark.parametrize('vectorized, single',[(Rotation._ho2ax,ho2ax), - (Rotation._ho2cu,ho2cu)]) - def test_homochoric_vectorization(self,default,vectorized,single): - ho = np.array([rot.as_homochoric() for rot in default]) - vectorized(ho.reshape(ho.shape[0]//2,-1,3)) - co = vectorized(ho) - for h,c in zip(ho,co): - print(h,c) - assert np.allclose(single(h),c) and np.allclose(single(h),vectorized(h)) - - @pytest.mark.parametrize('vectorized, single',[(Rotation._cu2ho,cu2ho)]) - def test_cubochoric_vectorization(self,default,vectorized,single): - cu = np.array([rot.as_cubochoric() for rot in default]) - vectorized(cu.reshape(cu.shape[0]//2,-1,3)) - co = vectorized(cu) - for u,c in zip(cu,co): - print(u,c) - assert np.allclose(single(u),c) and np.allclose(single(u),vectorized(u)) - @pytest.mark.parametrize('direction',['forward', 'backward']) def test_pyramid_vectorization(self,direction): From 128a96e7f6f44c5ff6dafa26ba7536b055dad3f9 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 20 May 2020 18:13:51 +0200 Subject: [PATCH 069/136] vectorized formula is enough --- python/damask/_rotation.py | 47 +++----------------------------------- 1 file changed, 3 insertions(+), 44 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 4081f2844..3f0cc7107 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -77,9 +77,9 @@ class Rotation: ]) - def __mul__(self, other): + def __matmul__(self, other): """ - Multiplication. + Rotation of vector, second or fourth order tensor, or rotation object. Parameters ---------- @@ -89,47 +89,6 @@ class Rotation: Todo ---- Document details active/passive) - consider rotation of (3,3,3,3)-matrix - - """ - if self.quaternion.shape != (4,): - raise NotImplementedError('Support for multiple rotations missing') - if isinstance(other, Rotation): - self_q = self.quaternion[0] - self_p = self.quaternion[1:] - other_q = other.quaternion[0] - other_p = other.quaternion[1:] - R = self.__class__(np.append(self_q*other_q - np.dot(self_p,other_p), - self_q*other_p + other_q*self_p + _P * np.cross(self_p,other_p))) - return R.standardize() - elif isinstance(other, np.ndarray): - if other.shape == (3,): - A = self.quaternion[0]**2.0 - np.dot(self.quaternion[1:],self.quaternion[1:]) - B = 2.0 * np.dot(self.quaternion[1:],other) - C = 2.0 * _P*self.quaternion[0] - - return A*other + B*self.quaternion[1:] + C * np.cross(self.quaternion[1:],other) - - elif other.shape == (3,3,): - R = self.as_matrix() - return np.dot(R,np.dot(other,R.T)) - elif other.shape == (3,3,3,3,): - R = self.as_matrix() - RR = np.outer(R, R) - RRRR = np.outer(RR, RR).reshape(4 * (3,3)) - axes = ((0, 2, 4, 6), (0, 1, 2, 3)) - return np.tensordot(RRRR, other, axes) - else: - raise ValueError('Can only rotate vectors, 2nd order ternsors, and 4th order tensors') - else: - raise TypeError('Cannot rotate {}'.format(type(other))) - - - def __matmul__(self, other): - """ - Rotation. - - details to be discussed """ if isinstance(other, Rotation): q_m = self.quaternion[...,0:1] @@ -505,7 +464,7 @@ class Rotation: fromEulers = from_Eulers asAxisAngle = as_axis_angle asRodrigues = as_Rodrigues - + __mul__ = __matmul__ #################################################################################################### # Code below available according to the following conditions on https://github.com/MarDiehl/3Drotations From 353fd3ceb602f52c027b4b9359dac24dcca761f3 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 20 May 2020 19:10:16 +0200 Subject: [PATCH 070/136] more tests now 95% test coverage of Rotation class --- python/damask/_rotation.py | 3 +- python/tests/test_Rotation.py | 85 ++++++++++++++++++++++++++++++++--- 2 files changed, 81 insertions(+), 7 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 3f0cc7107..cac0cec3e 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -88,7 +88,8 @@ class Rotation: Todo ---- - Document details active/passive) + Check rotation of 4th order tensor + """ if isinstance(other, Rotation): q_m = self.quaternion[...,0:1] diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index f424fd9ab..a9768afb8 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -510,6 +510,54 @@ def _get_pyramid_order(xyz,direction=None): #################################################################################################### #################################################################################################### +def mul(me, other): + """ + Multiplication. + + Parameters + ---------- + other : numpy.ndarray or Rotation + Vector, second or fourth order tensor, or rotation object that is rotated. + + Todo + ---- + Document details active/passive) + consider rotation of (3,3,3,3)-matrix + + """ + if me.quaternion.shape != (4,): + raise NotImplementedError('Support for multiple rotations missing') + if isinstance(other, Rotation): + me_q = me.quaternion[0] + me_p = me.quaternion[1:] + other_q = other.quaternion[0] + other_p = other.quaternion[1:] + R = me.__class__(np.append(me_q*other_q - np.dot(me_p,other_p), + me_q*other_p + other_q*me_p + _P * np.cross(me_p,other_p))) + return R.standardize() + elif isinstance(other, np.ndarray): + if other.shape == (3,): + A = me.quaternion[0]**2.0 - np.dot(me.quaternion[1:],me.quaternion[1:]) + B = 2.0 * np.dot(me.quaternion[1:],other) + C = 2.0 * _P*me.quaternion[0] + + return A*other + B*me.quaternion[1:] + C * np.cross(me.quaternion[1:],other) + + elif other.shape == (3,3,): + R = me.as_matrix() + return np.dot(R,np.dot(other,R.T)) + elif other.shape == (3,3,3,3,): + R = me.as_matrix() + return np.einsum('ia,jb,kc,ld,abcd->ijkl',R,R,R,R,other) + RR = np.outer(R, R) + RRRR = np.outer(RR, RR).reshape(4 * (3,3)) + axes = ((0, 2, 4, 6), (0, 1, 2, 3)) + return np.tensordot(RRRR, other, axes) + else: + raise ValueError('Can only rotate vectors, 2nd order ternsors, and 4th order tensors') + else: + raise TypeError('Cannot rotate {}'.format(type(other))) + class TestRotation: @@ -616,7 +664,7 @@ class TestRotation: @pytest.mark.parametrize('forward,backward',[(Rotation._cu2qu,Rotation._qu2cu), (Rotation._cu2om,Rotation._om2cu), - #(Rotation._cu2eu,Rotation._eu2cu), + (Rotation._cu2eu,Rotation._eu2cu), (Rotation._cu2ax,Rotation._ax2cu), (Rotation._cu2ro,Rotation._ro2cu), (Rotation._cu2ho,Rotation._ho2cu)]) @@ -626,6 +674,8 @@ class TestRotation: m = rot.as_cubochoric() o = backward(forward(m)) ok = np.allclose(m,o,atol=atol) + if np.count_nonzero(np.isclose(np.abs(o),np.pi**(2./3.)*.5)): + ok = ok or np.allclose(m*-1.,o,atol=atol) print(m,o,rot.as_quaternion()) assert ok and np.max(np.abs(o)) < np.pi**(2./3.) * 0.5 + 1.e-9 @@ -785,21 +835,32 @@ class TestRotation: assert ok and np.linalg.norm(o) < (3.*np.pi/4.)**(1./3.) + 1.e-9 @pytest.mark.parametrize('P',[1,-1]) - def test_quaternion(self,default,P): - c = np.array([1,P*-1,P*-1,P*-1]) + @pytest.mark.parametrize('accept_homomorph',[True,False]) + def test_quaternion(self,default,P,accept_homomorph): + c = np.array([1,P*-1,P*-1,P*-1]) * (-1 if accept_homomorph else 1) for rot in default: m = rot.as_cubochoric() - o = Rotation.from_quaternion(rot.as_quaternion()*c,False,P).as_cubochoric() + o = Rotation.from_quaternion(rot.as_quaternion()*c,accept_homomorph,P).as_cubochoric() ok = np.allclose(m,o,atol=atol) + if np.count_nonzero(np.isclose(np.abs(o),np.pi**(2./3.)*.5)): + ok = ok or np.allclose(m*-1.,o,atol=atol) print(m,o,rot.as_quaternion()) assert ok and o.max() < np.pi**(2./3.)*0.5+1.e-9 + @pytest.mark.parametrize('reciprocal',[True,False]) + def test_basis(self,default,reciprocal): + for rot in default: + om = rot.as_matrix() + 0.1*np.eye(3) + rot = Rotation.from_basis(om,False,reciprocal=reciprocal) + assert np.isclose(np.linalg.det(rot.as_matrix()),1.0) + @pytest.mark.parametrize('function',[Rotation.from_quaternion, Rotation.from_Eulers, Rotation.from_axis_angle, Rotation.from_matrix, Rotation.from_Rodrigues, - Rotation.from_homochoric]) + Rotation.from_homochoric, + Rotation.from_cubochoric]) def test_invalid_shape(self,function): invalid_shape = np.random.random(np.random.randint(8,32,(3))) with pytest.raises(ValueError): @@ -813,7 +874,8 @@ class TestRotation: (Rotation.from_matrix, np.random.rand(3,3)), (Rotation.from_Rodrigues, np.array([1,0,0,-1])), (Rotation.from_Rodrigues, np.array([1,1,0,1])), - (Rotation.from_homochoric, np.array([2,2,2])) ]) + (Rotation.from_homochoric, np.array([2,2,2])), + (Rotation.from_cubochoric, np.array([1.1,0,0])) ]) def test_invalid_value(self,function,invalid): with pytest.raises(ValueError): function(invalid) @@ -833,6 +895,17 @@ class TestRotation: assert np.all(np.take_along_axis(np.take_along_axis(a,f,-1),b,-1) == a) + @pytest.mark.parametrize('data',[np.random.rand(5,3), + np.random.rand(5,3,3), + np.random.rand(5,3,3,3,3)]) + def test_rotate_vectorization(self,default,data): + for rot in default: + v = rot.broadcast_to((5,)) @ data + for i in range(data.shape[0]): + print(i-data[i]) + assert np.allclose(mul(rot,data[i]),v[i]) + + @pytest.mark.parametrize('data',[np.random.rand(3), np.random.rand(3,3), np.random.rand(3,3,3,3)]) From 16f30a10d0f85bdd277b372f2cfbee47e69d3e2a Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 20 May 2020 23:50:08 +0200 Subject: [PATCH 071/136] polishing --- python/damask/_orientation.py | 8 ++++---- python/damask/_rotation.py | 3 +-- 2 files changed, 5 insertions(+), 6 deletions(-) diff --git a/python/damask/_orientation.py b/python/damask/_orientation.py index c145dc42b..7c3c614fb 100644 --- a/python/damask/_orientation.py +++ b/python/damask/_orientation.py @@ -65,8 +65,8 @@ class Orientation: r = b*aInv for k in range(2): r.inverse() - breaker = self.lattice.symmetry.inFZ(r.asRodrigues(vector=True)) \ - and (not SST or other.lattice.symmetry.inDisorientationSST(r.asRodrigues(vector=True))) + breaker = self.lattice.symmetry.inFZ(r.as_Rodrigues(vector=True)) \ + and (not SST or other.lattice.symmetry.inDisorientationSST(r.as_Rodrigues(vector=True))) if breaker: break if breaker: break if breaker: break @@ -75,7 +75,7 @@ class Orientation: # ... own sym, other sym, # self-->other: True, self<--other: False def inFZ(self): - return self.lattice.symmetry.inFZ(self.rotation.asRodrigues(vector=True)) + return self.lattice.symmetry.inFZ(self.rotation.as_Rodrigues(vector=True)) def equivalentOrientations(self,members=[]): @@ -97,7 +97,7 @@ class Orientation: def reduced(self): """Transform orientation to fall into fundamental zone according to symmetry.""" for me in self.equivalentOrientations(): - if self.lattice.symmetry.inFZ(me.rotation.asRodrigues(vector=True)): break + if self.lattice.symmetry.inFZ(me.rotation.as_Rodrigues(vector=True)): break return self.__class__(me.rotation,self.lattice) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index cac0cec3e..387ee84cb 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -119,7 +119,7 @@ class Rotation: R = self.as_matrix() return np.einsum('...im,...jn,...ko,...lp,...mnop',R,R,R,R,other) else: - raise ValueError('Can only rotate vectors, 2nd order ternsors, and 4th order tensors') + raise ValueError('Can only rotate vectors, 2nd order tensors, and 4th order tensors') else: raise TypeError('Cannot rotate {}'.format(type(other))) @@ -464,7 +464,6 @@ class Rotation: fromQuaternion = from_quaternion fromEulers = from_Eulers asAxisAngle = as_axis_angle - asRodrigues = as_Rodrigues __mul__ = __matmul__ #################################################################################################### From 23b1381eaf3117fc5924bf9c12e3860404494272 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Thu, 21 May 2020 10:45:52 +0200 Subject: [PATCH 072/136] give credit --- python/damask/_result.py | 2 +- src/results.f90 | 2 +- src/rotations.f90 | 4 ++++ 3 files changed, 6 insertions(+), 2 deletions(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index 9993e90bd..5a22c7977 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -123,7 +123,7 @@ class Result: """ # allow True/False and string arguments - if datasets is True: + if datasets is True: datasets = ['*'] elif datasets is False: datasets = [] diff --git a/src/results.f90 b/src/results.f90 index cee6aedd9..b5410f5f4 100644 --- a/src/results.f90 +++ b/src/results.f90 @@ -65,7 +65,7 @@ subroutine results_init(restart) character(len=pStringLen) :: commandLine - write(6,'(/,a)') ' <<<+- results init -+>>>' + write(6,'(/,a)') ' <<<+- results init -+>>>'; flush(6) write(6,'(/,a)') ' Diehl et al., Integrating Materials and Manufacturing Innovation 6(1):83–91, 2017' write(6,'(a)') ' https://doi.org/10.1007/s40192-017-0084-5' diff --git a/src/rotations.f90 b/src/rotations.f90 index 42afb48e9..f95c54e98 100644 --- a/src/rotations.f90 +++ b/src/rotations.f90 @@ -105,6 +105,10 @@ subroutine rotations_init call quaternions_init write(6,'(/,a)') ' <<<+- rotations init -+>>>'; flush(6) + + write(6,'(/,a)') ' Rowenhorst et al., Modelling and Simulation in Materials Science and Engineering 23:083501, 2015' + write(6,'(a)') ' https://doi.org/10.1088/0965-0393/23/8/083501' + call selfTest end subroutine rotations_init From 7aecc37219dee51cc026dc4f57110a6788a3c908 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Thu, 21 May 2020 15:42:05 +0200 Subject: [PATCH 073/136] using ordering as in DAMASK autogenerated by a small script from lattice.f90 --- processing/post/addSchmidfactors.py | 153 +++++++++++++--------------- 1 file changed, 72 insertions(+), 81 deletions(-) diff --git a/processing/post/addSchmidfactors.py b/processing/post/addSchmidfactors.py index b3c4c7500..9b694e3a1 100755 --- a/processing/post/addSchmidfactors.py +++ b/processing/post/addSchmidfactors.py @@ -15,91 +15,82 @@ scriptID = ' '.join([scriptName,damask.version]) slipSystems = { 'fcc': np.array([ - # Slip direction Plane normal - [ 0, 1,-1, 1, 1, 1, ], - [-1, 0, 1, 1, 1, 1, ], - [ 1,-1, 0, 1, 1, 1, ], - [ 0,-1,-1, -1,-1, 1, ], - [ 1, 0, 1, -1,-1, 1, ], - [-1, 1, 0, -1,-1, 1, ], - [ 0,-1, 1, 1,-1,-1, ], - [-1, 0,-1, 1,-1,-1, ], - [ 1, 1, 0, 1,-1,-1, ], - [ 0, 1, 1, -1, 1,-1, ], - [ 1, 0,-1, -1, 1,-1, ], - [-1,-1, 0, -1, 1,-1, ], - ],'f'), + [+0,+1,-1 , +1,+1,+1], + [-1,+0,+1 , +1,+1,+1], + [+1,-1,+0 , +1,+1,+1], + [+0,-1,-1 , -1,-1,+1], + [+1,+0,+1 , -1,-1,+1], + [-1,+1,+0 , -1,-1,+1], + [+0,-1,+1 , +1,-1,-1], + [-1,+0,-1 , +1,-1,-1], + [+1,+1,+0 , +1,-1,-1], + [+0,+1,+1 , -1,+1,-1], + [+1,+0,-1 , -1,+1,-1], + [-1,-1,+0 , -1,+1,-1], + ],'d'), 'bcc': np.array([ - # Slip system <111>{110} - [ 1,-1, 1, 0, 1, 1, ], - [-1,-1, 1, 0, 1, 1, ], - [ 1, 1, 1, 0,-1, 1, ], - [-1, 1, 1, 0,-1, 1, ], - [-1, 1, 1, 1, 0, 1, ], - [-1,-1, 1, 1, 0, 1, ], - [ 1, 1, 1, -1, 0, 1, ], - [ 1,-1, 1, -1, 0, 1, ], - [-1, 1, 1, 1, 1, 0, ], - [-1, 1,-1, 1, 1, 0, ], - [ 1, 1, 1, -1, 1, 0, ], - [ 1, 1,-1, -1, 1, 0, ], - # Slip system <111>{112} - [-1, 1, 1, 2, 1, 1, ], - [ 1, 1, 1, -2, 1, 1, ], - [ 1, 1,-1, 2,-1, 1, ], - [ 1,-1, 1, 2, 1,-1, ], - [ 1,-1, 1, 1, 2, 1, ], - [ 1, 1,-1, -1, 2, 1, ], - [ 1, 1, 1, 1,-2, 1, ], - [-1, 1, 1, 1, 2,-1, ], - [ 1, 1,-1, 1, 1, 2, ], - [ 1,-1, 1, -1, 1, 2, ], - [-1, 1, 1, 1,-1, 2, ], - [ 1, 1, 1, 1, 1,-2, ], - ],'f'), + [+1,-1,+1 , +0,+1,+1], + [-1,-1,+1 , +0,+1,+1], + [+1,+1,+1 , +0,-1,+1], + [-1,+1,+1 , +0,-1,+1], + [-1,+1,+1 , +1,+0,+1], + [-1,-1,+1 , +1,+0,+1], + [+1,+1,+1 , -1,+0,+1], + [+1,-1,+1 , -1,+0,+1], + [-1,+1,+1 , +1,+1,+0], + [-1,+1,-1 , +1,+1,+0], + [+1,+1,+1 , -1,+1,+0], + [+1,+1,-1 , -1,+1,+0], + [-1,+1,+1 , +2,+1,+1], + [+1,+1,+1 , -2,+1,+1], + [+1,+1,-1 , +2,-1,+1], + [+1,-1,+1 , +2,+1,-1], + [+1,-1,+1 , +1,+2,+1], + [+1,+1,-1 , -1,+2,+1], + [+1,+1,+1 , +1,-2,+1], + [-1,+1,+1 , +1,+2,-1], + [+1,+1,-1 , +1,+1,+2], + [+1,-1,+1 , -1,+1,+2], + [-1,+1,+1 , +1,-1,+2], + [+1,+1,+1 , +1,+1,-2], + ],'d'), 'hex': np.array([ - # Basal systems <11.0>{00.1} (independent of c/a-ratio, Bravais notation (4 coordinate base)) - [ 2, -1, -1, 0, 0, 0, 0, 1, ], - [-1, 2, -1, 0, 0, 0, 0, 1, ], - [-1, -1, 2, 0, 0, 0, 0, 1, ], - # 1st type prismatic systems <11.0>{10.0} (independent of c/a-ratio) - [ 2, -1, -1, 0, 0, 1, -1, 0, ], - [-1, 2, -1, 0, -1, 0, 1, 0, ], - [-1, -1, 2, 0, 1, -1, 0, 0, ], - # 2nd type prismatic systems <10.0>{11.0} -- a slip; plane normals independent of c/a-ratio - [ 0, 1, -1, 0, 2, -1, -1, 0, ], - [-1, 0, 1, 0, -1, 2, -1, 0, ], - [ 1, -1, 0, 0, -1, -1, 2, 0, ], - # 1st type 1st order pyramidal systems <11.0>{-11.1} -- plane normals depend on the c/a-ratio - [ 2, -1, -1, 0, 0, 1, -1, 1, ], - [-1, 2, -1, 0, -1, 0, 1, 1, ], - [-1, -1, 2, 0, 1, -1, 0, 1, ], - [ 1, 1, -2, 0, -1, 1, 0, 1, ], - [-2, 1, 1, 0, 0, -1, 1, 1, ], - [ 1, -2, 1, 0, 1, 0, -1, 1, ], - # pyramidal system: c+a slip <11.3>{-10.1} -- plane normals depend on the c/a-ratio - [ 2, -1, -1, 3, -1, 1, 0, 1, ], - [ 1, -2, 1, 3, -1, 1, 0, 1, ], - [-1, -1, 2, 3, 1, 0, -1, 1, ], - [-2, 1, 1, 3, 1, 0, -1, 1, ], - [-1, 2, -1, 3, 0, -1, 1, 1, ], - [ 1, 1, -2, 3, 0, -1, 1, 1, ], - [-2, 1, 1, 3, 1, -1, 0, 1, ], - [-1, 2, -1, 3, 1, -1, 0, 1, ], - [ 1, 1, -2, 3, -1, 0, 1, 1, ], - [ 2, -1, -1, 3, -1, 0, 1, 1, ], - [ 1, -2, 1, 3, 0, 1, -1, 1, ], - [-1, -1, 2, 3, 0, 1, -1, 1, ], - # pyramidal system: c+a slip <11.3>{-1-1.2} -- as for hexagonal ice (Castelnau et al. 1996, similar to twin system found below) - [ 2, -1, -1, 3, -2, 1, 1, 2, ], # sorted according to similar twin system - [-1, 2, -1, 3, 1, -2, 1, 2, ], # <11.3>{-1-1.2} shear = 2((c/a)^2-2)/(3 c/a) - [-1, -1, 2, 3, 1, 1, -2, 2, ], - [-2, 1, 1, 3, 2, -1, -1, 2, ], - [ 1, -2, 1, 3, -1, 2, -1, 2, ], - [ 1, 1, -2, 3, -1, -1, 2, 2, ], - ],'f'), + [+2,-1,-1,+0 , +0,+0,+0,+1], + [-1,+2,-1,+0 , +0,+0,+0,+1], + [-1,-1,+2,+0 , +0,+0,+0,+1], + [+2,-1,-1,+0 , +0,+1,-1,+0], + [-1,+2,-1,+0 , -1,+0,+1,+0], + [-1,-1,+2,+0 , +1,-1,+0,+0], + [-1,+1,+0,+0 , +1,+1,-2,+0], + [+0,-1,+1,+0 , -2,+1,+1,+0], + [+1,+0,-1,+0 , +1,-2,+1,+0], + [-1,+2,-1,+0 , +1,+0,-1,+1], + [-2,+1,+1,+0 , +0,+1,-1,+1], + [-1,-1,+2,+0 , -1,+1,+0,+1], + [+1,-2,+1,+0 , -1,+0,+1,+1], + [+2,-1,-1,+0 , +0,-1,+1,+1], + [+1,+1,-2,+0 , +1,-1,+0,+1], + [-2,+1,+1,+3 , +1,+0,-1,+1], + [-1,-1,+2,+3 , +1,+0,-1,+1], + [-1,-1,+2,+3 , +0,+1,-1,+1], + [+1,-2,+1,+3 , +0,+1,-1,+1], + [+1,-2,+1,+3 , -1,+1,+0,+1], + [+2,-1,-1,+3 , -1,+1,+0,+1], + [+2,-1,-1,+3 , -1,+0,+1,+1], + [+1,+1,-2,+3 , -1,+0,+1,+1], + [+1,+1,-2,+3 , +0,-1,+1,+1], + [-1,+2,-1,+3 , +0,-1,+1,+1], + [-1,+2,-1,+3 , +1,-1,+0,+1], + [-2,+1,+1,+3 , +1,-1,+0,+1], + [-1,-1,+2,+3 , +1,+1,-2,+2], + [+1,-2,+1,+3 , -1,+2,-1,+2], + [+2,-1,-1,+3 , -2,+1,+1,+2], + [+1,+1,-2,+3 , -1,-1,+2,+2], + [-1,+2,-1,+3 , +1,-2,+1,+2], + [-2,+1,+1,+3 , +2,-1,-1,+2], + ],'d'), } # -------------------------------------------------------------------- From 06e4327c0b888abc52c17aa816c95ceb5cf73f43 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Thu, 21 May 2020 17:16:27 +0200 Subject: [PATCH 074/136] replace outdated ASCIItable class --- processing/post/addSchmidfactors.py | 128 +++++++++++----------------- 1 file changed, 52 insertions(+), 76 deletions(-) diff --git a/processing/post/addSchmidfactors.py b/processing/post/addSchmidfactors.py index 9b694e3a1..d1899e9a0 100755 --- a/processing/post/addSchmidfactors.py +++ b/processing/post/addSchmidfactors.py @@ -2,6 +2,7 @@ import os import sys +from io import StringIO from optparse import OptionParser import numpy as np @@ -102,11 +103,11 @@ Add columns listing Schmid factors (and optional trace vector of selected system """, version = scriptID) -latticeChoices = ('fcc','bcc','hex') +lattice_choices = list(slipSystems.keys()) parser.add_option('-l', '--lattice', - dest = 'lattice', type = 'choice', choices = latticeChoices, metavar='string', - help = 'type of lattice structure [%default] {}'.format(latticeChoices)) + dest = 'lattice', type = 'choice', choices = lattice_choices, metavar='string', + help = 'type of lattice structure [%default] {}'.format(lattice_choices)) parser.add_option('--covera', dest = 'CoverA', type = 'float', metavar = 'float', help = 'C over A ratio for hexagonal systems [%default]') @@ -129,88 +130,63 @@ parser.add_option('-o', parser.set_defaults(force = (0.0,0.0,1.0), quaternion='orientation', normal = None, - lattice = latticeChoices[0], + lattice = lattice_choices[0], CoverA = np.sqrt(8./3.), ) (options, filenames) = parser.parse_args() - -force = np.array(options.force) -force /= np.linalg.norm(force) - -if options.normal is not None: - normal = np.array(options.normal) - normal /= np.linalg.norm(normal) - if abs(np.dot(force,normal)) > 1e-3: - parser.error('stress plane normal not orthogonal to force direction') -else: - normal = force - -slip_direction = np.zeros((len(slipSystems[options.lattice]),3),'f') -slip_normal = np.zeros_like(slip_direction) - - -if options.lattice in latticeChoices[:2]: - slip_direction = slipSystems[options.lattice][:,:3] - slip_normal = slipSystems[options.lattice][:,3:] -elif options.lattice == latticeChoices[2]: - # convert 4 Miller index notation of hex to orthogonal 3 Miller index notation - for i in range(len(slip_direction)): - slip_direction[i] = np.array([slipSystems['hex'][i,0]*1.5, - (slipSystems['hex'][i,0] + 2.*slipSystems['hex'][i,1])*0.5*np.sqrt(3), - slipSystems['hex'][i,3]*options.CoverA, - ]) - slip_normal[i] = np.array([slipSystems['hex'][i,4], - (slipSystems['hex'][i,4] + 2.*slipSystems['hex'][i,5])/np.sqrt(3), - slipSystems['hex'][i,7]/options.CoverA, - ]) - -slip_direction /= np.tile(np.linalg.norm(slip_direction,axis=1),(3,1)).T -slip_normal /= np.tile(np.linalg.norm(slip_normal ,axis=1),(3,1)).T - -# --- loop over input files ------------------------------------------------------------------------ - if filenames == []: filenames = [None] +force = np.array(options.force)/np.linalg.norm(options.force) + +if options.normal is not None: + normal = np.array(options.normal)/np.linalg.norm(options.ormal) + if abs(np.dot(force,normal)) > 1e-3: + parser.error('stress plane normal not orthogonal to force direction') +else: + normal = force + + +if options.lattice in ['bcc','fcc']: + slip_direction = slipSystems[options.lattice][:,:3] + slip_normal = slipSystems[options.lattice][:,3:] +elif options.lattice == 'hex': + slip_direction = np.zeros((len(slipSystems['hex']),3),'d') + slip_normal = np.zeros_like(slip_direction) + # convert 4 Miller index notation of hex to orthogonal 3 Miller index notation + for i in range(len(slip_direction)): + slip_direction[i] = np.array([slipSystems['hex'][i,0]*1.5, + (slipSystems['hex'][i,0] + 2.*slipSystems['hex'][i,1])*0.5*np.sqrt(3), + slipSystems['hex'][i,3]*options.CoverA, + ]) + slip_normal[i] = np.array([slipSystems['hex'][i,4], + (slipSystems['hex'][i,4] + 2.*slipSystems['hex'][i,5])/np.sqrt(3), + slipSystems['hex'][i,7]/options.CoverA, + ]) + +slip_direction /= np.linalg.norm(slip_direction,axis=1,keepdims=True) +slip_normal /= np.linalg.norm(slip_normal, axis=1,keepdims=True) + +labels = ['S[{direction[0]:.1g}_{direction[1]:.1g}_{direction[2]:.1g}]' + '({normal[0]:.1g}_{normal[1]:.1g}_{normal[2]:.1g})'\ + .format(normal = theNormal, direction = theDirection, + ) for theNormal,theDirection in zip(slip_normal,slip_direction)] + for name in filenames: - try: - table = damask.ASCIItable(name = name) - except IOError: - continue - damask.util.report(scriptName,name) + damask.util.report(scriptName,name) -# ------------------------------------------ read header ------------------------------------------ + table = damask.Table.from_ASCII(StringIO(''.join(sys.stdin.read())) if name is None else name) - table.head_read() + o = damask.Rotation.from_quaternion(table.get(options.quaternion)) -# ------------------------------------------ sanity checks ---------------------------------------- - if not table.label_dimension(options.quaternion) == 4: - damask.util.croak('input {} does not have dimension 4.'.format(options.quaternion)) - table.close(dismiss = True) # close ASCIItable and remove empty file - continue + force = np.broadcast_to(force, o.shape+(3,)) + normal = np.broadcast_to(normal,o.shape+(3,)) + slip_direction = np.broadcast_to(slip_direction,o.shape+slip_direction.shape) + slip_normal = np.broadcast_to(slip_normal, o.shape+slip_normal.shape) + S = np.abs(np.einsum('ijk,ik->ij',slip_direction,(o@force))* + np.einsum('ijk,ik->ij',slip_normal, (o@normal))) - column = table.label_index(options.quaternion) + for i,label in enumerate(labels): + table.add(label,S[:,i],scriptID+' '+' '.join(sys.argv[1:])) -# ------------------------------------------ assemble header --------------------------------------- - - table.info_append(scriptID + '\t' + ' '.join(sys.argv[1:])) - table.labels_append(['S[{direction[0]:.1g}_{direction[1]:.1g}_{direction[2]:.1g}]' - '({normal[0]:.1g}_{normal[1]:.1g}_{normal[2]:.1g})'\ - .format(normal = theNormal, - direction = theDirection, - ) for theNormal,theDirection in zip(slip_normal,slip_direction)]) - table.head_write() - -# ------------------------------------------ process data ------------------------------------------ - - outputAlive = True - while outputAlive and table.data_read(): # read next data line of ASCII table - o = damask.Rotation(np.array(list(map(float,table.data[column:column+4])))) - - table.data_append( np.abs( np.sum(slip_direction * (o * force) ,axis=1) \ - * np.sum(slip_normal * (o * normal),axis=1))) - outputAlive = table.data_write() # output processed line - -# ------------------------------------------ output finalization ----------------------------------- - - table.close() # close ASCII tables + table.to_ASCII(sys.stdout if name is None else name) From 72fdb639f085a7a576601580c2203eee14ea7292 Mon Sep 17 00:00:00 2001 From: Sharan Roongta Date: Thu, 21 May 2020 20:41:40 +0200 Subject: [PATCH 075/136] YAML parser --- src/CPFEM.f90 | 2 + src/CPFEM2.f90 | 2 + src/YAML_parse.f90 | 631 +++++++++++++++++++++++++++++++++ src/commercialFEM_fileList.f90 | 1 + 4 files changed, 636 insertions(+) create mode 100644 src/YAML_parse.f90 diff --git a/src/CPFEM.f90 b/src/CPFEM.f90 index 48d6ae68a..7791d2b12 100644 --- a/src/CPFEM.f90 +++ b/src/CPFEM.f90 @@ -11,6 +11,7 @@ module CPFEM use math use rotations use YAML_types + use YAML_parse use discretization_marc use material use config @@ -84,6 +85,7 @@ subroutine CPFEM_initAll(el,ip) call math_init call rotations_init call YAML_types_init + call YAML_init call HDF5_utilities_init call results_init(.false.) call discretization_marc_init(ip, el) diff --git a/src/CPFEM2.f90 b/src/CPFEM2.f90 index ee27a3ca1..027c6dfad 100644 --- a/src/CPFEM2.f90 +++ b/src/CPFEM2.f90 @@ -12,6 +12,7 @@ module CPFEM2 use math use rotations use YAML_types + use YAML_parse use material use lattice use IO @@ -52,6 +53,7 @@ subroutine CPFEM_initAll call math_init call rotations_init call YAML_types_init + call YAML_init call lattice_init call HDF5_utilities_init call results_init(restart=interface_restartInc>0) diff --git a/src/YAML_parse.f90 b/src/YAML_parse.f90 new file mode 100644 index 000000000..429eb6e62 --- /dev/null +++ b/src/YAML_parse.f90 @@ -0,0 +1,631 @@ +module YAML_parse + + use prec + use IO + use YAML_types + + implicit none + private + public :: YAML_init + public :: parse_flow,to_flow + +contains + + +subroutine YAML_init + + call selfTest + +end subroutine YAML_init + +!-------------------------------------------------------------------------------------------------- +!> @brief reads the flow style string and stores it in the form of dictionaries, lists and scalars. +!> @details A node type pointer can either point to a dictionary, list or scalar type entities. +!-------------------------------------------------------------------------------------------------- +recursive function parse_flow(flow_string) result(node) + + character(len=*), intent(inout) :: flow_string + class (tNode), pointer :: node + + class (tNode), pointer :: myVal + character(len=pStringLen) :: key + + integer :: e, & !> end position of dictionary or list + s, & !> start position of dictionary or list + d !> position of key: value separator (':') + + flow_string = trim(adjustl(flow_string(:))) + if (flow_string(1:1) == '{') then ! start of a dictionary + e = 1 + allocate(tDict::node) + do while (e < len_trim(flow_string)) + s = e + d = s + scan(flow_string(s+1:),':') + e = d + find_end(flow_string(d+1:),'}') + + key = trim(adjustl(flow_string(s+1:d-1))) + myVal => parse_flow(flow_string(d+1:e-1)) ! parse items (recursively) + + select type (node) + class is (tDict) + call node%set(key,myVal) + end select + end do + + elseif (flow_string(1:1) == '[') then ! start of a list + e = 1 + allocate(tList::node) + do while (e < len_trim(flow_string)) + s = e + e = s + find_end(flow_string(s+1:),']') + myVal => parse_flow(flow_string(s+1:e-1)) ! parse items (recursively) + + select type (node) + class is (tList) + call node%append(myVal) + end select + end do + + else ! scalar value + allocate(tScalar::node) + select type (node) + class is (tScalar) + node = trim(adjustl(flow_string)) + end select + endif + +end function parse_flow + + +!-------------------------------------------------------------------------------------------------- +!> @brief finds location of chunk end: ',' or '}' or ']' +!> @details leaves nested lists ( '[...]' and dicts '{...}') intact +!-------------------------------------------------------------------------------------------------- +integer function find_end(str,e_char) + + character(len=*), intent(in) :: str + character, intent(in) :: e_char !< end of list/dict ( '}' or ']') + + integer :: N_sq, & !< number of open square brackets + N_cu, & !< number of open curly brackets + i + + N_sq = 0 + N_cu = 0 + do i = 1, len_trim(str) + if (N_sq==0 .and. N_cu==0 .and. scan(str(i:i),e_char//',') == 1) exit + N_sq = N_sq + merge(1,0,str(i:i) == '[') + N_cu = N_cu + merge(1,0,str(i:i) == '{') + N_sq = N_sq - merge(1,0,str(i:i) == ']') + N_cu = N_cu - merge(1,0,str(i:i) == '}') + enddo + find_end = i + +end function find_end + + +!-------------------------------------------------------------------------------------------------- +! @brief Returns Indentation. +! @details It determines the indentation level for a given block/line. +! In cases for nested lists, an offset is added to determine the indent of the item block (skip +! leading dashes) +!-------------------------------------------------------------------------------------------------- +integer function indentDepth(line,offset) + + character(len=*), intent(in) :: line + integer, optional,intent(in) :: offset + + indentDepth = verify(line,IO_WHITESPACE) -1 + if(present(offset)) indentDepth = indentDepth + offset + +end function indentDepth + + +!-------------------------------------------------------------------------------------------------- +! @brief check whether a string is in flow style, i.e. starts with '{' or '[' +!-------------------------------------------------------------------------------------------------- +logical function isFlow(line) + + character(len=*), intent(in) :: line + + isFlow = index(adjustl(line),'[') == 1 .or. index(adjustl(line),'{') == 1 + +end function isFlow + + +!-------------------------------------------------------------------------------------------------- +! @brief check whether a string is a scalar item, i.e. starts without any special symbols +!-------------------------------------------------------------------------------------------------- +logical function isScalar(line) + + character(len=*), intent(in) :: line + + isScalar = (.not.isKeyValue(line) .and. .not.isKey(line) .and. .not.isListItem(line) & + .and. .not.isFlow(line)) + +end function isScalar + + +!-------------------------------------------------------------------------------------------------- +! @brief check whether a string is a list item, i.e. starts with '-' +!-------------------------------------------------------------------------------------------------- +logical function isListItem(line) + + character(len=*), intent(in) :: line + + isListItem = index(adjustl(line),'-') == 1 + +end function isListItem + + +!-------------------------------------------------------------------------------------------------- +! @brief check whether a string contains a key value pair of the for ': ' +!-------------------------------------------------------------------------------------------------- +logical function isKeyValue(line) + + character(len=*), intent(in) :: line + isKeyValue = .false. + + if( .not. isKey(line) .and. index(IO_rmComment(line),':') > 0 .and. .not. isFlow(line)) then + if(index(IO_rmComment(line),': ') > 0) then + isKeyValue = .true. + else + call IO_error(704,ext_msg=line) + endif + endif + +end function isKeyValue + + +!-------------------------------------------------------------------------------------------------- +! @brief check whether a string contains a key without a value, i.e. it ends with ':' +! ToDo: check whether this is safe for trailing spaces followed by a new line character +!-------------------------------------------------------------------------------------------------- +logical function isKey(line) + + character(len=*), intent(in) :: line + + if(len(IO_rmComment(line)) == 0) then + isKey = .false. + else + isKey = IO_rmComment(line(len(IO_rmComment(line)):len(IO_rmComment(line)))) == ':' .and. .not. isFlow(line) + endif + +end function isKey + + +!-------------------------------------------------------------------------------------------------- +! @brief reads a line of YAML block which is already in flow style +! @details Dicts should be enlcosed within '{}' for it to be consistent with DAMASK YAML parser +!-------------------------------------------------------------------------------------------------- +recursive subroutine line_isFlow(flow,s_flow,line) + + character(len=*), intent(inout) :: flow !< YAML in flow style only + integer, intent(inout) :: s_flow !< start position in flow + character(len=*), intent(in) :: line + + integer :: & + s, & + list_chunk, & + dict_chunk + + if(index(adjustl(line),'[') == 1) then + s = index(line,'[') + flow(s_flow:s_flow) = '[' + s_flow = s_flow +1 + do while(s < len_trim(line)) + list_chunk = s + find_end(line(s+1:),']') + if(iskeyValue(line(s+1:list_chunk-1))) then + flow(s_flow:s_flow) = '{' + s_flow = s_flow +1 + call keyValue_toFlow(flow,s_flow,line(s+1:list_chunk-1)) + flow(s_flow:s_flow) = '}' + s_flow = s_flow +1 + elseif(isFlow(line(s+1:list_chunk-1))) then + call line_isFlow(flow,s_flow,line(s+1:list_chunk-1)) + else + call line_toFlow(flow,s_flow,line(s+1:list_chunk-1)) + endif + flow(s_flow:s_flow+1) = ', ' + s_flow = s_flow +2 + s = s + find_end(line(s+1:),']') + enddo + s_flow = s_flow - 1 + if (flow(s_flow-1:s_flow-1) == ',') s_flow = s_flow - 1 + flow(s_flow:s_flow) = ']' + s_flow = s_flow+1 + + elseif(index(adjustl(line),'{') == 1) then + s = index(line,'{') + flow(s_flow:s_flow) = '{' + s_flow = s_flow +1 + do while(s < len_trim(line)) + dict_chunk = s + find_end(line(s+1:),'}') + if( .not. iskeyValue(line(s+1:dict_chunk-1))) call IO_error(705,ext_msg=line) + call keyValue_toFlow(flow,s_flow,line(s+1:dict_chunk-1)) + flow(s_flow:s_flow+1) = ', ' + s_flow = s_flow +2 + s = s + find_end(line(s+1:),'}') + enddo + s_flow = s_flow -1 + if(flow(s_flow-1:s_flow-1) == ',') s_flow = s_flow -1 + flow(s_flow:s_flow) = '}' + s_flow = s_flow +1 + else + call line_toFlow(flow,s_flow,line) + endif + +end subroutine line_isFlow + + +!------------------------------------------------------------------------------------------------- +! @brief reads a line of YAML block of type : and places it in the YAML flow style structure +! @details Makes sure that the is consistent with the input required in DAMASK YAML parser +!------------------------------------------------------------------------------------------------- +recursive subroutine keyValue_toFlow(flow,s_flow,line) + + character(len=*), intent(inout) :: flow !< YAML in flow style only + integer, intent(inout) :: s_flow !< start position in flow + character(len=*), intent(in) :: line + + character(len=:), allocatable :: line_asStandard ! standard form of : + integer :: & + d_flow, & + col_pos, & + offset_value + + col_pos = index(line,':') + if(isFlow(line(col_pos+1:))) then + d_flow = len_trim(adjustl(line(:col_pos))) + flow(s_flow:s_flow+d_flow+1) = trim(adjustl(line(:col_pos)))//' ' + s_flow = s_flow + d_flow+1 + call line_isFlow(flow,s_flow,line(col_pos+1:)) + else + offset_value = indentDepth(line(col_pos+2:)) + line_asStandard = line(:col_pos+1)//line(col_pos+2+offset_value:) + call line_toFlow(flow,s_flow,line_asStandard) + endif + +end subroutine keyValue_toFlow + + +!------------------------------------------------------------------------------------------------- +! @brief reads a line of YAML block and places it in the YAML flow style structure +!------------------------------------------------------------------------------------------------- +subroutine line_toFlow(flow,s_flow,line) + + character(len=*), intent(inout) :: flow !< YAML in flow style only + integer, intent(inout) :: s_flow !< start position in flow + character(len=*), intent(in) :: line + + integer :: & + d_flow + + d_flow = len_trim(adjustl(line)) + flow(s_flow:s_flow+d_flow) = trim(adjustl(line)) + s_flow = s_flow + d_flow + +end subroutine line_toFlow + + +!------------------------------------------------------------------------------------------------- +! @brief convert a yaml list in block style to a yaml list in flow style +! @details enters the function when encountered with the list indicator '- ' +! reads each scalar list item and separates each other with a ',' +! If list item is non scalar, it stores the offset for that list item block +! Increase in the indentation level or when list item is not scalar -> 'decide' function is called. +! decrease in indentation level indicates the end of an indentation block +!------------------------------------------------------------------------------------------------- +recursive subroutine lst(blck,flow,s_blck,s_flow,offset) + + character(len=*), intent(in) :: blck !< YAML in mixed style + character(len=*), intent(inout) :: flow !< YAML in flow style only + integer, intent(inout) :: s_blck, & !< start position in blck + s_flow, & !< start position in flow + offset !< stores leading '- ' in nested lists + character(len=pStringLen) :: line + integer :: e_blck,indent + + indent = indentDepth(blck(s_blck:),offset) + do while (s_blck <= len_trim(blck)) + e_blck = s_blck + index(blck(s_blck:),IO_EOL) - 2 + line = IO_rmComment(blck(s_blck:e_blck)) + if (len_trim(line) == 0) then + s_blck = e_blck + 2 ! forward to next line + cycle + elseif(indentDepth(line,offset) > indent) then + call decide(blck,flow,s_blck,s_flow,offset) + offset = 0 + flow(s_flow:s_flow+1) = ', ' + s_flow = s_flow + 2 + elseif(indentDepth(line,offset) < indent .or. .not. isListItem(line)) then + offset = 0 + exit ! job done (lower level) + else + if(trim(adjustl(line)) == '-') then ! list item in next line + s_blck = e_blck + 2 + e_blck = e_blck + index(blck(e_blck+2:),IO_EOL) + line = IO_rmComment(blck(s_blck:e_blck)) + if(indentDepth(line) < indent .or. indentDepth(line) == indent) & + call IO_error(701,ext_msg=line) + + if(isScalar(line)) then + call line_toFlow(flow,s_flow,line) + s_blck = e_blck +2 + offset = 0 + elseif(isFlow(line)) then + call line_isFlow(flow,s_flow,line) + s_blck = e_blck +2 + offset = 0 + endif + else ! list item in the same line + if(line(indentDepth(line)+2:indentDepth(line)+2) /= ' ') & + call IO_error(703,ext_msg=line) + line = line(indentDepth(line)+3:) + if(isScalar(line)) then + call line_toFlow(flow,s_flow,line) + s_blck = e_blck +2 + offset = 0 + elseif(isFlow(line)) then + call line_isFlow(flow,s_flow,line) + s_blck = e_blck +2 + offset = 0 + else ! non scalar list item + offset = offset + indentDepth(blck(s_blck:))+1 ! offset in spaces to be ignored + s_blck = s_blck + index(blck(s_blck:e_blck),'-') ! s_blck after '-' symbol + endif + end if + end if + + if(isScalar(line) .or. isFlow(line)) then + flow(s_flow:s_flow+1) = ', ' + s_flow = s_flow +2 + endif + + end do + + s_flow = s_flow - 1 + if (flow(s_flow-1:s_flow-1) == ',') s_flow = s_flow - 1 + +end subroutine lst + + +!-------------------------------------------------------------------------------------------------- +! @brief convert a yaml dict in block style to a yaml dict in flow style +! @details enters the function when encountered with the dictionary indicator ':' +! parses each line in the block and compares indentation of a line with the preceding line +! upon increase in indentation level -> 'decide' function decides if the line is a list or dict +! decrease in indentation indicates the end of an indentation block +!-------------------------------------------------------------------------------------------------- +recursive subroutine dct(blck,flow,s_blck,s_flow,offset) + + character(len=*), intent(in) :: blck !< YAML in mixed style + character(len=*), intent(inout) :: flow !< YAML in flow style only + integer, intent(inout) :: s_blck, & !< start position in blck + s_flow, & !< start position in flow + offset + + character(len=pStringLen) :: line + integer :: e_blck,indent + logical :: previous_isKey + + previous_isKey = .false. + + indent = indentDepth(blck(s_blck:),offset) + + do while (s_blck <= len_trim(blck)) + e_blck = s_blck + index(blck(s_blck:),IO_EOL) - 2 + line = IO_rmComment(blck(s_blck:e_blck)) + if (len_trim(line) == 0) then + s_blck = e_blck + 2 ! forward to next line + cycle + elseif(indentDepth(line,offset) < indent) then + if(isScalar(line) .or. isFlow(line) .and. previous_isKey) & + call IO_error(701,ext_msg=line) + offset = 0 + exit ! job done (lower level) + elseif(indentDepth(line,offset) > indent .or. isListItem(line)) then + offset = 0 + call decide(blck,flow,s_blck,s_flow,offset) + else + if(isScalar(line)) call IO_error(701,ext_msg=line) + if(isFlow(line)) call IO_error(702,ext_msg=line) + + line = line(indentDepth(line)+1:) + if(previous_isKey) then + flow(s_flow-1:s_flow) = ', ' + s_flow = s_flow + 1 + endif + + if(isKeyValue(line)) then + call keyValue_toFlow(flow,s_flow,line) + else + call line_toFlow(flow,s_flow,line) + endif + + s_blck = e_blck +2 + end if + + if(isScalar(line) .or. isKeyValue(line)) then + flow(s_flow:s_flow) = ',' + s_flow = s_flow + 1 + previous_isKey = .false. + else + previous_isKey = .true. + endif + + flow(s_flow:s_flow) = ' ' + s_flow = s_flow + 1 + offset = 0 + end do + + s_flow = s_flow - 1 + if (flow(s_flow-1:s_flow-1) == ',') s_flow = s_flow - 1 + +end subroutine dct + + +!-------------------------------------------------------------------------------------------------- +! @brief decide whether next block is list or dict +!-------------------------------------------------------------------------------------------------- +recursive subroutine decide(blck,flow,s_blck,s_flow,offset) + + character(len=*), intent(in) :: blck !< YAML in mixed style + character(len=*), intent(inout) :: flow !< YAML in flow style only + integer, intent(inout) :: s_blck, & !< start position in blck + s_flow, & !< start position in flow + offset + integer :: e_blck + character(len=pStringLen) :: line + + if(s_blck <= len(blck)) then + e_blck = s_blck + index(blck(s_blck:),IO_EOL) - 2 + line = IO_rmComment(blck(s_blck:e_blck)) + + ! exit here if '---' is found + if (isListItem(line)) then + flow(s_flow:s_flow) = '[' + s_flow = s_flow + 1 + call lst(blck,flow,s_blck,s_flow,offset) + flow(s_flow:s_flow) = ']' + s_flow = s_flow + 1 + elseif(isKey(line) .or. isKeyValue(line)) then + flow(s_flow:s_flow) = '{' + s_flow = s_flow + 1 + call dct(blck,flow,s_blck,s_flow,offset) + flow(s_flow:s_flow) = '}' + s_flow = s_flow + 1 + elseif(isFlow(line)) then + call line_isFlow(flow,s_flow,line) + s_blck = e_blck +2 + else + line = line(indentDepth(line)+1:) + call line_toFlow(flow,s_flow,line) + s_blck = e_blck +2 + endif + endif + +end subroutine + + +!-------------------------------------------------------------------------------------------------- +! @brief convert all block style YAML parts to flow style +!-------------------------------------------------------------------------------------------------- +function to_flow(blck) + + character(len=:), allocatable :: to_flow + character(len=*), intent(in) :: blck !< YAML mixed style + integer :: s_blck, & !< start position in blck + s_flow, & !< start position in flow + offset, & !< counts leading '- ' in nested lists + end_line + if(isFlow(blck)) then + to_flow = trim(adjustl(blck)) + else + allocate(character(len=len(blck)*2)::to_flow) + ! move forward here (skip empty lines) and remove '----' if found + s_flow = 1 + s_blck = 1 + offset = 0 + call decide(blck,to_flow,s_blck,s_flow,offset) + to_flow = trim(to_flow(:s_flow-1)) + endif + end_line = index(to_flow,new_line('')) + if(end_line > 0) to_flow = to_flow(:end_line-1) + +end function to_flow + +!-------------------------------------------------------------------------------------------------- +subroutine selfTest() + + if (indentDepth(' a') /= 1) call IO_error(0,ext_msg='indentDepth') + if (indentDepth('a') /= 0) call IO_error(0,ext_msg='indentDepth') + if (indentDepth('x ') /= 0) call IO_error(0,ext_msg='indentDepth') + + if ( isFlow(' a')) call IO_error(0,ext_msg='isFLow') + if (.not. isFlow('{')) call IO_error(0,ext_msg='isFlow') + if (.not. isFlow(' [')) call IO_error(0,ext_msg='isFlow') + + if ( isListItem(' a')) call IO_error(0,ext_msg='isListItem') + if (.not. isListItem('- a ')) call IO_error(0,ext_msg='isListItem') + if (.not. isListItem(' -b')) call IO_error(0,ext_msg='isListItem') + + if ( isKeyValue(' a')) call IO_error(0,ext_msg='isKeyValue') + if ( isKeyValue(' a: ')) call IO_error(0,ext_msg='isKeyValue') + if (.not. isKeyValue(' a: b')) call IO_error(0,ext_msg='isKeyValue') + + if ( isKey(' a')) call IO_error(0,ext_msg='isKey') + if ( isKey('{a:b}')) call IO_error(0,ext_msg='isKey') + if ( isKey(' a:b')) call IO_error(0,ext_msg='isKey') + if (.not. isKey(' a: ')) call IO_error(0,ext_msg='isKey') + if (.not. isKey(' a:')) call IO_error(0,ext_msg='isKey') + if (.not. isKey(' a: #')) call IO_error(0,ext_msg='isKey') + + if( isScalar('a: ')) call IO_error(0,ext_msg='isScalar') + if( isScalar('a: b')) call IO_error(0,ext_msg='isScalar') + if( isScalar('{a:b}')) call IO_error(0,ext_msg='isScalar') + if( isScalar('- a:')) call IO_error(0,ext_msg='isScalar') + if(.not. isScalar(' a')) call IO_error(0,ext_msg='isScalar') + + !ToDo :some more advanced tests? + basic_list: block + character(len=*), parameter :: block_list = & + " - Casablanca"//IO_EOL//& + " - North by Northwest"//IO_EOL + character(len=*), parameter :: block_list_newline = & + " -"//IO_EOL//& + " Casablanca"//IO_EOL//& + " -"//IO_EOL//& + " North by Northwest"//IO_EOL + character(len=*), parameter :: flow_list = & + "[Casablanca, North by Northwest]" + + if (.not. to_flow(block_list) == flow_list) call IO_error(0,ext_msg='to_flow') + if (.not. to_flow(block_list_newline) == flow_list) call IO_error(0,ext_msg='to_flow') + end block basic_list + + basic_dict: block + character(len=*), parameter :: block_dict = & + " aa: Casablanca"//IO_EOL//& + " bb: North by Northwest"//IO_EOL + character(len=*), parameter :: block_dict_newline = & + " aa:"//IO_EOL//& + " Casablanca"//IO_EOL//& + " bb:"//IO_EOL//& + " North by Northwest"//IO_EOL + character(len=*), parameter :: flow_dict = & + "{aa: Casablanca, bb: North by Northwest}" + + if (.not. to_flow(block_dict) == flow_dict) call IO_error(0,ext_msg='to_flow') + if (.not. to_flow(block_dict_newline) == flow_dict) call IO_error(0,ext_msg='to_flow') + end block basic_dict + + basic_flow: block + character(len=*), parameter :: flow_braces = & + " source: [{param: 1}, {param: 2}, {param: 3}, {param: 4}]"//IO_EOL + character(len=*), parameter :: flow_mixed_braces = & + " source: [param: 1, {param: 2}, param: 3, {param: 4}]"//IO_EOL + character(len=*), parameter :: flow = & + "{source: [{param: 1}, {param: 2}, {param: 3}, {param: 4}]}" + + if (.not. to_flow(flow_braces) == flow) call IO_error(0,ext_msg='to_flow') + if (.not. to_flow(flow_mixed_braces) == flow) call IO_error(0,ext_msg='to_flow') + end block basic_flow + + basic_mixed: block + character(len=*), parameter :: block_flow = & + " aa:"//IO_EOL//& + " - "//IO_EOL//& + " param_1: [a: b, c, {d: {e: [f: g, h]}}]"//IO_EOL//& + " - c: d"//IO_EOL//& + " bb:"//IO_EOL//& + " - {param_1: [{a: b}, c, {d: {e: [{f: g}, h]}}]}"//IO_EOL + character(len=*), parameter :: mixed_flow = & + "{aa: [{param_1: [{a: b}, c, {d: {e: [{f: g}, h]}}]}, {c: d}], bb: [{param_1: [{a: b}, c, {d: {e: [{f: g}, h]}}]}]}" + + if(.not. to_flow(block_flow) == mixed_flow) call IO_error(0,ext_msg='to_flow') + end block basic_mixed + +end subroutine selfTest + +end module YAML_parse diff --git a/src/commercialFEM_fileList.f90 b/src/commercialFEM_fileList.f90 index f8a5ad96a..346970b49 100644 --- a/src/commercialFEM_fileList.f90 +++ b/src/commercialFEM_fileList.f90 @@ -8,6 +8,7 @@ #include "debug.f90" #include "list.f90" #include "YAML_types.f90" +#include "YAML_parse.f90" #include "future.f90" #include "config.f90" #include "LAPACK_interface.f90" From 873cb80edd2d6752ff7c87efcfb3e5330806a406 Mon Sep 17 00:00:00 2001 From: Sharan Roongta Date: Thu, 21 May 2020 20:52:15 +0200 Subject: [PATCH 076/136] access issue resolved --- src/YAML_types.f90 | 19 ++++++++----------- 1 file changed, 8 insertions(+), 11 deletions(-) diff --git a/src/YAML_types.f90 b/src/YAML_types.f90 index 0282fcb98..ddbc6f531 100644 --- a/src/YAML_types.f90 +++ b/src/YAML_types.f90 @@ -16,14 +16,7 @@ module YAML_types private - public :: & - tNode, & - tScalar, & - tDict, & - tList, & - YAML_types_init - - type, abstract :: tNode + type, abstract, public :: tNode integer :: length = 0 contains procedure(asFormattedString), deferred :: asFormattedString @@ -102,7 +95,7 @@ module YAML_types end type tNode - type, extends(tNode) :: tScalar + type, extends(tNode), public :: tScalar character(len=:), allocatable, private :: value @@ -118,7 +111,7 @@ module YAML_types asString => tScalar_asString end type tScalar - type, extends(tNode) :: tList + type, extends(tNode), public :: tList class(tItem), pointer :: first => null() @@ -136,7 +129,7 @@ module YAML_types final :: tList_finalize end type tList - type, extends(tList) :: tDict + type, extends(tList), public :: tDict contains procedure :: asFormattedString => tDict_asFormattedString procedure :: set => tDict_set @@ -171,6 +164,10 @@ module YAML_types module procedure tScalar_assign__ end interface assignment (=) + public :: & + YAML_types_init, & + assignment(=) + contains !-------------------------------------------------------------------------------------------------- From 677e0819377ed1b1b938f7ae48472c9772b26bca Mon Sep 17 00:00:00 2001 From: Sharan Roongta Date: Thu, 21 May 2020 21:03:39 +0200 Subject: [PATCH 077/136] YAML related errors --- src/IO.f90 | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/src/IO.f90 b/src/IO.f90 index c49ca66d0..2f06dc614 100644 --- a/src/IO.f90 +++ b/src/IO.f90 @@ -536,6 +536,19 @@ subroutine IO_error(error_ID,el,ip,g,instance,ext_msg) case (602) msg = 'invalid selection for debug' +!------------------------------------------------------------------------------------------------ +! errors related to YAML input files + case (701) + msg = 'Incorrect indent/Null value not allowed' + case (702) + msg = 'Invalid use of flow yaml' + case (703) + msg = 'Space expected after a list indicator - ' + case (704) + msg = 'Space expected after a colon for : pair' + case (705) + msg = 'Unsupported feature' + !------------------------------------------------------------------------------------------------- ! errors related to the grid solver case (809) From b33de48528079df9424266477b42ff0b57d59f04 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Fri, 22 May 2020 15:12:37 +0200 Subject: [PATCH 078/136] testing broadcasting --- python/damask/_rotation.py | 10 +++++----- python/tests/test_Rotation.py | 10 ++++++++++ 2 files changed, 15 insertions(+), 5 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index 387ee84cb..d639cb0e0 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -160,10 +160,10 @@ class Rotation: if self.shape == (): q = np.broadcast_to(self.quaternion,shape+(4,)) else: - q = np.block([np.broadcast_to(self.quaternion[...,0:1],shape+(1,)), - np.broadcast_to(self.quaternion[...,1:2],shape+(1,)), - np.broadcast_to(self.quaternion[...,2:3],shape+(1,)), - np.broadcast_to(self.quaternion[...,3:4],shape+(1,))]) + q = np.block([np.broadcast_to(self.quaternion[...,0:1],shape), + np.broadcast_to(self.quaternion[...,1:2],shape), + np.broadcast_to(self.quaternion[...,2:3],shape), + np.broadcast_to(self.quaternion[...,3:4],shape)]).reshape(shape+(4,)) return self.__class__(q) @@ -537,7 +537,7 @@ class Rotation: ) # reduce Euler angles to definition range eu[np.abs(eu)<1.e-6] = 0.0 - eu = np.where(eu<0, (eu+2.0*np.pi)%np.array([2.0*np.pi,np.pi,2.0*np.pi]),eu) + eu = np.where(eu<0, (eu+2.0*np.pi)%np.array([2.0*np.pi,np.pi,2.0*np.pi]),eu) # needed? return eu @staticmethod diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index a9768afb8..5acbca6f1 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -866,6 +866,16 @@ class TestRotation: with pytest.raises(ValueError): function(invalid_shape) + @pytest.mark.parametrize('shape',[None,(3,),(4,2)]) + def test_broadcast(self,shape): + rot = Rotation.from_random(shape) + new_shape = tuple(np.random.randint(8,32,(3))) if shape is None else \ + rot.shape + (np.random.randint(8,32),) + rot_broadcast = rot.broadcast_to(tuple(new_shape)) + for i in range(rot_broadcast.shape[-1]): + assert (rot_broadcast.quaternion[...,i,:], rot.quaternion) + + @pytest.mark.parametrize('function,invalid',[(Rotation.from_quaternion, np.array([-1,0,0,0])), (Rotation.from_quaternion, np.array([1,1,1,0])), (Rotation.from_Eulers, np.array([1,4,0])), From 11eda510aae68ea236a834376246542296c5219f Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Fri, 22 May 2020 18:45:27 +0200 Subject: [PATCH 079/136] testing functionality of Lattice separately --- python/tests/test_Lattice.py | 41 ++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 python/tests/test_Lattice.py diff --git a/python/tests/test_Lattice.py b/python/tests/test_Lattice.py new file mode 100644 index 000000000..73f1b58dd --- /dev/null +++ b/python/tests/test_Lattice.py @@ -0,0 +1,41 @@ +import random + +import pytest +import numpy as np + +from damask import Symmetry +from damask import Lattice + +class TestSymmetry: + + @pytest.mark.parametrize('invalid_symmetry',['fcc','bcc','hello']) + def test_invalid(self,invalid_symmetry): + with pytest.raises(KeyError): + s = Symmetry(invalid_symmetry) + + def test_equal(self): + symmetry = random.choice(Symmetry.lattices) + assert Symmetry(symmetry) == Symmetry(symmetry) + + def test_not_equal(self): + symmetries = random.sample(Symmetry.lattices,k=2) + assert Symmetry(symmetries[0]) != Symmetry(symmetries[1]) + + @pytest.mark.parametrize('lattice',Symmetry.lattices) + def test_inFZ(self,lattice): + assert Symmetry(lattice).inFZ(np.zeros(3)) + + @pytest.mark.parametrize('lattice',Symmetry.lattices) + def test_inDisorientationSST(self,lattice): + assert Symmetry(lattice).inDisorientationSST(np.zeros(3)) + + @pytest.mark.parametrize('lattice',Symmetry.lattices) + @pytest.mark.parametrize('proper',[True,False]) + def test_inSST(self,lattice,proper): + assert Symmetry(lattice).inSST(np.zeros(3),proper) + + @pytest.mark.parametrize('function',['inFZ','inDisorientationSST']) + def test_invalid(self,function): + s = Symmetry() + with pytest.raises(ValueError): + eval('s.{}(np.ones(4))'.format(function)) From 7bd681a5edce04b60dc8f46f0a3a2e43dc5a9b5d Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Fri, 22 May 2020 19:04:02 +0200 Subject: [PATCH 080/136] very simple test --- python/damask/_result.py | 2 +- python/tests/test_Result.py | 4 ++++ 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index 5a22c7977..b45d4d4e6 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -1041,7 +1041,7 @@ class Result: pool.join() - def write_XMDF(self): + def write_XDMF(self): """ Write XDMF file to directly visualize data in DADF5 file. diff --git a/python/tests/test_Result.py b/python/tests/test_Result.py index c117f33f7..23db48745 100644 --- a/python/tests/test_Result.py +++ b/python/tests/test_Result.py @@ -185,3 +185,7 @@ class TestResult: in_memory = mechanics.left_stretch(default.read_dataset(loc['F'],0)) in_file = default.read_dataset(loc['V(F)'],0) assert np.allclose(in_memory,in_file) + + @pytest.mark.parametrize('output',['F',[],['F','P']]) + def test_vtk(self,default,output): + default.to_vtk(output) From b8e83cd26363bc0f93d976804af76f158f6ff7e8 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Fri, 22 May 2020 20:42:13 +0200 Subject: [PATCH 081/136] do not overwrite --- python/tests/test_Lattice.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/python/tests/test_Lattice.py b/python/tests/test_Lattice.py index 73f1b58dd..e99b2b961 100644 --- a/python/tests/test_Lattice.py +++ b/python/tests/test_Lattice.py @@ -9,7 +9,7 @@ from damask import Lattice class TestSymmetry: @pytest.mark.parametrize('invalid_symmetry',['fcc','bcc','hello']) - def test_invalid(self,invalid_symmetry): + def test_invalid_symmetry(self,invalid_symmetry): with pytest.raises(KeyError): s = Symmetry(invalid_symmetry) @@ -35,7 +35,7 @@ class TestSymmetry: assert Symmetry(lattice).inSST(np.zeros(3),proper) @pytest.mark.parametrize('function',['inFZ','inDisorientationSST']) - def test_invalid(self,function): + def test_invalid_argument(self,function): s = Symmetry() with pytest.raises(ValueError): eval('s.{}(np.ones(4))'.format(function)) From e2cf527dfb1cff56f0a1a5f57bb1b0b4aa14222e Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 23 May 2020 08:19:08 +0200 Subject: [PATCH 082/136] add missing test --- python/tests/test_Result.py | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/python/tests/test_Result.py b/python/tests/test_Result.py index 23db48745..f431e693f 100644 --- a/python/tests/test_Result.py +++ b/python/tests/test_Result.py @@ -4,6 +4,7 @@ import os import pytest import numpy as np +import damask from damask import Result from damask import mechanics @@ -13,7 +14,7 @@ def default(tmp_path,reference_dir): fname = '12grains6x7x8_tensionY.hdf5' shutil.copy(os.path.join(reference_dir,fname),tmp_path) f = Result(os.path.join(tmp_path,fname)) - f.set_by_time(20.0,20.0) + f.pick('times',20.0) return f @pytest.fixture @@ -143,6 +144,20 @@ class TestResult: in_file = default.read_dataset(loc['S'],0) assert np.allclose(in_memory,in_file) + @pytest.mark.parametrize('polar',[True,False]) + def test_add_pole(self,default,polar): + pole = np.array([1.,0.,0.]) + default.add_pole('orientation',pole,polar) + loc = {'orientation': default.get_dataset_location('orientation'), + 'pole': default.get_dataset_location('p^{}_[1 0 0)'.format(u'rφ' if polar else 'xy'))} + rot = damask.Rotation(default.read_dataset(loc['orientation']).view(np.double)) + rotated_pole = rot * np.broadcast_to(pole,rot.shape+(3,)) + xy = rotated_pole[:,0:2]/(1.+abs(pole[2])) + in_memory = xy if not polar else \ + np.block([np.sqrt(xy[:,0:1]*xy[:,0:1]+xy[:,1:2]*xy[:,1:2]),np.arctan2(xy[:,1:2],xy[:,0:1])]) + in_file = default.read_dataset(loc['pole']) + assert np.allclose(in_memory,in_file) + def test_add_rotational_part(self,default): default.add_rotational_part('F') loc = {'F': default.get_dataset_location('F'), From 0549e33a0035e7b4aaf08daaae06777d1fc11c41 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 23 May 2020 08:38:57 +0200 Subject: [PATCH 083/136] vectorized/fast --- python/damask/_result.py | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index b45d4d4e6..3921cbf49 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -832,14 +832,12 @@ class Result: pole = np.array(p) unit_pole = pole/np.linalg.norm(pole) m = util.scale_to_coprime(pole) - coords = np.empty((len(q['data']),2)) - - for i,qu in enumerate(q['data']): - o = Rotation(np.array([qu['w'],qu['x'],qu['y'],qu['z']])) - rotatedPole = o*unit_pole # rotate pole according to crystal orientation - (x,y) = rotatedPole[0:2]/(1.+abs(unit_pole[2])) # stereographic projection - coords[i] = [np.sqrt(x*x+y*y),np.arctan2(y,x)] if polar else [x,y] + rot = Rotation(q['data'].view(np.double).reshape(-1,4)) + rotatedPole = rot @ np.broadcast_to(unit_pole,rot.shape+(3,)) # rotate pole according to crystal orientation + xy = rotatedPole[:,0:2]/(1.+abs(unit_pole[2])) # stereographic projection + coords = xy if not polar else \ + np.block([np.sqrt(xy[:,0:1]*xy[:,0:1]+xy[:,1:2]*xy[:,1:2]),np.arctan2(xy[:,1:2],xy[:,0:1])]) return { 'data': coords, 'label': 'p^{}_[{} {} {})'.format(u'rφ' if polar else 'xy',*m), From 8a848979aa9ede6f4c959307cb5c981f1c043a6d Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 23 May 2020 09:13:45 +0200 Subject: [PATCH 084/136] missing test for IPF color --- python/tests/test_Result.py | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/python/tests/test_Result.py b/python/tests/test_Result.py index f431e693f..312fa205b 100644 --- a/python/tests/test_Result.py +++ b/python/tests/test_Result.py @@ -96,6 +96,20 @@ class TestResult: in_file = default.read_dataset(loc['v(sigma)'],0) assert np.allclose(in_memory,in_file) + @pytest.mark.parametrize('d',[[1,0,0],[0,1,0],[0,0,1]]) + def test_add_IPFcolor(self,default,d): + default.add_IPFcolor('orientation',d) + loc = {'orientation': default.get_dataset_location('orientation'), + 'color': default.get_dataset_location('IPFcolor_[{} {} {}]'.format(*d))} + qu = default.read_dataset(loc['orientation']).view(np.double).reshape(-1,4) + crystal_structure = default.get_crystal_structure() + in_memory = np.empty((qu.shape[0],3),np.uint8) + for i,q in enumerate(qu): + o = damask.Orientation(q,crystal_structure).reduced() + in_memory[i] = np.uint8(o.IPFcolor(np.array(d))*255) + in_file = default.read_dataset(loc['color']) + assert np.allclose(in_memory,in_file) + def test_add_maximum_shear(self,default): default.add_Cauchy('P','F') default.add_maximum_shear('sigma') From 82419f8649bbc891a5fe80e3234b12c04324db80 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 23 May 2020 10:38:25 +0200 Subject: [PATCH 085/136] testing selection --- python/tests/test_Result.py | 55 +++++++++++++++++++++++++++++++++---- 1 file changed, 50 insertions(+), 5 deletions(-) diff --git a/python/tests/test_Result.py b/python/tests/test_Result.py index 312fa205b..76dc1c8ef 100644 --- a/python/tests/test_Result.py +++ b/python/tests/test_Result.py @@ -29,11 +29,56 @@ class TestResult: print(default) - def test_time_increments(self,default): - shape = default.read_dataset(default.get_dataset_location('F'),0).shape - default.set_by_time(0.0,20.0) - for i in default.iterate('increments'): - assert shape == default.read_dataset(default.get_dataset_location('F'),0).shape + def test_pick_all(self,default): + default.pick('increments',True) + a = default.get_dataset_location('F') + default.pick('increments','*') + b = default.get_dataset_location('F') + default.pick('increments',default.incs_in_range(0,np.iinfo(int).max)) + c = default.get_dataset_location('F') + + default.pick('times',True) + d = default.get_dataset_location('F') + default.pick('times','*') + e = default.get_dataset_location('F') + default.pick('times',default.times_in_range(0.0,np.inf)) + f = default.get_dataset_location('F') + assert a == b == c == d == e ==f + + @pytest.mark.parametrize('what',['increments','times','constituents']) # ToDo: discuss materialpoints + def test_pick_none(self,default,what): + default.pick(what,False) + a = default.get_dataset_location('F') + default.pick(what,[]) + b = default.get_dataset_location('F') + + assert a == b == [] + + @pytest.mark.parametrize('what',['increments','times','constituents']) # ToDo: discuss materialpoints + def test_pick_more(self,default,what): + default.pick(what,False) + default.pick_more(what,'*') + a = default.get_dataset_location('F') + + default.pick(what,True) + b = default.get_dataset_location('F') + + assert a == b + + @pytest.mark.parametrize('what',['increments','times','constituents']) # ToDo: discuss materialpoints + def test_pick_less(self,default,what): + default.pick(what,True) + default.pick_less(what,'*') + a = default.get_dataset_location('F') + + default.pick(what,False) + b = default.get_dataset_location('F') + + assert a == b == [] + + def test_pick_invalid(self,default): + with pytest.raises(AttributeError): + default.pick('invalid',True) def test_add_absolute(self,default): From 376e45d7bfe7f505a02e90dc80c80ee8fa00f53a Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 23 May 2020 13:55:00 +0200 Subject: [PATCH 086/136] don't even start to compile --- cmake/Compiler-GNU.cmake | 3 +++ cmake/Compiler-Intel.cmake | 4 ++++ src/DAMASK_interface.f90 | 25 ------------------------- 3 files changed, 7 insertions(+), 25 deletions(-) diff --git a/cmake/Compiler-GNU.cmake b/cmake/Compiler-GNU.cmake index 858e91134..ebba8c0bf 100644 --- a/cmake/Compiler-GNU.cmake +++ b/cmake/Compiler-GNU.cmake @@ -1,6 +1,9 @@ ################################################################################################### # GNU Compiler ################################################################################################### +if (CMAKE_Fortran_COMPILER_VERSION VERSION_LESS 8.0) + message (FATAL_ERROR "GCC Compiler version: ${CMAKE_Fortran_COMPILER_VERSION} not supported") +endif () if (OPENMP) set (OPENMP_FLAGS "-fopenmp") diff --git a/cmake/Compiler-Intel.cmake b/cmake/Compiler-Intel.cmake index 1a2c2c455..6d96ff42d 100644 --- a/cmake/Compiler-Intel.cmake +++ b/cmake/Compiler-Intel.cmake @@ -1,6 +1,10 @@ ################################################################################################### # Intel Compiler ################################################################################################### +if (CMAKE_Fortran_COMPILER_VERSION VERSION_LESS 18.0) + message (FATAL_ERROR "Intel Compiler version: ${CMAKE_Fortran_COMPILER_VERSION} not supported") +endif () + if (OPENMP) set (OPENMP_FLAGS "-qopenmp -parallel") endif () diff --git a/src/DAMASK_interface.f90 b/src/DAMASK_interface.f90 index 8e4369840..67c7d99da 100644 --- a/src/DAMASK_interface.f90 +++ b/src/DAMASK_interface.f90 @@ -9,8 +9,6 @@ !> by DAMASK. Interpretating the command line arguments to get load case, geometry file, !> and working directory. !-------------------------------------------------------------------------------------------------- -#define GCC_MIN 6 -#define INTEL_MIN 1700 #define PETSC_MAJOR 3 #define PETSC_MINOR_MIN 10 #define PETSC_MINOR_MAX 13 @@ -50,29 +48,6 @@ contains !-------------------------------------------------------------------------------------------------- subroutine DAMASK_interface_init #include -#if defined(__GFORTRAN__) && __GNUC__PETSC_MINOR_MAX =================================================================================================== From a3d9520c4b85db772f793c8714885a67c37a28d8 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 23 May 2020 15:54:28 +0200 Subject: [PATCH 087/136] polishing --- python/damask/_result.py | 26 ++------------------------ 1 file changed, 2 insertions(+), 24 deletions(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index 3921cbf49..6526e63ed 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -599,9 +599,6 @@ class Result: @staticmethod def _add_deviator(T): - if not T['data'].shape[1:] == (3,3): - raise ValueError - return { 'data': mechanics.deviatoric_part(T['data']), 'label': 's_{}'.format(T['label']), @@ -867,8 +864,6 @@ class Result: @staticmethod def _add_rotational_part(F): - if not F['data'].shape[1:] == (3,3): - raise ValueError return { 'data': mechanics.rotational_part(F['data']), 'label': 'R({})'.format(F['label']), @@ -893,9 +888,6 @@ class Result: @staticmethod def _add_spherical(T): - if not T['data'].shape[1:] == (3,3): - raise ValueError - return { 'data': mechanics.spherical_part(T['data']), 'label': 'p_{}'.format(T['label']), @@ -920,9 +912,6 @@ class Result: @staticmethod def _add_strain_tensor(F,t,m): - if not F['data'].shape[1:] == (3,3): - raise ValueError - return { 'data': mechanics.strain_tensor(F['data'],t,m), 'label': 'epsilon_{}^{}({})'.format(t,m,F['label']), @@ -954,9 +943,6 @@ class Result: @staticmethod def _add_stretch_tensor(F,t): - if not F['data'].shape[1:] == (3,3): - raise ValueError - return { 'data': mechanics.left_stretch(F['data']) if t == 'V' else mechanics.right_stretch(F['data']), 'label': '{}({})'.format(t,F['label']), @@ -1047,7 +1033,7 @@ class Result: Selection is not taken into account. """ if len(self.constituents) != 1 or not self.structured: - raise NotImplementedError + raise NotImplementedError('XDMF only available for grid results with 1 constituent.') xdmf=ET.Element('Xdmf') xdmf.attrib={'Version': '2.0', @@ -1215,14 +1201,6 @@ class Result: ################################################################################################### # BEGIN DEPRECATED - def _time_to_inc(self,start,end): - selected = [] - for i,time in enumerate(self.times): - if start <= time <= end: - selected.append(self.increments[i]) - return selected - - def set_by_time(self,start,end): """ Set active increments based on start and end time. @@ -1235,4 +1213,4 @@ class Result: end time (included) """ - self._manage_selection('set','increments',self._time_to_inc(start,end)) + self._manage_selection('set','times',self.times_in_range(start,end)) From a26cba1457054c5188b7a44bdbf72c0a9b9ebc36 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 24 May 2020 09:06:11 +0200 Subject: [PATCH 088/136] calling a few missing statements --- python/tests/test_Lattice.py | 1 + python/tests/test_Result.py | 3 +++ python/tests/test_Rotation.py | 1 + 3 files changed, 5 insertions(+) diff --git a/python/tests/test_Lattice.py b/python/tests/test_Lattice.py index e99b2b961..6a2cc5034 100644 --- a/python/tests/test_Lattice.py +++ b/python/tests/test_Lattice.py @@ -15,6 +15,7 @@ class TestSymmetry: def test_equal(self): symmetry = random.choice(Symmetry.lattices) + print(symmetry) assert Symmetry(symmetry) == Symmetry(symmetry) def test_not_equal(self): diff --git a/python/tests/test_Result.py b/python/tests/test_Result.py index 76dc1c8ef..4eacdee4c 100644 --- a/python/tests/test_Result.py +++ b/python/tests/test_Result.py @@ -80,6 +80,9 @@ class TestResult: with pytest.raises(AttributeError): default.pick('invalid',True) + def test_add_invalid(self,default): + with pytest.raises(Exception): + default.add_calculation('#invalid#*2') def test_add_absolute(self,default): default.add_absolute('Fe') diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index 5acbca6f1..75fddf6fe 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -882,6 +882,7 @@ class TestRotation: (Rotation.from_axis_angle, np.array([1,0,0,4])), (Rotation.from_axis_angle, np.array([1,1,0,1])), (Rotation.from_matrix, np.random.rand(3,3)), + (Rotation.from_matrix, np.array([[1,1,0],[1,2,0],[0,0,1]])), (Rotation.from_Rodrigues, np.array([1,0,0,-1])), (Rotation.from_Rodrigues, np.array([1,1,0,1])), (Rotation.from_homochoric, np.array([2,2,2])), From 3231a491073c26bfba26a87bb3bae6c491569aa1 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 24 May 2020 09:06:42 +0200 Subject: [PATCH 089/136] centralize functionality --- processing/pre/geom_canvas.py | 27 ++++---------- processing/pre/geom_renumber.py | 12 +++---- processing/pre/geom_rotate.py | 60 +++++++++++--------------------- processing/pre/geom_translate.py | 22 +++++------- python/damask/_geom.py | 52 +++++++++++++++++++++++++++ 5 files changed, 92 insertions(+), 81 deletions(-) diff --git a/processing/pre/geom_canvas.py b/processing/pre/geom_canvas.py index edd5fe622..b309364e8 100755 --- a/processing/pre/geom_canvas.py +++ b/processing/pre/geom_canvas.py @@ -40,35 +40,22 @@ parser.add_option('-f','--fill', parser.set_defaults(offset = (0,0,0)) (options, filenames) = parser.parse_args() - - if filenames == []: filenames = [None] + for name in filenames: damask.util.report(scriptName,name) geom = damask.Geom.from_file(StringIO(''.join(sys.stdin.read())) if name is None else name) - origin = geom.get_origin() - size = geom.get_size() - old = new = geom.get_grid() offset = np.asarray(options.offset) if options.grid is not None: - new = np.maximum(1, - np.array([int(o*float(n.lower().replace('x',''))) if n.lower().endswith('x') \ - else int(n) for o,n in zip(old,options.grid)],dtype=int)) + grid = np.maximum(1, + np.array([int(o*float(n.lower().replace('x',''))) if n.lower().endswith('x') \ + else int(n) for o,n in zip(geom.grid,options.grid)],dtype=int)) + else: + grid = np.array(options.grid,dtype=int) - canvas = np.full(new,options.fill if options.fill is not None - else np.nanmax(geom.microstructure)+1,geom.microstructure.dtype) - - l = np.clip( offset, 0,np.minimum(old +offset,new)) # noqa - r = np.clip( offset+old,0,np.minimum(old*2+offset,new)) - L = np.clip(-offset, 0,np.minimum(new -offset,old)) - R = np.clip(-offset+new,0,np.minimum(new*2-offset,old)) - canvas[l[0]:r[0],l[1]:r[1],l[2]:r[2]] = geom.microstructure[L[0]:R[0],L[1]:R[1],L[2]:R[2]] - - - damask.util.croak(geom.update(canvas,origin=origin+offset*size/old,rescale=True)) + damask.util.croak(geom.canvas(grid,np.asarray(options.offset),options.fill)) geom.add_comments(scriptID + ' ' + ' '.join(sys.argv[1:])) - geom.to_file(sys.stdout if name is None else name,pack=False) diff --git a/processing/pre/geom_renumber.py b/processing/pre/geom_renumber.py index 6e51062a5..8eab9064a 100755 --- a/processing/pre/geom_renumber.py +++ b/processing/pre/geom_renumber.py @@ -22,14 +22,12 @@ Renumber sorted microstructure indices to 1,...,N. """, version=scriptID) (options, filenames) = parser.parse_args() - - if filenames == []: filenames = [None] for name in filenames: - damask.util.report(scriptName,name) + damask.util.report(scriptName,name) - geom = damask.Geom.from_file(StringIO(''.join(sys.stdin.read())) if name is None else name) - damask.util.croak(geom.renumber()) - geom.add_comments(scriptID + ' ' + ' '.join(sys.argv[1:])) - geom.to_file(sys.stdout if name is None else name,pack=False) + geom = damask.Geom.from_file(StringIO(''.join(sys.stdin.read())) if name is None else name) + damask.util.croak(geom.renumber()) + geom.add_comments(scriptID + ' ' + ' '.join(sys.argv[1:])) + geom.to_file(sys.stdout if name is None else name,pack=False) diff --git a/processing/pre/geom_rotate.py b/processing/pre/geom_rotate.py index dc2e8e2a3..bbfeceb0b 100755 --- a/processing/pre/geom_rotate.py +++ b/processing/pre/geom_rotate.py @@ -52,47 +52,27 @@ parser.add_option('-f', '--fill', parser.set_defaults(degrees = False) (options, filenames) = parser.parse_args() - -if [options.rotation,options.eulers,options.matrix,options.quaternion].count(None) < 3: - parser.error('more than one rotation specified.') -if [options.rotation,options.eulers,options.matrix,options.quaternion].count(None) > 3: - parser.error('no rotation specified.') - -if options.quaternion is not None: - rot = damask.Rotation.from_quaternion(np.array(options.quaternion)) # we might need P=+1 here, too... -if options.rotation is not None: - rot = damask.Rotation.from_axis_angle(np.array(options.rotation),degrees=options.degrees,normalise=True,P=+1) -if options.matrix is not None: - rot = damask.Rotation.from_matrix(np.array(options.Matrix)) -if options.eulers is not None: - rot = damask.Rotation.from_Eulers(np.array(options.eulers),degrees=options.degrees) - -eulers = rot.as_Eulers(degrees=True) - - if filenames == []: filenames = [None] +if [options.rotation,options.eulers,options.matrix,options.quaternion].count(None) < 3: + parser.error('more than one rotation specified.') +if [options.rotation,options.eulers,options.matrix,options.quaternion].count(None) > 3: + parser.error('no rotation specified.') + +if options.quaternion is not None: + rot = damask.Rotation.from_quaternion(np.array(options.quaternion)) # we might need P=+1 here, too... +if options.rotation is not None: + rot = damask.Rotation.from_axis_angle(np.array(options.rotation),degrees=options.degrees,normalise=True,P=+1) +if options.matrix is not None: + rot = damask.Rotation.from_matrix(np.array(options.Matrix)) +if options.eulers is not None: + rot = damask.Rotation.from_Eulers(np.array(options.eulers),degrees=options.degrees) + + for name in filenames: - damask.util.report(scriptName,name) + damask.util.report(scriptName,name) - geom = damask.Geom.from_file(StringIO(''.join(sys.stdin.read())) if name is None else name) - size = geom.get_size() - grid = geom.get_grid() - origin = geom.get_origin() - microstructure = geom.get_microstructure() - fill = np.nanmax(microstructure)+1 if options.fill is None else options.fill - dtype = float if np.isnan(fill) or int(fill) != fill or microstructure.dtype==np.float else int - - # These rotations are always applied in the reference coordinate system, i.e. (z,x,z) not (z,x',z'') - # this seems to be ok, see https://www.cs.utexas.edu/~theshark/courses/cs354/lectures/cs354-14.pdf - microstructure = ndimage.rotate(microstructure,eulers[2],(0,1),order=0, - prefilter=False,output=dtype,cval=fill) # rotation around z - microstructure = ndimage.rotate(microstructure,eulers[1],(1,2),order=0, - prefilter=False,output=dtype,cval=fill) # rotation around x - microstructure = ndimage.rotate(microstructure,eulers[0],(0,1),order=0, - prefilter=False,output=dtype,cval=fill) # rotation around z - - damask.util.croak(geom.update(microstructure,origin=origin-(np.asarray(microstructure.shape)-grid)/2*size/grid,rescale=True)) - geom.add_comments(scriptID + ' ' + ' '.join(sys.argv[1:])) - - geom.to_file(sys.stdout if name is None else name,pack=False) + geom = damask.Geom.from_file(StringIO(''.join(sys.stdin.read())) if name is None else name) + damask.util.croak(geom.rotate(rot,options.fill)) + geom.add_comments(scriptID + ' ' + ' '.join(sys.argv[1:])) + geom.to_file(sys.stdout if name is None else name,pack=False) diff --git a/processing/pre/geom_translate.py b/processing/pre/geom_translate.py index 1d08c23dc..25164b794 100755 --- a/processing/pre/geom_translate.py +++ b/processing/pre/geom_translate.py @@ -40,22 +40,16 @@ parser.set_defaults(origin = (0.0,0.0,0.0), ) (options, filenames) = parser.parse_args() +if filenames == []: filenames = [None] sub = list(map(int,options.substitute)) - -if filenames == []: filenames = [None] - for name in filenames: - damask.util.report(scriptName,name) + damask.util.report(scriptName,name) - geom = damask.Geom.from_file(StringIO(''.join(sys.stdin.read())) if name is None else name) - - substituted = geom.get_microstructure() - for old,new in zip(sub[0::2],sub[1::2]): substituted[geom.microstructure==old] = new # substitute microstructure indices - substituted += options.microstructure # constant shift - - damask.util.croak(geom.update(substituted,origin=geom.get_origin()+options.origin)) - geom.add_comments(scriptID + ' ' + ' '.join(sys.argv[1:])) - - geom.to_file(sys.stdout if name is None else name,pack=False) + geom = damask.Geom.from_file(StringIO(''.join(sys.stdin.read())) if name is None else name) + geom.renumber(sub[0::2],sub[1::2],origin=geom.origin+options.origin) + geom.microstructure+= option.microstructure + damask.util.croak(geom) + geom.add_comments(scriptID + ' ' + ' '.join(sys.argv[1:])) + geom.to_file(sys.stdout if name is None else name,pack=False) diff --git a/python/damask/_geom.py b/python/damask/_geom.py index 892000b7c..bfba3465b 100644 --- a/python/damask/_geom.py +++ b/python/damask/_geom.py @@ -10,6 +10,7 @@ from . import VTK from . import util from . import Environment from . import grid_filters +from . import Rotation class Geom: @@ -581,3 +582,54 @@ class Geom: #self.add_comments('geom.py:renumber v{}'.format(version) return self.update(renumbered) + + + def rotate(self,R,fill=None): + """Rotate microstructure (pad if required).""" + if fill is None: fill = np.nanmax(self.microstructure) + 1 + dtype = float if np.isnan(fill) or int(fill) != fill or self.microstructure.dtype==np.float else int + + Eulers = R.as_Eulers(degrees=True) + # These rotations are always applied in the reference coordinate system, i.e. (z,x,z) not (z,x',z'') + # this seems to be ok, see https://www.cs.utexas.edu/~theshark/courses/cs354/lectures/cs354-14.pdf + microstructure = ndimage.rotate(self.microstructure,Eulers[2],(0,1),order=0, + prefilter=False,output=dtype,cval=fill) # rotation around z + microstructure = ndimage.rotate(microstructure,Eulers[1],(1,2),order=0, + prefilter=False,output=dtype,cval=fill) # rotation around x + microstructure = ndimage.rotate(microstructure,Eulers[0],(0,1),order=0, + prefilter=False,output=dtype,cval=fill) # rotation around z + + origin = self.origin-(np.asarray(microstructure.shape)-self.grid)//2 * self.size/self.grid + + #self.add_comments('geom.py:renumber v{}'.format(version) + return self.update(microstructure,origin=origin,rescale=True) + + + def canvas(self,grid=None,offset=None,fill=None): + """Rotate microstructure (pad if required).""" + if fill is None: fill = np.nanmax(self.microstructure) + 1 + dtype = float if np.isnan(fill) or int(fill) != fill or self.microstructure.dtype==np.float else int + + canvas = np.full(self.grid if grid is None else grid, + fill if fill is not None else np.nanmax(self.microstructure)+1, + self.microstructure.dtype) + if offset is None: offset = 0 + + l = np.clip( offset, 0,np.minimum(self.grid +offset,grid)) # noqa + r = np.clip( offset+self.grid,0,np.minimum(self.grid*2+offset,grid)) + L = np.clip(-offset, 0,np.minimum(grid -offset,self.grid)) + R = np.clip(-offset+grid, 0,np.minimum(grid*2 -offset,self.grid)) + + canvas[l[0]:r[0],l[1]:r[1],l[2]:r[2]] = self.microstructure[L[0]:R[0],L[1]:R[1],L[2]:R[2]] + + #self.add_comments('geom.py:renumber v{}'.format(version) + return self.update(canvas,origin=self.origin+offset*self.size/self.grid,rescale=True) + + + def substitute(self,from_microstructure,to_microstructure): + """Substitude microstructure indices.""" + substituted = self.get_microstructure() + for from_ms,to_ms in zip(from_microstructure,to_microstructure): + substituted[self.microstructure==from_ms] = to_ms + + return self.update(substituted) From 594fcb2b72f93b467f852e99e92690571da30473 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 24 May 2020 15:10:53 +0200 Subject: [PATCH 090/136] seems more appropriate --- python/damask/_geom.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/python/damask/_geom.py b/python/damask/_geom.py index 892000b7c..7c2fbd82e 100644 --- a/python/damask/_geom.py +++ b/python/damask/_geom.py @@ -242,7 +242,7 @@ class Geom: def get_grid(self): """Return the grid discretization.""" - return np.array(self.microstructure.shape) + return np.as:array(self.microstructure.shape) def get_homogenization(self): From 34adefd4ca6a5c90d38ab701d2015d074f805523 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 24 May 2020 18:30:45 +0200 Subject: [PATCH 091/136] simplified --- python/damask/_geom.py | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/python/damask/_geom.py b/python/damask/_geom.py index bfba3465b..57ab5b3b1 100644 --- a/python/damask/_geom.py +++ b/python/damask/_geom.py @@ -590,23 +590,23 @@ class Geom: dtype = float if np.isnan(fill) or int(fill) != fill or self.microstructure.dtype==np.float else int Eulers = R.as_Eulers(degrees=True) - # These rotations are always applied in the reference coordinate system, i.e. (z,x,z) not (z,x',z'') - # this seems to be ok, see https://www.cs.utexas.edu/~theshark/courses/cs354/lectures/cs354-14.pdf - microstructure = ndimage.rotate(self.microstructure,Eulers[2],(0,1),order=0, - prefilter=False,output=dtype,cval=fill) # rotation around z - microstructure = ndimage.rotate(microstructure,Eulers[1],(1,2),order=0, - prefilter=False,output=dtype,cval=fill) # rotation around x - microstructure = ndimage.rotate(microstructure,Eulers[0],(0,1),order=0, - prefilter=False,output=dtype,cval=fill) # rotation around z - origin = self.origin-(np.asarray(microstructure.shape)-self.grid)//2 * self.size/self.grid + microstructure_in = self.get_microstructure() + # These rotations are always applied in the reference coordinate system, i.e. (z,x,z) not (z,x',z'') + # see https://www.cs.utexas.edu/~theshark/courses/cs354/lectures/cs354-14.pdf + for angle,axis in zip(Eulers[::-1], [(0,1),(1,2),(0,1)]): + microstructure_out = ndimage.rotate(microstructure_in,angle,axis,order=0, + prefilter=False,output=dtype,cval=fill) + microstructure_in = microstructure_out + + origin = self.origin-(np.asarray(microstructure_out.shape)-self.grid)//2 * self.size/self.grid #self.add_comments('geom.py:renumber v{}'.format(version) - return self.update(microstructure,origin=origin,rescale=True) + return self.update(microstructure_out,origin=origin,rescale=True) def canvas(self,grid=None,offset=None,fill=None): - """Rotate microstructure (pad if required).""" + """Crop or enlarge/pad microstructure.""" if fill is None: fill = np.nanmax(self.microstructure) + 1 dtype = float if np.isnan(fill) or int(fill) != fill or self.microstructure.dtype==np.float else int From 296308e11ecf8ead7660e55cb2ce6cf947421853 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 24 May 2020 20:52:19 +0200 Subject: [PATCH 092/136] fix for rotation around 90 deg more tests --- python/damask/_geom.py | 16 ++- .../Geom/rotate_Eulers=0.0-32.0-240.0.geom | 85 ++++++++++++++ .../Geom/rotate_Eulers=32.0-68.0-21.0.geom | 104 ++++++++++++++++++ python/tests/test_Geom.py | 45 +++++++- 4 files changed, 242 insertions(+), 8 deletions(-) create mode 100644 python/tests/reference/Geom/rotate_Eulers=0.0-32.0-240.0.geom create mode 100644 python/tests/reference/Geom/rotate_Eulers=32.0-68.0-21.0.geom diff --git a/python/damask/_geom.py b/python/damask/_geom.py index 57ab5b3b1..26a7611c5 100644 --- a/python/damask/_geom.py +++ b/python/damask/_geom.py @@ -590,19 +590,23 @@ class Geom: dtype = float if np.isnan(fill) or int(fill) != fill or self.microstructure.dtype==np.float else int Eulers = R.as_Eulers(degrees=True) - microstructure_in = self.get_microstructure() + # These rotations are always applied in the reference coordinate system, i.e. (z,x,z) not (z,x',z'') # see https://www.cs.utexas.edu/~theshark/courses/cs354/lectures/cs354-14.pdf - for angle,axis in zip(Eulers[::-1], [(0,1),(1,2),(0,1)]): - microstructure_out = ndimage.rotate(microstructure_in,angle,axis,order=0, + for angle,axes in zip(Eulers[::-1], [(0,1),(1,2),(0,1)]): + microstructure_out = ndimage.rotate(microstructure_in,angle,axes,order=0, prefilter=False,output=dtype,cval=fill) - microstructure_in = microstructure_out + if np.prod(microstructure_in.shape) == np.prod(microstructure_out.shape): + # avoid scipy interpolation errors for rotations close to multiples of 90° + microstructure_in = np.rot90(microstructure_in,k=np.rint(angle/90.).astype(int),axes=axes) + else: + microstructure_in = microstructure_out - origin = self.origin-(np.asarray(microstructure_out.shape)-self.grid)//2 * self.size/self.grid + origin = self.origin-(np.asarray(microstructure_in.shape)-self.grid)*.5 * self.size/self.grid #self.add_comments('geom.py:renumber v{}'.format(version) - return self.update(microstructure_out,origin=origin,rescale=True) + return self.update(microstructure_in,origin=origin,rescale=True) def canvas(self,grid=None,offset=None,fill=None): diff --git a/python/tests/reference/Geom/rotate_Eulers=0.0-32.0-240.0.geom b/python/tests/reference/Geom/rotate_Eulers=0.0-32.0-240.0.geom new file mode 100644 index 000000000..a3d1de0b4 --- /dev/null +++ b/python/tests/reference/Geom/rotate_Eulers=0.0-32.0-240.0.geom @@ -0,0 +1,85 @@ +4 header +grid a 8 b 10 c 8 +size x 8e-06 y 1e-05 z 8e-06 +origin x 0.0 y -2.5e-06 z -2e-06 +homogenization 1 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 30 14 18 42 42 42 +42 42 29 13 17 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 31 15 19 42 42 42 +42 6 10 2 2 42 42 42 +42 1 2 2 2 2 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 32 16 20 42 42 42 +42 7 11 2 2 42 42 42 +42 7 11 2 2 42 42 42 +42 2 2 2 2 2 42 42 +42 42 2 2 31 35 42 42 +42 42 22 26 10 14 1 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 4 2 2 2 2 42 42 +42 42 2 2 32 36 42 42 +42 42 24 28 12 16 1 42 +42 42 42 7 7 1 1 42 +42 42 42 7 7 1 1 42 +42 42 42 1 1 1 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 25 29 13 17 1 42 +42 42 42 8 8 1 1 42 +42 42 42 1 1 1 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 1 1 1 42 42 +42 42 42 1 1 1 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 diff --git a/python/tests/reference/Geom/rotate_Eulers=32.0-68.0-21.0.geom b/python/tests/reference/Geom/rotate_Eulers=32.0-68.0-21.0.geom new file mode 100644 index 000000000..e29cd4266 --- /dev/null +++ b/python/tests/reference/Geom/rotate_Eulers=32.0-68.0-21.0.geom @@ -0,0 +1,104 @@ +4 header +grid a 11 b 11 c 9 +size x 1.1e-05 y 1.1000000000000001e-05 z 9e-06 +origin x -1.5e-06 y -3.0000000000000005e-06 z -2.4999999999999998e-06 +homogenization 1 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 1 2 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 1 42 42 42 42 42 42 +42 42 42 42 1 5 42 42 42 42 42 +42 42 42 1 7 4 42 42 42 42 42 +42 42 42 42 42 27 42 42 42 42 42 +42 42 42 42 42 42 2 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 1 1 42 42 42 42 42 42 +42 42 42 1 1 9 29 42 42 42 42 +42 42 1 1 11 8 28 2 42 42 42 +42 42 42 1 10 31 2 42 42 42 42 +42 42 42 42 30 2 2 2 42 42 42 +42 42 42 42 42 42 2 1 42 42 42 +42 42 42 42 42 42 42 1 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 1 42 42 42 42 42 42 42 +42 42 42 1 1 42 42 42 42 42 42 +42 42 1 16 36 12 32 42 42 42 42 +42 42 42 15 35 2 2 2 42 42 42 +42 42 42 42 2 2 2 11 3 42 42 +42 42 42 42 42 42 10 6 42 42 42 +42 42 42 42 42 42 42 6 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 1 42 42 42 42 42 42 42 +42 42 42 1 17 42 42 42 42 42 42 +42 42 42 16 36 37 2 42 42 42 42 +42 42 42 42 39 2 2 12 42 42 42 +42 42 42 38 2 2 2 11 8 42 42 +42 42 42 42 2 2 14 30 42 42 42 +42 42 42 42 42 42 13 30 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 40 42 42 42 42 42 42 +42 42 42 42 42 2 42 42 42 42 42 +42 42 42 42 42 2 2 15 42 42 42 +42 42 42 42 42 2 18 42 42 42 42 +42 42 42 42 42 42 17 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 2 20 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 +42 42 42 42 42 42 42 42 42 42 42 diff --git a/python/tests/test_Geom.py b/python/tests/test_Geom.py index 0f8c10066..e3aaf84a9 100644 --- a/python/tests/test_Geom.py +++ b/python/tests/test_Geom.py @@ -5,12 +5,13 @@ import pytest import numpy as np from damask import Geom +from damask import Rotation def geom_equal(a,b): return np.all(a.get_microstructure() == b.get_microstructure()) and \ - np.all(a.get_size() == b.get_size()) and \ - np.all(a.get_grid() == b.get_grid()) + np.all(a.get_grid() == b.get_grid()) and \ + np.allclose(a.get_size(), b.get_size()) @pytest.fixture def default(): @@ -98,6 +99,46 @@ class TestGeom: if update: modified.to_file(reference) assert geom_equal(modified,Geom.from_file(reference)) + def test_renumber(self,default): + modified = copy.deepcopy(default) + microstructure = modified.get_microstructure() + for m in np.unique(microstructure): + microstructure[microstructure==m] = microstructure.max() + np.random.randint(1,30) + modified.update(microstructure) + assert not geom_equal(modified,default) + modified.renumber() + assert geom_equal(modified,default) + + def test_substitute(self,default): + modified = copy.deepcopy(default) + microstructure = modified.get_microstructure() + offset = np.random.randint(1,500) + microstructure+=offset + modified.update(microstructure) + assert not geom_equal(modified,default) + modified.substitute(np.arange(default.microstructure.max())+1+offset, + np.arange(default.microstructure.max())+1) + assert geom_equal(modified,default) + + @pytest.mark.parametrize('axis_angle',[np.array([1,0,0,86.7]), np.array([0,1,0,90.4]), np.array([0,0,1,90]), + np.array([1,0,0,175]),np.array([0,-1,0,178]),np.array([0,0,1,180])]) + def test_rotate90(self,default,axis_angle): + modified = copy.deepcopy(default) + for i in range(np.rint(360/axis_angle[3]).astype(int)): + modified.rotate(Rotation.from_axis_angle(axis_angle,degrees=True)) + assert geom_equal(modified,default) + + @pytest.mark.parametrize('Eulers',[[32.0,68.0,21.0], + [0.0,32.0,240.0]]) + def test_rotate(self,default,update,reference_dir,Eulers): + modified = copy.deepcopy(default) + modified.rotate(Rotation.from_Eulers(Eulers,degrees=True)) + tag = 'Eulers={}-{}-{}'.format(*Eulers) + reference = os.path.join(reference_dir,'rotate_{}.geom'.format(tag)) + if update: modified.to_file(reference) + assert geom_equal(modified,Geom.from_file(reference)) + + @pytest.mark.parametrize('periodic',[True,False]) def test_tessellation_approaches(self,periodic): grid = np.random.randint(10,20,3) From 17aa3c00dc93048d9af695b2788088f772d9f5d2 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 24 May 2020 22:52:00 +0200 Subject: [PATCH 093/136] more tests --- python/damask/_geom.py | 2 +- python/tests/test_Geom.py | 25 ++++++++++++++++++++++++- 2 files changed, 25 insertions(+), 2 deletions(-) diff --git a/python/damask/_geom.py b/python/damask/_geom.py index 26a7611c5..12dbcc181 100644 --- a/python/damask/_geom.py +++ b/python/damask/_geom.py @@ -612,12 +612,12 @@ class Geom: def canvas(self,grid=None,offset=None,fill=None): """Crop or enlarge/pad microstructure.""" if fill is None: fill = np.nanmax(self.microstructure) + 1 + if offset is None: offset = 0 dtype = float if np.isnan(fill) or int(fill) != fill or self.microstructure.dtype==np.float else int canvas = np.full(self.grid if grid is None else grid, fill if fill is not None else np.nanmax(self.microstructure)+1, self.microstructure.dtype) - if offset is None: offset = 0 l = np.clip( offset, 0,np.minimum(self.grid +offset,grid)) # noqa r = np.clip( offset+self.grid,0,np.minimum(self.grid*2+offset,grid)) diff --git a/python/tests/test_Geom.py b/python/tests/test_Geom.py index e3aaf84a9..7a3823ab3 100644 --- a/python/tests/test_Geom.py +++ b/python/tests/test_Geom.py @@ -37,6 +37,7 @@ class TestGeom: default.get_size(), default.get_origin() ) + print(modified) assert geom_equal(modified,default) @@ -58,6 +59,22 @@ class TestGeom: new = Geom.from_file(tmpdir.join('default.geom')) assert geom_equal(new,default) + def test_invalid_combination(self,default): + with pytest.raises(ValueError): + default.update(default.microstructure[1:,1:,1:],size=np.ones(3), rescale=True) + + def test_invalid_size(self,default): + with pytest.raises(ValueError): + default.update(default.microstructure[1:,1:,1:],size=np.ones(2)) + + def test_invalid_microstructure(self,default): + with pytest.raises(ValueError): + default.update(default.microstructure[1]) + + def test_invalid_homogenization(self,default): + with pytest.raises(TypeError): + default.set_homogenization(homogenization=0) + @pytest.mark.parametrize('directions,reflect',[ (['x'], False), (['x','y','z'],True), @@ -122,7 +139,7 @@ class TestGeom: @pytest.mark.parametrize('axis_angle',[np.array([1,0,0,86.7]), np.array([0,1,0,90.4]), np.array([0,0,1,90]), np.array([1,0,0,175]),np.array([0,-1,0,178]),np.array([0,0,1,180])]) - def test_rotate90(self,default,axis_angle): + def test_rotate360(self,default,axis_angle): modified = copy.deepcopy(default) for i in range(np.rint(360/axis_angle[3]).astype(int)): modified.rotate(Rotation.from_axis_angle(axis_angle,degrees=True)) @@ -138,6 +155,12 @@ class TestGeom: if update: modified.to_file(reference) assert geom_equal(modified,Geom.from_file(reference)) + def test_canvas(self,default): + grid_add = np.random.randint(0,30,(3)) + modified = copy.deepcopy(default) + modified.canvas(modified.grid + grid_add) + e = default.grid + assert np.all(modified.microstructure[:e[0],:e[1],:e[2]] == default.microstructure) @pytest.mark.parametrize('periodic',[True,False]) def test_tessellation_approaches(self,periodic): From 39505507f1f759b80226236e70e1ea328a32347b Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 08:07:12 +0200 Subject: [PATCH 094/136] not needed anymore --- processing/post/addIPFcolor.py | 68 -------------------- processing/post/addPK2.py | 50 --------------- processing/post/addPole.py | 65 ------------------- processing/post/addStrainTensors.py | 98 ----------------------------- processing/post/rotateData.py | 62 ------------------ processing/post/viewTable.py | 89 -------------------------- processing/pre/geom_canvas.py | 61 ------------------ processing/pre/geom_check.py | 37 ----------- processing/pre/geom_renumber.py | 33 ---------- processing/pre/geom_rotate.py | 78 ----------------------- processing/pre/geom_translate.py | 55 ---------------- python/damask/_result.py | 17 ----- 12 files changed, 713 deletions(-) delete mode 100755 processing/post/addIPFcolor.py delete mode 100755 processing/post/addPK2.py delete mode 100755 processing/post/addPole.py delete mode 100755 processing/post/addStrainTensors.py delete mode 100755 processing/post/rotateData.py delete mode 100755 processing/post/viewTable.py delete mode 100755 processing/pre/geom_canvas.py delete mode 100755 processing/pre/geom_check.py delete mode 100755 processing/pre/geom_renumber.py delete mode 100755 processing/pre/geom_rotate.py delete mode 100755 processing/pre/geom_translate.py diff --git a/processing/post/addIPFcolor.py b/processing/post/addIPFcolor.py deleted file mode 100755 index 014b0147d..000000000 --- a/processing/post/addIPFcolor.py +++ /dev/null @@ -1,68 +0,0 @@ -#!/usr/bin/env python3 - -import os -import sys -from io import StringIO -from optparse import OptionParser - -import numpy as np - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - -# -------------------------------------------------------------------- -# MAIN -# -------------------------------------------------------------------- - -parser = OptionParser(option_class=damask.extendableOption, usage='%prog options [ASCIItable(s)]', description = """ -Add RGB color value corresponding to TSL-OIM scheme for inverse pole figures. - -""", version = scriptID) - -parser.add_option('-p', - '--pole', - dest = 'pole', - type = 'float', nargs = 3, metavar = 'float float float', - help = 'lab frame direction for inverse pole figure [%default]') -parser.add_option('-s', - '--symmetry', - dest = 'symmetry', - type = 'choice', choices = damask.Symmetry.lattices[1:], metavar='string', - help = 'crystal symmetry [%default] {{{}}} '.format(', '.join(damask.Symmetry.lattices[1:]))) -parser.add_option('-o', - '--orientation', - dest = 'quaternion', - metavar = 'string', - help = 'label of crystal orientation given as unit quaternion [%default]') - -parser.set_defaults(pole = (0.0,0.0,1.0), - quaternion = 'orientation', - symmetry = damask.Symmetry.lattices[-1], - ) - -(options, filenames) = parser.parse_args() -if filenames == []: filenames = [None] - -# damask.Orientation requires Bravais lattice, but we are only interested in symmetry -symmetry2lattice={'cubic':'fcc','hexagonal':'hex','tetragonal':'bct'} -lattice = symmetry2lattice[options.symmetry] - -pole = np.array(options.pole) -pole /= np.linalg.norm(pole) - -for name in filenames: - damask.util.report(scriptName,name) - - table = damask.Table.from_ASCII(StringIO(''.join(sys.stdin.read())) if name is None else name) - orientation = table.get(options.quaternion) - color = np.empty((orientation.shape[0],3)) - for i,o in enumerate(orientation): - color[i] = damask.Orientation(o,lattice = lattice).IPFcolor(pole) - - table.add('IPF_{:g}{:g}{:g}_{sym}'.format(*options.pole,sym = options.symmetry.lower()), - color, - scriptID+' '+' '.join(sys.argv[1:])) - table.to_ASCII(sys.stdout if name is None else name) diff --git a/processing/post/addPK2.py b/processing/post/addPK2.py deleted file mode 100755 index 2894a5a90..000000000 --- a/processing/post/addPK2.py +++ /dev/null @@ -1,50 +0,0 @@ -#!/usr/bin/env python3 - -import os -import sys -from io import StringIO -from optparse import OptionParser - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - -# -------------------------------------------------------------------- -# MAIN -# -------------------------------------------------------------------- - -parser = OptionParser(option_class=damask.extendableOption, usage='%prog options [ASCIItable(s)]', description = """ -Add column(s) containing Second Piola--Kirchhoff stress based on given column(s) of deformation -gradient and first Piola--Kirchhoff stress. - -""", version = scriptID) - -parser.add_option('-f','--defgrad', - dest = 'defgrad', - type = 'string', metavar = 'string', - help = 'heading of columns containing deformation gradient [%default]') -parser.add_option('-p','--stress', - dest = 'stress', - type = 'string', metavar = 'string', - help = 'heading of columns containing first Piola--Kirchhoff stress [%default]') - -parser.set_defaults(defgrad = 'f', - stress = 'p', - ) - -(options,filenames) = parser.parse_args() -if filenames == []: filenames = [None] - -for name in filenames: - damask.util.report(scriptName,name) - - table = damask.Table.from_ASCII(StringIO(''.join(sys.stdin.read())) if name is None else name) - - table.add('S', - damask.mechanics.PK2(table.get(options.stress ).reshape(-1,3,3), - table.get(options.defgrad).reshape(-1,3,3)).reshape(-1,9), - scriptID+' '+' '.join(sys.argv[1:])) - - table.to_ASCII(sys.stdout if name is None else name) diff --git a/processing/post/addPole.py b/processing/post/addPole.py deleted file mode 100755 index 58f9235dc..000000000 --- a/processing/post/addPole.py +++ /dev/null @@ -1,65 +0,0 @@ -#!/usr/bin/env python3 - -import os -import sys -from io import StringIO -from optparse import OptionParser - -import numpy as np - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - - -# -------------------------------------------------------------------- -# MAIN -# -------------------------------------------------------------------- - -parser = OptionParser(option_class=damask.extendableOption, usage='%prog options [ASCIItable(s)]', description = """ -Add coordinates of stereographic projection of given direction (pole) in crystal frame. - -""", version = scriptID) - -parser.add_option('-p', - '--pole', - dest = 'pole', - type = 'float', nargs = 3, metavar = 'float float float', - help = 'crystal frame direction for pole figure [%default]') -parser.add_option('--polar', - dest = 'polar', - action = 'store_true', - help = 'output polar coordinates (r,φ) instead of Cartesian coordinates (x,y)') -parser.add_option('-o', - '--orientation', - dest = 'quaternion', - metavar = 'string', - help = 'label of crystal orientation given as unit quaternion [%default]') - -parser.set_defaults(pole = (1.0,0.0,0.0), - quaternion = 'orientation', - ) - -(options, filenames) = parser.parse_args() -if filenames == []: filenames = [None] - -pole = np.array(options.pole) -pole /= np.linalg.norm(pole) - -for name in filenames: - damask.util.report(scriptName,name) - - table = damask.Table.from_ASCII(StringIO(''.join(sys.stdin.read())) if name is None else name) - orientation = table.get(options.quaternion) - poles = np.empty((orientation.shape[0],2)) - for i,o in enumerate(orientation): - rotatedPole = damask.Rotation(o)*pole # rotate pole according to crystal orientation - (x,y) = rotatedPole[0:2]/(1.+abs(pole[2])) # stereographic projection - poles[i] = [np.sqrt(x*x+y*y),np.arctan2(y,x)] if options.polar else [x,y] # cartesian coordinates - - table.add('pole_{}{}{}'.format(*options.pole), - poles, - scriptID+' '+' '.join(sys.argv[1:])) - table.to_ASCII(sys.stdout if name is None else name) diff --git a/processing/post/addStrainTensors.py b/processing/post/addStrainTensors.py deleted file mode 100755 index 84c460b00..000000000 --- a/processing/post/addStrainTensors.py +++ /dev/null @@ -1,98 +0,0 @@ -#!/usr/bin/env python3 - -import os -import sys -from io import StringIO -from optparse import OptionParser - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - -def parameters(stretch,strain): - """Albrecht Bertram: Elasticity and Plasticity of Large Deformations An Introduction (3rd Edition, 2012), p. 102.""" - return { - 'V#ln': ('V',0.0), - 'U#ln': ('U',0.0), - 'V#Biot': ('V',-.5), - 'U#Biot': ('U',+.5), - 'V#Green': ('V',-1.), - 'U#Green': ('U',+1.), - }[stretch+'#'+strain] - - -# -------------------------------------------------------------------- -# MAIN -# -------------------------------------------------------------------- - -parser = OptionParser(option_class=damask.extendableOption, usage='%prog options [ASCIItable(s)]', description = """ -Add column(s) containing given strains based on given stretches of requested deformation gradient column(s). - -""", version = scriptID) - -parser.add_option('-u','--right', - dest = 'right', - action = 'store_true', - help = 'material strains based on right Cauchy--Green deformation, i.e., C and U') -parser.add_option('-v','--left', - dest = 'left', - action = 'store_true', - help = 'spatial strains based on left Cauchy--Green deformation, i.e., B and V') -parser.add_option('-0','--logarithmic', - dest = 'logarithmic', - action = 'store_true', - help = 'calculate logarithmic strain tensor') -parser.add_option('-1','--biot', - dest = 'biot', - action = 'store_true', - help = 'calculate biot strain tensor') -parser.add_option('-2','--green', - dest = 'green', - action = 'store_true', - help = 'calculate green strain tensor') -parser.add_option('-f','--defgrad', - dest = 'defgrad', - action = 'extend', - metavar = '', - help = 'heading(s) of columns containing deformation tensor values [%default]') - -parser.set_defaults( - defgrad = ['f'], - ) - -(options,filenames) = parser.parse_args() -if filenames == []: filenames = [None] - -if len(options.defgrad) > 1: - options.defgrad = options.defgrad[1:] - -stretches = [] -strains = [] - -if options.right: stretches.append('U') -if options.left: stretches.append('V') -if options.logarithmic: strains.append('ln') -if options.biot: strains.append('Biot') -if options.green: strains.append('Green') - -if options.defgrad is None: - parser.error('no data column specified.') - -for name in filenames: - damask.util.report(scriptName,name) - - table = damask.Table.from_ASCII(StringIO(''.join(sys.stdin.read())) if name is None else name) - - for defgrad in options.defgrad: - F = table.get(defgrad).reshape(-1,3,3) - for theStretch in stretches: - for theStrain in strains: - (t,m) = parameters(theStretch,theStrain) - label = '{}({}){}'.format(theStrain,theStretch,defgrad if defgrad != 'f' else '') - table.add(label, - damask.mechanics.strain_tensor(F,t,m).reshape(-1,9), - scriptID+' '+' '.join(sys.argv[1:])) - - table.to_ASCII(sys.stdout if name is None else name) diff --git a/processing/post/rotateData.py b/processing/post/rotateData.py deleted file mode 100755 index ee172c64d..000000000 --- a/processing/post/rotateData.py +++ /dev/null @@ -1,62 +0,0 @@ -#!/usr/bin/env python3 - -import os -import sys -from io import StringIO -from optparse import OptionParser - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - - -# -------------------------------------------------------------------- -# MAIN -# -------------------------------------------------------------------- - -parser = OptionParser(option_class=damask.extendableOption, usage='%prog options [ASCIItable(s)]', description = """ -Rotate vector and/or tensor column data by given angle around given axis. - -""", version = scriptID) - -parser.add_option('-d', '--data', - dest = 'data', - action = 'extend', metavar = '', - help = 'vector/tensor value(s) label(s)') -parser.add_option('-r', '--rotation', - dest = 'rotation', - type = 'float', nargs = 4, metavar = ' '.join(['float']*4), - help = 'axis and angle to rotate data [%default]') -parser.add_option('--degrees', - dest = 'degrees', - action = 'store_true', - help = 'angles are given in degrees') - -parser.set_defaults(rotation = (1.,1.,1.,0), # no rotation about (1,1,1) - degrees = False, - ) - -(options,filenames) = parser.parse_args() -if filenames == []: filenames = [None] - -if options.data is None: - parser.error('no data column specified.') - -r = damask.Rotation.from_axis_angle(options.rotation,options.degrees,normalise=True) - -for name in filenames: - damask.util.report(scriptName,name) - - table = damask.Table.from_ASCII(StringIO(''.join(sys.stdin.read())) if name is None else name) - - for data in options.data: - d = table.get(data) - if table.shapes[data] == (9,): d=d.reshape(-1,3,3) - d = r.broadcast_to(d.shape[0:1]) @ d - if table.shapes[data] == (9,): d=d.reshape(-1,9) - - table.set(data,d,scriptID+' '+' '.join(sys.argv[1:])) - - table.to_ASCII(sys.stdout if name is None else name) diff --git a/processing/post/viewTable.py b/processing/post/viewTable.py deleted file mode 100755 index 1f134754d..000000000 --- a/processing/post/viewTable.py +++ /dev/null @@ -1,89 +0,0 @@ -#!/usr/bin/env python3 - -import os -from optparse import OptionParser - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - - -# -------------------------------------------------------------------- -# MAIN -# -------------------------------------------------------------------- - -parser = OptionParser(usage='%prog options [ASCIItable(s)]', description = """ -Show components of given ASCIItable(s). - -""", version = scriptID) - - -parser.add_option('-a','--head', - dest = 'head', - action = 'store_true', - help = 'output complete header (info + labels)') -parser.add_option('-i','--info', - dest = 'info', - action = 'store_true', - help = 'output info lines') -parser.add_option('-l','--labels', - dest = 'labels', - action = 'store_true', - help = 'output labels') -parser.add_option('-d','--data', - dest = 'data', - action = 'store_true', - help = 'output data') -parser.add_option('-t','--table', - dest = 'table', - action = 'store_true', - help = 'output heading line for proper ASCIItable format') -parser.add_option('--nolabels', - dest = 'labeled', - action = 'store_false', - help = 'table has no labels') -parser.set_defaults(table = False, - head = False, - info = False, - labels = False, - data = False, - labeled = True, - ) - -(options,filenames) = parser.parse_args() - -# --- loop over input files ------------------------------------------------------------------------- - -if filenames == []: filenames = [None] - -for name in filenames: - try: - table = damask.ASCIItable(name = name, labeled = options.labeled, readonly = True) - except IOError: - continue - details = ', '.join( - (['header'] if options.table else []) + - (['info'] if options.head or options.info else []) + - (['labels'] if options.head or options.labels else []) + - (['data'] if options.data else []) + - [] - ) - damask.util.report(scriptName,(name if name is not None else '') + ('' if details == '' else ' -- '+details)) - -# ------------------------------------------ output head --------------------------------------- - - table.head_read() - if not (options.head or options.info): table.info_clear() - if not (options.head or (options.labels and options.labeled)): table.labels_clear() - - table.head_write(header = options.table) - -# ------------------------------------------ output data --------------------------------------- - - outputAlive = options.data - while outputAlive and table.data_read(): # read next data line of ASCII table - outputAlive = table.data_write() # output line - - table.close() diff --git a/processing/pre/geom_canvas.py b/processing/pre/geom_canvas.py deleted file mode 100755 index b309364e8..000000000 --- a/processing/pre/geom_canvas.py +++ /dev/null @@ -1,61 +0,0 @@ -#!/usr/bin/env python3 - -import os -import sys -from io import StringIO -from optparse import OptionParser - -import numpy as np - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - - -# -------------------------------------------------------------------- -# MAIN -# -------------------------------------------------------------------- - -parser = OptionParser(option_class=damask.extendableOption, usage='%prog options [geomfile(s)]', description = """ -Increases or decreases the (three-dimensional) canvas. -Grid can be given as absolute or relative values, e.g. 16 16 16 or 2x 0.5x 32. - -""", version = scriptID) - -parser.add_option('-g','--grid', - dest = 'grid', - type = 'string', nargs = 3, metavar = ' '.join(['string']*3), - help = 'a,b,c grid of hexahedral box') -parser.add_option('-o','--offset', - dest = 'offset', - type = 'int', nargs = 3, metavar = ' '.join(['int']*3), - help = 'a,b,c offset from old to new origin of grid [%default]') -parser.add_option('-f','--fill', - dest = 'fill', - type = 'float', metavar = 'int', - help = 'background microstructure index, defaults to max microstructure index + 1') - -parser.set_defaults(offset = (0,0,0)) - -(options, filenames) = parser.parse_args() -if filenames == []: filenames = [None] - - -for name in filenames: - damask.util.report(scriptName,name) - - geom = damask.Geom.from_file(StringIO(''.join(sys.stdin.read())) if name is None else name) - offset = np.asarray(options.offset) - - if options.grid is not None: - grid = np.maximum(1, - np.array([int(o*float(n.lower().replace('x',''))) if n.lower().endswith('x') \ - else int(n) for o,n in zip(geom.grid,options.grid)],dtype=int)) - else: - grid = np.array(options.grid,dtype=int) - - damask.util.croak(geom.canvas(grid,np.asarray(options.offset),options.fill)) - geom.add_comments(scriptID + ' ' + ' '.join(sys.argv[1:])) - geom.to_file(sys.stdout if name is None else name,pack=False) diff --git a/processing/pre/geom_check.py b/processing/pre/geom_check.py deleted file mode 100755 index e7e4d1009..000000000 --- a/processing/pre/geom_check.py +++ /dev/null @@ -1,37 +0,0 @@ -#!/usr/bin/env python3 - -import os -import sys -from io import StringIO -from optparse import OptionParser - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - - -#-------------------------------------------------------------------------------------------------- -# MAIN -#-------------------------------------------------------------------------------------------------- - -parser = OptionParser(option_class=damask.extendableOption, usage='%prog [geomfile(s)]', description = """ -Writes vtk file for visualization. - -""", version = scriptID) - -(options, filenames) = parser.parse_args() -if filenames == []: filenames = [None] - -for name in filenames: - damask.util.report(scriptName,name) - - geom = damask.Geom.from_file(StringIO(''.join(sys.stdin.read())) if name is None else name) - - damask.util.croak(geom) - - if name: - geom.to_vtk(os.path.splitext(name)[0]) - else: - sys.stdout.write(geom.to_vtk()) diff --git a/processing/pre/geom_renumber.py b/processing/pre/geom_renumber.py deleted file mode 100755 index 8eab9064a..000000000 --- a/processing/pre/geom_renumber.py +++ /dev/null @@ -1,33 +0,0 @@ -#!/usr/bin/env python3 - -import os -import sys -from io import StringIO -from optparse import OptionParser - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - - -#-------------------------------------------------------------------------------------------------- -# MAIN -#-------------------------------------------------------------------------------------------------- - -parser = OptionParser(option_class=damask.extendableOption, usage='%prog [geomfile(s)]', description = """ -Renumber sorted microstructure indices to 1,...,N. - -""", version=scriptID) - -(options, filenames) = parser.parse_args() -if filenames == []: filenames = [None] - -for name in filenames: - damask.util.report(scriptName,name) - - geom = damask.Geom.from_file(StringIO(''.join(sys.stdin.read())) if name is None else name) - damask.util.croak(geom.renumber()) - geom.add_comments(scriptID + ' ' + ' '.join(sys.argv[1:])) - geom.to_file(sys.stdout if name is None else name,pack=False) diff --git a/processing/pre/geom_rotate.py b/processing/pre/geom_rotate.py deleted file mode 100755 index bbfeceb0b..000000000 --- a/processing/pre/geom_rotate.py +++ /dev/null @@ -1,78 +0,0 @@ -#!/usr/bin/env python3 - -import os -import sys -from io import StringIO -from optparse import OptionParser - -from scipy import ndimage -import numpy as np - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - - -#-------------------------------------------------------------------------------------------------- -# MAIN -#-------------------------------------------------------------------------------------------------- - -parser = OptionParser(option_class=damask.extendableOption, usage='%prog options [geomfile(s)]', description = """ -Rotates original microstructure and embeddeds it into buffer material. - -""", version=scriptID) - -parser.add_option('-r', '--rotation', - dest='rotation', - type = 'float', nargs = 4, metavar = ' '.join(['float']*4), - help = 'rotation given as axis and angle') -parser.add_option('-e', '--eulers', - dest = 'eulers', - type = 'float', nargs = 3, metavar = ' '.join(['float']*3), - help = 'rotation given as Euler angles') -parser.add_option('-d', '--degrees', - dest = 'degrees', - action = 'store_true', - help = 'Euler angles/axis angle are given in degrees') -parser.add_option('-m', '--matrix', - dest = 'matrix', - type = 'float', nargs = 9, metavar = ' '.join(['float']*9), - help = 'rotation given as matrix') -parser.add_option('-q', '--quaternion', - dest = 'quaternion', - type = 'float', nargs = 4, metavar = ' '.join(['float']*4), - help = 'rotation given as quaternion') -parser.add_option('-f', '--fill', - dest = 'fill', - type = 'float', metavar = 'int', - help = 'background microstructure index, defaults to max microstructure index + 1') - -parser.set_defaults(degrees = False) - -(options, filenames) = parser.parse_args() -if filenames == []: filenames = [None] - -if [options.rotation,options.eulers,options.matrix,options.quaternion].count(None) < 3: - parser.error('more than one rotation specified.') -if [options.rotation,options.eulers,options.matrix,options.quaternion].count(None) > 3: - parser.error('no rotation specified.') - -if options.quaternion is not None: - rot = damask.Rotation.from_quaternion(np.array(options.quaternion)) # we might need P=+1 here, too... -if options.rotation is not None: - rot = damask.Rotation.from_axis_angle(np.array(options.rotation),degrees=options.degrees,normalise=True,P=+1) -if options.matrix is not None: - rot = damask.Rotation.from_matrix(np.array(options.Matrix)) -if options.eulers is not None: - rot = damask.Rotation.from_Eulers(np.array(options.eulers),degrees=options.degrees) - - -for name in filenames: - damask.util.report(scriptName,name) - - geom = damask.Geom.from_file(StringIO(''.join(sys.stdin.read())) if name is None else name) - damask.util.croak(geom.rotate(rot,options.fill)) - geom.add_comments(scriptID + ' ' + ' '.join(sys.argv[1:])) - geom.to_file(sys.stdout if name is None else name,pack=False) diff --git a/processing/pre/geom_translate.py b/processing/pre/geom_translate.py deleted file mode 100755 index 25164b794..000000000 --- a/processing/pre/geom_translate.py +++ /dev/null @@ -1,55 +0,0 @@ -#!/usr/bin/env python3 - -import os -import sys -from optparse import OptionParser -from io import StringIO - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - - -#-------------------------------------------------------------------------------------------------- -# MAIN -#-------------------------------------------------------------------------------------------------- - -parser = OptionParser(option_class=damask.extendableOption, usage='%prog options [geomfile(s)]', description = """ -Translate microstructure indices (shift or substitute) and/or geometry origin. - -""", version=scriptID) - -parser.add_option('-o', '--origin', - dest = 'origin', - type = 'float', nargs = 3, metavar = ' '.join(['float']*3), - help = 'offset from old to new origin of grid') -parser.add_option('-m', '--microstructure', - dest = 'microstructure', - type = 'int', metavar = 'int', - help = 'offset from old to new microstructure indices (after substitution)') -parser.add_option('-s', '--substitute', - dest = 'substitute', - action = 'extend', metavar = '', - help = 'substitutions of microstructure indices from,to,from,to,...') - -parser.set_defaults(origin = (0.0,0.0,0.0), - microstructure = 0, - substitute = [] - ) - -(options, filenames) = parser.parse_args() -if filenames == []: filenames = [None] - -sub = list(map(int,options.substitute)) - -for name in filenames: - damask.util.report(scriptName,name) - - geom = damask.Geom.from_file(StringIO(''.join(sys.stdin.read())) if name is None else name) - geom.renumber(sub[0::2],sub[1::2],origin=geom.origin+options.origin) - geom.microstructure+= option.microstructure - damask.util.croak(geom) - geom.add_comments(scriptID + ' ' + ' '.join(sys.argv[1:])) - geom.to_file(sys.stdout if name is None else name,pack=False) diff --git a/python/damask/_result.py b/python/damask/_result.py index 6526e63ed..9f58998d1 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -1197,20 +1197,3 @@ class Result: inc[3:].zfill(N_digits)) v.write(file_out) - -################################################################################################### -# BEGIN DEPRECATED - - def set_by_time(self,start,end): - """ - Set active increments based on start and end time. - - Parameters - ---------- - start : float - start time (included) - end : float - end time (included) - - """ - self._manage_selection('set','times',self.times_in_range(start,end)) From 77b68ab86f588143c2e1595d8731e64bb990a75d Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 09:39:39 +0200 Subject: [PATCH 095/136] using rotation class for rotations --- processing/post/addAPS34IDEstrainCoords.py | 13 ++++--------- python/damask/_rotation.py | 1 + 2 files changed, 5 insertions(+), 9 deletions(-) diff --git a/processing/post/addAPS34IDEstrainCoords.py b/processing/post/addAPS34IDEstrainCoords.py index c14983799..d71116c6a 100755 --- a/processing/post/addAPS34IDEstrainCoords.py +++ b/processing/post/addAPS34IDEstrainCoords.py @@ -32,15 +32,12 @@ parser.add_option('--depth', dest='depth', metavar='string', if filenames == []: filenames = [None] if options.frame is None: - parser.error('frame not specified') + parser.error('frame not specified') if options.depth is None: - parser.error('depth not specified') + parser.error('depth not specified') -theta=-0.75*np.pi -RotMat2TSL=np.array([[1., 0., 0.], - [0., np.cos(theta), np.sin(theta)], # Orientation to account for -135 deg - [0., -np.sin(theta), np.cos(theta)]]) # rotation for TSL convention +rot_to_TSL = damask.Rotation.from_axis_angle([-1,0,0,.75*np.pi]) for name in filenames: damask.util.report(scriptName,name) @@ -50,8 +47,6 @@ for name in filenames: coord = - table.get(options.frame) coord[:,2] += table.get(options.depth)[:,0] - table.add('coord', - np.einsum('ijk,ik->ij',np.broadcast_to(RotMat2TSL,(coord.shape[0],3,3)),coord), - scriptID+' '+' '.join(sys.argv[1:])) + table.add('coord',rot_to_TSL.broadcast_to(coord.shape[0]) @ coord,scriptID+' '+' '.join(sys.argv[1:])) table.to_ASCII(sys.stdout if name is None else name) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index d639cb0e0..ee2cbc0c6 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -157,6 +157,7 @@ class Rotation: def broadcast_to(self,shape): + if isinstance(shape,int): shape = (shape,) if self.shape == (): q = np.broadcast_to(self.quaternion,shape+(4,)) else: From cd4e992900f6cadad3e847153e36eb0ebe3e1f99 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 09:39:53 +0200 Subject: [PATCH 096/136] not needed anymore --- processing/post/addCalculation.py | 183 ------------------------------ processing/post/addNorm.py | 75 ------------ 2 files changed, 258 deletions(-) delete mode 100755 processing/post/addCalculation.py delete mode 100755 processing/post/addNorm.py diff --git a/processing/post/addCalculation.py b/processing/post/addCalculation.py deleted file mode 100755 index 79fdd9455..000000000 --- a/processing/post/addCalculation.py +++ /dev/null @@ -1,183 +0,0 @@ -#!/usr/bin/env python3 - -import os -import sys -from optparse import OptionParser -import re -from collections.abc import Iterable -import math # noqa - -import scipy # noqa -import scipy.linalg # noqa -import numpy as np - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - -def listify(x): - return x if isinstance(x, Iterable) else [x] - - -# -------------------------------------------------------------------- -# MAIN -# -------------------------------------------------------------------- - -parser = OptionParser(option_class=damask.extendableOption, usage='%prog options [ASCIItable(s)]', description = """ -Add or alter column(s) with derived values according to user-defined arithmetic operation between column(s). -Column labels are tagged by '#label#' in formulas. Use ';' for ',' in functions. -Numpy is available as 'np'. - -Special variables: #_row_# -- row index -Examples: -(1) magnitude of vector -- "np.linalg.norm(#vec#)" -(2) rounded root of row number -- "round(math.sqrt(#_row_#);3)" - -""", version = scriptID) - -parser.add_option('-l','--label', - dest = 'labels', - action = 'extend', metavar = '', - help = '(list of) new column labels') -parser.add_option('-f','--formula', - dest = 'formulas', - action = 'extend', metavar = '', - help = '(list of) formulas corresponding to labels') - -parser.add_option('-c','--condition', - dest = 'condition', metavar='string', - help = 'condition to alter existing column data (optional)') - -(options,filenames) = parser.parse_args() - -if options.labels is None or options.formulas is None: - parser.error('no formulas and/or labels specified.') -if len(options.labels) != len(options.formulas): - parser.error('number of labels ({}) and formulas ({}) do not match.'.format(len(options.labels),len(options.formulas))) - -for i in range(len(options.formulas)): - options.formulas[i] = options.formulas[i].replace(';',',') - -# ------------------------------------- loop over input files -------------------------------------- - -if filenames == []: filenames = [None] - -for name in filenames: - try: - table = damask.ASCIItable(name = name) - except IOError: - continue - damask.util.report(scriptName,name) - -# ------------------------------------------ read header ------------------------------------------- - - table.head_read() - -# -------------------------------------------------------------------------------------------------- - specials = { \ - '_row_': 0, - } - -# --------------------------------------- evaluate condition --------------------------------------- - if options.condition is not None: - condition = options.condition # copy per file, since might be altered inline - breaker = False - - for position,(all,marker,column) in enumerate(set(re.findall(r'#(([s]#)?(.+?))#',condition))): # find three groups - idx = table.label_index(column) - dim = table.label_dimension(column) - if idx < 0 and column not in specials: - damask.util.croak('column "{}" not found.'.format(column)) - breaker = True - else: - if column in specials: - replacement = 'specials["{}"]'.format(column) - elif dim == 1: # scalar input - replacement = '{}(table.data[{}])'.format({ '':'float', - 's#':'str'}[marker],idx) # take float or string value of data column - elif dim > 1: # multidimensional input (vector, tensor, etc.) - replacement = 'np.array(table.data[{}:{}],dtype=float)'.format(idx,idx+dim) # use (flat) array representation - - condition = condition.replace('#'+all+'#',replacement) - - if breaker: continue # found mistake in condition evaluation --> next file - -# ------------------------------------------ build formulas ---------------------------------------- - - evaluator = {} - - for label,formula in zip(options.labels,options.formulas): - for column in re.findall(r'#(.+?)#',formula): # loop over column labels in formula - idx = table.label_index(column) - dim = table.label_dimension(column) - if column in specials: - replacement = 'specials["{}"]'.format(column) - elif dim == 1: # scalar input - replacement = 'float(table.data[{}])'.format(idx) # take float value of data column - elif dim > 1: # multidimensional input (vector, tensor, etc.) - replacement = 'np.array(table.data[{}:{}],dtype=float)'.format(idx,idx+dim) # use (flat) array representation - else: - damask.util.croak('column {} not found, skipping {}...'.format(column,label)) - options.labels.remove(label) - break - - formula = formula.replace('#'+column+'#',replacement) - - evaluator[label] = formula - -# ---------------------------- separate requested labels into old and new -------------------------- - - veterans = list(set(options.labels)&set(table.labels(raw=False)+table.labels(raw=True)) ) # intersection of requested and existing - newbies = list(set(options.labels)-set(table.labels(raw=False)+table.labels(raw=True)) ) # requested but not existing - -# ------------------------------------------ process data ------------------------------------------ - - firstLine = True - outputAlive = True - - while outputAlive and table.data_read(): # read next data line of ASCII table - specials['_row_'] += 1 # count row - - if firstLine: - firstLine = False - -# ---------------------------- line 1: determine dimension of formulas ----------------------------- - - resultDim = {} - for label in list(options.labels): # iterate over stable copy - resultDim[label] = np.size(eval(evaluator[label])) # get dimension of formula[label] - if resultDim[label] == 0: options.labels.remove(label) # remove label if invalid result - - for veteran in list(veterans): - if resultDim[veteran] != table.label_dimension(veteran): - damask.util.croak('skipping {} due to inconsistent dimension...'.format(veteran)) - veterans.remove(veteran) # discard culprit - -# ----------------------------------- line 1: assemble header -------------------------------------- - - for newby in newbies: - table.labels_append(['{}_{}'.format(i+1,newby) for i in range(resultDim[newby])] - if resultDim[newby] > 1 else newby) - - table.info_append(scriptID + '\t' + ' '.join(sys.argv[1:])) - table.head_write() - -# -------------------------------------- evaluate formulas ----------------------------------------- - - if options.condition is None or eval(condition): # condition for veteran replacement fulfilled - for veteran in veterans: # evaluate formulas that overwrite - table.data[table.label_index(veteran): - table.label_index(veteran)+table.label_dimension(veteran)] = \ - listify(eval(evaluator[veteran])) - - for newby in newbies: # evaluate formulas that append - table.data_append(listify(eval(evaluator[newby]))) - - outputAlive = table.data_write() # output processed line - -# ------------------------------------- output finalization ---------------------------------------- - - table.close() # close ASCII table - diff --git a/processing/post/addNorm.py b/processing/post/addNorm.py deleted file mode 100755 index 4ac2bf899..000000000 --- a/processing/post/addNorm.py +++ /dev/null @@ -1,75 +0,0 @@ -#!/usr/bin/env python3 - -import os -import sys -from io import StringIO -from optparse import OptionParser - -import numpy as np - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - -# definition of element-wise p-norms for matrices -# ToDo: better use numpy.linalg.norm - -def norm(which,object): - - if which == 'Abs': # p = 1 - return sum(map(abs, object)) - elif which == 'Frobenius': # p = 2 - return np.sqrt(sum([x*x for x in object])) - elif which == 'Max': # p = inf - return max(map(abs, object)) - else: - return -1 - - -# -------------------------------------------------------------------- -# MAIN -# -------------------------------------------------------------------- - -parser = OptionParser(option_class=damask.extendableOption, usage='%prog options [ASCIItable(s)]', description = """ -Add column(s) containing norm of requested column(s) being either vectors or tensors. - -""", version = scriptID) - -normChoices = ['abs','frobenius','max'] -parser.add_option('-n','--norm', - dest = 'norm', - type = 'choice', choices = normChoices, metavar='string', - help = 'type of element-wise p-norm [frobenius] {%s}'%(','.join(map(str,normChoices)))) -parser.add_option('-l','--label', - dest = 'labels', - action = 'extend', metavar = '', - help = 'heading of column(s) to calculate norm of') - -parser.set_defaults(norm = 'frobenius', - ) - -(options,filenames) = parser.parse_args() -if filenames == []: filenames = [None] - -if options.norm.lower() not in normChoices: - parser.error('invalid norm ({}) specified.'.format(options.norm)) -if options.labels is None: - parser.error('no data column specified.') - -for name in filenames: - damask.util.report(scriptName,name) - - table = damask.Table.from_ASCII(StringIO(''.join(sys.stdin.read())) if name is None else name) - for label in options.labels: - data = table.get(label) - data_norm = np.empty((data.shape[0],1)) - for i,d in enumerate(data): - data_norm[i] = norm(options.norm.capitalize(),d) - - table.add('norm{}({})'.format(options.norm.capitalize(),label), - data_norm, - scriptID+' '+' '.join(sys.argv[1:])) - - table.to_ASCII(sys.stdout if name is None else name) From 3f221ab5edcefcdbe8299fb9882ac89c4d22ea38 Mon Sep 17 00:00:00 2001 From: Sharan Roongta Date: Mon, 25 May 2020 12:54:43 +0200 Subject: [PATCH 097/136] polishing --- src/YAML_parse.f90 | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/src/YAML_parse.f90 b/src/YAML_parse.f90 index 429eb6e62..75a59f342 100644 --- a/src/YAML_parse.f90 +++ b/src/YAML_parse.f90 @@ -11,13 +11,16 @@ module YAML_parse contains - +!-------------------------------------------------------------------------------------------------- +!> @brief do sanity checks +!-------------------------------------------------------------------------------------------------- subroutine YAML_init call selfTest end subroutine YAML_init + !-------------------------------------------------------------------------------------------------- !> @brief reads the flow style string and stores it in the form of dictionaries, lists and scalars. !> @details A node type pointer can either point to a dictionary, list or scalar type entities. @@ -188,7 +191,8 @@ logical function isKey(line) if(len(IO_rmComment(line)) == 0) then isKey = .false. else - isKey = IO_rmComment(line(len(IO_rmComment(line)):len(IO_rmComment(line)))) == ':' .and. .not. isFlow(line) + isKey = IO_rmComment(line(len(IO_rmComment(line)):len(IO_rmComment(line)))) == ':' & + .and. .not. isFlow(line) endif end function isKey @@ -535,6 +539,7 @@ function to_flow(blck) end function to_flow + !-------------------------------------------------------------------------------------------------- subroutine selfTest() @@ -567,7 +572,6 @@ subroutine selfTest() if( isScalar('- a:')) call IO_error(0,ext_msg='isScalar') if(.not. isScalar(' a')) call IO_error(0,ext_msg='isScalar') - !ToDo :some more advanced tests? basic_list: block character(len=*), parameter :: block_list = & " - Casablanca"//IO_EOL//& From b4de27bf6171f8efda6f073c582a14f8cded40a9 Mon Sep 17 00:00:00 2001 From: Test User Date: Mon, 25 May 2020 14:54:13 +0200 Subject: [PATCH 098/136] [skip ci] updated version information after successful test of v2.0.3-2514-g873b9fa8 --- VERSION | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/VERSION b/VERSION index 3ba40668a..6d4d1897c 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -v2.0.3-2504-gcee9daff +v2.0.3-2514-g873b9fa8 From c9ff18e4087c001620b6f00ed66bb2fc89f5987f Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 15:50:48 +0200 Subject: [PATCH 099/136] not used --- processing/pre/geom_rotate.py | 1 - processing/pre/geom_translate.py | 2 +- 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/processing/pre/geom_rotate.py b/processing/pre/geom_rotate.py index bbfeceb0b..9a65a0e2b 100755 --- a/processing/pre/geom_rotate.py +++ b/processing/pre/geom_rotate.py @@ -5,7 +5,6 @@ import sys from io import StringIO from optparse import OptionParser -from scipy import ndimage import numpy as np import damask diff --git a/processing/pre/geom_translate.py b/processing/pre/geom_translate.py index 25164b794..44c7e8718 100755 --- a/processing/pre/geom_translate.py +++ b/processing/pre/geom_translate.py @@ -49,7 +49,7 @@ for name in filenames: geom = damask.Geom.from_file(StringIO(''.join(sys.stdin.read())) if name is None else name) geom.renumber(sub[0::2],sub[1::2],origin=geom.origin+options.origin) - geom.microstructure+= option.microstructure + geom.microstructure+= options.microstructure damask.util.croak(geom) geom.add_comments(scriptID + ' ' + ' '.join(sys.argv[1:])) geom.to_file(sys.stdout if name is None else name,pack=False) From 784d6d09d9b5a336541c67332fb00183e4555c36 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 15:54:22 +0200 Subject: [PATCH 100/136] cleaning --- python/damask/_geom.py | 11 +++++------ python/tests/test_Lattice.py | 5 ++--- 2 files changed, 7 insertions(+), 9 deletions(-) diff --git a/python/damask/_geom.py b/python/damask/_geom.py index 12dbcc181..53c7322cc 100644 --- a/python/damask/_geom.py +++ b/python/damask/_geom.py @@ -10,7 +10,6 @@ from . import VTK from . import util from . import Environment from . import grid_filters -from . import Rotation class Geom: @@ -605,7 +604,7 @@ class Geom: origin = self.origin-(np.asarray(microstructure_in.shape)-self.grid)*.5 * self.size/self.grid - #self.add_comments('geom.py:renumber v{}'.format(version) + #self.add_comments('geom.py:rotate v{}'.format(version) return self.update(microstructure_in,origin=origin,rescale=True) @@ -613,11 +612,10 @@ class Geom: """Crop or enlarge/pad microstructure.""" if fill is None: fill = np.nanmax(self.microstructure) + 1 if offset is None: offset = 0 - dtype = float if np.isnan(fill) or int(fill) != fill or self.microstructure.dtype==np.float else int + dtype = float if int(fill) != fill or self.microstructure.dtype==np.float else int canvas = np.full(self.grid if grid is None else grid, - fill if fill is not None else np.nanmax(self.microstructure)+1, - self.microstructure.dtype) + fill if fill is not None else np.nanmax(self.microstructure)+1,dtype) l = np.clip( offset, 0,np.minimum(self.grid +offset,grid)) # noqa r = np.clip( offset+self.grid,0,np.minimum(self.grid*2+offset,grid)) @@ -626,7 +624,7 @@ class Geom: canvas[l[0]:r[0],l[1]:r[1],l[2]:r[2]] = self.microstructure[L[0]:R[0],L[1]:R[1],L[2]:R[2]] - #self.add_comments('geom.py:renumber v{}'.format(version) + #self.add_comments('geom.py:canvas v{}'.format(version) return self.update(canvas,origin=self.origin+offset*self.size/self.grid,rescale=True) @@ -636,4 +634,5 @@ class Geom: for from_ms,to_ms in zip(from_microstructure,to_microstructure): substituted[self.microstructure==from_ms] = to_ms + #self.add_comments('geom.py:substitute v{}'.format(version) return self.update(substituted) diff --git a/python/tests/test_Lattice.py b/python/tests/test_Lattice.py index 6a2cc5034..fb8ce8ea5 100644 --- a/python/tests/test_Lattice.py +++ b/python/tests/test_Lattice.py @@ -4,14 +4,13 @@ import pytest import numpy as np from damask import Symmetry -from damask import Lattice class TestSymmetry: @pytest.mark.parametrize('invalid_symmetry',['fcc','bcc','hello']) def test_invalid_symmetry(self,invalid_symmetry): with pytest.raises(KeyError): - s = Symmetry(invalid_symmetry) + s = Symmetry(invalid_symmetry) # noqa def test_equal(self): symmetry = random.choice(Symmetry.lattices) @@ -37,6 +36,6 @@ class TestSymmetry: @pytest.mark.parametrize('function',['inFZ','inDisorientationSST']) def test_invalid_argument(self,function): - s = Symmetry() + s = Symmetry() # noqa with pytest.raises(ValueError): eval('s.{}(np.ones(4))'.format(function)) From f07eaf19d049178eaf78757eb340cf2eeb398738 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 16:37:08 +0200 Subject: [PATCH 101/136] fixed broadcasting + corresponding test --- python/damask/_rotation.py | 10 +++++----- python/tests/test_Rotation.py | 2 +- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/python/damask/_rotation.py b/python/damask/_rotation.py index c147194d3..f90c5fcc0 100644 --- a/python/damask/_rotation.py +++ b/python/damask/_rotation.py @@ -12,7 +12,7 @@ _R1 = (3.*np.pi/4.)**(1./3.) class Rotation: u""" Orientation stored with functionality for conversion to different representations. - + The following conventions apply: - coordinate frames are right-handed. @@ -161,10 +161,10 @@ class Rotation: if self.shape == (): q = np.broadcast_to(self.quaternion,shape+(4,)) else: - q = np.block([np.broadcast_to(self.quaternion[...,0:1],shape), - np.broadcast_to(self.quaternion[...,1:2],shape), - np.broadcast_to(self.quaternion[...,2:3],shape), - np.broadcast_to(self.quaternion[...,3:4],shape)]).reshape(shape+(4,)) + q = np.block([np.broadcast_to(self.quaternion[...,0:1],shape).reshape(shape+(1,)), + np.broadcast_to(self.quaternion[...,1:2],shape).reshape(shape+(1,)), + np.broadcast_to(self.quaternion[...,2:3],shape).reshape(shape+(1,)), + np.broadcast_to(self.quaternion[...,3:4],shape).reshape(shape+(1,))]) return self.__class__(q) diff --git a/python/tests/test_Rotation.py b/python/tests/test_Rotation.py index 75fddf6fe..5a1cd145d 100644 --- a/python/tests/test_Rotation.py +++ b/python/tests/test_Rotation.py @@ -873,7 +873,7 @@ class TestRotation: rot.shape + (np.random.randint(8,32),) rot_broadcast = rot.broadcast_to(tuple(new_shape)) for i in range(rot_broadcast.shape[-1]): - assert (rot_broadcast.quaternion[...,i,:], rot.quaternion) + assert np.allclose(rot_broadcast.quaternion[...,i,:], rot.quaternion) @pytest.mark.parametrize('function,invalid',[(Rotation.from_quaternion, np.array([-1,0,0,0])), From b1b8d02320f59a50b1057b2780c51afc44c61771 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 16:41:23 +0200 Subject: [PATCH 102/136] typo --- python/damask/_geom.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/python/damask/_geom.py b/python/damask/_geom.py index fe4e9a17f..2609fe537 100644 --- a/python/damask/_geom.py +++ b/python/damask/_geom.py @@ -242,7 +242,7 @@ class Geom: def get_grid(self): """Return the grid discretization.""" - return np.as:array(self.microstructure.shape) + return np.asarray(self.microstructure.shape) def get_homogenization(self): From 248f199a7b4e57dcb8fe9ef9919461790aabbcd1 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 18:50:31 +0200 Subject: [PATCH 103/136] track creation time --- python/damask/_result.py | 3 +++ src/results.f90 | 21 +++++++++++++++++++++ 2 files changed, 24 insertions(+) diff --git a/python/damask/_result.py b/python/damask/_result.py index 3a43850ed..e4402e1d8 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -2,6 +2,7 @@ import multiprocessing import re import glob import os +import datetime import xml.etree.ElementTree as ET import xml.dom.minidom from functools import partial @@ -1016,6 +1017,8 @@ class Result: with h5py.File(self.fname, 'a') as f: try: # ToDo: Replace if exists? dataset = f[result[0]].create_dataset(result[1]['label'],data=result[1]['data']) + now = datetime.datetime.now().astimezone() + dataset.attrs['Created'] = now.strftime('%Y-%m-%d %H:%M:%S%z').encode() for l,v in result[1]['meta'].items(): dataset.attrs[l]=v.encode() except OSError as err: diff --git a/src/results.f90 b/src/results.f90 index b5410f5f4..9b634079e 100644 --- a/src/results.f90 +++ b/src/results.f90 @@ -311,6 +311,8 @@ subroutine results_writeScalarDataset_real(group,dataset,label,description,SIuni call HDF5_addAttribute(groupHandle,'Unit',SIunit,label) if (HDF5_objectExists(groupHandle,label)) & call HDF5_addAttribute(groupHandle,'Creator','DAMASK '//DAMASKVERSION,label) + if (HDF5_objectExists(groupHandle,label)) & + call HDF5_addAttribute(groupHandle,'Created',now()) call HDF5_closeGroup(groupHandle) end subroutine results_writeScalarDataset_real @@ -340,6 +342,8 @@ subroutine results_writeVectorDataset_real(group,dataset,label,description,SIuni call HDF5_addAttribute(groupHandle,'Unit',SIunit,label) if (HDF5_objectExists(groupHandle,label)) & call HDF5_addAttribute(groupHandle,'Creator','DAMASK '//DAMASKVERSION,label) + if (HDF5_objectExists(groupHandle,label)) & + call HDF5_addAttribute(groupHandle,'Created',now()) call HDF5_closeGroup(groupHandle) end subroutine results_writeVectorDataset_real @@ -391,6 +395,8 @@ subroutine results_writeTensorDataset_real(group,dataset,label,description,SIuni call HDF5_addAttribute(groupHandle,'Unit',SIunit,label) if (HDF5_objectExists(groupHandle,label)) & call HDF5_addAttribute(groupHandle,'Creator','DAMASK '//DAMASKVERSION,label) + if (HDF5_objectExists(groupHandle,label)) & + call HDF5_addAttribute(groupHandle,'Created',now()) call HDF5_closeGroup(groupHandle) end subroutine results_writeTensorDataset_real @@ -421,6 +427,8 @@ subroutine results_writeVectorDataset_int(group,dataset,label,description,SIunit call HDF5_addAttribute(groupHandle,'Unit',SIunit,label) if (HDF5_objectExists(groupHandle,label)) & call HDF5_addAttribute(groupHandle,'Creator','DAMASK '//DAMASKVERSION,label) + if (HDF5_objectExists(groupHandle,label)) & + call HDF5_addAttribute(groupHandle,'Created',now()) call HDF5_closeGroup(groupHandle) end subroutine results_writeVectorDataset_int @@ -451,6 +459,8 @@ subroutine results_writeTensorDataset_int(group,dataset,label,description,SIunit call HDF5_addAttribute(groupHandle,'Unit',SIunit,label) if (HDF5_objectExists(groupHandle,label)) & call HDF5_addAttribute(groupHandle,'Creator','DAMASK '//DAMASKVERSION,label) + if (HDF5_objectExists(groupHandle,label)) & + call HDF5_addAttribute(groupHandle,'Created',now()) call HDF5_closeGroup(groupHandle) end subroutine results_writeTensorDataset_int @@ -481,6 +491,8 @@ subroutine results_writeScalarDataset_rotation(group,dataset,label,description,l call HDF5_addAttribute(groupHandle,'Lattice',lattice_structure,label) if (HDF5_objectExists(groupHandle,label)) & call HDF5_addAttribute(groupHandle,'Creator','DAMASK '//DAMASKVERSION,label) + if (HDF5_objectExists(groupHandle,label)) & + call HDF5_addAttribute(groupHandle,'Created',now()) call HDF5_closeGroup(groupHandle) end subroutine results_writeScalarDataset_rotation @@ -755,6 +767,15 @@ subroutine results_mapping_materialpoint(homogenizationAt,memberAtLocal,label) end subroutine results_mapping_materialpoint +character(len=24) function now() + + character(len=5) :: zone + integer, dimension(8) :: values + + write(now,'(i4.4,5(a,i2.2),a)') & + values(1),'-',values(2),'-',values(3),' ',values(5),':',values(6),':',values(7),zone + +end function now !!-------------------------------------------------------------------------------------------------- !!> @brief adds the backward mapping from spatial position and constituent ID to results From b6812d58b0ba09f1fa95b043ff0a157b932b1dea Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 20:10:43 +0200 Subject: [PATCH 104/136] bugfix --- processing/pre/geom_translate.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/processing/pre/geom_translate.py b/processing/pre/geom_translate.py index 44c7e8718..6609e3f7e 100755 --- a/processing/pre/geom_translate.py +++ b/processing/pre/geom_translate.py @@ -48,8 +48,9 @@ for name in filenames: damask.util.report(scriptName,name) geom = damask.Geom.from_file(StringIO(''.join(sys.stdin.read())) if name is None else name) - geom.renumber(sub[0::2],sub[1::2],origin=geom.origin+options.origin) - geom.microstructure+= options.microstructure + geom.substitute(sub[0::2],sub[1::2]) + geom.set_origin(geom.origin+options.origin) + geom.set_microstructure(geom.microstructure+options.microstructure) damask.util.croak(geom) geom.add_comments(scriptID + ' ' + ' '.join(sys.argv[1:])) geom.to_file(sys.stdout if name is None else name,pack=False) From b9e16ea95110599f6c18a94f87ee2c01e0e22874 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 19:12:31 +0200 Subject: [PATCH 105/136] overwriting datasets makes sense in special cases but prevent user from accidently doing that and store the information --- python/damask/_result.py | 21 +++++++++++++++++++-- 1 file changed, 19 insertions(+), 2 deletions(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index e4402e1d8..244c11c69 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -89,6 +89,8 @@ class Result: self.fname = os.path.abspath(fname) + self._allow_overwrite = False + def __repr__(self): """Show selected data.""" @@ -163,6 +165,16 @@ class Result: self.selection[what] = diff_sorted + def enable_overwrite(self): + print(util.bcolors().WARNING,util.bcolors().BOLD, + 'Warning: Enabled overwrite of existing datasets!', + util.bcolors().ENDC) + self._allow_overwrite = True + + def disable_overwrite(self): + self._allow_overwrite = False + + def incs_in_range(self,start,end): selected = [] for i,inc in enumerate([int(i[3:]) for i in self.increments]): @@ -1015,8 +1027,13 @@ class Result: continue lock.acquire() with h5py.File(self.fname, 'a') as f: - try: # ToDo: Replace if exists? - dataset = f[result[0]].create_dataset(result[1]['label'],data=result[1]['data']) + try: + if self._allow_overwrite and result[0]+'/'+result[1]['label'] in f: + dataset = f[result[0]+'/'+result[1]['label']] + datset = result[1]['data'] + dataset.attrs['Overwritten'] = True + else: + dataset = f[result[0]].create_dataset(result[1]['label'],data=result[1]['data']) now = datetime.datetime.now().astimezone() dataset.attrs['Created'] = now.strftime('%Y-%m-%d %H:%M:%S%z').encode() for l,v in result[1]['meta'].items(): From eced5d0a3c9fa1046d1efae156888bfc71978b37 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 19:34:17 +0200 Subject: [PATCH 106/136] bugfixes for date reporting --- src/results.f90 | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/src/results.f90 b/src/results.f90 index 9b634079e..d1db96f47 100644 --- a/src/results.f90 +++ b/src/results.f90 @@ -312,7 +312,7 @@ subroutine results_writeScalarDataset_real(group,dataset,label,description,SIuni if (HDF5_objectExists(groupHandle,label)) & call HDF5_addAttribute(groupHandle,'Creator','DAMASK '//DAMASKVERSION,label) if (HDF5_objectExists(groupHandle,label)) & - call HDF5_addAttribute(groupHandle,'Created',now()) + call HDF5_addAttribute(groupHandle,'Created',now(),label) call HDF5_closeGroup(groupHandle) end subroutine results_writeScalarDataset_real @@ -343,7 +343,7 @@ subroutine results_writeVectorDataset_real(group,dataset,label,description,SIuni if (HDF5_objectExists(groupHandle,label)) & call HDF5_addAttribute(groupHandle,'Creator','DAMASK '//DAMASKVERSION,label) if (HDF5_objectExists(groupHandle,label)) & - call HDF5_addAttribute(groupHandle,'Created',now()) + call HDF5_addAttribute(groupHandle,'Created',now(),label) call HDF5_closeGroup(groupHandle) end subroutine results_writeVectorDataset_real @@ -396,7 +396,7 @@ subroutine results_writeTensorDataset_real(group,dataset,label,description,SIuni if (HDF5_objectExists(groupHandle,label)) & call HDF5_addAttribute(groupHandle,'Creator','DAMASK '//DAMASKVERSION,label) if (HDF5_objectExists(groupHandle,label)) & - call HDF5_addAttribute(groupHandle,'Created',now()) + call HDF5_addAttribute(groupHandle,'Created',now(),label) call HDF5_closeGroup(groupHandle) end subroutine results_writeTensorDataset_real @@ -428,7 +428,7 @@ subroutine results_writeVectorDataset_int(group,dataset,label,description,SIunit if (HDF5_objectExists(groupHandle,label)) & call HDF5_addAttribute(groupHandle,'Creator','DAMASK '//DAMASKVERSION,label) if (HDF5_objectExists(groupHandle,label)) & - call HDF5_addAttribute(groupHandle,'Created',now()) + call HDF5_addAttribute(groupHandle,'Created',now(),label) call HDF5_closeGroup(groupHandle) end subroutine results_writeVectorDataset_int @@ -460,7 +460,7 @@ subroutine results_writeTensorDataset_int(group,dataset,label,description,SIunit if (HDF5_objectExists(groupHandle,label)) & call HDF5_addAttribute(groupHandle,'Creator','DAMASK '//DAMASKVERSION,label) if (HDF5_objectExists(groupHandle,label)) & - call HDF5_addAttribute(groupHandle,'Created',now()) + call HDF5_addAttribute(groupHandle,'Created',now(),label) call HDF5_closeGroup(groupHandle) end subroutine results_writeTensorDataset_int @@ -492,7 +492,7 @@ subroutine results_writeScalarDataset_rotation(group,dataset,label,description,l if (HDF5_objectExists(groupHandle,label)) & call HDF5_addAttribute(groupHandle,'Creator','DAMASK '//DAMASKVERSION,label) if (HDF5_objectExists(groupHandle,label)) & - call HDF5_addAttribute(groupHandle,'Created',now()) + call HDF5_addAttribute(groupHandle,'Created',now(),label) call HDF5_closeGroup(groupHandle) end subroutine results_writeScalarDataset_rotation @@ -772,6 +772,7 @@ character(len=24) function now() character(len=5) :: zone integer, dimension(8) :: values + call date_and_time(values=values,zone=zone) write(now,'(i4.4,5(a,i2.2),a)') & values(1),'-',values(2),'-',values(3),' ',values(5),':',values(6),':',values(7),zone From 5d0a2aac8fd9e866428175f1779a4ee8e34bc8c3 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 19:35:36 +0200 Subject: [PATCH 107/136] polishing reporting --- python/damask/_result.py | 34 +++++++++++++++++----------------- 1 file changed, 17 insertions(+), 17 deletions(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index 244c11c69..412c66f6f 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -502,7 +502,7 @@ class Result: 'meta': { 'Unit': x['meta']['Unit'], 'Description': 'Absolute value of {} ({})'.format(x['label'],x['meta']['Description']), - 'Creator': 'result.py:add_abs v{}'.format(version) + 'Creator': 'damask.Result.add_abs v{}'.format(version) } } def add_absolute(self,x): @@ -530,7 +530,7 @@ class Result: 'meta': { 'Unit': kwargs['unit'], 'Description': '{} (formula: {})'.format(kwargs['description'],kwargs['formula']), - 'Creator': 'result.py:add_calculation v{}'.format(version) + 'Creator': 'damask.Result.add_calculation v{}'.format(version) } } def add_calculation(self,label,formula,unit='n/a',description=None,vectorized=True): @@ -569,7 +569,7 @@ class Result: 'Description': 'Cauchy stress calculated from {} ({}) '.format(P['label'], P['meta']['Description'])+\ 'and {} ({})'.format(F['label'],F['meta']['Description']), - 'Creator': 'result.py:add_Cauchy v{}'.format(version) + 'Creator': 'damask.Result.add_Cauchy v{}'.format(version) } } def add_Cauchy(self,P='P',F='F'): @@ -595,7 +595,7 @@ class Result: 'meta': { 'Unit': T['meta']['Unit'], 'Description': 'Determinant of tensor {} ({})'.format(T['label'],T['meta']['Description']), - 'Creator': 'result.py:add_determinant v{}'.format(version) + 'Creator': 'damask.Result.add_determinant v{}'.format(version) } } def add_determinant(self,T): @@ -619,7 +619,7 @@ class Result: 'meta': { 'Unit': T['meta']['Unit'], 'Description': 'Deviator of tensor {} ({})'.format(T['label'],T['meta']['Description']), - 'Creator': 'result.py:add_deviator v{}'.format(version) + 'Creator': 'damask.Result.add_deviator v{}'.format(version) } } def add_deviator(self,T): @@ -643,7 +643,7 @@ class Result: 'meta' : { 'Unit': T_sym['meta']['Unit'], 'Description': 'Eigenvalues of {} ({})'.format(T_sym['label'],T_sym['meta']['Description']), - 'Creator': 'result.py:add_eigenvalues v{}'.format(version) + 'Creator': 'damask.Result.add_eigenvalues v{}'.format(version) } } def add_eigenvalues(self,T_sym): @@ -667,7 +667,7 @@ class Result: 'meta' : { 'Unit': '1', 'Description': 'Eigenvectors of {} ({})'.format(T_sym['label'],T_sym['meta']['Description']), - 'Creator': 'result.py:add_eigenvectors v{}'.format(version) + 'Creator': 'damask.Result.add_eigenvectors v{}'.format(version) } } def add_eigenvectors(self,T_sym): @@ -703,7 +703,7 @@ class Result: 'Unit': 'RGB (8bit)', 'Lattice': lattice, 'Description': 'Inverse Pole Figure (IPF) colors along sample direction [{} {} {}]'.format(*m), - 'Creator': 'result.py:add_IPFcolor v{}'.format(version) + 'Creator': 'damask.Result.add_IPFcolor v{}'.format(version) } } def add_IPFcolor(self,q,l): @@ -729,7 +729,7 @@ class Result: 'meta': { 'Unit': T_sym['meta']['Unit'], 'Description': 'Maximum shear component of {} ({})'.format(T_sym['label'],T_sym['meta']['Description']), - 'Creator': 'result.py:add_maximum_shear v{}'.format(version) + 'Creator': 'damask.Result.add_maximum_shear v{}'.format(version) } } def add_maximum_shear(self,T_sym): @@ -756,7 +756,7 @@ class Result: 'meta': { 'Unit': T_sym['meta']['Unit'], 'Description': 'Mises equivalent {} of {} ({})'.format(t,T_sym['label'],T_sym['meta']['Description']), - 'Creator': 'result.py:add_Mises v{}'.format(version) + 'Creator': 'damask.Result.add_Mises v{}'.format(version) } } def add_Mises(self,T_sym): @@ -792,7 +792,7 @@ class Result: 'meta': { 'Unit': x['meta']['Unit'], 'Description': '{}-norm of {} {} ({})'.format(o,t,x['label'],x['meta']['Description']), - 'Creator': 'result.py:add_norm v{}'.format(version) + 'Creator': 'damask.Result.add_norm v{}'.format(version) } } def add_norm(self,x,ord=None): @@ -820,7 +820,7 @@ class Result: 'Description': '2. Kirchhoff stress calculated from {} ({}) '.format(P['label'], P['meta']['Description'])+\ 'and {} ({})'.format(F['label'],F['meta']['Description']), - 'Creator': 'result.py:add_PK2 v{}'.format(version) + 'Creator': 'damask.Result.add_PK2 v{}'.format(version) } } def add_PK2(self,P='P',F='F'): @@ -856,7 +856,7 @@ class Result: 'Unit': '1', 'Description': '{} coordinates of stereographic projection of pole (direction/plane) in crystal frame'\ .format('Polar' if polar else 'Cartesian'), - 'Creator' : 'result.py:add_pole v{}'.format(version) + 'Creator' : 'damask.Result.add_pole v{}'.format(version) } } def add_pole(self,q,p,polar=False): @@ -884,7 +884,7 @@ class Result: 'meta': { 'Unit': F['meta']['Unit'], 'Description': 'Rotational part of {} ({})'.format(F['label'],F['meta']['Description']), - 'Creator': 'result.py:add_rotational_part v{}'.format(version) + 'Creator': 'damask.Result.add_rotational_part v{}'.format(version) } } def add_rotational_part(self,F): @@ -908,7 +908,7 @@ class Result: 'meta': { 'Unit': T['meta']['Unit'], 'Description': 'Spherical component of tensor {} ({})'.format(T['label'],T['meta']['Description']), - 'Creator': 'result.py:add_spherical v{}'.format(version) + 'Creator': 'damask.Result.add_spherical v{}'.format(version) } } def add_spherical(self,T): @@ -932,7 +932,7 @@ class Result: 'meta': { 'Unit': F['meta']['Unit'], 'Description': 'Strain tensor of {} ({})'.format(F['label'],F['meta']['Description']), - 'Creator': 'result.py:add_strain_tensor v{}'.format(version) + 'Creator': 'damask.Result.add_strain_tensor v{}'.format(version) } } def add_strain_tensor(self,F='F',t='V',m=0.0): @@ -964,7 +964,7 @@ class Result: 'Unit': F['meta']['Unit'], 'Description': '{} stretch tensor of {} ({})'.format('Left' if t == 'V' else 'Right', F['label'],F['meta']['Description']), - 'Creator': 'result.py:add_stretch_tensor v{}'.format(version) + 'Creator': 'damask.Result.add_stretch_tensor v{}'.format(version) } } def add_stretch_tensor(self,F='F',t='V'): From d9d089c359a737acc63861961670650f80f3d6a6 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 19:57:32 +0200 Subject: [PATCH 108/136] avoid repetition and do correct encode/decode --- python/damask/_result.py | 42 +++++++++++++++++++++++----------------- 1 file changed, 24 insertions(+), 18 deletions(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index 412c66f6f..34c6e9437 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -1,5 +1,6 @@ import multiprocessing import re +import inspect import glob import os import datetime @@ -502,7 +503,7 @@ class Result: 'meta': { 'Unit': x['meta']['Unit'], 'Description': 'Absolute value of {} ({})'.format(x['label'],x['meta']['Description']), - 'Creator': 'damask.Result.add_abs v{}'.format(version) + 'Creator': 'add_absolute' } } def add_absolute(self,x): @@ -530,7 +531,7 @@ class Result: 'meta': { 'Unit': kwargs['unit'], 'Description': '{} (formula: {})'.format(kwargs['description'],kwargs['formula']), - 'Creator': 'damask.Result.add_calculation v{}'.format(version) + 'Creator': 'add_calculation' } } def add_calculation(self,label,formula,unit='n/a',description=None,vectorized=True): @@ -569,7 +570,7 @@ class Result: 'Description': 'Cauchy stress calculated from {} ({}) '.format(P['label'], P['meta']['Description'])+\ 'and {} ({})'.format(F['label'],F['meta']['Description']), - 'Creator': 'damask.Result.add_Cauchy v{}'.format(version) + 'Creator': 'add_Cauchy' } } def add_Cauchy(self,P='P',F='F'): @@ -595,7 +596,7 @@ class Result: 'meta': { 'Unit': T['meta']['Unit'], 'Description': 'Determinant of tensor {} ({})'.format(T['label'],T['meta']['Description']), - 'Creator': 'damask.Result.add_determinant v{}'.format(version) + 'Creator': 'add_determinant' } } def add_determinant(self,T): @@ -619,7 +620,7 @@ class Result: 'meta': { 'Unit': T['meta']['Unit'], 'Description': 'Deviator of tensor {} ({})'.format(T['label'],T['meta']['Description']), - 'Creator': 'damask.Result.add_deviator v{}'.format(version) + 'Creator': 'add_deviator' } } def add_deviator(self,T): @@ -643,7 +644,7 @@ class Result: 'meta' : { 'Unit': T_sym['meta']['Unit'], 'Description': 'Eigenvalues of {} ({})'.format(T_sym['label'],T_sym['meta']['Description']), - 'Creator': 'damask.Result.add_eigenvalues v{}'.format(version) + 'Creator': 'add_eigenvalues' } } def add_eigenvalues(self,T_sym): @@ -667,7 +668,7 @@ class Result: 'meta' : { 'Unit': '1', 'Description': 'Eigenvectors of {} ({})'.format(T_sym['label'],T_sym['meta']['Description']), - 'Creator': 'damask.Result.add_eigenvectors v{}'.format(version) + 'Creator': 'add_eigenvectors' } } def add_eigenvectors(self,T_sym): @@ -703,7 +704,7 @@ class Result: 'Unit': 'RGB (8bit)', 'Lattice': lattice, 'Description': 'Inverse Pole Figure (IPF) colors along sample direction [{} {} {}]'.format(*m), - 'Creator': 'damask.Result.add_IPFcolor v{}'.format(version) + 'Creator': 'add_IPFcolor' } } def add_IPFcolor(self,q,l): @@ -729,7 +730,7 @@ class Result: 'meta': { 'Unit': T_sym['meta']['Unit'], 'Description': 'Maximum shear component of {} ({})'.format(T_sym['label'],T_sym['meta']['Description']), - 'Creator': 'damask.Result.add_maximum_shear v{}'.format(version) + 'Creator': 'add_maximum_shear' } } def add_maximum_shear(self,T_sym): @@ -756,7 +757,7 @@ class Result: 'meta': { 'Unit': T_sym['meta']['Unit'], 'Description': 'Mises equivalent {} of {} ({})'.format(t,T_sym['label'],T_sym['meta']['Description']), - 'Creator': 'damask.Result.add_Mises v{}'.format(version) + 'Creator': 'add_Mises' } } def add_Mises(self,T_sym): @@ -792,7 +793,7 @@ class Result: 'meta': { 'Unit': x['meta']['Unit'], 'Description': '{}-norm of {} {} ({})'.format(o,t,x['label'],x['meta']['Description']), - 'Creator': 'damask.Result.add_norm v{}'.format(version) + 'Creator': 'add_norm' } } def add_norm(self,x,ord=None): @@ -820,7 +821,7 @@ class Result: 'Description': '2. Kirchhoff stress calculated from {} ({}) '.format(P['label'], P['meta']['Description'])+\ 'and {} ({})'.format(F['label'],F['meta']['Description']), - 'Creator': 'damask.Result.add_PK2 v{}'.format(version) + 'Creator': 'add_PK2' } } def add_PK2(self,P='P',F='F'): @@ -856,7 +857,7 @@ class Result: 'Unit': '1', 'Description': '{} coordinates of stereographic projection of pole (direction/plane) in crystal frame'\ .format('Polar' if polar else 'Cartesian'), - 'Creator' : 'damask.Result.add_pole v{}'.format(version) + 'Creator' : 'add_pole' } } def add_pole(self,q,p,polar=False): @@ -884,7 +885,7 @@ class Result: 'meta': { 'Unit': F['meta']['Unit'], 'Description': 'Rotational part of {} ({})'.format(F['label'],F['meta']['Description']), - 'Creator': 'damask.Result.add_rotational_part v{}'.format(version) + 'Creator': 'add_rotational_part' } } def add_rotational_part(self,F): @@ -908,7 +909,7 @@ class Result: 'meta': { 'Unit': T['meta']['Unit'], 'Description': 'Spherical component of tensor {} ({})'.format(T['label'],T['meta']['Description']), - 'Creator': 'damask.Result.add_spherical v{}'.format(version) + 'Creator': 'add_spherical' } } def add_spherical(self,T): @@ -932,7 +933,7 @@ class Result: 'meta': { 'Unit': F['meta']['Unit'], 'Description': 'Strain tensor of {} ({})'.format(F['label'],F['meta']['Description']), - 'Creator': 'damask.Result.add_strain_tensor v{}'.format(version) + 'Creator': 'add_strain_tensor' } } def add_strain_tensor(self,F='F',t='V',m=0.0): @@ -964,7 +965,7 @@ class Result: 'Unit': F['meta']['Unit'], 'Description': '{} stretch tensor of {} ({})'.format('Left' if t == 'V' else 'Right', F['label'],F['meta']['Description']), - 'Creator': 'damask.Result.add_stretch_tensor v{}'.format(version) + 'Creator': 'add_stretch_tensor' } } def add_stretch_tensor(self,F='F',t='V'): @@ -1031,13 +1032,18 @@ class Result: if self._allow_overwrite and result[0]+'/'+result[1]['label'] in f: dataset = f[result[0]+'/'+result[1]['label']] datset = result[1]['data'] - dataset.attrs['Overwritten'] = True + dataset.attrs['Overwritten'] = 'Yes'.encode() else: dataset = f[result[0]].create_dataset(result[1]['label'],data=result[1]['data']) + now = datetime.datetime.now().astimezone() dataset.attrs['Created'] = now.strftime('%Y-%m-%d %H:%M:%S%z').encode() + for l,v in result[1]['meta'].items(): dataset.attrs[l]=v.encode() + creator = 'damask.Result.{} v{}'.format(dataset.attrs['Creator'].decode(),version) + dataset.attrs['Creator'] = creator.encode() + except OSError as err: print('Could not add dataset: {}.'.format(err)) lock.release() From d6877da2b675ba3a1bd9e16b757d50942f897084 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 19:59:29 +0200 Subject: [PATCH 109/136] single source of truth --- python/damask/_result.py | 36 ++++++++++++++++++------------------ 1 file changed, 18 insertions(+), 18 deletions(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index 34c6e9437..2ff3701e6 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -503,7 +503,7 @@ class Result: 'meta': { 'Unit': x['meta']['Unit'], 'Description': 'Absolute value of {} ({})'.format(x['label'],x['meta']['Description']), - 'Creator': 'add_absolute' + 'Creator': inspect.stack()[0][3][1:] } } def add_absolute(self,x): @@ -531,7 +531,7 @@ class Result: 'meta': { 'Unit': kwargs['unit'], 'Description': '{} (formula: {})'.format(kwargs['description'],kwargs['formula']), - 'Creator': 'add_calculation' + 'Creator': inspect.stack()[0][3][1:] } } def add_calculation(self,label,formula,unit='n/a',description=None,vectorized=True): @@ -570,7 +570,7 @@ class Result: 'Description': 'Cauchy stress calculated from {} ({}) '.format(P['label'], P['meta']['Description'])+\ 'and {} ({})'.format(F['label'],F['meta']['Description']), - 'Creator': 'add_Cauchy' + 'Creator': inspect.stack()[0][3][1:] } } def add_Cauchy(self,P='P',F='F'): @@ -596,7 +596,7 @@ class Result: 'meta': { 'Unit': T['meta']['Unit'], 'Description': 'Determinant of tensor {} ({})'.format(T['label'],T['meta']['Description']), - 'Creator': 'add_determinant' + 'Creator': inspect.stack()[0][3][1:] } } def add_determinant(self,T): @@ -620,7 +620,7 @@ class Result: 'meta': { 'Unit': T['meta']['Unit'], 'Description': 'Deviator of tensor {} ({})'.format(T['label'],T['meta']['Description']), - 'Creator': 'add_deviator' + 'Creator': inspect.stack()[0][3][1:] } } def add_deviator(self,T): @@ -644,7 +644,7 @@ class Result: 'meta' : { 'Unit': T_sym['meta']['Unit'], 'Description': 'Eigenvalues of {} ({})'.format(T_sym['label'],T_sym['meta']['Description']), - 'Creator': 'add_eigenvalues' + 'Creator': inspect.stack()[0][3][1:] } } def add_eigenvalues(self,T_sym): @@ -668,7 +668,7 @@ class Result: 'meta' : { 'Unit': '1', 'Description': 'Eigenvectors of {} ({})'.format(T_sym['label'],T_sym['meta']['Description']), - 'Creator': 'add_eigenvectors' + 'Creator': inspect.stack()[0][3][1:] } } def add_eigenvectors(self,T_sym): @@ -704,7 +704,7 @@ class Result: 'Unit': 'RGB (8bit)', 'Lattice': lattice, 'Description': 'Inverse Pole Figure (IPF) colors along sample direction [{} {} {}]'.format(*m), - 'Creator': 'add_IPFcolor' + 'Creator': inspect.stack()[0][3][1:] } } def add_IPFcolor(self,q,l): @@ -730,7 +730,7 @@ class Result: 'meta': { 'Unit': T_sym['meta']['Unit'], 'Description': 'Maximum shear component of {} ({})'.format(T_sym['label'],T_sym['meta']['Description']), - 'Creator': 'add_maximum_shear' + 'Creator': inspect.stack()[0][3][1:] } } def add_maximum_shear(self,T_sym): @@ -757,7 +757,7 @@ class Result: 'meta': { 'Unit': T_sym['meta']['Unit'], 'Description': 'Mises equivalent {} of {} ({})'.format(t,T_sym['label'],T_sym['meta']['Description']), - 'Creator': 'add_Mises' + 'Creator': inspect.stack()[0][3][1:] } } def add_Mises(self,T_sym): @@ -793,7 +793,7 @@ class Result: 'meta': { 'Unit': x['meta']['Unit'], 'Description': '{}-norm of {} {} ({})'.format(o,t,x['label'],x['meta']['Description']), - 'Creator': 'add_norm' + 'Creator': inspect.stack()[0][3][1:] } } def add_norm(self,x,ord=None): @@ -821,7 +821,7 @@ class Result: 'Description': '2. Kirchhoff stress calculated from {} ({}) '.format(P['label'], P['meta']['Description'])+\ 'and {} ({})'.format(F['label'],F['meta']['Description']), - 'Creator': 'add_PK2' + 'Creator': inspect.stack()[0][3][1:] } } def add_PK2(self,P='P',F='F'): @@ -854,10 +854,10 @@ class Result: 'data': coords, 'label': 'p^{}_[{} {} {})'.format(u'rφ' if polar else 'xy',*m), 'meta' : { - 'Unit': '1', + 'Unit': '1', 'Description': '{} coordinates of stereographic projection of pole (direction/plane) in crystal frame'\ .format('Polar' if polar else 'Cartesian'), - 'Creator' : 'add_pole' + 'Creator': inspect.stack()[0][3][1:] } } def add_pole(self,q,p,polar=False): @@ -885,7 +885,7 @@ class Result: 'meta': { 'Unit': F['meta']['Unit'], 'Description': 'Rotational part of {} ({})'.format(F['label'],F['meta']['Description']), - 'Creator': 'add_rotational_part' + 'Creator': inspect.stack()[0][3][1:] } } def add_rotational_part(self,F): @@ -909,7 +909,7 @@ class Result: 'meta': { 'Unit': T['meta']['Unit'], 'Description': 'Spherical component of tensor {} ({})'.format(T['label'],T['meta']['Description']), - 'Creator': 'add_spherical' + 'Creator': inspect.stack()[0][3][1:] } } def add_spherical(self,T): @@ -933,7 +933,7 @@ class Result: 'meta': { 'Unit': F['meta']['Unit'], 'Description': 'Strain tensor of {} ({})'.format(F['label'],F['meta']['Description']), - 'Creator': 'add_strain_tensor' + 'Creator': inspect.stack()[0][3][1:] } } def add_strain_tensor(self,F='F',t='V',m=0.0): @@ -965,7 +965,7 @@ class Result: 'Unit': F['meta']['Unit'], 'Description': '{} stretch tensor of {} ({})'.format('Left' if t == 'V' else 'Right', F['label'],F['meta']['Description']), - 'Creator': 'add_stretch_tensor' + 'Creator': inspect.stack()[0][3][1:] } } def add_stretch_tensor(self,F='F',t='V'): From 20e3bdd857794fe842848ec5f54d91ea5bb27802 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 21:42:12 +0200 Subject: [PATCH 110/136] adjusted names --- DAMASK_prerequisites.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/DAMASK_prerequisites.sh b/DAMASK_prerequisites.sh index b72f19b7a..25a2e46e0 100755 --- a/DAMASK_prerequisites.sh +++ b/DAMASK_prerequisites.sh @@ -110,7 +110,7 @@ for executable in icc icpc ifort ;do done firstLevel "MPI Wrappers" -for executable in mpicc mpiCC mpiicc mpic++ mpicpc mpicxx mpifort mpif90 mpif77; do +for executable in mpicc mpiCC mpiicc mpic++ mpiicpc mpicxx mpifort mpiifort mpif90 mpif77; do getDetails $executable '-show' done From e8992e7b72aeac5ea58fa1b98a4cd11a380c6e1f Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 22:09:46 +0200 Subject: [PATCH 111/136] documentation --- src/results.f90 | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/results.f90 b/src/results.f90 index d1db96f47..21173c512 100644 --- a/src/results.f90 +++ b/src/results.f90 @@ -767,6 +767,10 @@ subroutine results_mapping_materialpoint(homogenizationAt,memberAtLocal,label) end subroutine results_mapping_materialpoint + +!-------------------------------------------------------------------------------------------------- +!> @brief current date and time (including time zone information) +!-------------------------------------------------------------------------------------------------- character(len=24) function now() character(len=5) :: zone @@ -778,6 +782,7 @@ character(len=24) function now() end function now + !!-------------------------------------------------------------------------------------------------- !!> @brief adds the backward mapping from spatial position and constituent ID to results !!-------------------------------------------------------------------------------------------------- From 9076fbe5259de0bd7a2e0319e5a4686374bf17e9 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 23:05:31 +0200 Subject: [PATCH 112/136] testing overwrite functionality --- python/tests/test_Result.py | 30 +++++++++++++++++++++++++++++- 1 file changed, 29 insertions(+), 1 deletion(-) diff --git a/python/tests/test_Result.py b/python/tests/test_Result.py index 4eacdee4c..4de8598f7 100644 --- a/python/tests/test_Result.py +++ b/python/tests/test_Result.py @@ -1,8 +1,11 @@ +import time import shutil import os +from datetime import datetime import pytest import numpy as np +import h5py import damask from damask import Result @@ -81,9 +84,34 @@ class TestResult: default.pick('invalid',True) def test_add_invalid(self,default): - with pytest.raises(Exception): + with pytest.raises(TypeError): default.add_calculation('#invalid#*2') + @pytest.mark.parametrize('overwrite',['off','on']) + def test_add_overwrite(self,default,overwrite): + default.pick('times',default.times_in_range(0,np.inf)[-1]) + + default.add_Cauchy() + dset = default.groups_with_datasets('sigma')[0]+'/sigma' + with h5py.File(default.fname,'r') as f: + created_first = f[dset].attrs['Created'].decode() + created_first = datetime.strptime(created_first,'%Y-%m-%d %H:%M:%S%z') + + if overwrite == 'on': + default.enable_overwrite() + else: + default.disable_overwrite() + + time.sleep(2.) + default.add_Cauchy() + with h5py.File(default.fname,'r') as f: + created_second = f[dset].attrs['Created'].decode() + created_second = datetime.strptime(created_second,'%Y-%m-%d %H:%M:%S%z') + if overwrite == 'on': + assert created_first < created_second + else: + assert created_first == created_second + def test_add_absolute(self,default): default.add_absolute('Fe') loc = {'Fe': default.get_dataset_location('Fe'), From 9855c617470ebfbe1a85e705fb1a68e4c58f033d Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 23:39:19 +0200 Subject: [PATCH 113/136] store vtk file in tmp directory --- python/tests/test_Result.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/python/tests/test_Result.py b/python/tests/test_Result.py index 4de8598f7..6d1961823 100644 --- a/python/tests/test_Result.py +++ b/python/tests/test_Result.py @@ -292,5 +292,6 @@ class TestResult: assert np.allclose(in_memory,in_file) @pytest.mark.parametrize('output',['F',[],['F','P']]) - def test_vtk(self,default,output): + def test_vtk(self,tmp_path,default,output): + os.chdir(tmp_path) default.to_vtk(output) From 6f7c7005b0d0d1d61d77144ebd843451ccd0bf28 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 25 May 2020 23:54:06 +0200 Subject: [PATCH 114/136] bugfix: - proper overwrite - no out of bounds error for empty time selection (just pick nothin) --- python/damask/_result.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index 2ff3701e6..021b66d4a 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -146,6 +146,7 @@ class Result: choice = [] for c in iterator: idx = np.searchsorted(self.times,c) + if idx >= len(self.times): continue if np.isclose(c,self.times[idx]): choice.append(self.increments[idx]) elif np.isclose(c,self.times[idx+1]): @@ -1031,7 +1032,7 @@ class Result: try: if self._allow_overwrite and result[0]+'/'+result[1]['label'] in f: dataset = f[result[0]+'/'+result[1]['label']] - datset = result[1]['data'] + dataset[...] = result[1]['data'] dataset.attrs['Overwritten'] = 'Yes'.encode() else: dataset = f[result[0]].create_dataset(result[1]['label'],data=result[1]['data']) From 7f09c90c7db51763f263d2ec43b3cca8cd9cd3ef Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 26 May 2020 06:39:11 +0200 Subject: [PATCH 115/136] different h5py versions seem to throw different errors --- python/damask/_result.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index 021b66d4a..d0f437d72 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -1045,7 +1045,7 @@ class Result: creator = 'damask.Result.{} v{}'.format(dataset.attrs['Creator'].decode(),version) dataset.attrs['Creator'] = creator.encode() - except OSError as err: + except (OSError,RuntimeError) as err: print('Could not add dataset: {}.'.format(err)) lock.release() From 88c49fc4f4498a75cabe0cb58b81648084fb25da Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 26 May 2020 06:48:52 +0200 Subject: [PATCH 116/136] also check values --- python/tests/test_Result.py | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/python/tests/test_Result.py b/python/tests/test_Result.py index 6d1961823..92e61771f 100644 --- a/python/tests/test_Result.py +++ b/python/tests/test_Result.py @@ -92,9 +92,9 @@ class TestResult: default.pick('times',default.times_in_range(0,np.inf)[-1]) default.add_Cauchy() - dset = default.groups_with_datasets('sigma')[0]+'/sigma' + loc = default.get_dataset_location('sigma')[0] with h5py.File(default.fname,'r') as f: - created_first = f[dset].attrs['Created'].decode() + created_first = f[loc].attrs['Created'].decode() created_first = datetime.strptime(created_first,'%Y-%m-%d %H:%M:%S%z') if overwrite == 'on': @@ -103,14 +103,14 @@ class TestResult: default.disable_overwrite() time.sleep(2.) - default.add_Cauchy() + default.add_calculation('sigma','#sigma#*0.0+311.','not the Cauchy stress') with h5py.File(default.fname,'r') as f: - created_second = f[dset].attrs['Created'].decode() + created_second = f[loc].attrs['Created'].decode() created_second = datetime.strptime(created_second,'%Y-%m-%d %H:%M:%S%z') if overwrite == 'on': - assert created_first < created_second + assert created_first < created_second and np.allclose(default.read_dataset(loc),311.) else: - assert created_first == created_second + assert created_first == created_second and not np.allclose(default.read_dataset(loc),311.) def test_add_absolute(self,default): default.add_absolute('Fe') From 670e08468be1cc67d53dc1b41796bd5113c4ca94 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 26 May 2020 06:49:29 +0200 Subject: [PATCH 117/136] reorder tests depend on other functionality that should be tested first --- python/tests/test_Result.py | 58 ++++++++++++++++++------------------- 1 file changed, 29 insertions(+), 29 deletions(-) diff --git a/python/tests/test_Result.py b/python/tests/test_Result.py index 92e61771f..772cf4734 100644 --- a/python/tests/test_Result.py +++ b/python/tests/test_Result.py @@ -83,35 +83,6 @@ class TestResult: with pytest.raises(AttributeError): default.pick('invalid',True) - def test_add_invalid(self,default): - with pytest.raises(TypeError): - default.add_calculation('#invalid#*2') - - @pytest.mark.parametrize('overwrite',['off','on']) - def test_add_overwrite(self,default,overwrite): - default.pick('times',default.times_in_range(0,np.inf)[-1]) - - default.add_Cauchy() - loc = default.get_dataset_location('sigma')[0] - with h5py.File(default.fname,'r') as f: - created_first = f[loc].attrs['Created'].decode() - created_first = datetime.strptime(created_first,'%Y-%m-%d %H:%M:%S%z') - - if overwrite == 'on': - default.enable_overwrite() - else: - default.disable_overwrite() - - time.sleep(2.) - default.add_calculation('sigma','#sigma#*0.0+311.','not the Cauchy stress') - with h5py.File(default.fname,'r') as f: - created_second = f[loc].attrs['Created'].decode() - created_second = datetime.strptime(created_second,'%Y-%m-%d %H:%M:%S%z') - if overwrite == 'on': - assert created_first < created_second and np.allclose(default.read_dataset(loc),311.) - else: - assert created_first == created_second and not np.allclose(default.read_dataset(loc),311.) - def test_add_absolute(self,default): default.add_absolute('Fe') loc = {'Fe': default.get_dataset_location('Fe'), @@ -291,6 +262,35 @@ class TestResult: in_file = default.read_dataset(loc['V(F)'],0) assert np.allclose(in_memory,in_file) + def test_add_invalid(self,default): + with pytest.raises(TypeError): + default.add_calculation('#invalid#*2') + + @pytest.mark.parametrize('overwrite',['off','on']) + def test_add_overwrite(self,default,overwrite): + default.pick('times',default.times_in_range(0,np.inf)[-1]) + + default.add_Cauchy() + loc = default.get_dataset_location('sigma')[0] + with h5py.File(default.fname,'r') as f: + created_first = f[loc].attrs['Created'].decode() + created_first = datetime.strptime(created_first,'%Y-%m-%d %H:%M:%S%z') + + if overwrite == 'on': + default.enable_overwrite() + else: + default.disable_overwrite() + + time.sleep(2.) + default.add_calculation('sigma','#sigma#*0.0+311.','not the Cauchy stress') + with h5py.File(default.fname,'r') as f: + created_second = f[loc].attrs['Created'].decode() + created_second = datetime.strptime(created_second,'%Y-%m-%d %H:%M:%S%z') + if overwrite == 'on': + assert created_first < created_second and np.allclose(default.read_dataset(loc),311.) + else: + assert created_first == created_second and not np.allclose(default.read_dataset(loc),311.) + @pytest.mark.parametrize('output',['F',[],['F','P']]) def test_vtk(self,tmp_path,default,output): os.chdir(tmp_path) From 5ad7fe04d0ac1436670a4bd871a7621b75af793a Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 26 May 2020 07:15:27 +0200 Subject: [PATCH 118/136] bugfix: used wrong type --- python/tests/test_Result.py | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/python/tests/test_Result.py b/python/tests/test_Result.py index 772cf4734..11395b23f 100644 --- a/python/tests/test_Result.py +++ b/python/tests/test_Result.py @@ -271,9 +271,10 @@ class TestResult: default.pick('times',default.times_in_range(0,np.inf)[-1]) default.add_Cauchy() - loc = default.get_dataset_location('sigma')[0] + loc = default.get_dataset_location('sigma') + print(loc) with h5py.File(default.fname,'r') as f: - created_first = f[loc].attrs['Created'].decode() + created_first = f[loc[0]].attrs['Created'].decode() created_first = datetime.strptime(created_first,'%Y-%m-%d %H:%M:%S%z') if overwrite == 'on': @@ -284,7 +285,7 @@ class TestResult: time.sleep(2.) default.add_calculation('sigma','#sigma#*0.0+311.','not the Cauchy stress') with h5py.File(default.fname,'r') as f: - created_second = f[loc].attrs['Created'].decode() + created_second = f[loc[0]].attrs['Created'].decode() created_second = datetime.strptime(created_second,'%Y-%m-%d %H:%M:%S%z') if overwrite == 'on': assert created_first < created_second and np.allclose(default.read_dataset(loc),311.) From 520dfe216ae97190f974be202e76b95f954209b4 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 26 May 2020 07:57:32 +0200 Subject: [PATCH 119/136] cleaning --- .../tests/reference/Result/12grains6x7x8.geom | 66 +------------------ python/tests/reference/Result/material.config | 3 - 2 files changed, 1 insertion(+), 68 deletions(-) diff --git a/python/tests/reference/Result/12grains6x7x8.geom b/python/tests/reference/Result/12grains6x7x8.geom index 7bb4a3e4d..4e6836bb8 100644 --- a/python/tests/reference/Result/12grains6x7x8.geom +++ b/python/tests/reference/Result/12grains6x7x8.geom @@ -1,68 +1,4 @@ -68 header -geom_fromVoronoiTessellation 2.0.3-1073-g6f3cb071 - -[Grain1] -(gauss) phi1 358.98 Phi 65.62 phi2 24.48 -[Grain2] -(gauss) phi1 121.05 Phi 176.11 phi2 295.73 -[Grain3] -(gauss) phi1 43.79 Phi 113.76 phi2 345.90 -[Grain4] -(gauss) phi1 265.15 Phi 62.52 phi2 299.71 -[Grain5] -(gauss) phi1 221.23 Phi 26.54 phi2 207.05 -[Grain6] -(gauss) phi1 249.81 Phi 61.47 phi2 152.14 -[Grain7] -(gauss) phi1 332.45 Phi 99.16 phi2 345.34 -[Grain8] -(gauss) phi1 312.27 Phi 118.27 phi2 181.59 -[Grain9] -(gauss) phi1 303.10 Phi 48.21 phi2 358.03 -[Grain10] -(gauss) phi1 338.26 Phi 48.11 phi2 176.78 -[Grain11] -(gauss) phi1 115.17 Phi 56.54 phi2 223.84 -[Grain12] -(gauss) phi1 281.04 Phi 97.48 phi2 27.94 - -[Grain1] -crystallite 1 -(constituent) phase 1 texture 1 fraction 1.0 -[Grain2] -crystallite 1 -(constituent) phase 1 texture 2 fraction 1.0 -[Grain3] -crystallite 1 -(constituent) phase 1 texture 3 fraction 1.0 -[Grain4] -crystallite 1 -(constituent) phase 1 texture 4 fraction 1.0 -[Grain5] -crystallite 1 -(constituent) phase 1 texture 5 fraction 1.0 -[Grain6] -crystallite 1 -(constituent) phase 1 texture 6 fraction 1.0 -[Grain7] -crystallite 1 -(constituent) phase 1 texture 7 fraction 1.0 -[Grain8] -crystallite 1 -(constituent) phase 1 texture 8 fraction 1.0 -[Grain9] -crystallite 1 -(constituent) phase 1 texture 9 fraction 1.0 -[Grain10] -crystallite 1 -(constituent) phase 1 texture 10 fraction 1.0 -[Grain11] -crystallite 1 -(constituent) phase 1 texture 11 fraction 1.0 -[Grain12] -crystallite 1 -(constituent) phase 1 texture 12 fraction 1.0 - +4 header grid a 6 b 7 c 8 size x 0.75 y 0.875 z 1.0 origin x 0.0 y 0.0 z 0.0 diff --git a/python/tests/reference/Result/material.config b/python/tests/reference/Result/material.config index 0b0808a12..4820b1eed 100644 --- a/python/tests/reference/Result/material.config +++ b/python/tests/reference/Result/material.config @@ -124,6 +124,3 @@ a_slip 2.25 h0_slipslip 75e6 interaction_slipslip 1 1 1.4 1.4 1.4 1.4 atol_resistance 1 - - -[dummy] From addc4c36d1b6dbbdd9244519ab3574ea4c318deb Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Tue, 26 May 2020 08:06:39 +0200 Subject: [PATCH 120/136] test for XDMF writer just ensure that it does not throw an exception --- .../Result/6grains6x7x8_single_phase.geom | 61 ++++++++++++++++++ .../6grains6x7x8_single_phase_tensionY.hdf5 | Bin 0 -> 2025856 bytes python/tests/test_Result.py | 11 ++++ 3 files changed, 72 insertions(+) create mode 100644 python/tests/reference/Result/6grains6x7x8_single_phase.geom create mode 100644 python/tests/reference/Result/6grains6x7x8_single_phase_tensionY.hdf5 diff --git a/python/tests/reference/Result/6grains6x7x8_single_phase.geom b/python/tests/reference/Result/6grains6x7x8_single_phase.geom new file mode 100644 index 000000000..14cae0973 --- /dev/null +++ b/python/tests/reference/Result/6grains6x7x8_single_phase.geom @@ -0,0 +1,61 @@ +4 header +grid a 6 b 7 c 8 +size x 0.75 y 0.875 z 1.0 +origin x 0.0 y 0.0 z 0.0 +homogenization 1 +3 3 3 4 3 3 +3 1 1 1 3 3 +3 5 1 1 1 3 +1 5 5 1 1 1 +1 5 5 1 1 1 +6 3 3 4 1 6 +6 3 3 4 4 6 +6 3 3 1 3 3 +3 1 1 1 3 3 +3 1 1 1 1 1 +1 1 1 1 1 1 +6 6 3 1 1 1 +6 3 3 3 6 6 +6 3 3 3 6 6 +6 3 3 1 1 6 +3 1 1 1 1 3 +6 1 1 1 2 2 +1 6 2 2 2 2 +6 6 2 2 2 6 +6 3 3 3 6 6 +6 3 3 3 6 6 +5 6 6 6 1 6 +6 6 6 6 2 2 +6 6 6 2 2 2 +2 6 2 2 2 2 +6 5 2 2 2 2 +6 5 5 2 2 6 +5 5 5 3 6 6 +5 5 6 6 6 5 +6 6 6 6 6 6 +6 6 6 6 2 2 +4 4 6 2 2 2 +4 4 2 2 2 2 +5 5 5 2 2 2 +5 5 5 5 2 5 +5 5 5 4 4 5 +6 6 6 6 4 4 +4 4 5 5 2 4 +4 4 5 2 2 4 +4 4 2 2 2 2 +5 5 5 2 2 2 +5 5 5 4 4 5 +5 5 4 4 4 3 +4 5 5 5 4 3 +4 4 5 5 5 4 +4 4 5 5 2 4 +4 4 2 2 2 2 +5 5 2 2 2 2 +5 5 4 4 4 4 +3 4 4 4 4 3 +3 5 5 4 3 3 +4 5 5 5 3 3 +4 5 5 5 1 1 +4 4 5 2 1 1 +6 4 4 4 4 1 +3 4 4 4 4 3 diff --git a/python/tests/reference/Result/6grains6x7x8_single_phase_tensionY.hdf5 b/python/tests/reference/Result/6grains6x7x8_single_phase_tensionY.hdf5 new file mode 100644 index 0000000000000000000000000000000000000000..7812f82e857431d0856af9149794358d84265875 GIT binary patch literal 2025856 zcmeF42S60b(tsBbMMXq0C)$ii78Ohbf{2QWITM5>C`po-F=IwC3y2Z3m@^|HVnR^_ z!2~7*42Ti)U&GGa-QyPbzeoGrgIe$CovH5X>aVJ6dS+*57g$?bRjbmViimrusE8_v z)QjEe$3YeQY3|3D)>1HE>-M(quabzMz5wi|2e z;>eLw6}j>DC>QB*a`f=vc5v;xLn*Z9_51mVo&0?rJ&3Lc@fUk>gCC*i;qB;5bX`dY zS6@eWFTV~!9fM5l{oK7=J;e4tZjOFpJy)@}XHhqxkNfv$eh_%?kU$e%}nB@_+&yGbOJO{*9ogcpS@6 zS8l}$BIW;B4+!TAwvuI@NQ(z5$pfMi*8}AiAP&5UK=C{v%*#UlI4oci=4a8#g|M>} zrLcZ2e%x0TSr=*L;#(EYhFyK#ow*%z!|aR#VupFQ($2nsv^lshtpRJ z^!d3@7IQUAJg+H1FV{vS%3&ns3%-2K{HdQiZ>lHq_H}o4_xf-3OSJ#>uW(&JSO6)A zw2H(Eijwi$@{ak#KgG6{L_tMO>%elU0?7I~dKQiUuYE{+&z;9`4Q;*s-2LHf<&Qc- zM}O@2&o{;W#GM^+O%!>9Re%w94T9Nv>H^jqu^676JH4;Dq|2_hS za3xUet|#)IkQME;1n8r^4lZF4RW`qyaJ@4Uqxiz8zKG z^Fd=|K)7%5mG?N%L3kY>n$G)D%c1u`HlkpXFi3`lEaK)7#Xl=pRF8)QJV zkpXFo42TXgAiBta=ph55j|>R+z4-FJJ}^WE#0VLXcF2GjBLmVN8ITUhfOJF#!~_`- zQ)ECoAp_DG8IUf>fOJI$q#H7TC(q)!vl%iV=E#6_M+U?K84yckKzbkpVucJyPh>!> zkpbz23`lQeK>8p9VuK7wUt~b~Ap_DM84&Jy-R1rMg8|5Z3`7QG5HcWxkpUTk49HMq zK!za$G8`F@5y*gyLkF)xj%2TM+U?J84yQgK*k~i;)Dzc_hWqJ z{dywz1A671feSJquE>D6Ap_!$49GZSK*l2j;(-i^Co&-14+fX_HIg?nAU?=|Oh5+2 z7a0&gWI+6p0SQ0`BoG;piO7HiApK$ao{vJ4rJP-H-s zBLlJm8IUk!Kvp6HvI-fH)yROXK?Y$OdFU!jS=qKn5fd8IX<0fJ7k! zvI!ZG&B%akK?Y_Y}*KQbUO z$bcL`2IL?zAcv3vIgAX*5oAD)A_H;^8Ia@1fSf=EcWI$q(0b!8= zIg1QP95Nv1kO7HD2IM?4APLBTTtEgS5gCw+$beiz2IMj_AXkt9xrz)(5;7pykO8@l z3`jCEAUBW!xrq!&3Nj$KkO4_W1|$s`klV!WI!Gw1M&zNkjKb?JV6HJDKa40$bdXU1|$a=kX&Ry@{j>}jts~PWI$db1M&(P zkbGo7ULylifDFhRWI)~`1M&_TkoU-dd_V@|BQhX`$bfu82IMm`AYYIH`HBq4H)KG* zBLngS84!_zNMva5<0kgU>7ipYReLIy+y8Ia1z zfK)*Sq$)BXs>py;Lk2_*8IbD8fT$w_QUe)~n#h1?AOlhh8Ian@fYd<-q%JZb^^gIn zj|@lyWI!4s1JVc?kjBV>G(iSL6B!VK3`kRCK$;-~(i|C(7RZ3KLkRHf@SRn(_6B!U| zWI%c$1JWBAkUq$O*dPPa7a5R#$bj@OV&LWNB`%Lo4U~)-9w7FM+T$@G9WdP z0ntDPq!uzDwUGg-gA7PrWI*a615zIukOs(rG(-lZ5i%f+kpXFf42UK&AOsnZrpSOa zLk6TdG9WFG0cnX0NGoJOS|bCZg$zg=WI(i$0cnd2hz>F!y2ya&Ap@e142S_TAcn|* z7$F1F4jB+*WI);@1JVH*kdDZJm>>gUiVR36WI#G21JVTi7kO8ql2Ba@CApMX5>5mMEEixbj zkO3Kp49Fm4Kn5cNG6Wfrp~!#?Lk46xG9V+60U3!5$S7n$Mk50<1{n}LWI*hZ0dYVE z#1R>gvB-cpAp_!!42T#R5Eo=XT#*5BLk7eh8IW#6kOA>V2E+#$ zkO|0u_#y-1hYW~6G9UrSfCM4~G7%Y&AY?!$Ap_-M91{sh8$bcL~2ILSjAcv6wIf4wxQDi`lAp>$88ITjmfSg1Ir;!0UgA7P4 zG9WB6AZL*Qi9-hD95NvB$bg(j1|$I)kPFCwBq9TH5gCw6$bei%2ILAdAXkwANkRtX z8Zsc)kpW3Y2IK}ZAUBZ#NkInW7BV2I$bh6F19BS~kaT1~GLQkegAB-BWI*mA19Bf3 zkO#5gCw5$bhII15z0o zkSfT4R7D0v6&a9f$bhIJ15zCs5OrigY9Iqr6B!Tm15z6qkUGeK)I|oQ9x@>H zkpXFd3`j#{KpG(f(ij<#CdhzjA_GE@0cna1NHb(Wnj-_!0vV8&$bhs$2BbAIAX>

hO$J@PVkE__*Q|#|MNvO}oCifymfB*ic1|P2^UJ`$1e1EDUi3JLxN}^gK z6_LNYr&!-lB&tCe*y3JhBIBwe;~z>AokBm7EiTfze}B#kp&yeA{Jh}fUDmu4 zg5KhBti|g$`BA){(oq$+*U6s4-_A-%sikY z;fHxZZe9IL4J)1pB&#fuD7e^skvz+pJN`&s)}^$nr1%vjN#-fxk597VH!1~>W2JP( zzq)zx_!W)=W_pG`D;@C{6@DEGLaZKTl<5)UBUxfKlJdXdN z`f^jfq&%Q+R#q)r$p0VcRM`$F>&!Uq;VP`2yNghz- z&-O&3oLiE(75Y(6m24Z_{?Fr7R`P$=D<1EqFzH{}w4^*xoS&@qfQgdi#98qFzY+!- z{a+I(o(If$O}6~}6BK*?!*2`oT3BcB&0sxI zt!PcbeQ$_+3D+xg6eaN}=#fZ8a0XmhRKE_Kei7I?Q4q)|rClcq;@ilId1-Bh3tH;` zMZc5zHpN*KS0$}qWmq|Js1y~rUkDM2EEc~A-K9J$v?P&o{JnleENk5LcwbRw0#jPKto}QQn%a1Y6nt&`TUhNK3Vq3lFN!eS#nwVN0wZceX``T?2{#z#aCAQ z(#mD^Us`!-?UU8MwDw{9pC3PE#lI~1@AhA5?UQA{EV-=yODmVve`)2VwNF<2(%M(r z`CD51O51;F+soo7YkZ~cUsn63&jz`*3X5b`rCN9KWTV--bMKE2c$3cz2sL>$YF;QK zOD;>ltntax|EuM)?2{#zcl%_;UuosC_>@*&TKi`{ z^GDw8`_@-uyZbM#{qo+v zwDVWi^&?qwS$s-spRD$>?2{#zrT5%NoC|@yTlctL3udPnKMkeX{1? zua?WQ|5wXp@sTB$6+ge*ep&X(lK*P^W%d87<+A)+TKT`-{?hutwESeXFRgvD+RIvh z%W5yn{?f{2^c6ydS^dkB%bMS%wNF-iS^fWNxhy`i?^HYmVL71zuSIU*Ux3iW!W!F zE{ngc{2|LeS#nwDSF-H?)pA+(mo~nBwf(Z}6YiG{t{}NzR=AH=xR+D~o&><%D5|88 zlP|zkJV6D8qT6&uwvytHQdK0mvspo; z3La1qS&IFfeBFKixUX6RoYfR;;+u(_d?)$&J9?16+<#3R{m6s>?)&y$!rj;+&?X_x zeZz|TXXEG(U*8goIDH&>L7(uwWL1$_(a44R7QSLfe{bKS`i=fl-_pFV`Jg@|&`8ff zubr+@dqZPgSCfwI#+te~7P;)t@8?VUEz%=)F4Du@=PdMVWME{VYtUZTr~@(R*vZ(a zQ+t!PunWSra#5WqzM_KgeSam%4uPK#JwjR1ekDHcrQJi#4Y>Gy)PI>LRV2ED?YMfv ztN1+mlUvFDs|AgPaXX7$ynW%}2;eE=>g(vt-9^vo{?lKaMJl2pUhYNvIe&3&h4zMA zWqAGB?_W6oMt|+#4g7una&!Ox`OCV9-_PdTU*laY`Q9TzzZGHoBX0@w?$1(keEBct zS>mto8~=UPGUqpm7fSm3nkh*l+5i8Q|9|V1)SJ*=C}q`?B}YBd2?<<;QhF_s=>IGK z|JIY$59*OlNZ=xr(rcl=kdO4p5V#1X^ja7{$VYl)2wa3xdM%6}5(CD5lZQ`Fn*Aa z^vDpn2&ME|7(d8IdSnP(gi?Afj34A9Ju(C?LMgo##t-t59vK1`p_E<=;|KXjj|_o} zP)e_b@q>J%M~1*fD5clJ_(49>BSYXKl+tTq{2(9cks)vqO6j#Qevps!$Pl;)rSw`D zKgdUVWC&b@QhF_nALJuFG6XI{DZLiP5Au;783GrflwJ$t2l+^k41tSKO0R|SgM6e% zhQLKArPspvK|azWL*OEm(raP-ARp9sI^kdO4p5V#1X^ja7{$VYl)2wa3x zdM%6}FqGqqW>nyQ_jFm~}Buct1%$HZv;I5^Yt3FEtY zk;{(QXH2utZax#$&amc{uMQm7;wjs&i_IkMg;&`&q6Fjft}hs!uKF4#moiv+)AOZq z>_WG$_t?zs^^ddX*8CpxN;J)?W5|6*-o{1Cp0yXo#Et0qlIeZ;{q-qz?yxoYRek2RK9t>& zGt#Z~jd*5hzxysqv(uU8{!{l3Xz`NG-MVDt$=2yiEsGu(B}+)kBLjEj?wG zbAF>u4USICV(ikdZ696x8vFcQ&3B*1=CK3jc3@Z+#Q!`tv6`-ofctizLEj>8je?BkdjWaEO(b7YU zkG$!j#Yf)s$Qx%`_Q)G&c{_f|8)tdrBX9Q5if3AWmp4AN>{;P6!n5VIe0Jdp1J96m z$Jid$jeUQ_?PVUkI+S7(c#N$&cJKJ9>G@1Z>v4{5d7GHDfVw|CdhchiPf|DBt`*5F z>=`|Qyv%25>7g|)T7IWBuCl6!7H3*|kn_*4tJC64D?iJd9$I|lO^>{Bre%-3ai;b8 zpuCNXmOb)ze5W<8vZ_bkj;F}^f3prRtA3ZaamkxKwB{GBE9S7x25BlqWvpy`VewVj#$(ud2@-rBFIswN`HL1GT6$=Wixy{j(?g3hEj{S3pI>LA^?f2*dT9BJ zmL6L3i`IIK7H3*|XnihB%U@+x4=sPmTV5@z{-VWs8vp!xAO3ms{rTt13(uo(%0GWz zn}6Q?0si^)X8iN$h3C)9n;yaM!t>_0@z0kRo=30GKY#u#|GfE${PXG4`RCEU=AS<= zZ{wn6&l>*u^U?hC=Ck?d%lG1+N56=F{(MdTdGk&9=hGAZdGtE`^XKJF4=q0Orbk#O z2+x~8#6Mp?mVX|7BmVjG)A{Gk@8_RSFFcPvpMUYIhJviTgJ}=~rGcAA7(nE`nyy>CEN8a?v8)sVf$Qx&QJATOY55D+^J?>7 zOw3?Qx-XX&XIgP6Z+ei=|K_@ly!jpN`MKZaZM{M3en?t+XvL4bai(PtEzY#`&>B}+ z)kEtzC~tbuU;mr+VOjONyp2oV?4gyPY3ZTGht~1Etm>iVud=F#RvgmOL+dz*{`&dx zlon@NddjN5Xz?kldT8YhdDDab`g#75H-E`n{*gC6wCs^L&a~{I_4y7hduaJf-t^Go zBX9nqH76d)6zrhb75NkDyw>E`AgpNYFYIcEzSy}$|41kNVJ3d11|-UiKJAL?6Bqc zD;4b(iG;GG{Ys*GMfz$GMx;{I#!O^fRb>2wZ>S7=IhBeEiba}L`1(o;Zh94p>Id8L zT@@8Ic`aP!v3suCsfw(N_A7`~L82nE6#F^(y8HOMdwUh_*H9FR8p1o?Y>}0_ub)4$ zb@%pg)a~Q$>*VI`;zIoVeZ_u$MfFuhTD(5aG8NGfFL!@#2d4-A`$LbdV^KBe)vV}^ zLQ!oMk%h0=(cjy*sD7ir)VDP6Yd)wC2{h6(&}*k_)ZWlo*VUwByRoJ&jzxe~1 zJ-nUV{U;GuUq@$mu~(6Epx)2?#)X>Te?xu2&t|Zf+s}FVclu4C$TrT$+^dF2UGhd- zLXqf5%E1GB^x&-hQS2qD41Zto_5av`Z^{z^>mKH|+<1rcgO+45k;sgXAAyCd*h}o| z?j-UQJGpWDoE<$KUBx1iznj?C)6wIPd14?mkWmim*WZ$hU=_YzdK*a`3iC}=ERJQU zE4N~fA;+wE9&mdu;TiH$;3~bIb-qOIR`BzBS-f2IPExNp@Uy*Z*Kch7v|Cg|C&QLW z8)IJ|uQvASlohct{I*VNo$3DU`)*k}-5zua-PtXRmkZmsYJWbu#pQlCdDHV?K;pF5 z4-{FVJ-g!Gs4d+FJ5;Mbd~ZUxTKsnWu`M2VJ1MdcQwED{8pOvA=jB=a_Td+8Jno!V|>Dn?A+S@A@-aDH1|`9jEf7j@?B~_Tt z=jFlt_J%nP{DT&&G4iH|79V-jvpQb0MfZmlS>t?q1?wCt6L%W&q+pSb~ zxZ0akU`1`_HK_S@{2y{rYsq#uEai*oG zta83}tci}ZW8=k1-*t`D(I&DW$lm14>kV3dr^T6;9$NXCmL6K`Lt1)hai*n*7H3*|Xw3^+_Q;zaT72Y9kGyfF zWskgZMtlBU=ecFoU$l;2wDjP7|M|R-H_o*DMN1DYKJuoA79V-jBX68(*&}b959$K7f=|RpvzphS;Gp+nA zZ+d9)kvBc^#+jBq^2V9g=Y#S#E?V};+wq;&xXP*?c{`pW=l{(*ysY|N-o_2&b0i6>-nGGmrIK?tvHl7J;>*ObKOSX{Eqhg-0$+X-k^0q zBrQF(;z!;%)3S#aXIgq_jjOEcp>-UTH$CXD|IPZatomKv#wBm|(8|xW^w8o%>-b() z_0aNHS=B=;4r%G3bsR*0{rq@Ji!&`fWz}D__>@&WwDN|$=|O+}Jpag>zvM0d$QvJ8 z_Q)G&TK3TTe211jwEQJ+dT8;HH-FI@m%RClmOZri$eSKod}!&RwQi9&&a~{I#iy+5 zp%sU;^psW3w8lk?Gc7%|=4n~gQ&!h4^5!pEoN4KyHNR--q2(`Hd}!&RH7;757n(xFfD(TRXw!)C2x7Pton-<=i<+! z$898l1dsp{Kmter2_OL^fCP{L5l(Q*tfcuJBFrz|N+JGf&2NlLxp2SS8c|YQ5Iy2^1$#QofS6{l)FZZ6tsMkihRIAa8lHBzt~0C+r^yAOR#$ zoIpwWO5XMtw;Q*S01`j~zng%(<;jxl`Q4nbe1g$MBFzhR769(-2FKg-1i;0?>Y$Icktu^sfx^s-YFE-RuNhF ziXHvEeT(Wh`b&LF^S5{jdfj3I<^~Y>f&g^DNq#^6`-H%mDeM7 zF4Dt&Cq?Mj$iT=z*Py+wQ3qnsv6Hb;r}idoVV8k|sB%%AD86Fx?~~Z_`-Sh56yN^u zzfWRqB#EG4O>P{*>+jzuu`Lq)?E56mp@uL{soy8@bo3Ydx;uLKc)P>5Op5gVTm2<) z!V(D}0VGhi2?U>(KEB_zU%EB87YQH%8U%jVye_F<8e>8oNB{{)Cs5M7`(68`TZwy- z01}`<;CIdIlKQ1FCe(ohkbraoCC$6vwO_iGxEBc^0U88;*Ss#NUm9aV9Y_EPNGDLz zy!&1IrCW)6kpL2)LEv}I>yrAVF(%Z31b!a@1(8zGy-VD^THH%`-fhTW$=y-ICA&qk zo<|)uOj2La!#BgCoDeAfJZcku+y;Cc2^gHbz5M*${R7}}%SF5X0)e&Jwu~K;c|LXyg_*3Wm`}4lUN}^hDU!uRer&u3uy({Ut(?UPIdb5z3$ zq#rFl-et`TH#>DEK7NGZ8`}H0iM_n-U7VbXb_wxlCRF%` zrR2V9C5U{=*3M87_%yp`Q8($+p2LNy)4G z*B2$_f#TzpnFmf)EMg(}<6jR32k?&w6wd>~_ZV!8%@;#^FK;jLpZAkn|D#_1Ub&?B zP3HT3Jw`HLWyP=0SV=vM-@h|14||HouW%et=hrs^1NbowSl>CpI?fBe^5FEx_ae-M z3jeT_9LKnCmq=ba__!60JH_MpAF3}m)l13)>GqO&UFi7NJb=G9T5ba49}cv59uVeb zJ^uJ0s1xR=;#KG;i{BQx{O55hhL3NdUh#PU?=AXwwk#HT!`1vR3_4aj#OFfQ%{Qi~|FR&6z-dOoaN+D0! z@Y}+C71kMoJ_S*=qBRA4akS_qT(3O7ToR9h9-+RHsIaJh9r*Du0y`%P0vV;W>qJ3( z8zJYFq(WL-;ewWWNsajZ(%MeuWyM((S0$}&@!wOk`&@P2mh3F1Tg{7gJOiFFAJnTi zUYeJ|Bp$vM`RYv^lh84ydPk7|7};pmEB|NAMQ^t;ZSyl2|3k?>pL61vIie>6XFkbd zymz)AKLOgScAn|JsUU;V(P(<-Ms6HatCn^D>oXFWZu8>`431|q+cgy2n;eU0Pvl;F z_Vj2Tduzijm7vF2On2vMm-YlcV|J?7=$iO4gZbpM{L!oTam<8;z0>=E{08G?T!-6E+spS>RXO?oIj^kPjNU z+~^d@n{BtMw*%x`SDt(|=ye8D$Nj{>q4{ylxj8*g-nx*>__nU|s&$hjw$;FWcU!7P zunm3fYYv|JkQuP_yGwVluS1@Z#u%{AmK59^Va7oRFBy*o;kjRF@>NopO#{b zwuy>Wg)1#1*yDZA%io z!T%PWRvx_s{$JKHr|({nf66?cHEdHXo6@Y&1=|-O&u#qpF4(u$@=Bmdn% z4iW4&vuW;)gB~)QZ$D}s19A(OX>7zGaK)$+l%1ANv->sl$ zR8@$tuo0TOw{4GQm#vz)vE7{nrpd>N9lC*h$;_}8^PvABjs@WlR>rcu&Yi23oSVSB zZo0*$JJ@&O%$|_Z(7x}E8z~MTZ(47W*Wxz`%(@9N-aYo^GSP

cp|Wj_Q~JkTmC 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
b0<{`1{c5kH!A6Orp+i<;YJJ4@? z$g#i)##d?cz*}p9zqeAYN23m=FjZ@Y&R7QW<82z8nhW`Lj>7hD10esX3|M<30FEE^ zqGlY-1$m8LSr58H|64O!t}+ArI(;_k(hBUWF(qtLDA>o$cS;F{`D4>{=ba%iKF5Cf z%PYhDQT7?0xCYvjrwx)$f`0=&YqoS)m(Er=XW6hK#P9oN!!!y^BboG}4|9DYquI5Y z6P|5@_^;FG%-A(Pq0F#^@Yl(dBUE*wPQpiQ#-KllZE@E+2pb7+`0U# zx#QIYW_&1Pde0;?I3SX_x@_F;wD4$l)XK&W!$7`f!jRop)`T)_y-O3b!M+MDwyvKH z@m1x_jGJeHpR<0GIR(Ifdws>)li>V(XcfaV$66(^8&1FZRIghEON>{&dIjg_y&k(9 zZw>kXap${T)xf^K3SS4#0sYm^y)1YF`MXzTZ9CQQNakC^al=wUeyOvT$7GQECOFJi zT^!0ZSGj9&&Lff;Z3oFKLXh9Ny5QP=mr&-*zzeo^uyFpX5H)Q^{0dVOX5#f?Fjx?v1+cu<*(F_fxE3>ehqV~-KP>dsDD)VBJbhPJn%dzWZ+H!u)Nr=S80p;Qz@VXO7W@{+Y``As$*u z?7Yh=x<;AdY|QnmdN-l}+FLTS&%^brC3E)nQU!Uvs^0=q?uWB8XAi#_2=;fqlJ+ti zW!aEY332J(4r+s&xZI*HZl zZTkIoemL81i^axUAfK*%ulaW1PMO?BU|-VNmHroF8XLVn#7ct(8@ z$k)XCWv>SNUk*+Q=hjcB&a}?YgYntT42U&^`JZNH9#$FT0rT8^s>AwZ&7nh$S;&7I z>_nSHAU9m7z5LiNSf4mKPdE$q-6}jaG!3qgSj^t{y*=0`YFPM?JAY{;3f(^f^q;KQ zvx^V3&#fCCc^LZN+2T^&%^-ipy83hHm+DrxPX<8$iywAIc3lPgT3iWiQUL9f zdv2Y-VrV3@RW)NP~AC+jHx)r zBI8&lW0+WbnGIZjvU=FI(_Fazw8weSxXUoUHP*_POu@eMGwf>I1pg~v7`=E5*tfTe z&N8*Jk&I~O5@uOeH2XZW^U3kt{7i7#nGE@R=#%Tq_dtGkx_M#L<>S%p(&29F=7Zcx z^Y-vS$iFkQdtSBkk7U$?yfm7^`10!xGM@$VF3}g<>?emZi#766dd*E_PL6S`xDo8{ z74v9x!m)T(PRNwykAE8?r3)Pf$T=y`nK!7$~CUeh2x9b+vXP`f7eK=KC{MNI6kDWd&coqtDS7B z5fsW?4DOJeL&(_(&#Z?pC`6SEAXgKRy|c2Kj`(9`8r*3T4J5Cihf={^x{z zIeo8f6038vP3p?W;cQfR;I@M>zt=i8c*c$ITfd(1RhuWVLk4^_2#5S{cJp-295{a2 ztX3N`6xxqnyY|=cYCfl(a#9d!Fa_<}iM{9-5IiYDchL zT@Rc$0(k>d_Fa|dk<73<@j(?1!1>p7>shYc_(rdeP}>yBr1jq7?+^X&U;psf5$z;a z?L(ce6*@(*TRMf@Ukv?^++uWv%a0*f&+kbE{rA?Y+0U*V!LCViNmK&;&e8s13eaBb zMYuy@%OqC(;^Reeg$On$Z?X9m;M;i8=u;n{eUmF4Ze&1vw~@n|eQOxOwp($`HXq~$ zjwkBepOnZPQLp$p{6r?R_txsiz2W-o$_|0o55fEyE_!G)#V?V$|E%H^JD6W_gX_AV zgzM8gns{9{fcU)9qhNdYOSz1K)tQPv;PZz!`?6}+t`q^+nMc$N0Q<#NjGGt2{HvC5 zY~^8?e;1x7TR200Nw8k=`T)#7m4^ev+d%%9yzJ`%@qEay?;QF%!~Bf98CUQg8Wz>Z=li>XMdgn>8A#nV0xiNX(Zf^coT(_$q$Q{(WcyxmNWxKgyl{m;xHVR<{ z)geD6=;`?D!}!8X<}COG*PjC_Pcyr6J)YILzQIug?BB;so?3ZIBJI2_JLYr+Arw|7^!R z9N`SdXZMZ!KaSQ(Vi~WBqvLLcvqwKIIK2ww0XwUE&4%^OvhFpikAwMb{`OGR zG28e;JiAeRDRm*(cLFZVWWe?LDTZruHp2KaDnu<>hBC3!S}7UB{M>A8rn?yC=Mtm) zY~y+n?2_xZUe1R3montX)Jh#o?Xc^1a!RO`rqEigZi z+vU8lhWLCmsa3mvaq(Mx@EpjWw|w|1=To3y;(}@)YdrKYO500p!mli%R`A!TMvHrj7QyBYEu1THn*|!1|=- z)e{#iKptUcyXqjczfwOhSr6=Qx2aCIu5f*$h4%3tOX2#4Vq?QGmT>)g>X4JkOX2!U zkWJI3ZJ_=5%XT6;_5p|D%?Uw{8vNo091n@*3>V)J`^j*(ZXH z&=wCe1pBMjY}0}}zNJoS{WPt95k}5$s6c4wWv$_FSVB#@EKmd@1D5 zMhTnWXae7@CR28&1HadkN4LHS_D#<=(bfd{^~?stvqAp-so#=$Fux*K^{naw@{~Kd zIlEweZNILA`$Vw6=lS|fD>#01_@-mh5$vBc)o-`=^hoB&{>_6P!Sz?y)Bz8<{P}*@ zm;K#+Lz$GsCCx%XZhzuzKtITToi{9RF%IM=cFL}gSBEm96XQH})^(h0{MT? zVT+aA`e&ZeG4m|Q|4EANtGtbY{A_ajcERIl_SkBpv>_nxeWYvOb8vlVitdwP$-w7O zNaoV&u)a{ZW`FloiwM@*w!PX`;B(VlGfoZiqkVkqQ^Z_vf{&V_GFU*HM#ZE z2+!KjCc^r+ej`K0iEw_gFmd-*?)vt=>Wb5z!}?y=*(NOu`rovE$vBsz(X3Mwr8ZoC zuePgITZ?cwzFJmma4{;9X>_{kcw19|`NO=o?*9m>q;X57vQ;%{Bk>pgq6N@AP)_T7;I`R9b?k>D_xf4W&8 zv^-&aZSEc(9}f9l{ivs5+Uan%vbfKHBp6@&L#~~3AU>mJr{zb${20*ZN5uNGaC}!g zqGSU8(T{1}Ru}S<^4&(WR>S;sn-x7Q2-Y9XPN_C(5B_x! zapbzg@$A$0D~{;l~{fLH`s{N~h~Ezh};< zU-2$nAK081Qe`AuU-jGe!|x7UU!LXZ_n{r=zi@Fy69(GHJn{7H1oo*$PKu#*S#uiB>;m>JHCxCOf_%MC+`&a)pW0|`HMkJW#Ecj< zra4@{7;B{Qs2bR}?!w&o+mK%s#)cSe2Kyi1e7B`O$kRLQOeuiR*G4W_)vg-wk9lI; zf2w8@d)j4Y%y(G7N3EIFI|J4?F{ej2tqby2JHyNsVErFr`|ADR`Vs8--g*t^fqa0z z!pFPdpCCJ@!@GcguW?D|3L$@-bB^;+1^Y%CFEP{y`;NLc4ReLh*YYBFjM@eFhs^vs zSLXwKKIj_J-1HU5D~(T2Ukh?oL+hR2A%E_iHeY`zT)*CP_Et~5?!8|SX;xT9+XdwR|-hCuu*RkMhS1N$pq z*&Lt+`Dfvq_2z@VhO@i8(t3{p`Qky=I^UrEpi!!4LLt8{CzT9yY$Mn`A&1VtnfQ>2 zI>NfAgMEHx4q@lOzQa2;uFZh^2ZsFUG3qYdUs2eqRbTG&O`nwuHp~LKRihKrmV^Bf z{X1LNh4Fow*mk`t@Tp~^y<;)($$4Kp@h#+^BmH%4D}((XZrVF>$FBnodWt+@{^|so z_9>_l!TK+qclrj*k5PLwnZ;ng`EZ1DFO!;Of&H&GG}Q_NdA5$- zrb~LTzG`CpaY(fYIM3AiIvv_?xq4OOC|o~ZHmOF3)^Pni-+Im^1GqoSNzLJEPq;sz z-;loRxX&lg&OcG-0?0d7?Ah%6hFCV%D4^*)_sR0CWF~XqoN~jv z5TEDC?zA&-e2+g}y=FBSpLOPfyPgo=u>t%0jg60IdsOY`G!5c=_v`I}+AzN79+Lxa zLjD@RE%ioFVmRC3UF`tw_}q9y_zEppU;0go=oWSzt}mQ#5XI$B!;44SXujo{^7URWUX4J$%xqhw{wrcx#l&X) zmcNA0SDEb##c=*L#XnTxB%FUKuQ}ZLD4ajNyxY3ZIXHi67-eFa0P}x)qY)eKf&J6m z`t&~!^LNVI^(}gW{WigtTVBKZY@xYX-RCix%;RYXD{X@KgHMa%(~sw|JN>F%^nvrA z<}H==qM`kv_7OJR{H{^um4!95&-!>|;62bkbn?8;QILOLCiKs!1o91Ycf4N@{%>V; zVxJdyWBWdwYF>1wZ?Uk%1*^5ntXqwx7q#)O97eIdTIVjgE4gU_E= z&x}r~3h}4yde(Um9N!+y`ndNt{s10c6)!2```c0c7yyiRA1xRW>}wf?ylSG8Q8DcXy(&JV1LII z<9Y;v|Km>>ZnZcF*Pouun8xML=q)z3o#Fl&@3HgWjfeHmxh8k=9>V;Nuh+{V4L<)B z?w7RNhByJNh}t)abw_KLRr%O|NeJ`j<1tMXt156 zC&}O9^W;x%s__v%Gq%BOs0*_6m_t2$dU<3?)5f0)>d zT_2NkwoOZ8Hui&u!Z(%IjLwPp!i4HAnZuuzj;p(vGhX$tUA}v!C9}s?&3)GgxSp7F zp7bUrZo%WlFF|N3`Ze$HnWj%qiq_eZ$D!E@NqCDv7#Yo69cH)dds}f2*4No~Yt&N0IBb9OKD#iV31wb|)+)$n;;ic~ z7-rH?=zm_rMqPgwX^40oq zAJMq`?_>1XY6&CWSyq0{ylA}Qeph1^c153cA&)=nuy5R)f}W`wFjk>KEsWmgGj6Lc zynYFKtevi&3U+?lP5oV)$19h&W}EL!Um7>8BkPkrz0vSZz}Kj@Y_kdb+bvLR%6^}xp)vqC z+iC=NH+!GY>>4`twq6H||KsSomGY26_QY-vXWE?MH!JYQjw$* zLNZJEau1SGMr0*PMhQt$A@O_s{yKl1_v`(8BlY zJMozpol_Q;+x<@#2mGrt69s)P^{*zs1pAad@7sj>8{iqD*X7z01FTr`A3d{}97?}w z;a3fLAx~fpWZ6YTt&5Sl-}8lWxJ^KIcAo_DJ6vaX9r!$DJIUS#`aIKoD(>E8gZpH~ znWT0vlY^4}e&c$$4?Pifd=$mBjCz0PxW)z8RqHfqmQ&H-*&{->En|hn)VZ;%(0*7i@yC} zmlH*#^boByekIL&)nY#z(o+(-6vs`2idR{L(qMjX2g{k>9lUG4+c)%-QAXw4{!bkW zSba;8{*yRx_9U^(*;GlJ0?jdql9TsQDxf_@%{*vr9h`K+r#1ECf4(xu4Qz({Re(>Mg#7Hj!&792<7*VstyU;hjJau* zpn$j>*4FOA{OHA9W@(UTgu);987fWT{^rgl2ZA2HMay79drcpGs>>d;gLqzjm}?>v z#*euFJJo-8wKmqb`F9Y3 zMrs#w^YQCF4{>N@D5v1iFNNwE9^d#?qKDrInJ^M^b-$Pk3mL`L48>jQ~#V`kUKad$jOj1)5(^ zueXq=8M*ahT)9yG)%iI+s5@(lQ+ekBPwR9}lM|;pYK=3WNVxJ=U2GT22bUbU64LtkHYzW zitxaCF)x`=e#V1{MIBsvcJCHN4mF*^QnUnAoMM?+2L8(N6?{hmUbW`Gwp|%yke6^c z)nv3T{@hb3<7TRe%3r_Ka05PC7Iz-zRIiXvS<9{;Zm#XRVdQ_9&r5Ly>!ayRKnxw=YsOL6|pO| z$|Y*dhS>TtADsq12F%nk4*;if-vGnrmK?IX^4u%zC=oYba1`;b(ZWuLDP9`Y#Qi1brxgMgzfL@_N6`bampeiZgpLvO|-@_I~ZA^#=3 z*waCGg)o{=5I>YWz17sBl!!y-ZBh5*CnUQQw0YAmyf`)vPZL3xgywgy_W3RZ05Mb zDZxOxOC2*<60f|3x>Ji>xf@{}bXB^LJKisbzt%mvCr#EwH%%VtkAKlX4x5h(X91_~ z?yHggTa-w=RhISIydoOT+szrwqJ~)#ldtCh4_}^lW_qw*FICZy%R$YsFF2@JI@Rvb7zH#b?agBH1+>pJum_}Kiht1kfi zx}Wehw^W!S;+Er$IL2LwE=t~E@0CB~r_xt`90$Mm9p~*nvA~7(?3V6d%H>7_0%5j7 z>D0K}*R7Ha>-*N%leO%S?=M`HS9aN$pynHT_NO=RlFF*9jm{^CqJ14Nw^l*tYvuT| zjTR$n)yXWfBRinA#FnO&AQ~JyK<+6AyBxW)D`vs(l#W-g`}dloi|fJH&%wS-+la~F zLnrJa4t+Kv0iK7d_r6%1Vw zncC=XOm)h0r!CT2d&sY&76g2l|4IDLxuC5`+yhp0a!6*YZGwY3{@|^2RyKW|oTo{M z+R4+;8Ha8hU;d7MKRAEgYnLq^cfakQbX^$-a~3r&sPZ6^r%pvQtjmqtcbzA#nU!~7lRi)!Z!cC+GGtreQ;|O>59w3jDIR5c2Cyrqa*z8*&}WE?Qg-Q)4303m z64~frjJY4D|6)zuA~|Pge5wSyR;f*UvMdC!dp(VPXbUUW+)T~g?ZeBLH~?o# zxgs+X>MNfj#g?+!I9X=w_uSt=ZCu6oiFz?i7Zn(rJSYL2L%SOD=)X~-an%ABs##W) zI(=`fCr}yjkqpS1;CBmes((MhuK!LAth;@a!ZUNaoYiKqpG|x`cRWlAYxLPh?gP6f z%*gM9*n|-wG4{8y^6g$XJLobc$q(bE}q zTwjyj_2j+@O0beSZworlv|V%}j4I;J?&I_Hi2%y6E*v}5_Lbs}csTgcQSvO%AUwe2}w zTD(`co$d|9&4fsF+0K5Ul~JW2eB2ssND6(qlwg2)Q1WXj4+p%dWTtQp^0YIC;OR?m zjuTI3YLq@v!hlh{UM$G6M8@BeakGCg7C!Tlo$}nc(z{SfQg!rr7J|pVlrf zHZ-}Y_SzJ5);rf6-}cxN-!8qd&M+X3CP_kT4%{~AM*l4JHPDAB_CqTM{N)*<;klJ; zfW0KkKSp6v(%cY#ZieTV5}=N;-e$Mz+M|vyzFebJZPUV1LWTj4<0Wuk?ZMv< zK<8y;fiz(mUCb9-%3*S4on&%3I41195~}?p5^-{8y`W7=Rs+1*k5uLD$vVi(u4#CD zQXNm7O}TttKo=|aKd%~veaq5G6SixL26)W==KP5`c_gtkx3n}Oj_fE|V%`Ie)5ch& z9Ox9CNV!dxqQH5Hrzu&8nmB5;Td{Lm7dLSHQ_=^!JVvFcGPpGGGpDl=e=kcSr<9fH zZCYW}OjX^s6F&`gKkgd>&UC=|5lU+v)b2b>%C)1%TrOtHZU6MKZO#7kiaUO{tWr9a zqJg;?>UtM$!ue#BR{gQGBvOr!=H5BKPyRP*p$7U~(ckFNI%b7SJUQDet;KQXaDSEe zs3|%YKHXUj^*P*;C!qQW7pi2A<2p*@L{kdoV^^7JQSQLKR|*h^%9jWc2VuMupzuPKLgyP=p|z(Z-B}s=Km81KJD+yDs}i(@G}+;)}ZPsQs*_v$1=+r=+fsa z`rg1N{`T+XwxKD9kqQS~~cN=EMyyS-=|!zSSTUtd3kM9o4r2^>FujQr2jtF>WZP zs^1N9C^>E{PXAOFk0*W79E)Q`zb#$!_izxAVzX^GCGha+;ZLyw9If{0&{Td^v|f-u z7|*SMKBY%< zxgSHG<(&HJBTg-X)tSy=_Cyifkwuku+JXg1w{I%yfIca-QDW>!0nxQzzhgk)#C~~` zj3;mKb=i8eQ19U#} zpIG=qS^V?2y`L=L6pMZqW6YJtIWs4$@?Ih7(bI{Q1k%fJ0n!%k&5Py0!eZ z-Vk-sayYHd*)a{wI6?bWIY1Y`YtV0*27P3^99yO}#c^{>fVTs)Cf1X?S{C@?7pd)< z&O#~Rv^CGyY{U4?`fzdkGj-G$lkj>iN(L)4Ua{N1t%0+?C6yNe&abt%TOkLCDCgMR z<5Le#n*#QP8Y%RyK|IS&%LzNp8RE%fhB|X_?iTD{(LUS3iG~l< z{BweQA1ogCAUsk*u6h%K!OT;&jktb@7iheRcd;y4=D4svs&=A}=vR{HP9p z`|;!&Kgt#hEQ>T%#Z-KfatF%gv2xAoq7B5&M%Juv28^T+7ukzOr0{3nhet@|B)k-L zGTxwH{;xfU9e?8J%tk=OIOe1^t!+aZjz;7RnY>o|Y zv_5Q-WuiJbLfH)Q1xd?a0fkby@$i*NH_&;M)KDxqrHq>Gm8MoJM6uibFepBAY zaG}ekULEi{!mpX0`M`;_{Mbbfij(l=xf(z6q$1jCeQ`t=_)ICyJhvMVLT!!;*C++G zaP{oC?u~I7-2F_5!W8V%N{yCt2b_USg(&IwW~dWu-Vk<@!bV!}9g99`V%2$rSs&n& z952(Uq$q^ExKiTvXLPU@Bm1M==Zx50kFjMZuPBz!X5WCZTbHE!uY`o;Te?^|!*#Ij zrMPiADLpLd6cX(UIG2VD7SAw=VnX%thA*QlgPo%uZ+9$zA#)4wbJ~4W1`Q}sg(m~f9}eP-!53Zh zxvP&M-C7&Tx9@*HU1o=A9J7Z7LFY@ECBEi>*PXKYD)fyQ(*H)1HH%e1#}fDJkF$xR zf{O;kX}}p%czpKrGY-Tzb4Tx8yD_3DkGkrSVTqNQc)dzMUoGAvT$f;6bvesHPc=h& z+V#^=V?qn(?7c0P5UYR#9)I7n4LHZD4juk_MILp2Q0yM@G{cvM$F;-THE`K$FCQ0( zzaqhBE*_Atv#o7b-3K}F)^C>>x(W+CF~!c;Evb(w!|e6*0jIV6=;5RHwUK6-aFcVq z0MZH`sO~FJLxi(S_99@9sQJBLEpTo+L;0OreA5z(S=?W8G!n<5C60Rv(qxbTN5n!c zoO%xN#vSUXg1O$idHC1G=q76k_R0qpYQ;W_M-XetDy7gm+#U?7x!YH4Y@4$ zDN|G_=DY4Gq=9nUPNb$n94@_N+MDrK4qw0gL-P-}8BT5a3_rEPf|?y)GuZ;p^-Zf= zb1=60?ztH%PQ)w|A~k+As@TTXC6w;+Hc51f&*TryGOEdUzFA(UiR)a-I`mnLp^jFC z$lsR0!Y@af#kOESm)5$;4Ew`N8FX|T+VXH7<$0PdZiQ_UqI;W=Ibu@KkG&20xCy*S z%RRP5TDdDarP4-?Ms)M`T`SkZWf5bnx}fu|Lf8H%&?&^cuPe>Z6w$PY&QZsj;(fwC zZIu$HxXs{XQ6%6Pm>L{qi4n&Up*P;9)@veRIZ}5Ik09FYp&NP+{vPyq4fKXOAALII zs^47)%q@3T$R26p5e3>bT3;n}%Is4T9n^WfRqsE}^3=#*W+YJxh%86)1 zv+|PwXN3`YQ~=JO=RquMf6Xw#qwU^tT4S_vF{44#ND9RY*I;$(e0ZWM#)B2w z_7L}VKJ}{}=akWJ>E%2!=o@lST?d0*?62~>!+z2s@x(ohMg&Pz*Jn(`1UnqvGnJJG zb~RipxqY)&0cjenH2w$>$KP*X`0evV2ItbaAI=0m5rs7&l%VsXhD6|(CmQ(4X|o}n z30Yhe9`)F|P!AP3#{F%A_0)-(j`jU5W$efGo@2U)7WrQM(mfKXiip!)D>}f#BJW2l zKjayQ7vB(V*K5+sc;)V`R}xr{mAZ0{q=O#!8A#{@POzfxm~$u*2W>~w>6{ftl7E)I zR#93Y1`?}(8Pp3lw%-JIsP}h3_w1i1=7`vQdn+9DxhxV9 zq}^qJ-QP6}{w6b{P;ud^q7(4FO%}_?fL%|=6k`h@FSwka4Apt_;XC`o=7N&{ky(xw z?`ymykB`*Mrcr>u;>6>_I2#ObWd`$B-x>=VEbZ>P>m`QDxfkj+K<79Ax*wvQxW2f0 zM-kJbp7Blo;V+cvTy2$0K$|YkS34RI1$HqS^s?GzO5?cNs-G@KQaHQAH2m$F7?x&S z7!3kGqwkduhQN4XME{aWqAC1NoWjRVZwKn2fmNBoOmV{psa&~ zo=uk+d=x>gZBIY84@w}#z&ku*EXycYY`jqKp$N80`g^*mR0)qgx89D57sX>&iQl5Z z?>g@u#P58c-|TZKDiYR3GzUBPh1M9Mc_SjKrA3Iv&+(W)*kv2ARx)l4=le3dk)A{i z#1OY}-1?Fj@=#zH?g1Q+-!IHQfyU?d zo-aHjJpMxyTkMN0^C=a@KebhVH?nCXt>ndzpMl4k`LeY$_`1f>exqqW9p3hNzS9V4NEerJKFM{8LvI#nc1=8rJoAA*;G1{o3)9BIO zUqWa#!TjGd;L)i2yx$XeeGBw3quj-a#;D4aya*ET&TaRwd=fV*n_Q`720pId`fszJ zDIj@KHM>(8%$VYGhCr;n2I}5-Z{Zr?=m>o-9|wKH#Fh^mrfMP8p%b#gDki8&EB{a- zr7V&sF9nx@J_lXOeWZ8s;eW5|t+yy7QQ!Fdw_8XDtyFI3aR85}65ZoRVKgZF{x6nn zh5pvP&=UVz)$jk9 zVSWyAymcLT2{v{9vF(&Yq^@#q8e2_tQ0cBqc_9zFax`tz8SIKZV%$>Ppo1b6Zxr2e z;Kc;u#_6U9hImkAmvb8EJQFc%v9sTt6?XUQQ&Jn@O$djoh7=r1d~!dU$2K!Z=GCfeoAoYz0b zg^5S?EJ=#$_-%Y;uM*@%Uu9P;aYPp}yeId!1hC>JQP0_CS9!dscsp_*%vW#7ioO7R z(sLx5RL`j4tT?|*b-T<_OsM5AUVjUuU7MYaLFXWu=_ec&hA4#hO7tUF3iKzbzH>fI zAG`e;`^*J?nt7`eJp(xPRm7Q`c_A$HI4J6ir3n)C{NP23&_M-xo&-(MIi(=+#KYk= zvd_OBdHNS3sOXRAALn#q#OLwJFdB4@l(Q{Yh0$=aa4Xo}62CcLS;Tc$0{OeP{Jac( z18FJr0-u48SWv(8w6#2<(7n?$W<X^ndj&DUL_^a9=J%=*2tQzq*|QZL{XiV) zSq8K0F)%_-Q8!-HII3X|MW#bL_f~Y@UOg{xA|lCzO~;W4L#z{;Q)tc4h^3uQN)W-W zpfI1J9vGMQeo~vV=0IsTuO%^U^258H&t0T*DmeDWo}^2Fv+MKzt+fK!hZj8k+G)vz zE56J9`OnK7`uS&Pr(nM1o(;zRpm)kO>$X>(Hpt2P?775elxX3+!)k`P5Y8LBdio{U zr4`xyZ+8S0>Za|A=Vj1BX9}rKe9uwE(f&MlA46U4t-Wij4t4QBhNonrgg!c*Q(~|3 zju*K~+;Drp#D;`#pRyo8{FKFfD|P(#gZygN?^jo=3EKSgQ)zQu53P;e;eP?TeBLtj zUj#lGUq&LVITVl&(|iMXBiPPb6Y23fJ=5ppLFcdM(QWGpVTx_4*293qF!I`Z z+J_NmEzSrqd0OHDu!dyjk5RNUVR9w(RMfXAQt$?%-~tcYn}jM7K**_ zz$O~}RawlpT$(0^i5(wvt-5Sc#@OP<^SxG>ARnOC4mc(i3|xC*bl~Mw_Z79k(Pi0o zw~Ki(MNO}T^?4(-8XLFQ9r!d|Cs%L7TbCev7c`FX8{y4ljBH`k&v?Sz~=< z0@lN%A9IEQlFHc2ut#yGz#LhW-ud;Cz=^2-YtG%tQ%M~=zP>FHJZb;d$pZQ+V zdMZvAoe}p?Ee}*fdEP}0Veoy>ZtT42&iZ%NF{h>u>{4QUxpLG=97za1lAbgtB8MZq zCFF-XSi|?c^**r6xA&D;>L#3jwcqHRre#2G#>Quk1d>qO!#Lh|U{^6s)SO)2x zC(-p$@}a+undz6mnBvdex9oUeKc95@rurYixfbw#ocFROHl(`wqj^Ie>HIxvwO7Uh z2{MnFB!WJ?O7V7j@3e9A1XD+_x<1+~U}>K>DTg)$ECOah7w5%eM=7G?KQt=wkEC^RUO3#Jh>D{4_y~k;l73ZYy(jqnDG!k{*GC!IQ@T6~>=s1Z zwwF?X|lanlS<>Jo%*&@^? ztc4m)>}J4K^E9z@AmK3w_2~UpB`-tUh;a-j? z%B-C@?0N8YXZ@miU3raQYJuJ@v9mN8$|0AVk{?bF{UPa&(@K7UIIPoU&XmaKL`5~b z8xLO=yKcIn<4!pf?QB)1vtCP-8faof%>y{;XGTGeNSE z*YduDU3HoPvg%cG@NV_T&6E7nh}POyWU_sk2X;+b z)#miUSjV%uST*sKoWsedqdK++sXwLntyAH~A8M6-cfO0t6Pk{syQ!dF`jXP~Qj&No zZXv!aTpC@FX1~4D2jF<1$)*qNs$t}+m2Q{9@cQHZ$)660jcJ6?_E!$u{Tk1%0G!?r z(~ldgbx_u!+`jv#OmM*D<9)F)+vH<%(iF46W9iQH*ByOKyzOap-e{wvhdMh(qO1{J z_>B9{Mk7pc-GlYOUp7{>-~NiLqrtd@r=sXPdDlddK$o?mO%oG(jvm6$#6~;^=y~A{17k^{IlbFl8$ZlXvfAgv= ze!$zz_*I(O4~a*4}82$2GYFp)zL?}t-4}uJv2(owf9JwIv%Lhy4ngj zy+sf9WwkS6OSV1h2VVRl_lzxZL_C0dG`Y!}5rD(g;xV;zKVu`-W-IAzf}(%iGd)tH zi;^68??ufk;IRA$=dVEgd$@%zF!=L z_o<=Wm(N}^L;OXCmVToJ|J$&KOjuu&LCt5*_XXb1Bw56B%`C_dkcQ&K=&AvyO%NZi zS<}N}6@MbDiCXy0K5>DT7m_%Y;!e!Y`MuyMvHvCTTKjtYMzbIdx}BIp5oN86x!7oZ zLN7vIJQA-y1vs@eL)MQEXyItq+41~s3G8!Mp^{pI9$y{ra#jaEZW3m_J%Bg%-#*G5 z1qm#An5um-#SDeits<=h3doZFgsuSiUG&1?@jC(k$Q*tmje1lZDCnfq8JALSG-Z&x zmjUL-mQz}<0A9nP$5W3H^fm0Z`+THX0>$5-=KIVrMSgYc-ijvhQP$Yj6+Op^f-j4F zs(bO5Y@edESAvfQh52>7tA_bn%QT)l_i?|DZ0v0@r9fliL-Y5CWl<)ob9$dCfiBfP z|7{6;V&ei!Kfj{DWUIWT_j$5t@QU@QZqf^&>YQr)_!H|vP!F~Fhla6OaG^OjULBVEnCsfy=Rz9(4R<;CKGj~V!2{<4_s z^@}i4NV_BseIue>%fD!^E6X6RWzpgAC+tY5km1u#UtEySx@zlQ6+G6*_w=TR4*q$= zC4%|3Ad*h*6x|Jcs4nYso(I2Qs=fJYR~!RcJ(-%Q(JY3`YE1fUGZgXl>u>hRgFa=H z3HBHK>GAIuRavP)j5u~P`SMbX8dk0y`r!<5oM*9A9tU`Af__ZKvc~A6v+CV!7D;^j zFS62)f&JZ=*t|uE=a0@bHaCj-G53MAbGrp)(FN|ePoId1At#aVi7YUGl}6W>3D$WY zgOkQb8W56KpyFzLD1dLGfy7NZ8T`ninY7a<^K|L3OIe;Ie6L|ByYrZc*4%Gx(MTDh z%_5DY0pK&-RQjD8^y$pZ{CV_~1iF)Usqr?0ETX9!3|&v)LZs!=_8icsQ&KvWQkfs| z%*0N=gLB1Mdnu-S7j&^WyS=Ln@F|TpfBYJ7+%E?<4N_2{K|R*W>MakP)KpoAqyq2=4R>X(DC$_1s>EOe)qe}yTxq21Nsin zwP&wX@$+DvmdW=_4qAxIzRybq_&7<86OTKpqZ`NhUfeFxz*f@9HtRErc=1rNp%d5@ zv~kfX7slu?33f4K0vhT(*mKX31MmhvCfJ$d<>&xj0`N&zs#u}CZH9{Mhn;#(%i@w( z4?^gqBv9jFCbmZ4bDcBLCK_<)3(|;&c0{B{=ZHUqD`2(nH}#Ug>EU3G*lo}U~zNi)0s^13GW zNGW8o06v{116-1T^U>5oxI$!&%yBoPT|Qh1T?|+ zeWv{qeoY*^$JDlRG4kWcL(?WL)nrJ4iW_Zy)(OB_obOI*EfhdjM>LWMmQ2X`bpoqG3H14VNI5tMc1d0lGH6gGAuV&#greCE;L;Xk0yWViNN0q}pYTmH#A{hH8E?Lq(El@A@Z;H*4o%8!*x4s%Na z&Z6O~J2{*L%AyWN?j1EbZssS9>5hHa(#|wTMW>}c5BZYN?cPDE*d4oEv(weo zH4){1OHQIW61X(TC+^NYBC<*RzCRu2JK0BgYk>dT6~r!`qNYXO3tVV))Dnrd-aN8= zl7RNVez~d)I9Gei@|xe8AkXB#$0-LSuw-P^fe4;;a;L~op9;WX(X3W{2Yzdhpkq$? zYKh(%{GL$%XNEW*4sjRVw#4)C%J-T8r?R8JA@BDvnSM4UU&NacvF0U-#Ft3owzGV( z3&4X;lxlrvU&oYi?(TnPL`2K#)iBnpjeIV&vSx{EV%CF?=lB38y_hdJFJ1;Y6XMd^ zuSz3p-gIyA3s!h5od#3G`7599$=uF&g^g^j`)A`#k>c_^o97c9)O>ZxSgKGKueK_P zP(nO69y}mTh*}`OQ1hxvdai@a^HbgW;rsI9_L>0vb_U{VXxY2~_Ic$#u&w{igf?%~ z?_o&PLXi=S=J`q{XyM?Lj~MV_OBrAM6TD7d^&a6=OIAQk!S)BA*Kp$%n$6!k{oyNi z=W}=NW!!JNoM$X8zDNX|)r`jKpl|_wc%C}e&z#c7XF@b*Ivq(jCI_-cm{(a=ZlAwkq zGEpOx)P7{cjS)6&VZi6?3!eX24V6)tsFWqGy&8_+(2A$1@xP)(~MS00#k*4Dc`xLbT;@F!2*2P$Qd02N!Bs~WbT>+dk;c=hBVI1B|VfNIU zgdb>f_r~jLAiAq39x;SSA-b8y&|jc)P)-qwJ1mV0$Y<)spRSX~+^=Q%*Kd%O?SrFC zz^-D~>$4Mp6UKQjMs1Ptc5r@NMjZ1#Ex4o zhRB>hSX96Z?it{JI==1XmkbN@hdfnuuD?=F@U#Tda=5v5duoquq~u7XMy_a~obTP5^)H%gocXzRrWKzM3d5XwjooqXVfQ zx)7=^k%^&&IBee=@N%cGZQr*ZX~wU-$lFYCV3t6M8`<2~oSBqhACwyS3~-X0_7u*C zOJG$`sg^_6)REik_d&iL6lipq=_Li|vX`yZ=nCL%@Mji(cGN*c1wW&WDkUuPB!>3- z6Im>KJ_Kn4&aSei$&OokxPHkpR$NmK2krV^p}3@u8%>+CBf+kz-FL`bpig|RW^0U* zIBF-2W36Zvlu9}w^(~Vgdu{mn@7%-oj?Y~BLMx3}K5~gvGppeU$qU9kC;4&o+tK^~ z0Zy}Ch{sRh^^v2FAJzxl-bE3X7iMy*P}eR^<3BVRlpevF}(5axg=R`OUF?2)fF7uAp^;(S3CEW!E7HK@&V_UYpAc9`4ahCO z9CdNFVe#6@3UO=^x69B?TofO!I5fP|ubi|P@Ad_FF*t?LY{;vi(oc=Ytc--v!nHF| zD#=24uxS6Qojyh}mridRBLlp8_J%5*t0?xcDEd)ymJM5poN}3l`F5dH;fEm4hNk@sMMEN(Aa?rbDglM zsRUgnip6uu!0QvO&&9_kx_Fk)r`;O*$D{X~`5wKfhJH*Qd|d^8FAX;OQ}{^)-c>w& zy3%Thwg|>TwnfIM%s|6w=Q}oqFVDf9{T)q}OZ?MFe%#UUq&UNs5BpjTGiD)8)K2i# z$_9OC?5X!EE&n6`Zger)qEo?>42J|{-xD#9^N~4*ow`9GdD;l@9tpOR*Wvq9be&Pm ze)$!$|29`c-gyoDp^f#(F5uH}y*W#Qib&qA=~o`uC9jsz zPYq*l(4B8rW4Fk|>t7{#B23};t5^2_2mLD(A@i|sfloH?@T{)A9(L^bX%*cHzxA&7 zxF9KXokV`pl(W+ZLXaF|+Bp|Ap72>MXjDeW&Fbqhyoc-@NcrL4FNsF%ZaKyP&N=OE zINfUFtFjqZCZ1@qpq=1I^a>(^6=CQ)QzIo0hHa)*Z%r#iTH561zz|& z@G+rY7jIe@ez^hua>?_y9pM&6@Asxv|I4>TW{JDE&MNAmjekd6M*!z4ahJF=`0L6q zKUeEQ9kgnCfJJNG4s$B!Tzab@j+7Onglz$bj%I&JW0xAD`RZf)11lgar46I^Ke+I% zzb{?d!JfpNyD7e)^NrntVmw0d-CTMywdV#CrgO3kHkQyuGD7ia|#Lt!6 z`hN0&=P7@Lwf?dtYWjNH$u>$8e|eR(@Z*>SW^Z`mvjlw9D0?+L>J0GWy0h5jDKjL0 z%)oTRmWV{{gmeYLF2Y65UEg=s<@8fw56?Lwp4QgcEly?J@%qMp?2&f3@m}KWSK#x8 z_(uNl4Y2oq@}3t5NGLbQXz1H%anu}P_5X9So$?8Z0EZhW?g-Q+%A2ZjT=m9-y&K?KL9ct+S(wubEkJ z@PPY8VaQJ^HjlGA_j~A>u6puY9xTy(@&nC)Ch`}mGDxE~K@khoF@}KCPsJZR9W0Ki z>(5H0c5q_r(May|z6Qu^zJ+FIJ*KPg&)a#=D6rj8-~Lt#w@4d1E_{(h4*Sy+YVH}M zTE#ulzuo0s^nZw=EL)P@rPr&ruUZEUtL^aPQ#-y5~E7ESq)@4-DqL*a;XoLm6nox0v z2=UV_eJtg~j5zu|+tRzuFN}%nfBXf$n&K-S;?+E`-*w+k`0*8R&VCMej$>3ul~qT0&01k+KbgvNfN!4Bq zRRR0LJ`S*~j2Yu|&x?h5=&3P-Z~TxG^f$B2HI6ugKGHyH;5 z`zLgfCbNoN1>h(c^IMnxGl$<>R$PkOt%Y?su#l~~5gsRPmF)t1{FKWKGNF#u+Q(!` zA7DoJKhSbLFafCL+15PZM0(B9q?(FCc3Ox;OP9v0$V3JO6>FrtNSe7tH@zT`|AWU zHMMCF&&MU}ZzYD)X4?ll%MSR+rTPnL;3m--I zQ;q@7)Z+^$xG#tyU2R);t64J?NBP=sp9ddqF6LA20zNDmZ+{Cz9l{N)#&?;yFghIl zdCp%5epj(1l**PDFK0`i+^HLc)8DwB$OxdL)Mxj&e1$xxiF=%Iiw#}qpXuIt*WF#1 zVKW7zRY4%LZ;}aq!Fqvks7DHmE=ZqsO*BDvcSeic0jK@#0o71yY4m%_ozjHe9Q)D_ zZYRoU<9M=$h62?231wnV1lae1-QG8T#SphKbJF}5riqIAR3_{_MbNp(*v_4M;RCzK zg2Pc#$m&5gj~BdeJzVpan7>;VD;L&Z+xh;S|8L6s1o&TK;%3I9tCrYpcd~P2kUC1y zIFYK*D36D)|D{p@oHa$y5{gn~oINp|^mcQQ#845Q;cd%@SuO`f?0iREu0yT3DI6>%os_I_TaJ`jPAM6xd_?!OI4~S@z0siWpcUpFXOa>YyisuWsb^u0mX{ zzPd-Z^R8g+=UI5up8|)GGUw&~D;>SMq*bx~%9;}o`T9eb{LucA0+w+8D!V)Hsvq=&^iJ^w%a$1n8kIc5RLUTYdAgY22?NeXO@Zaky%pz5W*}3b zI1aMPTAFU=$1*0uM|ydL&{dzfzrNtFP)aHa-EZoMuFNDKZJ6L-v47G2$Fy)_+xK1u z$Op1=WA!T7=UXLbVCtuhY55*(`;m;0(V@%x9gJ0x@RMFYd(cP9v+INa)ZJSr1Ggw{ zu8~{EO&S07h@jz4H5DtsnNxqcwX<%t9OQZ?Gz0Igb85q?FRzfLpJ3kvdTmU2>zr@} z_$b!x?`}||M@g0?PIVLWB-8NZ-A{l0B}ZqJ3x+wIQXq!4iwb3k_Nu8KOopcY4A2z
w1%?ANe(E(L0{p{9U}hl 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�dyj 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⪙Hc&>p1dUn%2Cq}k|3D^c$<26YMj38rvf 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

jKQ~Lq8)Sb^Oo|dEF zfFDPGJqMnm#m)SO#=I1TMmD(3f$q0lO!nVe7)6fFS8o(0P>`m-**C#-5>iG4f(-Dc zo-6UY^r=v5Plehzy=VufAfA--Av5r1(;XSoJ3?tTh zM5H<%^5})$08;;M?b7AchSiGv^@E?2@J#fyh%&r~x@y`hQ=(-2ta&u{^DP4U#cFH1 zONWZxHdz_v)G4@crMS)q_}7HHOyg7iQZ#7H>sbGO7PrmRI;X6Uq7{Y_Nh>=FnltDz zGcuY&Vd;NzdY?c&&Oz6*?qs=B5%>ssyX{K6-Chs=Z;uPMK|kb=q-O=N*V`1y!1;SebL%QL|5cpS&q`O9^1-oI9S7hsL2 zpxoS}Oofnt%FjexQRXF})y6t6e!z8=_vQ^#bSYR`+>hZKoOi}+TS@lXWk@kI^P)ZM z^Z9~#PVWO`^zTt_$rSLW-uHiL@=VBh+(LWP%!Yv4juKO=mEr$Ce>!^;^!YD?AzNhN zm2c8d*!LeULu%r`jVZt{2&+lKdx3w6U7yUOiJ&0Ht3GV$1QOEOX2Pokd48z5Bzp|% zdQqgGsRp1!@(os+KLLGX>zDX_p0ojUM=H*>+pQvNP~WxQ+`}7fDh5{f6{(O z(@>Q7^v}1d&{xp%RB(@AB8nKad~qId!s{Df$I3LxxbjU`bT0Tp?4fGk(TDxHUB5c{ zz=ncNWb)f~z&(hPQq+B;N)g}5f@!17S^Vu7Z4VLf{GXn^S@W+b$Tz`ywq1>kr)1xY zg#%x%+@C};1OEQqSawXyg@SFOGK-n6Q}I_`r?yCiGW34zOSmz_eV^fz`77dNB;dAl zXN(&KeKB;Ikc8*ataGE)@+P2t0RllY5ceLL{W52LDENHtE>8#G%QR`9Z6&$O(D}Ag zgPXuFeEM9hY~;wObX866^)m{}d1{zq0rL*iEZ57F_$qO0Rkc0`@Eu>bLRQ1r3M{Ci zdZHC@_|7!F81uz6wEmtmJY~5MlP*O6W7?IBif&7k#sco$A89{($ThmhYW5UD#CY_JzM##Qji@S|DCYU zPFj|Nldulgx4^jHx|R4*2HnVNRslLqJ3Gtr5p>$L$e|DLJWid;-v#*6(SvQ4{ke^!zo%BVf&i{Equb{LW+&h{sy}Wgi1IX1vD?x*{9Um!+vD3Uw z!eg;_x4CA3e;8{x=L)>f85z(=06O~TP3EiQkOI_bUw3S({XG^FPfGj$yRB#Z*3CJ@ z)1ZIutYqQeLd+7;&LmQvh^F{`uM7eX-|_Ex&^+MzqjlVhegE?&<$#kXqzX~lA+=S} z(h4jjVe2IV=ORqqH--p(gPgjwbu}LW&y#*2pOGYFAef^q4f{jA^-HJ$)=}cN=4L%t ziJx-(3r|riK)f+uR(HOwzY_a@YE!2PZ|6e@il&*K8WKiL}vec0xO4Octt^N8P~ z43`!Wm1cgPZcH9PL9$)k>0<4;|Mp(`EyzFBZHIXVKwsrD-AivL-5GO$6EqW(DTd|*)N0!OH3je?hnRi7f+7X~uA&nVv!dc= z9f!4-rlm-d$-6(Jau$nPJQv;kHH!4cM^Y@UDM&#}l4ePqjQ83vmu+hTpB$Rk-`ao| z#NU&d&2pgNs>IQHAJA>`@1Ao0wpoH=L-yRi2Y768&RxqN@FAO^&L{`?%B82 zdU>AMF)6Zc#C-N0_e1# zDl6%l{?}LEep;$ZD@EHs%9twyo-dcTJ|qP38c-Hj*8%;fb4T-XBJ^w7m3(PqOa~v% zobspH;M*g9LGt0o`x!JUbU^GzLmd_mD()7BIr_Wur#_1LcVgY!SKJ#-p^hZ%;I=|0 z;oAf~UIUolF_d52m~tZ{>8Gx=+hGn_H)isZ4fy}`gjsembkt%yKku*o5U;#~6LA8b zo%r{Q*Bh^4j^ktg^8KS3Bs~7}K}y&i68f>8RKBNu9*>^BW7N{$hiwJa4N8DlWd>A7 zr0yi5>shv?HP;5vZS!+NtF3LAz+K4l!vOjQyV6E;pkB~)?*6v3Q6xkhd0Iqi0X#1& ze0i#@4;%XR4_$|IT-4m?e+cSve|{G{40Rtso(Weyo&c^(KZL_owMm$IPh#ygtRs2d zK#5is_;TvksF?!;UewlvyZn}S8(o?@1Qa~dIWR5kTM847=$XCMyzw9L3ZPMVL5 zXcg9Pngiar?5nE94rENC{ zP|bZ}`n#Am%ph2_Puu}?b-R7eyE36KZsXsDtx6J#&1|*lhIO7bVusQ;M?w_G=y>Pc zdHC)pX-DQH=p>F@y*ELhcj`P6OLv!uScKXwSizU?1;KQ^xv>rVZk&@p974kWtiz`d z1I~0_p}nI9ys7_r!*P-!;OcxPy)p0uTBIdClZJD#tL|KW=(~FSYjekyCh#jTwK2bZ zZ>$6V>?a+$1^%lK?u9qC!ai3Ll3aJ|fj_0$O2a8@GD;(5Eh|DlWY_4vITe_bQenIk znr~i@o3_*+1c*=L*d9M3&1MJQXOPR@U`s_e$f`Rfz&~O56Vus%H}X~AC9nVv{}g7eAqKkNO_7ls$(BS^6uI#JmgfMPF8b=(Itb^B z_H@_=)Z>h9H;X;ZqN1mxCb?A5qi8=0&N9P2$nXADqN%(OJB`_QCqNzhRB4?8AK)Ll zmzSh|`UC&c$fGgYg#LsEpFNpZNm$~z8hrztFDcc*A|+g}%}pl3gD_QdCtMFZ$WiuL<20jQ@aO%8d3k7wuAS%nRVtIpi@q*U;? znS1k&zu*AO3v)Rd^|?mi%e{>cZ`%`4io0>pEAXqF`CxXoS7HIzQFx`cf$x%e<4*%) zn5VW38a5n*dDQKm`}{whT0o=UHyL)F9l_TsBRa1Oh2lli!k;W71T@5R4|SP=?~3SL zvXtZk78+#gu2l!0oJCJ3G4Mw+&}V(f5A!_p4NQM|jsTwb+Mc)-NkGicPXAK@{_b=A zla(nNg3qnT%iP`4h9k&A+rjz}%n$yw7kv90=9gX6*QMTr?@EEPf9$6tF#lz7 zBkds6mmh@W(++qLk^fU~pUTtFe|W~e$ariPzjaS>Cqv)hg*OtJ5jV;Br@Obo0VU{* zi)Uk}0i9&=a9#2qZ=p?hQ>GAQ(WoZ0{&F&k36IS*lyz>)*`WI*OM8OLR z;tW0YO*e>)`$rh-L_`UQ>tRDpkt`LvTPKQ6%R^nJj&mQ61r>9%T=3F<=cAz z?@pHbt(OWos^Yg@N%}hq+A7{5Dg`>gmk05Li4Fqt5Pjv#0k~xca!ufZI#F81fG-R1 zQwPbrLl)YlC_rRyn9Q45Y*cV;q;4;~hj-+(#z1Fd5up(tfqU=?$Np>a0R(ht+{Acp#)ed}T;JD&fYbu&h;dT2rPr^U^^}UZnKih2juj>|12}quJ;ruT+U-wtL zZKnW_wFJ}4zXv>4=*qxH@F+zkM;7i~20T{!EY(aCbS(zDk>n&eUwP-)p1pMgJZ5pu z;;sS#`JJ`dM0!CSEH+SAQ_(7VJy42RhISsCf;w8MpRLobwNVu5 zxN|f%mx9i`_xo6WgN)U`{e2?|ddo)Q^$K<11x)uYEdRJj!NXl^LoKk+8k`&?R{v6D zO@0xY1bCx3JCfIIdK9e-*XFWEQV`b+FKxqqGG4FA*`F6jK+0@-L($ORM|-|1`U>z1 zxo2HTL|BKI{`l!~aS0Mpa|&XupT(->Dbx4KqbN1q^O}GK1wDAWknq1xAtzIl71b%j1cQCpWOPtt-!@NP?e4pc} z4>&VKb0W*)Iu*UMy*j1}zC#1I#B6fFzscb5@2X4SqiAv`vg#rDb)S-9Hi?^>K?0+7 zM}}%Tv9c8Rl)e=iwaf*a%_G&~-{Upil`2%UbulkE3VwG>nb%qa=%k-{uZN!lJhp0} z_%|Qwu++2mi^I;Ks|97yu0dQI-dGH)pC+KAZpYUvQ@|HgX318Em5d^~n_SN_!MVK< z>b7S`8Tz!ozL(yNf*dbjn0gCy>X(k4*MB}fgKiaaN7O5IV)^oMjWl~Q+V;`cj_+bU z7U}=Id|94~y7P8oGVB9aqNSz??9cB$9cnH3_M}@2N^`+n_A^;mTH{IZ$K~0cSiQd! ztM`X3Ubh6_rQ__K(Xn+nb-T~Z-E%O1rJ8!#5`5-gk-R_4t4(8_=Wo_M>Om)qEL11M z9RF0^p#=k&3y*zlcURH56Z^%Iyzf6GqYp9pS zEP&@>l`cQCyO@OC?YZ`>@GqeA99Ns2>6+2O%IZ6`+lNsLT{kb~Hwo9sbr_ro9Y&Gd zD8Sis4pmPIUFZKAgefwki>!JJSl`uqG8cSlJRg<1nQcJ*>P_=f96$J%FN>dcXBkEZ z5|=i&ZGvBHn`3<3vthLL%y)d`0r(4+N}s zS`GT-s!HX~0{%ZO!}#w6_@A2QUHyHpmxSY(_%es#-}xKy-Yx4+EYx;u zsSbQ6odP^J*rV$3GgaoBz6PK_P>RBAz<=~_{@E*>;BWP*p9zM#;d=pgjmK;t|K(RH z%smD_(SvsR9_tS~@x8@pX{Y<}-j!Y$xja~l`3;`T{JKmiD0g$AXfx7^s~DN&8b-N&szI&r z9fHD}j&8@mr}Q!h{n&HxQ(yfd|Fqon6}J2{Upr>HfOTwBc)pmAAY{b1AR)YfUZ%|c zD-0nZL%NyZTg=0#!?i0W1>)s-Xi>4~3HTk}W%?lj@j4!+SI*HEiaWONWm{EPz^tjS zu3dsTH?e*a83`>Q^$+8A`O^dx{ykBLjei)ei4Mjb0)NJ(bvYRxh`TXzF~Q(JwCe${ zY_)L+UJ(uWXfC^e$C#o{U4-ur)T$Eq^})HA_*+>O+B}0kX?Z)Xdv)R$TBd80K5&0u z3~%c3tiwju4{SN~puX!-aJLb7ubq3!=}Xt4Id@VV<}UOtff0d#LY#QT`x+){F;jYSfKBT z%lvCkbMOG_nQX6k4e=ta&po99eJq@B(Lf`e3cmZ=?^OS`;g>Ck-6Qknv9AEb{x%?I^}l{ zqifQ>8IK`e2M(&F{C~bkinVJE5U)op8sYjkLh(}Vp7&{&!3XoloWud}8>DgP9tYoR zbep-{JGz2^L@Omb2;9SHu{uXU4)8r!|8m_I$6=(WS)Gv#euvEInwc_*VVJM^*U4n1 z1xz``z{&`DWA+or*i$a>jlc9LdZdkj7EhBDdSIU~ond6zM?ZqgP2`PN+=h|dQI|{N z?sLer$b3*}GZZU#TuY#uE#NX9W&a^P@XK{S%EGl{0fjdRMeee1MtMqH-JS3}3qsFn zb_k4MU8%KVBf>D~&hzQL;5V zN5+m^u-4d4H(ynNy9JPucxI-X=eMC)QB)AQ5D`lf}OAN9La}uR{yxf>%uy9Dx>w7HVAWLOW)tp3)p3axaS7U zNh(=g74u|=?~GXb37pvpK9{NWf`yQu3;tbv;0!(ygG()Y*}*r=uf8(;2gIEk^=H@M zxll~LL|)F;0-yBbhQ}Ddr}QwLclTlF&*V3=y43~veTPE;kx2^X_AMS4D$sZ1KpwG# zpz29P!@{o^)eC)WGi}>kVczJxrs<>o&xxo+#Qf#=@G%tmW5o6OXjlAI*DAM!e#S{pz`O_``&?>J*%J8v)0X6u3>U3i=L5fG*IM*y#Iaf`l#1 zP99f)yphK$(JKRb4{3!-lI>Y1W)A!n&;siWRQu86)pYeF}4J zK^z))OyppW?I-QGAee*7sGo6nfVnAY5?#C<_+2oL6w)sb0WP9ru=i1!!+w25cDkU$ zyfFVIne-6mw%p15eBdi`bXU$Vevw(^xx}h63jQ^*DW0rTEZtbL@Cxmo@<}9n=DD`t z@GQQvFS+RS)j6!nv70CxM1=d=_{l0Jbl^6ZbFUoRShPLz}(ba<`f6`$>{D(O(w!Vum8;LV>k};&9mZX&Blnxvvt=E5gqUq z5j*b290I;89<9l$Cuh;@B(1sKu@TgveB|f%3~yrYw&}#h0V}W5T|s|$&=8o= z247I`*R!Vpx6tav#TNqpAskfEYlH9TWH>ylUk4oJ#rgDy4y?l#Vo7o91^>m_W+VCs zofuuH_$>y!#Vxw$Q(-_IJ~y$}(|C=FGHk-Bjc`si^A)@Pg6<~f)|I(A3VjZJBI0c; zRMfR&JnOA;GkW!IudO}%Fme|!8lZ(dmYr|@;~C^JIpG^Cf{@2zXvUpPW}f1ZJB$;z z92W4u^IWP?;CB;N8zprK@Oi}8rIcU&GicaISxZB`6JJkK4-Wu-(dP1G@01S4H4faj z`2o+jNj*IIRup)R4V@(U`ZQh=I2mla4*rng7hcl=&u#Y4)Dj}iK>y{$dj7~?&Vee-*V8mqxEL+?fljdvTtW%H02t>E8L=WUjesVkzk}%2YtmV z@>@gnY$$G(pZ>&RxPWi89{SRG5qvnk{utd{1zz=VcaP$=W)vP58bRb3hB~rX#UJp~ ztqN^SIrn@R*$f_MUW7c~Vb}ITt|1WbZFc>A?EV6tS<=4y+hhc7MFq6n1RV8LrF==W zkAU77)$bmvY~CN$A;U68`B(J5vVx%=SU{!6C>SA=&(#M=wEL>gS_tCE#!M zZKvET%3>Y<_~zx2Y*i}aG@2MZ0Dtd5sef+@dVNi`pt?NZ!@Iok4sG!7)GSr$DDb&# zqZ%zY!22W5reXFC*0Giw6BfG-K3&*^<0QoE5`QbX2k<+EtV5F`ZcWz$^#Y<1 zpCSDMQoFWc?q=AG+#X+#KYnBwxw!E++47Cxy02X$PEqjvrXs_&6~Mirdz;!Fv|r#r z+Ep4IxKCwodi1dZ?tM0cMV$7){qB=XZ^qk<-m4z#&Hy|=Qa2NGm}Lah|AKN9__Vt{ zZdfjXb%?R=jkNP$V0v+0?Gq69?c=rCfpA}Zd-Lw#IDGfSs_s#H)F%Q8QHdzI&j

`HqKNnW-aqSdJ=f>^jC1aDpL6bWpn>rvoY&nsKI_MDUf&$K8AS&}abSxen-t*i z3wJyOtxSjEo^)B}F)yOSlp^_7zw6Lw$46_=BcPX=``C4nau_oTsU2VP8ALA5F01x% z53?+K-+k(MjlWl>$J4>@Vyd?3`2xIOmOj@z)w3`k?GW87((iSMJ@cN%6~G&gvn_O+ zRKplcWrniDdl#}jL1FSAUs$*L;g3xS787Nlk(6J=zpsl%|A#jy&#gxF(k`M+a~-~o zNA<}4NXS#BgP>n^q^+YJc!D37<|MDYA4C!fwX|)|=aGd{y@l*UKm6itnC&&wMJ$+l zOY}3uJIjxPA9Vs=eS4-OHxTlS9^C9#NN6A~m}!0F0&z-Z)4`S}@V-WfWuIumK0jJJ z>+#Pz7)MV|_&91VVrlc@z>ojwUOp#xHwOLizmHGn8%5WlyERz_fv`VqnmVLzfa^Nv z$t8&3cd1-hl)zxe6mc)!NDRfo7Ss}qvY=~EFuOwwdVddN9xXOaf(7AMEbUPJuV#91-=1#m)Y@XFLp=}@eOyq@LBE#gj^Ac}*4!~dP> z{qvum`Q+Tklw^p%tY_O--QXVbft(o&*j26B6;Xcpp1gM?eH*Y2Y0{;ai>tvny^j0{ zC-Ce!G8!Hy;T{&-%8C3sv4}c`?yv6&)FT1q$&Q0ugXj&pUglXiuLY|8XdnMUBo|CB zH4l7zhqOe?hG!t2U9K}qgSdc=875AzO_KD^?!A4LV*Ps`6vR$)I!T}$)p zfDgNN!?NJ->$ZFrEC3%auI4&Q13u*YPN^^s=jE{^+gCkThkU%wdXPYzyVrl+?H#<+ zb-%uFec0!nqbDqb;r`f)+S`7Y2*Ia|KVKMu_f@?2`H>y$^RXz+;~JD;Hy)|<81mGE z9;GwqVTgCgWRDf_iw@&`LhjU!*g+J{Uzc{$cOG5bVpH6055!62D>wn-0z!A=OI_ew zjQZREx`6$uG5W#x<77Q*`n%-X2zH+NFn!Hy!1Lqhp8xBO97F?#e1A&=O2*dF@7_PPIt_nn7+F9(WpZmD7PDSk9p{d+skhPNFF zc;lWP@!_M;@1<*2Bq|Mh28Nq$>=`e6&|1_rR@0ZDpI~`jfd~AfSHH!n^zY!8FFnhR zQfI~4Ar3^;*wBKoI1 z;LPoRU#?t-^Wvy0^v!(Ph7)f$Mma#9Z<6?T)|^5$rfb;IS(6~3C62xI2Ed1Z2Pswk zRc3K?XY^|$z=y{b$2mITd;Tm%8rRK%ZvC5ADRb1Id)^>&C-NcS%)5>k;sh~%iQMm3 z3qgJIUu^pea7Cd8{iG1^Hf$+t_w3e(uw>`9}7W5*ia-=AqjwAVw?_4_1Cy_@k z)n1h59BQj#IsFmzibt2b6C^j=@VTStB z9DeipU__DlJm%nPk*lumL1LGUa;fi*qaHH)xFdk;Dm>+Pn)-i2{8YQ60`b?Mr_x=$ zme990=Kha{q8dBhkG9lC1SA}u$1V*#tzovzEjf9Z2bQif|LX4$o_@{p)D+e!kY*rR zhw}>YBswehtPSr`3NqLOKFk#$ES3RpbM;BgjF~#*6Sd>*O5j`+PI4N03C`jVue}8A z;M@_PK7;6g|F7-TBnjnQlx;`1B2Kn#yo)IGO z;~Q^g$hBdeTP~S$!o%PXT9%w@KxZ=gM|;#Wt~q4m+(Y`34|Ke*GzM=kx8ujOBUWRe zuf>z_v?#j`;)S-Kzh1+AR!ZX?>-f-vl9(SDe1Q0r19t_hgWd&MCB^-JOmpbOFn>e^ z;43x$8(zfr?btJSb~WF z@t0G4x3TFtm{;JcF{%Uc*V@hYq)^b!(P@2C#RIyI_j(WM^uu{67k57C6r0Cn1ypR2 zl|9IAt4;0d&2jW_;O1!`z(t}Z*46prFh7&l`^mLiZMeqUMo;JQC^9B@Rd`=mfiBht_%WV?{~k0$Ugq|rNtIAIub$2|&pe2`>2fxYegr;~)A3N} z)YDOv`S`Q97Vw$fwR0MGuMtr0{b0FWz&|GE8_1~PeL0Z+wXAA}IX$N-roFfZtK;BJv9bd-yAU+`$0+plWSNwwRy~R-2gO)Byf@eShNS zW0+&X93L*Od>rhmq5m1%t~&Jl&cwhE;F0_VjUPIJA7m}EuONYSdOI86{l{x9>ghOS z?!Cq&G(DCyfH$;Hm6|F7Pm*kQ^Per~Ri<2#&R{w|hs=`O7J`+4pCt3wy|U1b|1FO= ze1?9{SC@OnXr^Iq#zF5>MW7>S92V@v33lw5bi3UVw{c_>Ce|wf_Gi`cMqd@gO}F9| zQl7!P;Fee)jRibkcX@QzM7Rp;cv;G3g1^v@Sxe%9xXFZ_g7Ff}oo)KsruQ6p7lm`@CI;jLK*~hr`?#`XNtNZ_;6W>z}`jYTzJZe82jq-*q1Gt}G1Cvxnkj zfA#0};4fZio^7198Ae_o7^+XhK7Wq=C#Q3>9?^G-)wZ&OpK1OxO%MC?JZQJ@GVD)l z18qqx?9amn_6x)zKDa=Xhm>7s5nGM!OAdpbuclre)h34dgIO^Kh8OD5?s^UN-0?wF z94b+L1^oMw1?|wcfH%IU6mIx~e{WY!qE7lclM{ZX0;eN!achA%@gwhz4bAEU}g4t}n}>yihe?7?nG z%0A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
  • ~aFv{2l*0PPC4R3| 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

    eNY^Vee?07t#lO$U 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∨*y0n5%VAQxJy9$LK^g$ERh)x*2}gbNX6VUfv2HKQ@z#up%q`W z*1o^vbq8t*_vCzX9iGobm5dn3!C${-!5`#UxD$`Vxe0Wkzr{rq z>Y(zh=PYcRo3P$v%|)R$(8o@Gba}ZL`0gb(B}fGLcb06`iNH$?P82%$%e5cv@AXz; z&xHK+f?rn7Ls%Ewtw+Y0k!9g}J?OOWq`SNAO)SK#)=Zs&0$&jQ(~IH>ZCz+#x-EeUo{RC~J2J(Q-KcIQ z-Z?m63K{uQbaAQP!J{7|K05<0vC=G&F#~lj&ipZXqDMiO_Y|$#pb300wevrk7A5)-Tj5oynva7B z=TdMns!Sl2EE9zk=+76A;n!^~Yr+!N(-*Blm&U!ajqx?ScT`N?Ig|E4e8|6-QteM0 zvQK;2ZwolmWij3(Q~{uezaDpp1iYqSN1EQG0gocD@(owb&StFNIz$x#IKZJ@iCj3WuJWwNVB=dYd>Y_o&zX=o(3_Wf1%sKe~pdiW*HI%2#LR9^LOj*CQL7 z#}t~dK<1sZs$3%|<7P@eqZ0Iw9qy6;2Jb=Ef+4EY-q6?jn1i0Z74FxJ$XpH7VGD`n z-rmZPr>u{6y@h=0>Cfza580aVmMecpDDwz%a@L=_{u%nr$E1`}e@^1Y`PoakkXQC5 z>b!9g>qn2Zyl3d{&Eed=`x<10i|`J9%8ZG|9IVK>=VQoX5vDT_&2%_6kG3^xKReg< z4!xpcFT5|9fpiX+z0^G$k2HP|9-XX!_%MS(Sk3qjj+LAP$y+;+T-;bs9Mx)mK zjP5aM;3pKgbje% z87HM!$dmY2^)Uplia|EcoeXHg23+*uKP8 zfT!!eZr&1~N85`G7m9MygoaW(6vE?>p3w}2K*AhuXeV6#VF&soM|w96 zxF8NMZp*p}y4B{QLqo5R7Gm}q`!h&%9*qSk<==e#79kUYs9Ol=BbpxS`SmgmvFxO~ z&R!4qDRAE4mk-37eysQNUKQeZ{@L#?t!3k5+51XLjuv6%x;}E@g?SXKeZldY%R6*@ z`1qCI`!W!>O3Tek)p*3+JVvv}A9POYI5b_~&EX9x;TyvGh4|W6cfr(a*;p!WOR?f) zAwDNQ9hY!^9;w+61`FMYLpvkbHg%@J|LSXTC&S%%WaDvzG4Ubf1&pM zvebcnj69p2Lj`}&xlZ-PCh%?SWpdji)@v~bbs^XCjcLp!WH^w|1UP)Rc+OQ;B7PNC z)pHVbHEvyba?pLH18J{v7AEud#U7Hg?$EY)0&^6d0dD& zcW?H8mYYY^*3q}#>P8@sohcJ3rdjC5i;P~&I`H3$tx)~|`PY+=EW0**!3W_=dzpeg z^wEB&qR}zR!f_sxUSC0sw3LjI)w9xxX+&S&8;dZ7Yw$zt5z z@X9wDp2OCTLtLuPacIAHYiU?8=wiO{7LNH6k9N2X7Kr4{VGVC#rp&xSbQx(s(K3O0 zih{a`lX?$2HSB5dHmMOmac!5$y*PrlIWtsFJ51o)D=Fz8swZ)m$7+4Ya63{rzBSDm z)sN17QPvoXC8B{O(ogYUWE3bERNlf@kCneYQ%&>%y}yVmi&R(W-|-dLb@V(DzcyMo z&kt(FKBr4o+ClFxFPCgI;7&&K16eooQiT=>Ca^)BG%@PNVdYQu#}CC?egtF0yhq?TDg!Bvwek42;_16%ti7WGKF~l z6}^H*Mi!=~UFLISF2W(7M%k4P&m(4|z$-6@qtMvkwW+Kxndq)Lg-6e9Jj(Lv|GWzQ zr^Q;HDghagH}4%Oi-UZ*_PK}ov&<}9C(kR}bGiWcgdDf5;D+Z%Un)D&2ii zKMR@DyJbeg^F!jLlvjBV_i3F&OAPSdL++L5yl+jQfcI^4R*BGuAQ1CndmQLo8(5zm zs~U#tZ

    -_XIvwQYLjtatcTGXmW0pv?11tJSkDo!5dK6W+0XZJUhQ&2?^kBiPPBR z$QZ!O?-a5--A?fj=fY z9UT}-M6qS|{`Z(?kj^G~xXz~z-+$q%8{{?(x>&n@eo}??*ytt`l0?KTPZ$ylAkN(0 zek$z?=&{iRWf!`snr>qa8WUGO=Ie=5HIWe^!@gstxMoj|l@GTD{IJxIIu z2qD`Ge7sH>S+MLML92V;u2`I!!0SW#_C@29_)A6NtTV)!<;TkeCrj7@%0*$2Au_fMHxE--rXG~4bL%)o??LM2LK@^;z zPZ6jMzQiZfpQxRdBWqwNy8}5rz8|5O^Y%DQXZEt(i7` zI5UCf-gy}x1iby4;wSmr8-ORIIl8}r`n$yM?{4>(pr7KJcD>!|Bv$QCOSVRUC!A0# zUOCi{#zyF09Pt`NvJg=?a8DoxyYU|tr+SdNQ-}V=j7HqxH%N7dW&{bI+qF^4If-RY zpHxrZn#7Y8Pg5;&K3MA z^!9LxObiaAn-4}aM4^sWr)p52FgXc)sLm>Bt#%~y=>CHH8VQMatsRVod8Vs6SnlCH zfgV~k6mGzMzi{36?2WZ1{Cw;4iF?Jv=-is?y>o*Qw~*^pYJm^1=N)~Xdr%unzC`(B z<8VK6^q4N9Oc_LPXdX>2%TFN1C#&L>kZ)GR4UTz1{?#9Sbfq5VC#vda8VBq@Uv@A) zO#wXNZsL0xSM_$ZG)60-AJC6}Ro+;<1wIG`S&FhhFHfK|@!w~k&Jt0~>Z``(xh6b% zk6L`Z67s>{V#gXFUX}Vj&s`05hbzRzc2_TLF~_1eXZ6fezN90X?!nomka!e!isk{% zfjF~n=F2_hIqXFLY3Ig;0-XJ+sW$t^M`*g+t7ZuCYttLamwkYX?zgo%B)}et4yJIq z5FkF>ouaRi_&W|!ucXd|_RnG0EtdjE={~Gv(tdu>frQ^y*tc9yoxsFsQb5$3DrB@Y z_hn#?j8A9xDA#-jy(pgQ_mNZ6SguJjhr0IzvMer7H-NsIXO@Z7!Jwb;XD7=@DeyBl zx66rBK|EO^F{<1N{PjKHC8YD4j1%Z(O6GUbSBJIhx!-^ znN5AF=dm9|JQIyFhXB{2aF>nm+W~dh_TzqfupjQ5yig(w`~{V2RUm8JT1%P(VX^{`ChX$WPC>a zjriRJ)OqXJ1_Q*af>bOt4VU|Hg~NfjFI@UD@BORy{Q+;3^xl{GD7O-oeWO-e{s_F~ z@Rh5NK-a&##p0JO^#3=R{MzEwD@O0?_D4>y_95e^qt;4XeOQjxSDD|7go(}7+qq+5 ze-N$M`>3H3p`KHmT^(dRG&H5|wGI3~FKxRTv;^^tf9rS3jy%+rvQ)$(PC{+(U8!AO z&tZ90KKWCSM_!9rcpYe%g*Esp>72md?%|tLw#~xxh|jtuUHD} zGZHpfR)p2K3o}kaT_&mXrkWb$ZQNyVUQ0)3pzCA34gK2kUf|Q@B;>Ip}WBWCw`BI!!-6@za6fEs82lSecznM+Vy_Gkav- zp({!k0%ahcf1@BL<8!?SIdSgq+86=d0NY0UlCoNS_d#%5k_GU|^U>MyA<(s60fj8w zjpMmzAFWomVuxdk%spuxXn{|5A?hs|4IZ9PRRSN$^74`Xre-qY`Q!PZ#Gnpy|I~@) ze=v=?GuD2HQ@5kBxS$lWArT+8$GLOhtK(f=^)#2M6B!55zg)I}et;*j19cG3XK6?! zi!G2*$;H0#cixZ}96U?ZOq#~`rgf_n<=W7()^%DTBf!rkJ-P;(T5_rdeaR2$yX35S1Tyr?_Xy@l_tY7OZ*!7?QKiK%G<3N~4RNqI!X~JKl zjHvt}OPql&7r6K{0FFe;6Ih%D96)}Js*_7|4nLObAKdF%fZL-S&H0%>V6$6h+oFY_ zzH>vWwnb(h2~!;qxUnq)Wi_~^R0U=r&cchHZ@|Y{CEBq)9O`GxF#>ZoP*;hOuJ&b| zD8%k>-SQ_lbMW2gbkwIOiZIJTnx`=w^GG(OXzB@yM_Rg(p*g4|w1bR~6gi+R%^uyJgwC0q-3= zDyh8GiW$Dh?QP%JiF7W6e@x*dqtT^hlJ^IA?|IjKP~SU)==P{TjOm2_l=Tz}GZ@EP z1if(J2S2GW!h+FB@Edpgz-s=b72jmrzou}n1JTiQUY@xP@z0^$AS1v zrQF%?51Q)mZv6N`)K>h0_ol_*?oPBr+;ps2 zmW=p*wLQOPOhm>`yjMD)5A3R^N=@I#IxM~K?u_k=X)LJpiKS;3^vfuV@6gUCV#`j6 zgQ3Z-P><}SGkws3u#52-erw=+)4z;+XfcO9oezAfh%CeoQLYjq=W}r9PYoZots-38 zr~926_EoVz&zEw<5>TU;AAQZPOr%|PM3s^lkE~BlJBq{o@)xZ;uMha#N|_$b`7<*} zhIMW3PH7!3+3TudW-yH-SU8_B#DdP-PR|O#pWS#ekm@T>ekbm;WBM895u z`1x?e$GFWRBFfD?#_$sOdg+sb?g`@cxF(xVBl+btzVWm4YXfRS{)Z}r@+Be8q@ZT^ zsc*%{L&R?$3F$!o_!kA}x}(&rYh|7bL?rf1+4_h244R#xzCmYEhuc{n#$DEfc>b70 zPY3ANojWakQI`G?Qa9e!=(@lPePlvvYZG=g5cdZ98CF2OKxR!m zl>KxcPICQIW$8o0;wLXzw!nMYV#xi@F3_*^W1yRRIzq<9Bi#1iKv#p^)r5PzE~5XG6a1Sf#JUtIBP4BOaMb5VU>*I zA5M!cf?l}QKAj#9(4p9%c(;{(JrCu232)E}kkFW<)Ga!y9>hF#-A@%D_=Zu!tJlEaP+a}xBhv@{*mI-3Yrxl9*(~cH z>I6S0p5~fZdEj{-%?<5=IP+yj%^L-~33QhBPuTN8A_^ATuu_6Pm)L6)o(hn^$Hza> z{HwQ;#s6S|l3@ySom04V9&oB7`#kU(;JxwR2TkLkPDEFlvnxn%0_}VyybuDsjwH*m zc|)lt%+YB&8Unt+PwnoSa^MN9^^0}f9^&5PHJ8UMz^5u{(P~Eq)KB+uuuII(45FHG zO8P9H3B>G`;_>)35uJbTSff4!_hozs6 zlF(YjF+&~MJ}d^xV|-4a+d7t_&kfIWRMT`Ay+jo<+rObomqi90owc%#9nhyuakaQ< zI~l7lxfS*Hc^2bkQW3R0rp%R}Up8vwtmj>^h{U>d^lw>2&Vdp`Kk5QTE zOP)-%{zN>wGgmvd-T^pm@B51f1p4sh^J|AZpdU?C`N*jz;Fkt|k~Cj3u0*?aW;uLk z$k@7rICA7jAJQCZsjq-_x|nM3_jGpwQjx52mr^Am|7Rb?nZZwLwtOe2I_w*Vbu*%6 zVZFaq&lZloSc&Rht5mD3gKn6Bd%+-W9|}3?9LMl!8jIax%3d-FGIZ~*w;g!)LA&UZ;tW3z;+$OR9IfyrovRu1k@)P#w(i;~)L`-AZtwx_$5VCxmSh(AdsZtR141(bi^FiY*^QM z1D|e5E`;&Q0$h=zs8FaWvt9<8*#CHZ z0`Noq0Ad9Rcv08!A(3o)(3hK%S+scodIiVX!sa7DH{{YNn;u^kGG?^N63hdAt4JCx zX&KO)Zz66S{5_3nvhy9*FXkh$wte$Kpm&i9wn`o5eOP73`RuC`BwS_A@jc_!1isq# z@tGmabG`Iw|MyLx3(9S9r3!eu64zx-xaz0zkW|SlyIX~5LHijWgEZ(}=&a>R!Sj}fR9dR>)>IJCg zK(>j(B@)V{QxWn8e6{Aedx#>$-4Wx)1n136JW5kms8w2s6Fj7>n)v6DyB%?#pI;mr z^E*iYdORC_@Q78t;_wdXjWzw~hy zp7Q4CkW~=G;i2kxx#@Z%k(#Ahb~x>O^rW1DYe+N>g?s(jYYF)PkG#wC0*J%+CtN6F z`BQ*5Icm;)|CNnXPhTM&Oe(>-i(_6h5FZMB^r)I@jY7kxiwz~6GdHs_dZ3hh9GXa_C0s|{=hc${*SO@JK(5M!cU@3d~3yyMt}Gk{_4?txDwX1 z$!OTt|CBkzKTgAO13t1d=ohuCtk#1%{BW0a<%OHmIP~Gd;=My{=$Cb8VKg%lHzYGm z)|Y`lYU$7STrM5xs#U^(j{_O`22j_v0j~+)%xG8?hCD81xu@W2Hg+_hQ#njsh)If< z&g}qRTv%kjCGBc75?T7aEz~&^-Ox^=C{2h*E5d!rx2vJP=y%EODa^NhaU>nJWf68L zdj5wnnS+^L{wS1WFTvL&PM8G&&My_g7;5N}fP^xQ%Kd((Bazm94lf_PLod7hi+z9> zSKei=%?fqu6S=R-7G3|g@=pjWbn`}KmN_{}ZY51()w86>wM*LVBJu0fpn;X>RLYkw>5 z4am=VUfqF|hqD}S!hIKTHI1|b+{XLQqn|^7+w|3z6sW-aG}?bOiDzdex-svbqi}Er zBMVW%o!k46!GZdqhD`Xr-#=ZxysH2mOaFBDmM{tBs?)h=nD$}$bzO?P;UxUMv~^4Y zcw&BTxBayED^bU;t@ypOpwBq>*?8tJ@7#a=2@CkOkgoUM?EPMV7Au3K4=9k(M$<5D zDd-8~2C2GHBJ}rH-M77`Q-`y1B+r!wOk*9c_w_d3pocal8#oF2gtW)xDnekMeZA&E1r0vReFrM11;~KZBp7K3r~da7gDd3CGG$^o)c~U;{>D1qJCUBx?8#xqc&K%iw{g z6^O%Ce`F7P{F=t5_nV}a=yMVEgDW6nnW^xWI4p&HQN{nfH=*c)TDg`MM!JY>}Vg{gL20{S9356(7g zj^U=T_Mj^VdhklP%is}s4qp?dWBcGae97$+Ap_50t&#qr;M7XAzroogzMYJ(=C}OV zqVGdf)?#@!Bhy%GUo3^mS{_PmoA$k;NJ1ZMm>Rfq!Ot|~#Lk)XGbmcyPQx&%4wEM| z9%;e4IIr~#eZJ6!3KUcmvIL1Z|BrdmOin8<%iPu@`=$f!ZjjF~G$Er?;R@#*MSIX> zgCwefdR%MH66-!vEk1Oxin-f-8nX$|8NLEvvy9ICuvyTBuw)a;ENE%PedGlyY8Ypj z4H6BHw7axhO z2u+~jx2Ei3+zt4fKEnnR;CzR?K5!JymSZP*ePQ?MY4q7|_?kG}ugoodp5W_aIO(%c zOBWsJP=v(<2ZQcG7x9Is)EyFb*K|*4g7{EUG=11Yw-RM|**@FYIfGM)x+Y&Co|hlg z)lURH%GQ#zfd<;3lOFN>mj&z_5AVcFYyRrR42(f@=&H})It>t@Uitdl|~@{GrI2gt8@!= zUMi{sq-E=Iky3g>{4>ZyW$0JuBcbkD`jt2N7!gN53bW4p(TWxP+2S9A|6gqOsM~b{ z8GRGx7L#HGJ&>2(7mh)_$!GU*PVV1znC`~j&_Z~hzE^3Lt14_mF*#u-#n-?GMnLhl z>`W`RJS;!MGt+_A@=Hn57olIBs`GH&d#JyCeGv5NBlO8DmQeG5tH%cEoezzN_iRBK!)z#UR_>Z^bA^r2Xm#jiU zSGk`WYHRo5TL+@FU0##0*pAwLMzFp(+bB{_oPm9wq|cGQNXAl^A4%%(h5p9y-Q=_2 zn|Qz4!#`D_0R1cvQzFQa&`e#O#hD|0*ec`_!>MN^Jj<*+_#kEicd0V*Ctt2aLwnD} zIS!GrURqCK7U(jdMx|fWp!a${j6HNiqX11B%vOs)oJq59w_)a*10&{rcXA=7=Z9T+PEq-%?ACbjq<(@t>dkj zv0qq|v#|piL>_3WF$SF+tD1|GP|t7cZL~?ND8PXt#jlpRbFepc;br==V$8#Y1wt`2)8 znCGvR(i_?FmFU@u`kG)T89(z2VRL2ZL%I=pwnIaJ2RdGi?WD;^GFSEsvB5r8LBAtl z9^(0fsy}$vvPjr@^vAUf$m3G4|8~FBUx5^VdlN&(LC2oKqU0y^vG1%n@nZ(!2ZtCH z=>nM|bl~<}Rkk(>5r03-O|I?53-#6cks;t$kf@WL^mGCba9y9g59_OF*U7zWB+%0% z1Tma}aX5KJK5J8uaf7nc^*ee6DA$&E%>6V8bYwX2Gr%>IR|K+T9u(pyH!m@=pUK9@ z*Miw&WQuV@Nb2?7bn~dm%S3u;JqqoazgVeglZ{p{-|3I}6^D8p*+q0SLC2iGa=GO# z_!Te8R*LHa&nnQPxZWWfpMTt@Fn_rOxAWz>`@%do^Imgykc&lM%cCFg9LYpd56&fz z?|p}w`dKfgLi`Mb&%2t>0atHPh_bp|h%ftVa6Q|fjfcp)w|4I;#^Zipp2R@Cz~EeV z#3jvWM7tjN^6~9VwBtbGpWEOsmA@-sXdTAkf6Jk$2zf!B3%|4_;KYv({h*$@l7sIL zG_NbF!Z?FR!b*X!buaVHwv$4!sOyCAW2TsNgrZ+8o-}!fCQFPrHi7p=&9amr+D}9u zlsLvXmjQ46n#BA0XdU)SOpQ+m-i2RTv1mCw&pHQ_&pize{{&{?R^BrP zOqK=MrT^|_m9xM{;+eO1JP?NXrzkw{wP&J^(hLxwdxxZpEHBT%{ICl6X>CEhX}9f- zCN1zyZrPx6iv5s{g}M)N7xES1m*IPwi$tKW2+&Kb|+fdcLOPdyLv2z>hTG*+ts6D8fVyD{Hmr6@nO#9mFLBv>;IgW(_;kkFMG<~=S3Ze z^iZ<72ypcnF9}($c_KRHbHAswg^X6ly#+~@by(2cW0V*0a4R-1RIkwnK8Hge#g7p2 zLA_m@>A+`exv;mb;8_QA^_ z1|O)>=Z9NB_fm=~mV>jKgf)a~pK(LHaaJ!$>@jGp;c_4|T>AdMPEg;(W9xa`|Yb4G9Sw?6;u;-KW9bi{aIv`;@43 zVxbfI6pUyy(oWd+p>Y1~vc8&ScyLQpAr#ip^6TTZMbP&r9I&sjOKS}8l3uuB*aZ6X zrt`}|l6{yiT!CtjHwk!u-1!Na6Zo0QcNktE4sd1unHvMxH-Cv zewZJ(;`!OAmzC(!9wve%;4REo^u*L4jz6r#KQ!;KtcH6)otdid^ zh26V=+#|ibn zY>JtokGE=iZU%I*R2K%@M4*qO{7upt18WcVx0%29m}V4ppYQDq0R7kF0wFitb~WN1 z?@1g#q3>qj#(WmR{1ZN~m>unNmW-j*dC-B@pNNxYl(1zaa+BbLVGQ@ScstPOdprgF%J-^SS z1BoxKN6~nY(J#(z9*SGWY(SeQn=p69zd8%PTdc;49G$}st z_$-X00E4nUN~;a{6eH_=tRM8zt1dr0Zd8s>r|jLvO-n{b#D|ZaP0KAI^rzZY@0z{xIj21ity2KuwTAGqQ=)JQ=?}qXW zDz|<_AkWm|&nfZ&ge%k7x>EOUG4L2!Gg>WEhPv@yX1&#q-4OSRYzWF$LEhBOT``~x zb+o-D6W45e5Tk7UuS?K3OwBp}G-#j}?-QtPFaUf^CB>6*X0{C}2IpS9ncs~^eNz=9 zz@ORn#KmV13!qNqTaZNsIDni+xJOh|qs6);YHxyUfa7&oza*o|eUA zTvi*xp$rm_D!Oq$?G!z~M=Lg7FrSFn+ld~n$tu3Ef`0a6@?q4Lqo}l3&_fjZWnOoT z*MFO-$9y}JA7^p*A;o^NvAsJgaC`9Pc*e*y3MlLKvI9MeS!vb*rwy>AWyB0c-jJE~KhWhDOrazKDp^rZNIigXyR0(?S$~W4Jy3m0T zUyHx`0Qzq}rS*Arqc^X={?35DY>n-?r^@SIyu3w??y&0G1V-AG6GRDBlo;|mnG$+b%c;`?&99{!}B z#exC7G{3ruNP#czO1@klF0(VZJaUhO=M67E4}$kHqs{kAL0wfSm-Tg|ANveee|Co| z`$aF(#7%$9+o$nP|5PE)k{s0Ep?Nd7w-1?_=bIJ|^x_>Gd)$7$B;lF1H$rkRCvcqe zbnP*QN;LW9YLwG=GXAXM&MyvnCCrpF3++(Y4$inFt35B}{iZDg(ho9<9^U(h!>8z<8 zi@vnJ*&Kb4g>>CQX{!0+(K^lX434Hb%qto)g(+sxz{?iK!yZ-0d?b30+RrXj{9t#z z73f0HK9xCm<3=}nVBfbcY&M0y=f!N&1P1~Smci<5^b9V`tzaYpo?bc~^x)bw=!FP; zSlY$$1zmM2P^qB+9jw{pn^~Y2XOZCT@(ud&Biq-@n?cv;@XVl}riCwlc*}lS=GhE( zJQ)|w13Ed4g@fbYa|Y4an>XeMl_pS#lH7J%i1S$TMZ4FSoAIs!rz!i~VbC|uj(*+) zx)9Y?Nlt=On6-3^=WAOVi{b1o>cejF-z%$OkJt4yksOc@F3#1hh-i^eb9?AcBY5w8cl!`o z593@`o83}_akQV5GZ8#0k+HYQ`RFP#?h*E6i-Y&hEJ^vrfl1(X>}@h=jLSz9984~W z#w29Dw`fhuun$K^4~zvtKA3feK`k8KUoNhbhr}bR5c7xT_g^9YNmi@fAGO|#PBeWJ z$f5(kqT64CT8(m1NQj-#65t7%n|9~};F$qua<5q5CE*NFroIahZ-|rfLmC>vx46cO z#92bd!%A|NLZA<#VnH8&6!6T33;RDxyvj%Gzqw2~tiZogwlt1?iHzRvV=UiST!oJG zHIOf~b|LIDP^Pp_#2Utn9K0d0zV@ah-hDWQ&T8|iikbOgft8B_nc*{dmP`M;4Ob6x z(UDXoSd1e57q^8Zfo~jT(^9+->Vrj(UUA2O{)SPi`{WyoatySj<=b1+=t;)sT>`{Rx%Mhz?a5G!cxxKFwge#mAX|h&r2Vxxiw*)1ydg%e#Q$r`%X(chJv9^ z?Q)LE2tp60`1!8Q=t_Fbr>}EUj-b4`ehlh@eR6$&4dqcn~4)A%UiJcNg z^SLNV>X*L_@bp~$uTbXw?!_6ZHeg2vK6qAFuN(@Rzzi0N{Wai|mwmAG&vnrmY~z=y z7nKb0;jqT0dOy?=Zu2$l6v#!%ho(ml<$_;IW{r9X;D^*fHymY-Pax0hWW;h;=-cB5+}qZ#ZI2Ek~%G6ddAY^p9!Y_?>zrs$FVT~XPm$D@Zakf z7Zn#hAu4%7{1lhy>9Z##&Weg2heM+O-??u^I}ZLcBmd9u+uw2i`@L`5nm9Szm~pvU z*gBZmIJOXclYh@qxRo%#67VQR{_a0V<`e((si7t>|MzPD{13nWIT?QYZuy^C=lbt~|NrxUs~J#`CtUmc zg?0Y@*8kbXC@7ec{`+M8=Lc36_7-<+%qZ+E%&h+&F*mU@v9h3`aJII%V`pOff36eJ zf5-V>eWkLmlAar^jm!3?wAZTo@J2VAq5`=|- z`R46H;Ofe$)Mk|-ypI+zKUWTon*2M9+Ku7=TM4G^^m0V{eP$s4AG zjC=kKj8`-XN#+$b2|50RREr^Tp{tK8xORe-@3bPpl*>D2&vChmFJzTfvmgb+ysr03 z^6y~63GU|jYlC1eIQD%42pVe+2$2^!zLf3!JkRLI#m(8nbN6A~N!K2TGb z6SO=xp6o^U370mnsojVF*V7M(blHEaLhaGx{_0teidxTZ7KsVtio~5|Rqs!^5r%D4 zAN*puQIXymKHN_KilB6mmSwZlm~iLdd}aRpJwlGypUGEdHwePLygUK-jVjd2q!}XE ztSc@ZcHlXiZc|}Ed0l9Mbf3U(DJwHcwyE&l`}lk3+n0p>jMTIl0lEap;*qn%eF9m) z_SUO(eFA+;-lvjn4i#Ee7D*NZ4+%FWE=5j%k|rF@AL&*O*CTAN)njYumLZV%f1e(I z8Ah<5H5Gn+%7$Pt?pw;tgoXHx2}YDPp=bIP-;HgQxs~k+J|t+v z<}#|d^nXxv)=^QtO&q6`R8c}iMOsukq+{sr&Si*S$yKu~sSz*b0Qvffd z4sIHEDdMkyhx^B(L!fW-ck0HZ8a6rx8|5b0K(C7ZdxF6QG$N|IlN>k1ns*I`kwEC-MrHj~EjTR@#uxe06S&72R(ZVyuT2>OyLF_7FC=z#s#3scLuJt>OkY5jQOV^eYCY`q@)Pe zg^iD5xcejt3f+eFE{=uZ)b&U?^GZh)Dth0-pce@Z2_5QJSsYPRJdeV|r5L(X|8jj- zb_Ks8^)yqXNYK8qeI%9B6_loIj#d~4!->`13JizLA%o7THq_M%3~di4UuMxm%LPAu z@lqc+bnU9Oc3LiIs^9b!`s@vX&y?d#>GhF=*0pzGkpya26DE_-gkqECxtB5!gq~wc zY&rXaQ7$Bo;$V&tJb}stPW50+c3Y~s{PrR!?NOZyYj%f&zgi#oGV;N04Q7wcH|}5( zOx3>EG7_)V9x678l>lRDpPMUA2}pJA>b%{{5TsMT_~h*2M7;heIz)AUE>xw&Hg$(d zz{{g+KE$;Uq;UH@U!*4k)HZ0BE#VA~b5D*ozc_?iH&5l*zgI#5)?wk#+pZY0&B9XW zs)iPx_LEh^889)<7#MG*j}+Z_Tm7diK2DsTnDWv`mEM`}t`s&fM$aqVk?sZe&-~1; zFbsn?b`mD9(tOaz@`mX-!7vC2di>E&G!IJOlajAT5MeR-eqhrxA53{S5`V?t6^xeO4 z@e@9_TIPn#lCRmBz8PZ0*P5Lf@;>pjs`sn%jDr*0de4qgheLNk>-0%pB65wj{V=#l zW`bqM<5zu(L216|gHvD#D7R2&Ur{FFY~=Tu%OWALJSp1in=S_&T6N$5sJKJBhZv6* zQz*{mJdR6gA|U?-!(NWIP!xB66W6Pp58Ahn(k0bdg5n=}>GnVZy1(BT_c~|^aqFLN z^|RT6q)Pn>ReDR12$MPXGS3R##SEUbX8U4*#h<#_pSIX>9&~+N@_@p*hFS3`J%;K0 z=-Z#@ixkatlofXv(5bIQuzEZObSuN}4gEfg4B1|{Lbr&>Cv#KYGA$H4mlN5qcoQ*T z&&ZSc(~)3lbom+e8Dl&zCJ@VXF%(bpuKj(iV~ldwD|a=FXu}7UaS8=#F>H@{@l`@o z8}4@Qrihs*LQt|1zx9AN9Qf|NWha^m51oYg`tx|P<3y9U2!|Ua^5EXNX-0e$CGRC{ zWQqw%v3rS!E$~ZngV?>4a3IffT+ASb;6V8u_Q;+H(3Z~HYb%`%ox;YC=qpTNt;pub zpnnMR>rBcDh?&E)M3>2ZZ;X+sCVXo>{4A(-l5+ap6=2OxvMX#P9DnY+)U|q63$o18 zZblxh1d7;aLA({S?K#qRHI6pnNU^51?q{^57FSlWYji0Ih%f#6a;0>kYVXrBxe)VryuQEQW*jryGL;#A0wNEVvrIAyUrzB=3 z5kx-k&T4+`h}_v9bLl&TFeCGD*P7!g)Mb12^=Z{{?C()2ZcZWJFE7J}9PW{JvcC9q zr(Ouv?%j`+C}hS&X}jp0{235qF6`=9#Zq}QtYDid3w+cuQs+p5mhlzMvq^*lRsz` zhKBQel1t}JfI}+XE1Jy*PelLME4B~|ntvumvD_KxyYIa{x)F^jQlny1DUNW4_VYDu z<1#RuJNdQ5j)<-6C;x4xMx%AvDp9?Sh*=3Y>#M5Wfkh@=L{%yt5`&XF+`sW61;xqa zl4GJk;a&XlPOkuRzBuUd=fovgpDkw=-7O9^q7UV+4oZRA(d%|X86xDkeD~|#nG3M) zaWksX+7~F6{+c8UNI~D(<@!QvKb(r3i%F)Iff0Ant+k3=kjstESI;$uv<{v(`Qm;U zbhzK=SBD<#?%`hyJQV;&aZs{k6^ecHH7%Qlnm8U-TabIw5^VA8a<79Xz7J?#J-&Jl zoT}RFKS`6IzC$NS^|&Q`>dw~kzUB!Qd>I3KD`SxAMc=BNBoUeDKYblMZ3#iu@Ic$d z7d38npM2wH2|ApUDHdeQZBOv1*^p`!i1bXD*17qhsr8^u5qBi){lrW;6_JXw?!-tZ zI(_W7WqrbNIRppgDMpoZ-O;JXp*V3R6zAL4(@T~Lp)K~sRHUykFee^Z$W$aVvJr;g z4-JTbu8u(lL!ckBssvL_x_V7XnjdV)-k| z3Lw*YX=U+pFhoE0e_gf57@vF)o(xbhK$nsGDt*+>aO+CQ_6tTW3|Oo_+x#&DlnOY- zT0{Jy_DJXFVN+)~9n5DUt?ma43A?knU!KMBAi8)^I?9SZM!yK1rj5^{Bj7Vgeh8X0iTm< zP=7SZsY=leZjbG>?`kswZo?ne{X=R{B~e;@sW1qL%Gvk>@g2eseDf_xzL9OGGAk&{z&|A~Dn3wkf+D@)X`7aI_R4WqV zAK(k>qQfeu1K>F3Be4wWB`_ax}iPJ%Ry>Z|V6vYOABbH6D?s!w#t$1sAl%&;Fx!V&Dyt#Q+ zPbvtXzD+IE+X{u}R}b3#6>{tr+@rYxk6eMT+m-UrkVuG@2~tKukt;syv3bD0q3AKW;sQ|# z#@~|FVjl3DLi}w`#**+jpuW7@ENVLl?2cV-%l$#XnFz7RodTh7 zF@0Mjr@I)eDW~0b{S1VJNn6W+Tmmj;J6-n<2mEthji_;2w)FP)=P{4G7DJy)Q>!`G|SLi+!9wZsnL^vT>EGsI529w|B~z z>~=;9?h4C2w29E<*PUNKYY!5hE@PB`Sx{%Lt9fnB8XAg*jXwt$!MAs_2lWo~-?@rV`BiT^WEVKE0r zinZwfqzXXbjk!DN2MO36mAXtet)Rei`})BM68ut0Fn>Dlg_GLjcCMctAaUtmp}=Kr zICyX9VFSG_l-U2d_TsN5Sc*TNaSX|U#BS%@I%Beq@SjxB+^P*wM33AML05?J78L%F z8HJjiC-qj2Izw>$slo4kM7Z-aw)oi7lb|3NaAW(QJCqHW{rM7{2W#Ysk`2?rAX?T- zPxV(Erf1HkW-tcB+wW5$s|)e(hb652&^8 zy8a-2ru~k`@b>IIALtVrE4*}=1)@z24}~d{uTvmgHR)9lM4hD@xC)+VXZU`VH6jSI z(&{f(kK{x5zl_df3k3KPzI7(|o@|U1MlHwB5+F>5G^A?p^vkZ3c}-af9w$k-2Q|9!m>WQ5=LOa72q ziiHrqS`(dZPxu{sVtqB%4H_d3zaO?14{B77dsPC{6SC_6CVU5v0!~qHgOuN4X=uFfnyE zRy!sKB-ah(My?0J0s3>@5ub?oW7s1pJ}U_N^sQ&-(t@!+^@#8TUr!j}E&RHxItc)(0 z7>W=IbT;E$q2l;f!%#;Q%vWnYGGK~DwTF7MZ%>J!xX$;X^V}pLWViNN`%5F6?;9F- zvfh#bA^RV`cSXTe|6nZz60jN{c6^rXiv6P#>U?i~K&9+`D|s3yRz-VV&g#@g-UiYx z^LxSYVsJ%FyiEhy^awl^tVK|qu;gYqM1Va*4t7$j!BF$e*jv2O1^l!Yb`|-0gIVX8 z5+ilkLsY<1!5dqaJ4Nt1rT&G(6;&9x;bT@xeiKQbgZ*|{rV_*)4brL53A~M7 zDY(TLS#Yn*70wC2nntgRQasRtRX@r+tNmwjF9(DD$fIEHVF+Pr-$gV>#wokwnFEZsw3Z5*4+S5_CETtsu`*r3QjkG7aKi8Ws zl<~$W$^hO&eMZO=KXf?Ya~x9GYCWOgWQE42jF;ljaxkl_l3x;(X`TN zm;g5}(-rkrlIy_wd*KfB9KOpR9;16i@M!KCFyehj@(0GO< zEIH|op|p;QyLb!1{9$R3oQOGIGrvGVBcX(^AKHiAY&J*kE*HTr*GO=5|L;JJgCh`j zpBJuXb^xA<(I;jKZg@xS^Z4&_JMfI#%>Gl74>7IL=Vfx-Fs12;?_dlO9a+8>?^wFw zQ^AYrcPgWRis!e1%$g%4bVl9TGwTmMoul)dY+|T=&dKXst{=>coZ&j6lM7KTl@ot- zyn!|1s&8$CB&u0GXrkZpg17TFwYLSy_4k&Myp~reoFmchx!Y`l<4XK4f$I*Cmn(23 z;)4M;e@h9^?ahZ>FQa~cc^Cx?jcGq5Ih`PVp*H@4aujqt-^!Zic1LEZny)JHUa<4m zQ|Eh^5xzP!`QhzVS4jPN(pBt{9)=hcCoP`NgVQ$mHx8}1p{3ZgrC)+8q-axWI}qJ) zp!q!^by5>}Qd?crJY3<2wX!w$-yr-iFa5wB=0GT+erf3B6pRDM&xf8>$cBtK#o(yx zA@H&N%Jy@)K=9_7lHZXGfw-12rgvhAnAiv$g^4a8-o||Y2GJP9KWG07xb6+o%OAcl z>@md5BO}Z|zU0FP>x=)%DA>V+3-&L0!@Qw}dO`jwy&Wu>=lq`bv4)`5;K6g@ZqQF8 zlrof90@w3q2Z~c+SVQGCs~2qvPg3%onuPO#`AJ*mZ*FGPZx%5fC(iQ_?IFZ4G^RY*8J9I*aYa1Khnd>6a+97w zklv*2s0eWYb+gdhTPFfRG&`c2&E5j7M$9{=sQjSln5Vjxml@CqW`C=&(}0bt?tAuR zePZEkw2OgTKA2g1*57vHgG=I8HyB@N0L4#%ubEf4!My%lSJj3Hme?whYJPcxW})+H z_nZQ%7O@$87$br(r-j_om@=kD|J-#;HWw19WmSD=WRdE_b(fzVM3@h_yiysgh-V82 zUMAKDpnpLHl?w4VFxpbmgZ}qal@FZ$=IOb3Put5tjo5A)`U{n?^8_ zmeTR~tSm-Ln*>dWm;x%t(R9-rpmtxb6RU_D7<>8i{YM_dYJI1kWxRe^t;vKcXpe|C zGVh~5BZ0Z#$;~YJ;k`3(r^>xPrtqQtxR!OUtb+@zt=@mWrgsVo__tRNUk!q=8n^(96ESCQee=Qn;V_i&{L3hj{bM}4ITd_juYyMnZ@kPMh7i*(68MRol0TSh^T(+Izh=gB(WAp-X|d-aD3`gr<{^PZU(d$1Q>wGPXf z;)1#f57)JPm=*l0%60x%yW*;=#%BRGWj%#NAy{-^= zJ`;{nNTMq}F`PHX6`Wn3=TknD0-c+aqt7i|!8_!V_xwkDO!QgRHttu)eyaxuDkbfa zKx_Pal#mAm!)>e z;6wY=y;R~PH1*u!rY9dSU)RocPA!C==j;teq6rY-<&)DbNy6gmn~XXJL=a2g?oOnz zgerhiO^Ruxw-G8ki_37uVkGsV&M#R0{&fF4sb)#mf*Zm;k zRevExg%>>GuFtvJuZK(h=kLyHDB&k3?}k%cCip3d>-IiM@_Ew6^I2b7ft*fcN@krB z>Q+|`>T6rVP~ZLjYkeMIotey}ZcWa|oIG5XDkU)Dly2mdtq(@Oj6T2MD23gUxh)-+ z^T9G#F;+#};j=!ZgR=y9og{nZt|A4ydj&x?X6 z{$-onvaS%3<)d&f)fox`iL)YS&tcu9N2|}U3tsuO61F2B1Kh3L8I!rrXhe~aFuIWk znxiIXxn8({V5do6rE?4~=Mt9vznUyPq=9!P>eJl2GIVoNJcxxzJ>iyvLn%f5CyflO#EjYp}j(qFy zTLdgoy`QnHZvzF&EjHbNG3g>W)9502J(F_B%5eLffqZo~mPE7&JC^ zic&)#2t&{0No`zs@DFujWN{eTcTmfui7>(!^fHv(0wmz?Nmp*8^K&$2u#cP8S`>bXQY6?ZIcyrt(I7Y02$E2_VG-I0{aSqR69;7rodQ*4Lz z;G5$vZim<~2yzZOR_CG%8hi~`wOKqN;?o+qkGf(_-Zm4Zm@{O4WIy387Xs6NcJjA* zU0^mKu*8Wr8_KmaxPJ46ko{QcgaEn_=vwD5``Hl!HnCCHE>pT-hAio9&sDM?dWU4> zU-(6h=}qF9r^7*LD6q``{5&s2Bnc-xH_eA4e+|o=C|3}voqR<-7lay}vFujmuE4OO zab{CT7x}+Vea$8B^R`zUC4=PqKR$7LjLSL&hqes<#W_@fhnw?^kQQ z@z`weP;VG=XkUWcyBv@v*4$^&hlF}EJ9R_lVK^MPJv4nZ5Y0ZVL@~6x!aq5M`3c@Y zykcK)-IP5KQuLbm1dc7XkH0*xLCr>ldrqh7_7zBCLE6VZdsvNtt^Gp5ph`Rj)+9;u z1Vmv?_))3Zi^dq*858Ij6pizro-CY?%7HU!2jiaWdVw(EQSUKdLo|=0<5D&D0=+kd zp^pkfkcxQSD78Bnv!qCVwb|a75u;VBO>{y*p~AE`4L)SOL3~1^DHq<7T<)C_^Z@qW z=TIn~ka`CZat-P@qr^NR+%|itT>I4GJMdPsW zmfQF@zhd~nPWmW6>;T;2O>=kEfUGxk4*q0xfj|cPC@LOnblB~_oRSz09im41631fj z?D(brY(Y<0Yrj~ytsR3i(`luwxo-y>uYL*g)Jws@_%;`Hm_3LRLs_IvBcM@Xlv2ee0!^cI;&;YFaH3p= zk2%R48y9GcAM=Ict;vY!H1{l6;k;{ZMCSq3-Gh&tl>E}A4;Yot)0t*S6gYAuDHU^XEe%oEIc`$}rpD znb!#xH-p_^W}+;f)Js6#-RWunby#EL*~NL@r*Wu$^s#>FSshF(W_o0EIvz)9Ri=zg z3t`UYzjyr+1Q1Vh4?UT#iOfv|D~@(2Fgw(LqNUmeBO(tIV>sOL?cd|oa|M=I|75Y_ z{XTK9E$IpInzO=yOPBaBab|#qisR}dEk~Giop#VUDFv_)IPb;oHr2}J0=TLTFyw8UqgpBg?P(2ux(E6^s2V0$;8fagWveqTG#!eN<5#(AQe6{wg&W z&P0D8+NpWMfUOCWqn01GQ!0FFKHv#G+({aJKix2hW3-Fi9xx-amULzh5o@xW66GsN zXvO}hsFTbWTo@`5iry}QjR)?nuiv_Ybg&UGR+F%SA~UGyfGc$TUb6cCmoF%)QVoTsct)*Nmr65?j2$qm65(u+kJ2*r|2R zHb~I&XG8MTFK1YDq;{T-Jb^Xed(wVo>EIrhtz+TuY@tnJdWNvBkGEp4ZZK73!(Tt& z#}?&QfK~LmZ^~`KS@(Pc%P5(*8#m%$9^e9@^#czEzy`yoX@Y+YI3VM4lZ-?rB_w)} zPjb;X;+_37uG>vnFm7@se6-RUE}dV12p0y(J!v~_qiX}_XH4L(ry`=x+l5^6{jJHB ze_oqlhCy#%6iq8DL2*F1CPS7vK2aL@;B+$!;^{3cm_Ay-+w_y!+c`=Q`A9(3Ce#v? zXjYgHpSMT)+lNg;Xq`Yiozslwp9A@2#eWzm?8IS#PRf99(jI>=jrGgN=fQV+>$t-f z0;p;6`&6r}I563EE}oeb!ehb@34C&v5HHbB7qjLJQ)#qXVr8dr;_od9)p#F_VsX{a z&QnCUm;vX#vZcTvpCJ73pgX7^d9(WHoex^SdtzBT_0gkhjF^2g+2#l@fy#ZGgo>p{EmDiX?9Z^atbc(qUjL?*ZZo^_vq^Y zyF6{|C3-#hT)vrpp2-451EZ&*L<+o=&);QUKMngYc-%^qmV@l&ilmiKIq+O=mb!3I z6M~qoe*fTb8cLeotP|4IKveskgY~#A?Cel~tA4=&V|#C|v@+V@S+H%ZaNvU-$Fh~o zc^m9)-S;SYHV4`)nHw&ISi$<6oH+ebJ_r&R$awzE626J@{2acZf_H!YR3Cljjhxej zwqH#aWFDlxDf!wLwK6|ftKyHAWSziEKXU6L{NVZ^ZANDV;^wZ6qSC+Aisa&g;g~@*G9TYUS$7mWAMIGE|kvynTmZv zf=5j}#_Q)?QMm4XZGhuGxNFr!YtzSRu64^wwOQO^fY>ic>M2HZg76efHuP#$$TzCg?4Loobs zrTb?BInG-Uxq6dzk?4j|!VTy;U`Ly>K*~2u?#Y>iAfdATGg-Um6!+(=(&a!6! zy?o=gd-d{wv|{S=%u*TV@4pH=>Z}dFQbilsMO5JR#ZZC`$e8!kDD_3n2%Mb1!p|hMU8kBmVNI zup~Wp_x6L6;PTke#L_zmK7MUpGs$y81;+2Gy}o8--7=)%ZIB469<%noe%AzSDVzC( zX|mz<(STB#n`&@+Ji~VLwkXQe=w1?I1MsR!7VOasx%%{$8k^Np*6Y_*g^g&^ToQS1s!B9olVtdil9|mJL z$6PBTakN#5%{M#Ik`7P7%k7SPM)<5^$*P%F_(QKQ1 zg9sZm?{be0hN3IRJt%L^gMatgmc7&DV7SR$_bRI!Fn8u!xUERT*%N&IBz0ZzQ&N_m zqz=QJ>=W1LJk0R@bflWqW-wSXt><=pHO0X)^R$n<^FSxOi2hlnH+(P(O35Dz24xm| z7u_vy@YA$eInvLHWJh7`&Ob-&$$3lLqv(OdJety!L&q_8Zh$%Iw+FIq4zNkQCvz9c z4=v_Mey|hqNkEe46e`4C$c=6Hh3X4bg)Mw!&QD|i@3^krcp$9N=(t4yt_)ic9+G{; zhY1Q*rAz_%-L^={hNT#ixf84zf0}`V^&m@xp(j#Qef^&3U;=f$VwYVPkifTM_wkUskG-rm}Ngd{&LVC-Nfn$Pp)J_f7pyjXrdXO2#a)bUM7OLz+jy= zjRh{(xE*_zY>Ac*VN3F44lqla@7w*~{@5lE`b{7G-~%;hap&y->{NMjP&Taq^s{6| zbR7tA@?y>8&q_bwmsxxH>M{ZP;}UN6k@d^`k)d6UZJyXV&6vLTnH$c_W@Yt|&-?GP z;w9oucbtD(vRPqQ01q;68Ty|!0ddon*%>NdY!oa0Hhj<&UaS4PEoekSu{>(23sdJX zW6A5tvQiLE{_20>_`wbb2QwUZxPy`6JcYKFaXPg1S@r6xkYFn7iT%6h_86b!-a;Wp z)`_JR87@#J;jk$aS5QCMKdJfRLK#S2ztcK*?^|17W^B=#phyTZp8I8cqL!?)$(e=@ z>jps6MBeyZtp)CV92iw);s}JNByWYiT9#ub7m*<&~Q7^M{J5{%I1qZjKibeyR?GVU>|h0$#v6cS7iWpCW4e zYV7WNLqzeXJwCeR`pxuK)V@|mH~f!5EZb+f05+^c{HHNWj*7;Q&v84<@ql zicb9&0K2T~xgw-o*c16}l~2_lL@W3;+dO>GJQtY);>gD=7e7nhu*GqayIvcg0#M0v zZ{9?WAM%qu(xdc_Sl+7bZW!f{5g-0*KX)`AtZ#L++$!^e%Z{|Sy89haQsL9pEI%(e zH-B9;U)&N+>aHf5X}aOX{s#S#%y3ly`6in-*aq1(LzQILB9J%U$0pXi07&suc5b`u zflgV`@bhUK)LqvMd+cHhdA3KqbIDP`+cD$KGr0)lX38r~sFuK=V$W0S#9i0$qeVoQR#b&baOjhVROY} z|9)Ac_O#C!*D+6IE>`MXE4RaUOc$A3*h(PL@B1#nV@`;uyqY(D~Y0^DAKmnqUuQSq3k~y8)7q558ervzy zGEe1_>5dfqqwy-k9vIB=vw@Mv4wDwwo z@2W+ViNa~<9yIba$kK$%EH}lY{`0`?2;UdC#~fgK$-yd${WNCDCe_$9SVNYWMT5|! z0v-tqs5tvy9*k1GR<+x&1f?IF0=*ZkAVRTSs5o8$PG0?;^7KI{$c8~dA9WZUdioET zf4czL+)w)9PU0MF_BETW(uDJuQ1)wMIJ9#R>0xXV?u4Z?5p#2|{f0@~4;K;L) z{x;?`{8)K#tUoRk^5ZmHyBNLk`Nf)o)lEB$VbvB;-XUSBHSfukwS4e$o|0DMbc3Wr z&tJV$v%`n}FVxz|^;k10jZ#6Dgb95;2mjBboa`kx4`oH;=Y7n)zaBVYa^gsFV0<*v z%f4i#Rw)H43bwy8{<5Id`)^;Yl@nIk#nG^iiGf*iRb?0P z2bUt8|8Z_KQbYlGWY+`5=H2mG6B|XzF=Nmhxpc8$#2qURSQm*Hb8YT|h z*0*Uff^rU1Qg_lv|x+xpr3D;4~*?{`5O1g1L%XN<9?Gl z^&G_qBB4#@IQn2Kn%>wKdkl|u*qq1%byKBpFBQR;Baor3ZX=*)Qtww_L=35$r z7g6ZiW4_l&J`rk$!&9hks^i6jEKZ*qhXmF=S zKc9$K62FZ5lYKMOr89ZN97QC)Ummoyjsf>z(&&HUdg%Pa=1W_*Bp^f6%%-j(4iOTv z>H`YNK0tcBOb-!n`riD>${-DmCtMK(+V?`|zIy5a+B@S-7Q$7i4c;*J>4q1H6gf{=OpnzC!WKmnwol ze2=q&#A6~nW@~+a?IZy^_Kk_OYl(s3exb>}Y!{>terI@!Iv+AOMrVvY_2BZe?{_af z5dq2Q?o&Vb3?Vw__=d*12UHxLm=D>~2P`-*n`BJDz>V{dg30;51kJuCr!{9x*;&1l z7nutsT7{c`UQ+|j(SgqCEhVyFEGlm4B>;@d@7@@4>4C29R&+~DAbPiFxeOl*#_1;F zzT?LTV0esoV>>w*+3#coFm2`lNk?ryfgI;&#amZK83~~FU06$c+Y8hsd7FpwoY8Om zQNR3#4_+u|Jhvy0oY$=cXs2GOx#Gxr*31hscAqf(@WdT7 zOVo?AUwHvF8)53MhB+E+?`|IAS4FMgX|0>yo+xab+;?%GCw!rdueT(Su(eV^RhFj^ z7S7RpUQaQA8>%v6>a?D4@9BX@d-8N)SXxo*9nk|$w>N}qhynnwvqFuMpz;*5|QMZ4>aQ^yq&a-Fl%=S#Vtc=cqsIU``$%EazEKG5e0PuRH!~- z+wn68g~K%Ot6R>~Seep^2#WM>O|8#AEyi^m?2P>}E38kZUNOkg}OMrJi zB;D<wG z?+msQt;Nd!-0_9zO!@El9Jup<#UnzD-1kS_y>j=S6U^G&|4F0f1iA_S?R2$)xc=9` zOwoye!$t#!-0ik_Q=akN(02#;Q5#q8%%uB{DyG z^WgJXOICO&QTy^*nmZ`QZN=EJ#NleGYJCq=Ac||hy5s%M2eO{*dH9Yp2$Mr5+vLr1 zp^?_t-utZ`#BIww{b1}1B_ahU+F#iL;j#b8QceQ;RrSSpk4E9G{fmzei~8aQ*OJ}d z#6TEyRxVv3`Jt|Nvoo7wF8tIk1_OBq_%b~#6!Sa~X79=V5#F(dFN;A_sp&92*GVeCBQ&NUob8y~okk3RZa(zgT{;fn}4V3ECU>Soc-#PVj32Vyjp-!#-Cq zGGv7Qsn)C`z@t}jV_JcF zXghY|ZGWyB?%m*FU|0$S>tMPkV`|zsShuH|L7J=sbf4`XK1zVP9iOSeD}hj>%&tb; z>;m*5|D?_Q>{-C+NKp-h_svrZiP0hG>8-|6P2LYx zf`<~OGq|wNH1!Hs;t>$j`0uJJhXme$!|$T5q(gNikH!INUznN_ocgwF5BN8;es$#c zfmxP<=gThPnDp$q=&1@#c+$DzKzD?IPZL<*l;yjD>X=~Tm^Be!mW%pamMehwa(}Y~ zI&4AtPUx;ZWL|#ui0JXh@9g2zkVFQ>qAh%E$z)*X3`fhyTKi<0$Xt(!xP!lFC{pTD z3se5pgVrlY(?Z|nkn7bh?p04Ic^b^IH9O zgM04N<^zUucw+TQ_pX;`Q7uL1W7XbMz&0VOTf7~BwyS4he*QQp75x_&{x};_C5z4H zB)s8{Ttt-eKmhjaWBv2(Ik}&6?nIK2n>XIOA$YFlq$mE|{aJq{)E$NP8qap}dEtCu zR-rC=J=_q=`!Fn+55E?#Rc%n|fTK|(-aX}oRaAGxWU}?4TD0h$S6~R&vzOxVRhK9z5cTaXQkF!?fQJpCR+?6#E!FJj|dXFaEa2eQ$Vn*J$C0a3oAPc=By|ML_;f zj)grRi0GB3_Eh!8ZV;XbIk8gcimTS~Cay;cpmbl}oQQ}Iv=4r$JNWSs&>H!SG17a( zU|L=4i^B|fL#ONLoB1ewHk@7HFE)UIP%c{GdRrvQ90;9!TnH(B$Ce*d znZc1;_8n!<^no>`){~vd0*ah;fWg5V{I4q23C)JV$uIkFvtEwH(!GxwqfXfZQ}z$3 zU$0|vLj7sl$Y3FKKYSnkJ2?_;#~$2$an}~2s_Ew2vmzkd;v4PBFK+Phg}VAbI}c3T z_z`kpLPK` z_~m*ntnQ8abUH>C)#-}(hex$A;}zX@PfP(UpJDg*kO%|fNM&8=D;>P}mR?J9R~V>C zR9}j@dIW}Qzlsbw1;P51TIu3{5m?2^W%NeU0mqlSD@MOX;H8PgTbC~sKz17QIe$G% z7(Y*ag_6br@_+l&Qwb>9aZ*LN-2f<_)0Dju za6yTnt&av#xsaq$yLt42BkGRYmKIqUfVvz%O<98@sst~@X!-)IfBpJz&QJy1+D5ig zYeLaz)V0UbQ3Cc*-K02pEffdt%P_1=XFx!U)JD-c06qdln$vQ>f7yfO-KpFr5fglN zL&T9lpAETX_cEWhnPa_Nb*bcMdpOFRA?u@Hj*fp+oS&zd;flkv)a+;-T)%Vdx3_=? z+J*(22WXyv&U&`gs9JZFx{|YE*`7`Ix%NrT-`<568)NKpSWm*^_D&ZX(tgymymL)U z(G1U6Yp}gn(8bcX(jTT}$$UxW?>qi(JdmP#d9TuhHIAxZ(#_4v1{VgOQFU^EaQn7J znbR;Y)EOQ~a`&(TV#UO*#S%;8YK!TqUm(Ht4gQbbdhw`Hdm*!5)dJ*PWuK)N#bXku z?}^?o1%Qv_#MH+lAmgZ>1f8x0&}Y$pd+i?q!#jMnwx%kOEUn(N7*9fL_92q5sXzLu z)ry;5_X1wC9GUOY0XW;0@`ui(0M?7xOaBqQIeHF*0kverXbw! z^SkXJO_Bg#5A0n&Zte~5(d+NX&dqFM>FTCMU(Zt8pmw0Zw_wlKncpm6&TX8p+ z=!s?M?3&Q2l)*nuEHxfRo-m}BjrBz&A6$xKcT5cSgvy0)I6vO8fUDcDoB7(UAX&$E zw;EpjKHa1wb!*NWzW@B;Tj0kKEVR6)*EQ_|q&@0~NyXa00XM})n|W_&&HKXssoinN z<>@VNCyVcc7Nydy*ee6ym<(|UyRqezwH65=?!V!w(a5Wht=Vk06b6p zpki%Nzz_@BsmfPdJ&t)SwSTghHpQ+V_sP7ZdLG7KAuAJ5_J%4=5$9W5@O)o~yaDGT|TLVogjaG;)|gP6lQYR2;Wx5^n_2gD{Y;HiBG%# zmY)xYgOVy|_o7YUlEYAe@^BbDx^rfV9q%!b^tkxZv&{#}o|GAkKjnyxDh9LqibcY| zWrtz|c%3kJ_6rM){pE0at{}l9I0(KiJ<0frA`;h`Lq3tEoq&cuYtdB4OrhTPp=QRW zK#Y>>%Wd{98*IKdtFTup7_#@=%*^Dn$KLE~W-jZLKu>M*et{>(aFK|oTYZC}i8ifX}h7G&hoKJ@bJlBS^`Vnd2~%d0}RahrV#(ynT|7Ln1U$OqlHW zr2<8wnXNx9CBTut^_;@CvDmGPX4k1x5@AoIQxDaj5?Io7izDyY30P@=vc|e97Lz^7 z`}*DOK>T|z__Li5j!``v8PCDrXPEH6%0GpUkSnA1<(D5`ShYuM2p^pztmiV9bG=pu zWjj;)-nb>eW^uaUrv+ZvjU~-*ri1bDw<1MCT}}+f)Ngl+pGqAv3bZqxwZqrnQm$^N z@d)^FuauJaivu=xclWl0do_IP#>e$QTLf>yDSRnN{dD+_&SjK%h#;*f)x^?E4nSLl1^n1j= zL$U;3g7Oy&BWz()?%So<;6Rwt!Cd$X-`Abs>KQwV>!&RWR6E++=d~qV~Ksjg=4DzHYBDYdi;Q?@Dz=oK}P1YQ-uF zg7I~O(?t!8S%qjj-H_IA>*##$vzlBCH?A7z7w`Y~GLGIAn)+kquWcz%QMyLn2 zBJ5J*hGL+sJk#Uik3LwIqu^Dgu`1Xo=`idP>V(NnPDCEL9|Lm)TI!dV9I@9+nGQ`b`rrnATBZ z$y)9Vvktf~N;7)E=|drY$40y{Zf4zlkz{9F2g>Q4GGvEWYsPPoev8EZ9%a~E92JFg zQ;knl{7d1Yk2pMm`(gG&zwizIh{RYg|GjGw>Iog>@;V!H6S1dfr}R!8jl`zErTgAv z^T*mQ1ch9DbOPRI$ED6LT-VS*F3F`O@bme};({s{_*CrO7Bx!{6u&{bP`Ka-E9-hb zkCX&syP6Na)B*rK#^Pw)lcTZmGMV3QB`z?_;M>9JmT2s|OwIkb>18lcC&1opDGIHMad*wu_P6vp;tPw@U(GpsoWJy?C{l^;#lh>Xhw0ga>fFm^LNBcamhtsr+!Cs zoh$N&lYL)R_Wo4BW0}lHZSN+*d$-xaSabxICm$p`Gnoi$zp|VceBgy`zo8{_tBHe& zF|(!v?y;EHXwSjzOjpdT+rDz~YwUkL7(W=~%iw)~uPl1Q0N7>ejp=`M#VG0Q{4rT#yCy)#0AfP6;b466vLwES+*C?xN$eFxvTeK8<;Wmw7Hu} z411fFvizLS5Td<&roF?Sn7CCD3Hf*==6(7kOUffvjQ?}IaJxVh7PK>Beaq<#RIGAo z2NzAwn+5Q9FVFjLodMVrtpz>1LO)El zhbom6*CDR>Z>6m*C;XbAGuYV^06hkz; zev76=3px*`_D7tf#1v$c!>4)xEGeka7kDcQYp2<-@}Gq8a;Y5e@>ws8{?>$LLpLKf zL7UB%o$ZNDDfqJW$Ckoz&VfX3S9uuh(6sYTmI*6#?mv>0sQ`6nm6#q%YQXD_Mn#bl z01J-}uIJPC!TxHugb(~tg})SMq95J!!Yr~6ZgE+b!0uil2J1>)m~rAHL&>Nb%r`Bq zH4oB+KW7_{RR$PgXVkSUQ{zIh<=c~wUM7WNnJu+tx#sx3?GjyF2SpgxK08;{*>N7v zMe?z{+75)oI2R=sSzKpu*sC^lEW+7(7!mYVAZ+feNK&DI_A!nDB=L zzkwJ9I9Nn#F5K>feH^vrwN@&HBXrBrO?pqm#QNnD_I=Iv47m`3h3oI%ITUURFTG+daQR#g-6Q;@Nk>m$U4!>! z-SIhFUYmjODjlBx%wPPg_Yv=PQ>Rms#Q%TW3gLGOsC2O3?D4ApBpz7Uzj4}y0$r?k zuj|sRUO#CupjxnYt7njkfx$>(hbjl-A=4EW`C9p#j9xO-0}A@dH+{*QEoC6Yv?hW zEXc(E-6!F9RgZ#`3%X8p3X!-U*3Vhq*A_A-PIJF_gZm1Fzf&X*l)>_EJ9d9@Ukk;K z_TPPNTj=6-?d`|0FzDQ&8)lrQkCoU>7O>;F9!KgcIcb7{n9}D*7GaO$p~39I45Mlw z#vPhiKu1~uJIpLc_XM4xpd3Tmc2hhQ&OQHgN81?&NMG#y*5Cu3OFn&A%h$)&GcJC8 ze-8Ii}^XuX6^Bv&#VU-_3lVq6XxjzoDd;d3VG z*;j4<+M}@tvM-jTW4y7>UuC@A#xXDrOE{Ox5eo;;r?a!(|kJXHUy3#~X|M<_k?^(nvP2PLMGzG5b z+;xu7T{kiH9b+)|jDPBb8l3}tw-b19r>zuSih>7;IyOE7@tA(gHKr0gS0egPw(D|P z0Jcp!&B8Dk1*hwtPZxX&!0hH{%zypt^FjI2gWp zk5k7UYaJm!qH*Lr%rH$o;f42@XlvX&{Y5kxhO8L}KYJJqUAalAcdV?jv07RmX0JS~ zi5Mn%c?+L|3)8bcC-s9Qjup2DVnQ(Wy5)tqjC`o57v8t-sS62=VU(MlxUaXxT18(P zK$86M3#B2kSa+@t<pTw4)H%yvDFs18k=~m^-LcT9&q1z}FA^#g)OvqakHwM` zrETBK-c;fgM{+8~u zpWzwUBcT$$<@oE40tukh?pyqySeOZMwfLDnQoW>jEpT&RBN?em;|y5PW7K zWU$~^0%1hZEnZo3c#hBzL#FSH4IU+Q@hw47#9xw4@=nL*aBsZleOywEfD^*z$rajE07rL|mUu+ZX?O#|xU|j@^|> zRK>#iP6rSDOu(pDxbM1?mt*7Wfi_o9UQc0vUP_WTKjsAOmf$ zo-t5_BP}LMwDcNKP49R0eLqudxJ27T+%61uss7rVvrEGIS`1wJ-g#n~GQm*>=}FkV zH}Aik>Met`5{WAIc<;>5$nY4Z3@@xi@rJI(i70sQ(6DHmuRnB8PCCix=7R-ddCIM}WZ+fRJ7 z%NWG_hvpCWwv+;U0@_c4^!Hwm;Y`(WqOuFlqf3WCiFP6eIyHW>C|((txeAbdjhlB1Hw z1`D+&uMZ@aLe9z5Xg@o1OnP-G`tU&j9IX1r^J~%y8+g&5q6osU{TrRnK3>d(ML$Xk z)CSyPxBhL@Vcf4K9=syFs_PEza$0uAEUREuQN`(NkK-Vga-L{76o6Hl|A)a#+xPj#nAQgC>GAC!*90P3Q}RAy=iZgjxB)j~Bu{pBN-!(XV-al5Chlqkug5 z$6JY*pu}cqqwWP5Do(5)nXNrn{!4IJ{|93hf2jWXV=WJl9xVBEc6$_`BYkLLOc1rl z@2|f$x?S+~g3_dpcOLhHn)q2;k4mazszlYI>v#{|7vu7wB2`Q1Ir?6bYsMSPsl64= zl4k`&1ncR_K7~QXGRDAhveU4>DC6GiI8nG?5_zcl3GNR!b3JBrlM&{hcccD?c} zlpZMg{3p*JGA8q&r478luiBUW;w^tD8(6FDJ&=f{S8dA_QrN+Vrt1qYwp=iump9!v zeca(|mPc15hMchFOJDaWmWuEm5m5BA;S_A7{BFe7>JFtI-6213e+tHaR9<$G&A{5z ze{>4mkAnPp3w#goej?TN_l)$-De&?@1yzHmE>=j}$*68i;Bih z{Yp5|R1v|@VvKG4S?M?43c&I%nFnrq8Dk7{eH5&W8F0-pYzrCd!terd=ffQ7@Xp@Q z_cwcZ@8sn-x31nxhqHYZCr*;!y>nMeJRU^i`XEgkvodEaCZE){W@CZ-#9qAYKa1y+ z)P4?01W!6Z;%NO0#l*h*5RGk ztC83tnu7;V@IH4ow>7evcPSX(<8|Hej4=20eihbKE(Qw16H=ZPajVXcAi?ti=1;2B21!Z|~ z-Xb~c>5K+C{DxFcLPZ{xbjLTf>CmA=6FUN18#G9E)KBq(79BAAcP!>@=S%n-JRf1Ee*ut9c5Rs}8X_)v?sdD`j&h}h$llx9t}k-0`< z@I@AFfJJeuuv32_q!vb!s_ak!0|8sz;-q~-9(#~VnV=J>h+%Lu=y3wXO}Yy1C{6G& z^9FwrBA^RK6_G7CCbcFM*v~m3hS@j~hFL8Dni!6Jj1dDR%Ex##BrVVnAr7N#DPyEj z{l2=vzzV&gzx87++5jB95B^Z*cpR0HUNqX)S40Yu{P~ycb%7e!RFRsyE~x6G{vl7M z3-Z2iH)a&-qZbT*s%>X=5rx#hr{$S;2vhkUaqW&ip!b+Cw(BxNPkZe@NxQBR-)ai% ztu`8gi(Tm>Y4@qYj3Zyo^G<3Y0A5QLBL&1dKHk>DZ2)8hg>OX086&5|Aul*fG>~b- zYhIThhUi4L@YlsALvUS``w_Xu)qNMG5msjJd$P&6#^z|v=hJz~8A}j#xBJM0LScH}}<(hDRDmsdn_EYh^bv#6rK8Dz=-D|5By1koFO= zRQla~T)hT(o~3F;ZD@-;3*{_?3~j;Bx<}v72IzyhM=IonzWP94g`F)uMIZT%xbFL( zwng_#lF^-ML$st@)cZ<}M4MT_*4nv^IUP1INjg%_ zX~6~_hAL;u-4;f3d46d|)FQ~J&{=m^LIL$lnpH<-$^sDJ$F;&EhU_B0mswV@AV#jG zL*y!AfDzA7a5ss9)CxXMne)`ZlAof8cwZJhUg{G5b%qD1m9`vF6fs2NjvZ@-fDL7J z3bUPty67iU@5or65Lno)-yh#3fWlmPGb#fIusOz9)ytub%0J(i99K32+;5a@h5g*X zNVK$sZkIi(%D3*A*0Kce7(C9>``LrhhHpQq=GYK$%Hp3-AVoIoP4s+MtWmon6_u^2 zDfn}lgudL?0!fUpMXYAigCVb0$%SD-boGxPNw+&dCpIM76Qh+tg$p~c&?N(8mj3U~ zqg`7tZPYCGCqx@f>5o-BjMT)>S6xpT{jCOMgmyUJll>yhUGLQMq}nB(%UO7PK=X^Z zVy}2J4gWlP@|^l|j+}rr?~Kuf&=J6xamK5GFcmb-pn7h8LJFkx@>TClNTH4(S*bvM zYOq=5Zb7%ngzn@}zCUA5jn>Vm@|UIr!AN=Pl((NEVmw)S#cW9fT-ePhKE^pkm~u)h zE;N2iFl;iocK#VR(q#V)MXJP6g}bw|!gF<$p8O?Yd`uol3%I0KtgE9&)bN_$Qw+5@ zAA2$EuMTdIi@h#yGe=i8GetXU)WI!t^E{gd#?R0qCQDA`nB_H}ZTwnm!N{l-q zg3Z9Cviv$ZpsKNpr_P8S7I;S_*H;Q~FfF^?P638n=Ck#%B_Qr?XgyqJjmX*JRa+ z!&`qb`KPMLC@{+85dJzR#dW>%LTrxHXFYOzgXM+#HNKHd$$Wv_ZmUyrmW{@+kMzZ!3!d0d!M?KP)!P z0rC9QuKeAjk6@38CeK$!ko5KZ{c<0C-FP?=bX~&+h`sIfFY{MI=1mW(aRgC|=22~G zM!>bPip50D2w9LX?i=HLHX23^(&Fo+Vtn+W1ahPzi*-WK$z*y^;L>}LCl=ie00N}0<4I)ZYT(oBM+Jg zn{HFEx-# zJ?@%<1xUP5&lv5-lNe$+1+kk8Y=AY#*?*ms0(d{a;oq`=ub&w%FXG14 z5U9zeeSKI9DLO5j>ljr7q-V_Ui#e$vY-pV9l&uQ-tE1xTZ?6Ih0(1H}b{WBMIvShD zS>))P-~Tw$8JG;H7m-8hT*C9=`l_h@{)8*eK`7nRu5T2Is5trTJ27%aG()Q2fpZY* zS^7I-Wrz?}>#A}S$MX66Ws`4*2>w~$uSO}D12`!7@jrZfM1WrHnkl$I_luVfnWD|2 zo&RCI3$vxKr8y$T(*+0k+M?cpU>yc8GvJFJ_p1Atp+eg<@)=c8bS^=xKfgg3q)-eH zbrfXKQ{y;N`*uA*BKmOQdXgn_WqMhEqvkj`*?hRGuE_{k4{C;RHyDBDIUU;MeQ~h; zTA{EcUJleg))N1C{TRAM%I-=Ta11;q5vw8(qy_g{_S2J?lu)+%+n(&KrN*|cVa1i8Um zoCCk=H)qJ#bkSPEihuK>E;5aOR)}*@t#)tawwMA4?7pC*_(%f9+};0;bHss_a}zf7 zQGy)HCB+LiD0L{E73YBeK9lCT3Nv)~3TUA9H$%eu!w~0Sip^JM;te(U{bg@>8b@8~ z7T!!8SKCfF*Im;E?{&Pd{)ZOHjV99tB7h`SsY{C}g|4=%{SQsOR1fvY>mjyZj8t`j z5~%w}muG>Z0$ABtP`v3Uf!a-*0&Kzx--=NQG019z9}!b8%`fcH7o zXI3_5)RoNjcALo)I4LNQ+z_(?CO>vV_4<#aApMz9#qSWPte#YSen%5T?~wN$#rNS# z1roY%@|8ePBk^2stq}Ml->0clD~z_jylWi=hM@oaRPf@O0U-Njx#>G%gdDFhYw}j= zgYh?yhXZ!mkb33+IPyQa6=wg87V%403+XAEAcp_X!9zRV#^NwRv{6$_Iw&iM#H9Ym zL9&X-V!(50V5@D=#v;!Qz~OC_$1j5(tUmhGxvq5t^J!~i29C@{cL~D2x6B) zHcw|TAyyXwTIEqjB=9>#zso`&g#8&bJNMoJ`O}=qHT~-VXq~(~Bj;p5%D9wk*n|wo zl^8?nmn)L|Hr|H<)e*!Z!}SIwz0+S zw;Jf~|L5R$75T+oPF)bsJRDBruK~_YBvs=ay}Le8AZ{dtINnBnvS2nrw;nQgXc`HD z!?yN1ZlC3lpo+WfWTqTwUcAR?`dJQ03{w&|XswX^>T*IiZQWU5>_>mh}jGdpQ+5FoH6xPQ+sw?{0+ zP6^ZO9)PRO{_*2RTcptQ>G<;iGT_Ilf43`x3^ipJo_u<4nK+}IHz|lIB8C#4>!;dh zh>JBwJzBF0NNv6M$$Y*oveS%

    %Qrdr4BVGK_}c?NPA<@t68QBi=+XiO~>ca6UP8 zrOp)n$ZewZ|7U{ujN1cqyN$u?pF@7tMq;Qi&>=N7h!3SZ&GvN$^8xe0Rpo*?HE=O7 zKlnd{6vsl6vNe!-dp5PLmlkU4OZRz{Z;B?=5B<|6(E&^JTgQLMYN6mGb{mRc=@272 zT=Yv;3z*FesDBVr17Smqf)m+_|Hsiw%KSpIWHGc(67EBL+vNW^s1af=RM*r*?EFeG zcAQ-Q$3gVVN|wrAE0k0;eI;bt6e#-Xhj-|kAxqQIZK*;|^o}En^LN?Kil7(N&To}3$bi@46<>8qj8S5{0$EL)E%0gmuE(|^j}}MY z%zEViCd!l+uPo;MCYY38nW($-i^!j!dreeR4pHo`urb{EMUa`FWoEc2kJ6%Iv~JER zAa!-e7p$iEy8ZU(j9@=Nag-yK!yi~d>OHS0w{cx$@BTUc-hu)k%VmAXRI7??TbFX# zzbc>=r3}kFZc%WvF@wWI!VoD+UvRCKHwQHt8Agl6>Zpp!d<)5aBPw8bDvQa4kd+hB zRoI^$s09yeP;3h!3!O=6J%4tzOaD8K_Vx_%gB7jy)m3d&?b@NRVFl;{q;@U;au``2SANm8XNV$;*gGA4j)SnJXIdra^^n5T4yq(eHFV@F?XN^jHSkAr z<}{}Bfan?Iq;+KcA#pHxccM+OgWw`&cO)cK4V|BOep%p>9ulnZ?@OxJ16P7MYX^wB zNT!V5E~Z%q9e$?#nCYqj@R`#~)*#&_)S6MG`{o}*zj_N_3m@zf>y*S!kWk7YCI$BQ zjf;9{b8Y9x+am@*GONXF(M}baR}Dr#`$G>hmVFbrw&+oIKjr5h=YK@UhgeeF1_vq+ zJDwfqPKioRr>fiSb0e|32DyfOC6vD6wr^Of4Gh!YNQJv> z93bG{B~36T(E#%FM+#N<)sgp>f2n)BCEzhDFUo!_4x*_zQ~Dl@qy6#D?|tkJz)d*u zQf9U>SQDN5o0MaW%pYdllWx%i52W*=vnut#KNF9IG8;YguPF6V*{mSAextO*l9~ye z`kLpRK+S|sTfP6@Lt_l0d$W`+^6*nRme)d5hYis0DJzM~?-W4db_R!Ch!k+z9Tdko zn!A&G?ufNMn$7qaHR)rBU>g+$&H*#~@=NBQ>d0iB&hI(j1(*3I-&9XytuaLQ>= zMni7v_fHepz*AmVkK3gJXqEI(lQ8KKuts@9=^T#$iYCFX^amb6dxUqrNw=O6-dMi! z|Gc7vR26Tonknf3J-^g|2ho9JIh25|Om@~iXwU&R zwi08{Ckg0ZO~Wivmjx(!FqYQ~X`}gHc#op44!FZ29OKt+gJ_35x3C6%5X3egUw2&} zS!HivVT~H-24Of{R!15wu6uT~6zQW7ZE?M=7y9VkD<>PiCV=v4KI+n_JAlBPr|uVD zYJ%}{gXe=?nxMqFV~8S887QypYI-affvWKID9XS1ewE~@e9oFEGJZ2(@CRsu`ootLu7*W}ih_HroIUmK@Wuh=(9wi1~|3wgJk}TX6^vv_)5wsBbpanV__z z6NJe!LvTv%es-~gJ`!K;%9#)6N1<_NuPVQsHw31h z_xp;~wSd^Fmvz!>3Lq}wU-3xf5aQX~$eS6IL*zWAWW3M-DP2UvfmYTifvN7viB5Kq z+gLQV^obEfKamKNnr1}XHAQhEYz}~`X(DGn#sGBYP<>d7F+g#v*Aou%fUHlKC0~3nL?aZj=Arb4sLJ*WYaqQL_4Lb9bNgtE0yq^3fZq8c2(@()eir0T^CfuBcWKMb%eK zNkT6QA-nyXW}{^yAbg5pJv>Gp$czrpT_LCgD^g>zQCeAaHBK=zTg4cVuzfi0;K7M_ z56H<3j~oMB%BG}oudKkoqYpC2#g)MOCOLwFx-dF6-S#)hy`M06@?6F!c zwWq|ygCCSMOU@wwT$6ajJ3T;?L!O;Iu7}pwUWHq4I0Fzub|R)xANXiBTpRkShn{|* z7>$jQ1I+f;xz!zVfY77J7aAjnyly9UQ4@^-_0O;f{l`Y&Q%>TInI0o_^@4v_cC{7g z$XNUMq}d9n3oT#cueL&uK6*3{oG}8E&q~TwrIkS)rRaYgg^6652*S_qa}iv4@p;G= z88EM7mi(sRQCbt3EC&J2Zp;xci=JNdqjl4jUELhxLi3$}PKTch1 ziEQCpJU9|4)H))>Rz-y+tdl= zJFnatvNVX4E*ctFy4Q)dCLg%g@z=dM)}4hTIJQxF_o87xA;oj6PnO{s!R&z*SEXS; zu_t0rd&Ec$7zg=^`IxAI_~3eRoFg~sAdjEXYQWVhq2NDMtQv5|5f!fy##zpp0{=;^ zzj>$C(Ya#_ zZ_??G_0Scx-j_6Q@HvnT^@eJrExFWa#`u8^oHx zY?1ZH5ga6zsqWJ2psHsSL;f+V1jZxzpCh(~!SvegvooUXsP(aM+329U~z5 zA~Mw=1_RV138irk`~w#mkM^>nr(r#^yB0@4zC!bV92{(C4j!V_1V0>BOWhA?f>wpj z-M(oJG-#|kjr(XJ_o&W?Gf)dyS|9tDSY!q|jcW$N`8SF4sdCojsT%}> z!f28KjV+okPm|Za2!TP>e1i6Mh$6J+*Io`a60rELBRh@oY{OYqTb67FK@58GI`gk_x${h3u^aY~SzmpdE*y zT-jMJ@cFIyHRW|0q}>14Y=cV@?cI8}G%rB|;wxCP3Oke#)t>O~7(Vy!-Lwu;^fUmg zjz^~~H^k9>uA3XBQKUfj5!dw*1vW(O&%2@X&m5(5dg~1**a4^OBL|+on&_K!%;@Z1Gn_@=>fK zAj=$FwBdhvQc@r2Na%ST&#^&S`M16nCK@9hvXL5ZktHJEm#|-TTcn8b&~Vn8mK3_K z?<9p+y@N}AqJP+^G{AgMu4R|$8Zqfe$woTaETQDz!6&mzYDjID=bG?ufF7T^>!RY# z4%&y`Wa~WVMd`!=aqDRw6n3p>wSmkGtZ)Ra-qO)PVFOblhu^ax$B_fx*6}Zds}=`9 zgiRUk&3I^+&K^dN+nT;-;RfNE=sTN}cQ=SwV#4VT6Jg}1=ls_ACw@OB-)9L@Iff*D z7`-7HOCav$p0E}=DiG~oh6oJ$Xu9o5Qq8yqGTh*lc2(gAVzMrB>;ELt=($dV%?5Uq z`A1{pxVI57&99r|yeWf<0{v)bNQF^kbnZW?*xy76tveAEKNQiW1wg=CPe9mOR?C_1 zx}bmJozP6LF5(~|l!(c2g2j8!=lR%ZP+ktPQSdNc;cVLbo%x$SD2EWqY13$fgJBd{UmaCUIs2;D5Ejk(8Wie8DFbaYnPCTJ9uo!_tF0)pR4Sa<}K z(dbF39Bykn;7*)f;4&5h_PN+x(*Og=s@K=u6+VQ|x2hy*ShUdfxs#q!Zl>s2LI)uw zoflYZq_KJw2%(v;onxPKwb8RPP0Mf7oq%5YMym_a5YZBR{l7iqM<3LV%^RsRgGJ@p zw3G&1mt~qry}@dP{xY#$G7ymh6`duP*X}8z;Jule#voj;@vHx}M(G0feRV8$T#XTj zWOT5DyBcZ^`gr`ptPJ>lFT_J<#~kriuSY28Xo66TspWmGB-qKx+ywab&IsACnRd_x z$6snDr8tVCrKD|b#}QHB?EQ5n=D8tQN%35cbPxk8fvo{wg``nU7G$u<(Ez>FGl%M$ zSOA|i-=bC%3*rf6Ic)#M5d??zoSS>f2R`h%@@_rlLvi0S1zzwtgN%^;te$RNFl9CA z{G?kK`NvPX->8!ZJ9m@h`=S`YK;l6h37G~8c#_|9bjS#e6O&rkwycnf>n!yT4Ff>x zDOq(eXogB(FvxEeK_ryTkXCoY2*fsI#nA9PBpjN{xN$QU5%LZlyLcyE6Xo)dR2A+C zqe;d7`H?$1s4LO4ZNmV9a6bH`2X%n9XAV04ofksN?KbZ_s&oL0XP2(sjwl#k$SB$I z7X{Zz`1wR*#1PH+4gRN(RL}rBtA*=;9i3y37Ss++QJd#s+{h-IEY`zgqQM?z7TlziQXLb zg{b>N()MRc1MvGn8o@#9Gf^OH6yY3oiUz0gy_Q7A|2~jiJTODcB6nw*UrPcn!_Up% z=cEvI=#I?*j!Ja}5+CNIfO6S<&6;&|(Z#kxHPYa0hM_pSXRYJTU6X!^JWsy^%x4Jcn61a1GDBtg~Fxcv7RVpX2AOqUD zY@8!m%PB+K$L2t>H8Sl_wiSwx<#+JxF-P2ugrZ^xQ#8Nm`|^yvDKMJUsjb2B`!lt& zw0$)Y5EpBw`9T#}4}boht|5;quf8q!v@-$fDb~s7_P!APTCRM_Rr^F})j#$Am98~- zM9$9sbw(c0=zEA>^;AP+cRn&-R1gO%K1^S`wj@C-ZGpivd2yuoFh2R#feT=`bTl@H z+8p@UaR}pxXq-JA2M&1vvlO{@!7tX}Nlu{qsX}YS*HL$i7np$gKYH$w@&+LG_xc|H z{$HZ%n?JX@e+qyI_AwbwLlKlj6?Qe~2P+7@lRv&HBM&sbo|G$l&I}CNB>X0S=^^ve z>URz3AmFl3uEO|L5!s^L6URAKkP&^1_vM%q5Y{iCc(g48T3>c_JxP{EZd`}sC(Lbu z`8&0ZgF+Kk0q#QuEd^LfBlml%o1)N&jRtMI6Gk%$k zLI|%%9Zzo*0);=dmy~x1py6um-EdqdWRb43jk1$Pvr6<5q#V{j{iMQRProQ|`|PPd zrp62u9N6001x>+L4A=T*rU`O1(|rB}GXVj|pYLXJ83V(ct$DUD@#l)y>&Y@*vM8o# zgI)W%9WtVz)YdXn0q^-Z2fohYeupzRjrIIkfgxkXA8_v|V9qGCmNd@fdIIt?kZvi&=P6|ewD0mubbvE{dg6ka4*vON zOgOqB0#=d@E-<|m0qJpvKOcQ5f?&u`u7`pK;00mMl$=fxW{WlY=d)ASr^(>KLUW8eL;~;6sT&58Fiz^l-|93lUc&_}?*r zL#LG~)7~;5g@r6ZKROdYhBqcFT_;C$#nE1`R;fW?LWvW(h!d#W^IWDZhsYwTAfWUi z1l_`t{F;%DfcnC>&hTnUVA)ta68TXA?etqL*6$I(nN;VD!I6DJ@C;pIBMTqU_4U^1 z(6j-`6=!4)O=I+{%@j@mCcHz9R73Vr3?KN2B6mDIg-Wo_NqN0ZswF)lHc!+}GX$P0I6?!B? z+2?4Yq>dQ6=S0IQOwi4{&cj2&%s{^|T&3{0GKjg@XY4$phFXVH9?|*Qf)qEE$<{bU z@UgnrD#cg?L?q6Ta2E5U^F*0?M>lo!`M#0Nkbx2S*CKXgpGFU4u+s3Oa(rGjQ6yc{ zp$*#mC^%Vmr4cu=A$HYR8hqRIE52`S1-xJUx#Im*1AM2Udv%tcfbK=Ax-IhR0xj*% z8l_wfAR$;Yua4^l?#5iaS47RgGQG?&1LXoSE7^MS1Nj1>Hr`QMDAo?p9N!vwa2|kz z1UlXN3jn#%gX;>(x`6GU{TaVf2_)w*$A0v@1o-JjQ`2$F3|x6b?wxpKkr>nTq1RY) zk>GYMxY@aa+aKPPLgw) zHRPNHlqevIWC@CjI0%RcW<->r0xBv91{6hRp@3O}1VK?iP(f4#Bq*Y%pV#O4s*dmX z{c&%dx^?Q-J5=$Ty=V9C)!nPtUcFMI4HumoZ;=&l^E}Jxtn7sQSQ>8m4J)Dk!A6Hd zW(}~~e=$aBQ5lYE(DysGxWVVK7boKRY_Vyyuwa7`GtjsHxLe!POWu$Wudx&_hr#y> zucq`{VBpR@B0ZA|s3;uMD6Xju>2k(jn3oihQHs@95wn*^)j|JvYS* z2Ba(B^M2Qd{kUyWW0wNq589j{{%MwcHT|sn((E zpRMp~x3P7ysReMY6N^aE=D?jF_A9GavxB*&SEJY?52yD3(?)NeDV?h^htTPutk0o3cv>Ww(<{mg zCIo@v@b6U~<=Byj8S`S$iW z1!$(dU42iD8E?6>ZaHz(7oy~BBwlC`>+4`-pnsq`Y&;bnf2eGkmKQEG`C`}+H>{do>n5p(8RDr8XUkWC<(D37BXMb*%km-KdH9p8 zFv+Sr^PrE`Dz|@GZ?_v--lLg4V+N3WwU%Yo!)bDW%11ui`_r_iWf4oInzm5e^GW7% zuO6z^`aL_{s|O~_-Gf87ZDG@n+;I*BYy3v|VgVmT1S{{v=EHoYsZw?Uyb-F4Tjhku0xgWNjSyWcOixjv0#J zgyT;_PkxnM&)e2pM_&6XKv%eBnx=o5KGfr}CMZZm#75P6!oj&OCfUwf_>neQTo5@* zGx8k&x>~!77BLU$$#} zcT>bWt-brl+!W!8cjW3$kr0S_^nAvh@WZ&*?EM((V~In7I`S3yw$Naj@^T}$F?2Ba zJ~~jT4P4KcC}o#S;Y%;W<^diH>_-l*%g!o5c_{D0J!c9V9}a#J&XC8l`%R|?cvj*{ z>f1T@Wn1Xd_aCt=*MlGz0h4P_wBek;-fn3|Ik@u8w^Dh%0dDKh-OJp=0|F0|gc+X7 zfvZDj3QPI6)Dy7wkZqJnrNLRfdzr~@!$Y`f!LYyj=W5^rW`GC=pOp2B;}0Y+~( zJ;@>bJyn6nJ#OqahLYiv)zow+xRUX7``Sr9Y%X7aRHs%AyBfa?JkxT9O&CFc?V28( z+Fl$W@yrJ9N`Jmw%0!0xgFFkvFN|^Jt&`?2=JoK(O+Dd*$BFfB{z0tLk}6ET>%85X zWr5N1V!U@g5O(U?+0Ifqb2#>m`&8ZsZG7gq`}0<^1Kip!aC9>fcipMe8`%HM6dum` z#^&7cfEo>ty9U=D(ew&IOjtx7JN>$ze2!iwyN=%&<#Ze*-`x_}5wdNWHotAV(pL#< z=(ZAN-GO9w zPadqPJ$=Z=iwEA7)z+Ph2S_SfTi>Xtg0pP5W`Yz|fL$vx)i%Hk&PMoUP)y9=m&A67 zwI*gr+Ehbtt8M_9mDkvGy!65Swz=7USAFd5OODpxJ z9{*E>oV{bm`zX-G4HCPoe@ZyH;hHCjjAPYS@F}92du_25Sn4(X@;;@B>%OP>_>XhK z$0x(w2P!zA_$L2i#!n8+ynf`|kwsm&@G4e?epVM$2NLEaHrSy3LR9O*Ehk95+EC#n zwE_&dweJj$T0vib>GH6tGt8Z%WJ=dJyh8EjxL)2JaggAES(+@3jh&lxz^cW~a|5kv{iUL67<|CrG6 z?lC`j#A_`$)ny5sJA0Q3yNI-Zjil9F4c?HoKY2VvLI9E!o61&;3t-o(>TG{{~-@>ZiOJw9! z?YY5(P0tG5z)XC$x^L0}3I`2t5r}!+ z_09BB)-aMZNO%8)IWUFh@7g+~07r^ve+WJzkx4?%29(L|EXnXx^S1iiU7j!r|y6 zM+1N@Cw38tiDOQR>)IUQIXNbSInohm_nkT=A|25#?9%4*b%fuvskP+t6+=)tx^Mlt z%Z7NfZzP2^%N+Q`s&1}(CJ7@Cc2!t(NMdUiQGc+O8Z+ zlSjjwK^^+Nj$m5UOoRZM!M!yBgI$-+@O+VF&bnuAz!2qC`F7YAwhi4sT-|1i**7!I zCSI~Ytao4t*_jEly8nn~>Y-7Z&;8um3*JVK~><+UjxIJwS2RvBH6n-f~ zpYw`mn|>+dWs_UUp7tJK!soAjVa^fk%PM<3mmINivipm;y*;>y4ZQhcXAkYVTP)^` zHBq>h(}|aDhU~$e(?Z%bMJ}&>Kiy2&FM9`SuBlpR!-{Q`yPHL{VS(k%>`<#cG8lil zF1peLtklI**o3vfi*;(Pun^&olTT{CQtb-O2P;2YZZTX; z=<8+|F&e|-XZlnoCL&JwO34xJSsgel7`18pO>>xI-Tq`CR|k*1!M)lySAw42%NDoN zE?Q?p?DUhCUNVE#A$HCMfML3Oj4hANfzxi^>c(m!ex{zW`m8tw2g&k$j4F$?SMDm| zwtDJNStmX6X2mG&*h8~j=dZZKwf2eObXOLX3Ytah*5q4ZH4s=W*JYMP!_*mA9lpRlDSg{05eu2;xQEoST+S)A2NRn z^{@E9trIVf=^;CtoQG_`J=}6|=4^2?g^=h2!YvEpux{F>&RtFvhHOd(Z}`jLgBL2# zEW!Y3*DWuboM6LMHjLjKi0g7E_SlNG^+Y`0DaS+41H535%1ag@EhAL!BHdgh>|iH( zy;PD^b-}Vb-Q*y%E%sfvlAe%JgbfxY7tan6@?JHaUQk03+-Hl`=?g6(XD>x(^0_6P z2v;}Dyi3?YR;?I|kF!DZtoHdQo&jiK%)3=l#vX;hDAAEg0LyPQy|cI|578$_X6+aS z&_0Ae__&4>?9*lR|4v}t@!b{Ldc^ZP@h*uw5o%bz&fbTc%^WW{HK}{n*dzJNVD2>~ zG9HTBremSbiYwD%%1`RCV)%lVm#y1MEV22-XLG@mh?g;751cdy{V4ypthag4uRgJ0 zyW1>TjQ8WP1`+S@TxnEw-GC`(ZOqb@6c>UE_C`$H-^Jiw>WitXwM4wGt<2R5XGh43 zwCJffG6s4dxqX}1L?DL$Xnu|Z2}{=nnU6LZp=4zrlL3)mCRMXI{V0_mGfeNLocXX4 zIE7z!v`eT$$uWPrk}|>`*`G@_uF%9y>Z$`?$7SH!mj&(YU2O2{9m~Sgc0KGB`P4Yd zNX(O0SDKI`3mmyb4XQF7_|`b|K>O+ncpUw5SoNzroLf@yPi<5J7CoD>?}A#8DEBN$ z_KgTko*8t^e{F$R?ap!?C)NcXImMi#udHyBZ~7H8c57f;FYtYvffL-`mw2d>(4%fY zRUZ^7wgcwJ$+PMK8qk;dwlw50GagH5HE*CY!&DFL!^aqa+cv%~Jl)ptxF z=gpD#9LF{B+}_7}aiu=+$;+;5>69J>-bkwsCgS;a*gk&HX2OM$=^^(6h;{H+=kSk% zla^R#z#B`KqK0=pE27q}v4Bk9(6hN?Dqz`U+#UGY8DcUrEnd}XVcv7;hsP?kVd)il z`Mk~>T4sN3^)V)WY`V{MEvbQ!n-=+~W=Z73gc=Vd{}jcx!UbL7UsmA#{@$rA-ejER z&{Cd0}Z!!H$9#B;=fsvn05>=Lg!rcT(`Ty0!K4SC!ko_=xMOVR|Czxy2bG$i!h z&tY3$uV94W^fr$b1r)5&yOQ2_hyhg6eN5MKkl=NF5XJ3L%rS$-pAmC3%jRa$TMr$f{yX1I z76)CR9ZJ`*Ly7evu5?+9*$`Ix>VZ0x zEXR7OO~`}xVZXV!Z=SGL>Vftu5lhVb-mtp+oFLfMr~Z8SeT-b9zjo#I?RuybVQd=r z)*G}shBoqT5QNcD-TFBRONf!W+epo`2Vw)y=4fe3x^i>pVEQVDUqEUsue&_!N2NLqdBsR zX}w-`NFHJ~YkGEiD#QLW_My{ON^tKaBWa5b1(_NJq4dzbxpV(~X z0aoJME?j-f39?MnCDw(C@VYvvn`xUFTzJyvb#RL%Hs5?%G3;mtZ`h79E37hx7^Mdp zvc&z|$vNC|^QQ$Gw5K-q_Hn>caZIe0fdm9pGIH+f=D^y=!S|1`xI&uj*4jb>b*lI( zP80I`MALw1cC09BKMVIAc3{TPOWGWaZEjfPEUb8SU0#u7QA>O*KM(VpU) zF_U}fLFjFJ*2ok1A#OOh#8C$r%KQT&2|E@YZ@lJ40;R1tP4(=UaWtgVr>jy_F~ zN0-pwKDLs>wQ5ifg4g~;QvVE)470y4*YUePnU;JfTNJKr=DP`r5SM{kEb&Njpd_I1d^ zlHeHz;m}p!AX@7Xy4xOX#w0hUXW64-!|}lDqXK9mZyeq-DgY~#Gb=6=?SRY_Mn^Sc zxaU_cZ)#`>-rxIPtR&iuOb@R`>sjE(i`Pb^!YwezQm_9sCEaXY_o} z^LXKdJH6VkET+j!TwiR$zfY6(*L~%0KRiut=J(ESNFmDQA3x&bu+0)qkBilR*OdfD z(G|f$uVoON4h(G=mBAPGVqnB*h5A|ejuhe9+6d)4kB2(^U^&D)kUyuXvJt7OSuPu|jWIV_^ru~|Sv(|&glCWNe;{z7aif&OMN3%Z&QBE&u)#pLAE*ApHLK!1dp>%i+oi%r zj8+F7!@(Mpcy+>le~qV+XxrZ!JgdND3mwADDk=op%x`=auS9`W0nNf;boN*sq{44O zZ;#4fq@*qm{qO~X*5zlfjE4wx9{S4J&>JFkl-)TL)j=caRQ+u zS9`UHk`;U;T;tcKEkU&LEH{D3-O7A_{Ur^|KN$z>ZDqmKpn;DZAPfC_8hp;`8^8lc z-MuHDyFji_L_1?E3A_0yI(wfQ!`J**Gb6*=&{CAp&lF>eGR*}OD~l}fXT`Vji$7%` zdE(OL9fZF?>FomhszZ9v7P`8;q{jsuxkfVc2)n|N!-eiBXBkN1pHAc;Fq%OkfRoo8 zcg%#QdN!+}h@o6i5|M9~V!tm~V4osV>gB7otPG$@e_=$p$PSw7b(J>wset>(&C#6R zCTPG~>-0I-1T7MpSXep%XZP%HV+)ppN}C_?t$kMDxOt_A*OU@`?wx-TVr&C=%lf&5 zjuRApYHrK&HUh1!#oIh=gphNVG!RX1|-;-cWjfVN;^h^(DS zmHWhquF|P~&LmfOn4cF6~%9l)tID3hlB(&Xl(^AqS-KAiuEkvY#Ye8k({w`YZ`iF9qy^H4KnaSDSmt zz!|=-N{GHvqz?>vVNzS~*uqY~L5r;Gs(6ylJMWCOJxT^i^qskBg`rb=XI6gWfv(sf z=U8?*5V}oCb6U26^R5?5Z?E=)0MlI=`cy*y%51=3F+qD$t9k8rlJHm}y7%EJBa`~pYpe(j$ zwq9$TEEo6rO{|eQx~pHUHzN^wYhR^TmZXl6H#XmIFwkWIf7ZtM&QE%1E)uwA;h6_y zpL`no{1gd42cTA|K%XW+Hid#e2)5m(-Do$yF#z}ENm*(+_8fbPX@Clg)+Ol`PD zzs8*K6G|kWU8+|?3pcax1wAT|ZdZ#E!DR51%dLOK=nt)hAB-eF+ahI8t8vqUF65Pt zd%m9)1J!)L$grpGSUxUrG3}EH@bsIQaMFvw;-l7!i?%#yEVEbIb5I#Vo@%!>OUWXg zD6eD;5P4_e>_RJ%i2n&mYAzxCqq7-l4idpSXys+}wuPwYp>20=-u1dEs4eMipbO%G zs059Eb7A@g$U`{n}$Gd${`Y@ zWdH+Hu|hO;GmO8VrMH}FN!}*%Ba=S*7&-pdL6xM4L~{9~ggf#Zy+Mw9l|*KgH>fvH z%I3`3z^2nS3$=?3 zhcS0hIw)d3NuZSW;_^+R9>PA(K7qS?9r5lnRl&b7lYw@GG06+{m-Y#KD7S{OzF?&u zRs&QIP~3i}i~^G5Qd|E~;3eG){FQk_vo}0$1ItqyOXWY&}>6WoG=y*h=eYEER znfSzUs;)H(oODa$KFtcr;UACbN^0Vm%TB+bwJvz!YFGfnkPe2ZUY?xMQU^KKwdq$5 zYCyT&o0KJ8bxf*xdp=(gAoo;5`d_$Q<-F5nlnk#9froJhNU=BZ9H+p;rrcS zI}AKm_Qq$A06r!o%Zdg$*rc^)<@bHrsTRa!EBza?PkKxvi}P?RidGdBhM3ue$f#X-Zg;6{yple?@I8X z-z6SQJpaw_5seo6W{DsAoOPC1tqA@&63l$6{^( z&U*w7+1o#+jWa|I*@QHcmBcnYJ2Kf!lRok3JKrg1Q0-KhrnVCP5RLC8=Juv=zP2m0 zI+n<*UA0T-=5|v&*?8o<$$4kY)^3_LQuBt!q~faSho&HYPqCokp*5^A-c<9Ffrv}& zJHNiTzz#ctGY*DFNWxvlD}x8A#2e_nqdQ~{v4E_=X}a?}0Z#;PJepGK2s=MfJE>!$~MZoH8QAjZ{*i@7a1_#!M5gDJRkhJeVc`I+!lo8 zmbbq9Vhj7rt=u+n8DqTHlMwA)dN4Ubt>!v!4zG^Ao``v2i38`C;s;4~z!qe~Jn_R8 z-u1>@>z}tn4Qh0cL$3#l#YSmwf8mDpxibOvZkPd2n?rr!Y;09Dj zehX(qH&8$FrB*do7mSAM(u0SlX{Ta}A3a=Qg?E104Y`@y;x(OjZ^u=LJmwdoR72Ax zvi=6CQ$sFtkl2~`W_^|=Y`!%x*m2Pahu%*av^~**0N0t~$U6Y!3y*`oT>#j+YU={Y z+Y0wve~i_??EvxbPZ-?$po&8o-38w0n;yqi|nhTSpG zMs{7N01t>po{(&j(K#Xw+vds<+I*eF)5T zcQ@+{r$D2D_*3SXEHNapg)JV~h;QP}Z6ft)m8`#*S&>`Al1$82e9xDi}zW(+vM3#a|TPBYQvQATZ z)Z$1dSz*l?ipIoy^5>)Ubc|ufuzR7`hv$V6yx-xi1Pqs?-JPEz&P7O>{u~=~9h8QD26mG-Y$?>w`2Q$H;q=#rw%AlZpN*%h@y@vI<+N zfD7<($GB5(9;iFRnN|61veq&pqGX(fW-OE1U3R=!42GWEdk>VTPrqSwwEfFt1P>B4_9Zc*x z24$Z3YS+tfgK85DQ$6!6kY)%LW2<*hH5nq?*6GK=r-?Z54clJye0PO2yX_Ri+>GIx zCf*9R)lS?ZeXN{PCFl=Kwaz>rK`Mzzv%fyw&7DjlwLXfRGxzu#7Z1e%hhW$FWeyY*yES;sYj{?8gTecTbIds+c>T$?XY&QRkY6wtai&fJIA)}WtZ&(1egd7+VZz>+ z&&0`L5ifw6)#badsS(e&9Y@_}ce{dbna8g73@IEGy}QD<))YV3l%15%a)h6rvJMG$ zR&XcqhR^CoYjl@mthUjhz=nRQ2^)de>gj$3r~u}hbxlNmia2@7q0*T3j0BODDiw69Vrb9oCH3f&EpG0p?HZ+@rZFCBq3B$ip+&CV zoXm8Dg3Z6GV|QkGLyh-qU#=%M@RU__sEyW zT0A(V|N5IaTw}NYQpP0#KidVuxaPmoV!YPC<;$M1x8i6l{be%rH&C~)z9tI;Ka!3V z*o={RHafU8T((BN@0^e4Kap`lkW^^cz=Kg1kHpR&R|F>DlyNkb!<_Y1tGTMyfR4DH zJ6(e;-mlZ=k+U#{M)xxk_7raXq5SsD0m7c};(Gz}T(tvUORA%Hbriu5*B{iohslEC zz|sw&=e)>1wxw%Qb2U6!`PDur(GtsoGCSoi%Yb8<01;XFiDvQCzvNAwJvO>s*XjAr z3YDZ_pY2~*fa~F<(qF|)`22wp-Q5j3Fn04$K+!KE4!pR|W(!FN*Jg9RmXXj0E$Xzl z6%pTdJM+QFjFdj^WNhgZNV9}bmk+*<4p76PpiR4ai8$#yjilm;<66*uzk}u6N($~5 zTSb;2+S%rM4c*`7$f>kSZCscmOFq_{8k}duOELKi%8^9<7`|giQZ;0-%Ad20FfOz-xT)c@&GQj!PkP)L|uU113S)=2z$zu z%KEEByjq()+t-32cg)hB>eq;Q|v>uk^nDjf*JEJ=L)(c6Ea=<))Nyni<0Ui#0OAeir zgLQ0UMy(XW-t*p3fJjsa&sLW18(~JkW~?IL`H_M=y$2#EK2dN;b^Pb;SX=zL@rkNE z4#_q&dxZn!`TimteN zwa^=``v<;cxK7lO*{EGzX=x6DT!M1(L|vPOlGpCC@fv7%vL(zY(F?OmpPapOP!2A! zzVL84BnM!lhH(c7J5Jh$l*J3~z;!M&{V!B`>-6Rfvk3%habD0=wj}C$BsqH$XtY5* zxj@+q4>{Y1Dijm>AMy>6jmb(-c|R_$y+{T}rgX2`jX6Q4wYQlyffG-^TI_7l#hpg$ z3O+EJ!QJzE;kC<>a4LaLep{0rKDyq`a-Ts3gpc{+O9I#L7d=_=))JkS4zG`$utaHX zwsZx;j+Qk&JUJnt`?ZP>&2qtPD9)zl&eb`aK?=k#rCgWn$XCi-0M%a zhY1Bexf**H;EHV0V`H%bt*;5k?l4(`&ac+UMz`nW-dRxiCPP8i%NrIgFMgt(csxn| zP8*^bg{{xJYodzEVeghUxEf=0d(>9*7I)CBGk0A>9CxkaIZMw+hR~oSqGdVg2qkBl zx;EuIBMa}o!ugdH*sPNB@CcC~C={UbP^w%P$rabi)LzP9j%C8;_YdZ2RcH9jon;ru z&f6K+Yc9@_m7mWH6@74kAoE}6{z7t8{F@RY&zt4W_59!*YrOI$)Jj6p3O#N)$9U>H z;Job2Pme(2I)^SK?hTLw_Rrm-3)+@=`(eJJr=%5jRJOliJwU`Ur*iGye##9b*fJ~S zCC!QYZqWgf!=_katY9}WWd?OF9503~bfDzN-CceKV&LeZxoX5h2bZjDCl?4l&0A;u zB1+gER~73%pJyY3*|$5k^IyzSdQj}l@H!)mOpAE&^@}-t-TtP{>AMPM^Vk3IAWOkS z(a(+PTO`q+E&9}KtS2OYzO((vs1KZr{2<-3NCuih_}0q}Hb^UOJ<{H7iwk8;@=mQ@ zXh~!GDW|j=Ue%^Lc^niY`28Mr3uJ#40x!< z8iBcR>DMP?2H>0aK+=EF64^IuuxyWUhkg0RPp7JEu&w99E|&8)5T{QY^~uznyMC*%S2CQxvhjAJCmfnMBIQ|#DN;_`<~Fx^nO*Qj|FVa zom_L{$5-0xyo9Q?n`}VSbdbyv=!hO03uFC=w$IVKkG?WELAK6U2`r<70hw%L?REON zHsrC()Vw`B5N0YHC-7HyG{fY)Jzg<*X7k~KJH~3p6;2Ykz02Q@XoK3#b|3mqO`N;M zHaOOyiF)RFO4A*huq*JXuHgks5TSnJ)J-Jx{@-m(*q|f0uhSY=ED8^-edvzsf45=E z@TiLq*&M4^e3YjfH$_3Cf3*P^@M->-I@W76DTmpq!;erQa|%Tr6&ywVTa!G%$Fn4@ zx6uQnK03YPJw}0B0W+uVF6pD!zOl&*`|a`7$b+_=bSD(Ce}Zo0@=Ey7(_2h<5>$l~2U_SfPH9~Xl@Zc*^ux`l;>|UpC=4ld!@@;3Yu$GJC zfRDP}&>cNkA<6G&U8jdnzKl{X-_Qg3**%+k)QR}LL$A_~s9R%xUOKs&XiMzhrlop{ z(4+j=T{-p>@$OF#T(v){3+KrF#_wgw;8tn-qC(mlUi!Q!J~wTFGyG4Ff0h;p?e{h} zR*g;4=1fB8TVy|yH%!U}-w(0^mzN)kZWD2EF~U+uS}iTGg)@=kaeKDT<0#zg|$Ja)r)F%Fl*36oU@S?ddQ#r zlxRepsn`3n&#YHrQ!o4WO+$XLT3LNXP2DVcfaXb-j9~yyir40&XJ*NVQ*;)0iLQd} z9Z3U!q0o+y82dMb97rwwB1Y6P(vrLKowb?*qG{FpY$I18Yn9N#sW3g9k&3;*9j*tP z72Ge0tkuKnIf|F6vBUO20XesB@WX)v2)KQFJ2=G zCOQTtxtbWkyQ1Ksrs{$MbUUx+8jPZkxa?SoKPU5-Qw?s!s0hMMG_qPP8!}Hud zm4o+fi2S%G8&}TL;bohKxjl9gcsApZLcfUwR=%d?oFwdAEe0NHA^K$8T6UT@pII1p zu47sg!YmBab7$3*g80#rd|XH*!WgC6A4k$XnI%Wm4%>Jx)&X!Y743IEW#`X6WHId1U>EF4}IF!?PUk z+Q}gcekZ9V?XWZ*!jtC)bHR52`G!5N^te#aLQ%9sq`(G+uI(2$ zqO(S_(SgSsiRTuVvY4mWcPXN@R%~mwg)C^*c-Wq&$l^kusOO^qS-jb+)Wuy&g6HF-hdO* z9%=b0pLc>aHyLlou>PWT(>NFJ4)>Cka{K)!o%_gd*U?Q^(HGFVD{JcQ4<4k=_!O1) z&mJW5G`Bo2|85R_$G-(9Et$jBVbt`#rw8|1QcUgc=;0g98dXyQ)7LazOPn`Hww%== zCU*?+^Qv~A!jrr(zWwyDaqS3AuAe9RsiG4s==6Mk&Ef&#(&2mbrT{9IGza_l>EX+l z_PWt;cra4thlXse4T>hQ^hvQu67sMw$6-_vPNdG1ZF3if4auj!EgWA3eOuRwZ9cjR zB$t_vx7*U=B`3{acilOWB_VRLZHpK(Pq(s+NBH9W@z;#5M`iKLoh5~1x+Y+^Yf+ZG zT^1kAf66M=_l5ILiXx}=d;uv}CZ$DGQTMQ4RvD3pNtah`tHrO1QCo7iERa^=)-J35 zkkdB6#q*=&Q4CSn__oF}(ZtTr~7;L-}k{k zRQ|*N|EKQn|M2BMXZAn%-<^T~i7&tWE${!?=KnNb(vkl9BmLL9!%O0$83@V!*AQMAApL$Oppf)ANczA2-hhed{p)vny5AGB{ym<7u0QEF$5XWap88+F z_xCJ+ZL_ZWNiZkL;a~l9Bu?TNR+3FbQh4IVgyfC!zt00dJ&7bnjQE>O(z=aF2{EDJ z5wQ_*$w@Nt>t&K7BV^*@*F_}#YZ_v8`F)42t^B?BhTq-)_5X|ol`if2N??3Qx0l8x zg$E!B1nRr< z-!5I*jA;)PR1b|1_Mf$vQtjRo^{wtd0>cAak@F9Fmg99j!%d0zpyX2RKPCl2K;oIT zZzffMq@8{$W;Z*KB!)#ldwasR_JJx{EiE8_^SKX*xJ*() z%Z|=;5hNw)b&frbgt&~ZxdRUjfh6v-VZG)Wq$s3pl5V#n zJ@wB&hmt_3*yIyEn+a0iFEQlZNyO%JC1bS=Nl;L{p-bIO2}vc%6j!Gdq_$?pZAwi5 z>S-?q1}0&k{;0il&twb!Lyz&_^q5()ng$p;0Yz(V75(NE;45>zofT;Sq?}7}J*VuD z#K#I9y z&=SqR|6-CAQnYmgR_si`=37?>JSDb)8-=B>X@)vTZbsZD?3k?TP+HTuNkfIFT@9aFOvkj#LH zlTUWn6aEisw*r$FB@CO3+0RLS%m8hA<{L?4%0S|-tvG)!5=q8!{-(hhkaW1f)X@u& zdXYD2YI7Vm@4aCy#z=*(yB(XCIINL6T+sjPcp_3+Jo`0RcEaWG@WjVI346b?{PZvL zRQxY`?*FF8uWjjso`)KdFK3`W_Baa?zJ&Pic9TJB?HX3u0T(27nZNBH&4$%4<4Ob{ zngGfDL7(lnAS6w7EA%U7gGH{-NGOHi6TXjwM1d5fB%Fy3oz4W#jicH}UA2)^nmHh- z7LSxE$>)8`yMQ(6W!9CS=15Xwwp;Tg8L69X`&Nr(g2yULbAeD(Bu)O@6e&2;b7nkt{> z$$=N+Z+GlvP(mujdgw>lW^B$q+%dT!2QqI;j{mfIPoq9&Dv-ar?Z4ZtJXs;cTfMZX4R9n6g;~s@Pg)Da@U6Id|XWoo6f^UyT^%8vM=D2T)sC!S! z?8{@hu?-jgphqH1w0}X68Jcb52HUoU0;zHDV*PF}B&~f_yS0(v>*S}m?d1c2bhG8^ zCgMFM)Kjl-uowFv_4ecW7qh-VeH|dD@QI)+V*2fipTvE{qG5ThDG*3EI{FV8xnnaA zhTf+Vd}#d5`b9-3P_554yz3+QK5R+$(k((xN_UoUSA_vd;O)PGn+*lyJBo#Zpb0*GD{H^?~ zAZ%{rNT?RxMC6|e`;G1LLTcyoOz&VkHVZs1YBfv((#~_lD^t9X^3n3ur{WZB-eP!Z za&00|O5vJ5FG0`eXQrl^1f53L?aG1)`5B=Y;&#pnNw(@WIul#*PkIvM4A1=#d`+WH z>&0g~rT}T+<=zT=LT;oVN>L>f*MXU5@t1BYkc@R(&Gc=MbUS?R(A@}ZzF70fBRmb7 z6PE8i(<1guRqOS&ChnI?rEA+pw?p&zh*Oy&vAwK!?TeF1NLtvI5p^ULsAHWm`+bPx z^2%ejsM}2NjUx9w)y+WKwyWsVGgqV@Bb|&-+lGJAQ@wb18{Y_V-g?h%-AKqWlAGAh zwoX@Uej-61^&l82Vs>t~DH((ukohq(PSC$Nb)ni}15!*UgH{Xe0;=+cPpgUeBa*ty zv6US$NP1E*DbzzH*6G4f`C&Jt7!D3Q-rj_yjH5xPdUpV6-P^I1-Gp3Dr=3ngVm*8$v6;q^axv|GAFAGR(jHt)WqE4Pyv|32QKMv#o8H|v~6E=M5sLfU{@LJm-qmTZI)i2bgJ zolDk>L#n>{6WN=)ffUJnd4I7Rk|g!bO}-}+dWiAP2qj{?YM_4G1fk#5&c$4n-u`d& zocLQVH5Um@Y4zp*n_Oz%uGhG3S3dkHmncEq)zFj&f6AriI|-{>74qOuxkNdh`!hO? z82^V{YWD2deI=5Z{|~wJCp~vmW~CyK$RAGmt_hV0FlE<)MCO5{^E+e_37*MuTT ztG=Z#KMi^QpodAR>*Vq;LVmYr3N#gk0IBM3wJl3HQfeEYc)j$-=I!I3me;NY(yi%V zL%PAlddKs&hK`u8t~o+h%O9w;Wa>;n08zJ2>vIKXERv3UhFX*Ti0gRij&NfDlB5P7 zZIUGTFr$i9{@WU$dKQ{I`b^NdNdLUBcpH-9AKBh*4gd;yQKiZtoY12>yC<%t{Tn?l zV|{^F90)xzFsInzR1Cpy9=`GChhH7_Ce@bRtNJwZs_Q8WW(n~^3zEx?P!bZ^f2R)o0$l`13b&#YZYuP0WLDY8H>dt4`wjKG)N}w}x1E3Kcbe`fda2W&4b% zb^h2qXOME5htSg)_wKK#+zM3rL$AtN0tr6RZm7>mK}xEwd7=w3&y`K}-}(ZPnzHvW z%_tQqhx_cx1PS?Bwa4Ee#UH5+du1sHxBnYGt!qb;_o`YEdj5S{`b0WVS7%?6>j^}H zUd?lv#Br}oJ($)`$U~1qV+C6YI$tp8?C2201hp22JmAOnMQ)Zc`kZ^@EWGYf35y=!yN`=c1 znoBa4DI^*+m&W(gx19Gq_xE|;^E>DF*L%+6kM8bu?|bjH*Iw(h)?Rz<>o!3g+p$5Z zDh=&}bsPPKVAuB&atF$QpK5UiLoL8NpU@&VDgeKa6Hu!l2D)`_ZPpFw$wzPZSyy)d zji1dOBXS~p*D+O6Ycrku!U>hX_U>cbEr`D-&%fynd)gwsZeTcq&_(;~7l<1(lri)D z%P#DLhGt*jlmvd7Tb#YM5pp*&>+YQF#;A&Uom-)Z_OHtJEoLCkQ|(#?Qi$7Mo#ndz z6F7No#i@tqp(m-0i`U6PAL88X7QO~uB2HO)C-|)MeHyng_;37Je=7*2UgGz9yfh*U z4Wa4 zUB&~f;fIVKzms-$XR22m5nnJY$Ix9jH=XpuKBVT$3I}O#M$J~xDq#uY&!5)Snz9ZI z^-L`|Ldu`nPMzG$^?Wfy=S<_Aya4^2DEykI5zM@2;U}c4VDtw+{Ot<8pvrX?unXCU zM=zc5z0m3NwP2TFreEHaZYQ+Tk|w1Rd&EEG>d6u4Pme3Y-qngw7xUKF2iq|;V;qrf z3;%e`oZdgdj8KIVde+ZF0CC^?we2?F;uYjh}Jw0?BBMpl#~NMna8?5XCU5~!Ck!kHRz7BJCl7u z=TY=%*96XAdYx6o?LlZ;fhW(WIWm;EMU+@F@YC5R=xqna9iAn&=*SM>THGX|OTmBR z=eXGBvLkb`e~n1r)=%#w^rf2|L0MR@IYLUabzt{e_NrWLz`e74Qx7GBKjUbwg`-%v z)n!*h;}MtMD--o*fcvsXikD6S&T|AjOsfO^d}HM{NBEbhRe4AELY`FR;)pzdLPagz zI`0G4BlIAT%Y;BYUr~P9x;Mbjf;&ZX%)tMPZH0XfzgY0xHFW{ ziYILD^Efc{?mSbmMDTe)aa3Itc(_?W=D8pEROEVP8HhN!{^Y!{Pr%hvBL_o$5a($Q zCDtwhe!h4wuiuLH?4nC#iooY(zBWE-;Jm0=?r zos!8}+JyC*RT5N_0X|vynLa7IcSS64UVaI;`8C9i`&|w&#Wsv;RhWh3G2nz>&@3@C z;NjJ6SGg;;GpZFU7hf@lyv5IbeHXA7@z0M&J|FCdpO1#8ug5-p+3HBcK;UY{s3h$K zoSmGiaO{l_Lz~1@kIO)O+nzM}k}2et_~~1RDE1vfr^ULs(Er7}$ghUre>v}Ck9y!d z3qL-y@6Fxh0(pKZEhC43lQS(sYhRl&nUtURIt}n8d1B#%CeVkH6k23~`{LnM9}hx* zqeUigXdy1u8{Fm)3OQfl3y_)uoXoss{cHrdDl2(BIn#-$IzC}!SqtK&pD%S+E=E7? zS~Btt@VoOy;sZ-&Z#}0eQ0UGlom5A7+&9TL7G7!6llT zUto)7+~07is@+<{ehB!O~ciR2382d@j2Erots{w%NK-NH-`e7Vi~q$2jC1t|vmA)mXhE?v_0 zjFr3y&pN4<@Uu?0@2zrW=zIE6^CR3CHS3Zgr?8cTKAN?1<5I|1t^TcwpEu*ZA!_Dl z;iZTZsEVgei2vf9UW(lJXO156I2q(VfzS{8A3ThJoF@=&=jz?eAr^j4dOj~L8c}Dc zgWYE>L@cqd?7mSgVQ zhSK?p-;tNQtKR){jWwaWEwVq&absx3x^B4{w8eGigYDaRT3h` zJ7Blx))~8BLVO|VFn{?g;HT(@!pWSjjOtTPca;X@>v-r(>w~=r_S+H7ip~tpv+B@j zBJzrtmJLeydJ{@%;C!v%4yJ0Awm;W)FXTrnqb>`0gC8CFAu;fy$E$K63;SZ3TSK*X zJ&5Weqgyv)Fz$zxpOw%xiLSnkQo{VZ-_p5@Z*ncl| zb5Q36ej0ifYUMyaSsVDt8{k30NuBb~0fe3;{(P=8{D`2{!X9DBdttiM+%JKII@#%7 z^#SxZH{VW+0-v&3)>0QiHXrV3mtdZW~_YU~a z!q5FRrx~yBD;QdZT_k%nlu*;yRnum9AP*!l=X9_!qndLieF^fSbf=gv_gd&foq6-^ zU3QSexq-qPpf7#qFL4Tf>FYD3n?1vRnI*9AUXoK1#phx>moIMP`EBo+tvt7{N_~F;xGPj>w9ez1Kh))kV z_T~J;u3=|JwJ<5jH(?v2TAW)oJsG$cQ!=b8w1c564_F^ zD0#)a<{I*`$HaQe{Xq||W0DQPk2mjY-S^0c#D=gvnE<>kONz9$aA&AVLjtqhfS;7; zeC1#LJ52tlD2(-Ls?O$Y0WPud;~cG7Dx0CfROR=@gk1uT{mfT=H5GX1aNeq*$(*4_ z-Ao2JfRj0^c+Us|pARp)RT2XHZcX|bLZZ>0W2$xmc2I{4RjV|W4^A4Oe$5GO{lCmhpC4kmo9tN)h?Tv(9}n+ zjjsg=b#~DG>^JDS&BuI~Tq~wW?dSz(1$mrP^!TiNzEvIU2wW+lhM8+Q4BcsoD0gU|;&n zvR+);&3t0vCvpFzw2AgTmDIJM@4mOU5&Fq}liVc4XAh3taH!HoT+2UyyR$W+gk2ma zE`;4?e%ksI`yM*{+>`|w_Jod2OKGVEUH6)E#3A_oH&@S?q&gF7uGjrf;GfEJ&KG`z ze53KTvpZLS&O@(I@<)4Hlk@g@h@);gddw+7{*xBHZrcETFj$Z~I~exP!cSY!Qe}HQ zuaCC8J-Tm^E1}0NUBM%P{%0TNDoNC4sN-KMvh&>u^=8U6`6lpxtox0gH~19dJ+bl- zaI%?m_^yG?uYeVpP zYSvM!xmbs@GUdDLv9Hg|PoMi8bZNQUeYMz!vhZX6E_5&V&-Fw#;>_LrTZjV>Nqzqs z4!ysBKG!@0`LKYIWiI3W33bPcEzk!2Y`A-R@T@gMX@nc>&;lO%8-7!@2A>y#GB<8S zT>33Yw6Y2N`bRo;_pU%swnlHTyaYZIO8P22b`gpQyIW!(LicSxRKFAPYM=k5{L=x* zZ#0CqKX=Mp1AUZBvi36QKbI#C+=4uQdO0lk)xUAq6lG!XS!FVHo-^=@g&)=K zrj+Zp$QNcmZK&S`{Pfm*;M0b@@cLt$<#M(#sz(jZXp8{g!sO>H9uIj2yq*^1i_BSD z*c<+bpl8GtFFgYKw<8NXTH#msx$RE8i+=Ww*L`*letp-Z_f4MAqo?dI?_NWDv(9Hu zDR>|K{Pp!kz$Mk3Mwvt}3j}E`?mGW{SCqZias^{>foJ2zpy?-|%vbTk-ScyI}YM zL5sl6Yk{kmU6ezS@1_qJ1tzNDwa;;fnocyK-e+<=@IZUL9VstU0}+Q01dV%%am6@_ z5A*{67kzO4!i9Yt3qOng;1c~_H+^qE;z<@rdUV$`Fm`j-)^c_r5!67 zswBbiq}vukTNN26iUIGA2&|J>x`m;qDTMa$A}%d1+&hRoJFQpsJvk0~d;YzF&Y%OK z=ZdXp`v!XNODBnsz=NBY2ZrRGu6m?Hu{9~LOvF9 zF*CNpj#&5^>Nndr55LDuFaD-(YUBd>d_C3k9enPbm04Vmyaro(-JKLyLh-$PcG?$u zX1ncfmV_yzdOF)&b%ht9#iV;(p?}olSfdlO5$~-H^{S-S?YND(>ws8dvYX+@H_`yljjC`Vo)ivdzPOu1@Lb)#t#y zTp3MMZqRecr_}q{2PX#73p9f;?!>P38!_J6c?AyP@KZ;9PYz!Meh$5ubUX+B-@fc7 zB8mLo=cH{%CZQj#fUHqN(0{ON=k;QKEc{4rOq9vkwuz|TOU&-)0*>V^f5pEZ>or|I zJc9=~&v*s6djt2xP8~Ti7vIm08Bglz55&_?27r45_qMOlfgFl#!ka%BGW6t*Pecpxq)DCDi~#6U zo|Zdj8TfqizQ6W9a8LeWPy8OVuXA1Z_!jmZS~8h$W6;lfiKlK${ZVJIXpYH4@YA-H zj!XpIqjLZwm^oJAN_a7u76ZQoNRFT zjY>RlkN=V2h_Vmj$XDUi7x3vKd?|DW=)D$???wI6{}i*N5G(A%24xm@0zV(kYIMv- z|JT>V@qfp@e*C+moq}lZ`av*wAN*g4dQs&#=ta?V(yajcaBaUfqN3PO zoa!pT{)$qeo(d|hU=k(oh;=U@u&dqtZ)Fh2oO{G^Bg>GPxG3|$_aP~q10{?cD?*+~ z+u-?U9!Dm+K}r9v`4q%^OVrsD5uYtqG4C~i|J)X4f9^QqOg+&Hi$J`g;_=XPTK>Uo zvHL1iJAe1aB0WMGzmt!e4?Y(LFHn#(VyJ;>CItt~2z93XX5wgn`^>4E zI}j)Hgl64e3i`v6%C4P=&+dy9_da(<{FxmUbr87P*D}OdVSiqKydh{d;;(1=jQd2; zGfz$E4TGM@PQ5V|=kl!l=%l@VF8)=SR1H0I?-s)T`p1#MjxCsP#$m2?`2Ec)w*_DF zb3i{=y7Im^{n)gg!{6R@5v*ecjtT z=?9V!H%_@%w$cWAsPc(hb`|){G32$G2>NJQyvG%cyYnZzXR8>OaH()PGVN*``;` z4*s|L&kujbC|D^VuNs!Y3KT`j` z{*&%>KO{T_be8&0ijVV0N;<}6ssE(+C0y!i+x@rtPx^3tiF^Y3VX6P5t2JM9?FFAK z^`B$>+-9l&q}ERt<|>DNu+)E2$y>5{j)Trp|4B`heVyeAf6P+_)%u5|D+$hHsLJ=KP>g1RJ-d*<$VMdz&}gyCqY2a4Rn_JPx{HDt@N$n zztw+^@ngtR|49`^HFL#-PnP;my7JWqb`QvzrT&vP%8ZC>0G*}&lj^Vi;L4A2S?WJ2 zyK%Qd9)ZqM|4G#ZKFv7`I!pcM7(W55^`CjsYZZP#Pgv?d=?@Yowx0n%EcKuCa?`F| z0+1(5{U`NPeDjTQ7?-8~lYX4@vE(Y`z*7H7l`j=jm;pLV{U`m0pL~}3PgYzStN&!h zrLp=?R$LmZ|769bvHDL|TpFwYWW}Yi`p+?be%~Wz|5L?JQP;hH*V+GDfj!HA#_qca zo&3MIWBJ;D`?nLv?qN{BZcuPj#_rC(zb5_bzQeD(4rBKn-2O;nBBlD*|JeR&%}uF$ z+i&;v@cyg)?Ej;^##-IAhT5V#WhA5|WLL<@OUtcrT&XB)qvWuC<*yDVQh&Xm|6im2 z>BrvguYP{rNf{egMoLC%g_QgX83j=(MP)fzWhtrUAW5-N6aH$G`KKZ4eG-E|^s)OS ztndHp_eq2be`^pu_t!ke{{DWS#Ne-w{%`k5=A*^fJpbW+61VNX_TJ9hT|GUVam(bd z{{CNGuQ56O>-Ap}_?HC!C4v9n5>So5bUE~c3U$flq}&ZHqxeIr zI;o1tJJGuodBTIX8}r8@&yrZ<{TcVzsFfMFBs*slivOxeK^yj?%f<(D~ z@*3o`L@H+B`R}1EHw4S(9R<8LEmyT)}My&L#6sm%ZFZD2^AAp~Et$XX7un z)Uak$9lRgaPeQ&&i>GCUE5W^q_KAr~$a`%TZkgNUiSx#TFJ;?TG1Q@JS-wHYGoCq< zkY$8($o0Gj`*fG14x0pb#$mrMAuL^~i~RZt+r8>LFz!O3NAzR`LJNh>et8r5Az!Zp za~8{EzgnQOOL-Hcx@zsDV~hLxS*!mpQx@0;Vm50VW{e>ei7QpXUL__i_1lxe$%9_@h12AK$<$)sv7$NIw`Z5Zp@o5p1? zK)$4E?i!2KrONUSdo}Va`>xje77H!VuK!#$D;1 zW{y01T8vS8Hu55zyYhtbTzYEVR1;%U)V=W-C!e!LUSy)Q=ePKo$RoTOo@Hr=daHT8 z(Ou!FJIKcKxWyS-{pX%ZRyg;Qba4&L1fOq{rU`QCs2nXq$hdz9_m4!wZ$DX+JHQh_uJ`<)}p@6^6Ek-lEbIg^JE>>=k5aDW6O&Ih;SV z+$&CA4SI)#<&8WEhMKBVq}q;rkK~WQQ;Wd=zq^i z!T#qGxJP(&clT}wyy`vQGRHWEs48|v58!vFsFUnpVvY0}syFM$Yxx-HbG5%OyBzYQ zla!X~TjHF&RN@NG8>_ZBWayQy!|#0`VcY#2^(My^AJ1t4J#5*#h)^Az|0GDi7lfW` znU(L-k0wW$O-iS~N z!p*mXEpTqo(RKH|8SdxElvyWlMBRt`GhJGjdt$H8ywtMfVnkSlsTEf2UVZm00db#tS%4h7y zPS2eu%VSKc?!?Zy`oJD`-CXFwQB_&>gG6MFIN=;SoqX@+rkz2#U7`gD~imk&B3pPi5xy=DtTt*Q&+Rg}WH zhsDL99N1m0fuK?<^zE$W?JfMq47GR3rt0T@xF7I=GskEv^2ggY+w0>T_u2Y0i@(7x zdN+2bbE5x`W}7yPAfGyH)f`}hJZ@Te{DA^fhAxiIQQQVTZ9b3Jf9*r44aGv@Q}rOf z4_a?lVP9G@`e~+{H|kiYr>_an#5}W|HZ6v|*L|9qaUJ%^PW$kv8lWCOH6%@h>2%LGH=V;aoyD(TVSJ(jjG>&fjvIXblg>&zA zpACavS$Xy?*@Sw(vQwMapw3ipS z`%UlCE!qry=+u!KDTIBQhzU6#0KF^ea)vVW{N8IaYzIAWXcT=Tgnm>d-thM0KG}qA z_4~yQ8ESZf-AfJRM}y>cS@a|S>{l$LHrbA$lBoM;@}S#(notpl_018J3Fknb{=Hk| z#jF@YpFgy(s~7UW*cfo?sWU?<*P6Zff_&{cGee#|kpBhAD1Kq&?>|rPT=E8Vt4YN_ zPXWIY)H6?-;+!D<F9-1nK#DZVR+QSEejQVA zibi~(#%Ug93ml5LFPu2!M5yuJJo-OTr^cBOT_J9Uy5m;^gSxQCaHq1aCFo~>=Fkpx zWN1zCp?nh?oMRkJKX}BPp}9GPG*0_LKD(c9ZnP&<^~*CdJg5gB^2*w*hrFIyP^5RO zHR_iyed0{{^?l#NVVTI^4bm&0L|ee`oXB`l4LYv}_b^do=!d6Lmki+C=3?*u8_AGQ zv4PqQam=rvs&29d?9ptY#LEuo)BV;TH6ieuZT1dIXMG8+5$s*H3+?B9P4~mSM%7z+ zRY%~*>G=j_M%8TR`6r@5sN=ikTpqC<_Ye(YhH$UCs<}_|dVMgV9(WzH$Nez+ ztn=qe71V8I?N{bE4ndqlMOl{se~j}y$DM;+A1T@KpaOA1>+y4qX^@YH(gub1z@Li; zR2#xU@8QZnfqFK2(D=svb2z8j`y*K==hwJ1HtINI{@(XX_2poH#%rweXNDmTvfsjf z8~v0vj~uuT`|}Hrl(`AJ7FSN$V}$nSE>8EwJvM5WO{$Fy8|S~6q77Sv^x z=ei^wg&g)RFU@X-e^12kj_^TmJIjvkYQVi8_Bj*Vf7$8Pq^Cb+(0{@VK0iCujY=uW znMcE}Wt(4JngTy(bC|!h5PXg^_cNM@^P*bmpFGxR@4NMK)to@+`#y<>M=@?f$-);W zA^%`Oonr~`4{2Scf?_6wz7_2$@DTmbD>W3IU{AYGc<}5n1FlM5mU{)da1Yr7+%Eu7 z?rEbT+*s$c`R5PG?;!N+%%zQb4v4GH-+1l~zvj%I`o_kA(6?RLF6_d%5(;r2mAoLQ z8{#~Z5$A7l-CwW}xUtYBAM@oner9(zD(EYWiH~AY{LUN zY>>wmSyy#DXM&F08YS%je%R8+ISe8$ouAX1z7X+%&9Z*+4Dh2+J#LZ9PRK_tGi9R> zq4)HE;81Y`Ufxw&JPGGC)oh;{l7RyO3tR*=Q3qHvZ~FFKi1)9a+vF~d{Q~ETCnejl zfA}zkcDV*WORbgmmWRLIKqc*~LH}(XUKcFjXRp+M6)XomwDy77DSM`Bb+^OuK=e1g z?Xdg~;De9JeYv*|3?&m3qWJ5)GvtxIkSyq<1)Dro(7#%u>jPKBtK*flS0!NF_KOD$ zs2xmCaaIzysv$!!@*Y}afVg@_LqKje>>|f_e?k=WtKf-JRW5MABSA}R8u~ZU8?@Sw zIu5R7+a~V7IjVCj*BocqVYc=piLKa2+Z0% z5w{q6;_rfby7v2CqPPbvy{7sh=+uf=?uRe$U^2JPzN;&M{gcfhy(2$ichYA1_o9HS z317lh;K!>jH@#3^54*NA52He{UibI~COIJ97+GCRWD);Q-NF;$0{$ecVybULK7-*e z`6j`>;u16Jy}*zEj&r-LuwKTztwE%mA-i=Sf1kbTJInDVF?C$Dj-MwksaQ=3pm3jvI`g-DFK`ZS2d;aX*sI#REU*xQb zbw@qoj{P->`w1<%I4vdx{KyN;4-`f`*7zamU>R`0V*8n%GT33+p5?Y;h&L=U*G#$t zdq2G>?}#hpZ&5BEiF!Bc$wAj-Zj9Sf@cB0GDbibJ)bpES9~Lw|SmGS~_$RM~kSy5O z53-Ss6LCmSqe}W3Q|xnF?B18bF7os>?xsP1pSv?Ju3O@M^NYUb9N76!ooOG=xH3H= zR|QvAS>t{{s+&nJ@cQ}V^RH0XMH@0=#;w?=+sQ5#kVHS<)9yHR?ZQ3J*E~CeFz$|T zJ+GZn@A}TRPi5h+c<0QV{FAnXvdmUeyNv!t)Td1g03MIaDRuA0{@OsWh%*8E2YdgF zPzifRbOxKqI)CibTSa)}pFv*rlY(5Y!S0Uq+=^F&J)Y3)-u4rAl(}KuE(@k^0?^i#?qBz9)!V9{zdobT+;g642qi$u$^YJ|! z;DFkVovY^fpbq5pSKGR773#eBJeRe*z~|QS%e)}xmGi#kSz|pz7ja0b!>-S$CH~03 zz9RCA?$tWjJ^$hqi4NHBMKWKm26CG#^G0h5_*IT8?#zPUH_D3?SPg!{@`oixFmK1Q z;QHYZ+|LM4oO%uOEgkQ9XE*%5nB)tsap-^IuKglS(7&}8!*?9P{{6eQ>CqI}W2Hrh zgcj^X<@8&={iq-8Nlbb5686~S$#?PBeH48IzDw({Pq(~rOu7N|taB@4JK(q4Bi5Pc zVjQuwl_RIoPq^tr$46+-PMivhPzNu3baj(A+7FCOzOe=CrE;D zaWbL280!-`yf^i*F0*_&_EjOS7QVKB*>2oNUS!cRr49VVEjr&k2loDr&;H6I=)(os zBaJJa80z(oMWs*Be(uydflU}U&|zK8B)mRw4DFOdd&Zzq$q4+-NHTQz_52BQLHlnE z+6zorHR}xcX_K$Hcnbbv?~cr(@t~W}x)(gfiOFnH)$Y_XfE`RdSHB*17rm-*^#u6! z`DcF=j>G+YnMw2K%>g~BZizu7?9Q~YdF3Uraie`? z6(=w1Bj{v3^EBiU!gcFBD&bGLi|%Ucp`U$Uj<9J02kP&CIXn=A_|WlL)dBQFzJ9kj z1AJ4eoK*Zw3Vvq(?Blv?F)zo%?!W4dqx7$Gbl^UXevVM*FF$^5#nbL}==W#cl#Q0C zU!L?}yF#Ejp=B=Lnc<9hoqs-e^phQosGn%kmM|OCcc*%}-vM?A3(c_Z6xYi;t3!c@L$fsAD`_Jh%bk&v?*ZKW9`N;@C~z`s&&zwZc<#d4VB2@l z=P<6AEelZ}l&wAG`Ue->i&B+17XtqsetYkDjbFHxU9ce?_MWHFJ6jHRp)D1BJlcT~ zEiIbjb`17jd^vs5uR6d^*C4AkurI}mTqYIyw}n^qwD_=&3Q9|5?O|W>mr6c7!npEZ zi>))k=Y~b=TSWv3wcxQ{)my~#4=)rbtwlda4)ICMgKQ*2II~e?NFHsy(9IT ztU9qTW?xqE@(TJ1;oC#mVBdOSgW-!ih}*lTM6#nUm=fmm>GFqtbDQ~O=YsAtf?th5 zd&(cP{%bdO!Y`L^SQmH{{0wg5(d5FqX`R_Hs{-~r zZG~a8D)<@4RFE2s6Mod?=_}9!%eVw^4})^PsG8b{{Lk%4)l08}-WkyLJ`Vb@@sW^w zpAqg`H)-16hhP3GsBguFafhduO4@9Nznj<8*bcwE-J{;38tYzNFXA>8`#|v@R$sCNxI(?05oO?Oiu;RSpE^u| zJ%>Nqy;L7^3J%u2KXV&!X7cn8UYM`Zi1?dn*k3e+T{&2!jrzNi?RGD*FH%*O+;Cj*IIK zLVv1nP2~jt%b%ugu|XVLdXkQh@IW1XoNE^LGsuUYK9qv>x7X+r^Z-7ri2U>fc{HlP zTcH&9{HP-LPba6^Bd`9!kE;>y2Uo6Lvjpc2YF`)5KjB5_L8+d7@1buORZK@dZid}B zmU_b;>33`#d_`Dyl|FI4`PK~mw)Et@1Ae&wv5RZG0{G-oCC7)M{}G{86c6l0M|xab z6Xw;*BW~;m|2xOO{jwbVyV1Q@R2leL(<$G;i+wjO^KgzM`v2IhT$l*`Ze!n)o1qR| zJ9hnU4*aa$iPZdZ&@Y@SetQ;qDxTw&*IYsG*w&P$1pe9m20M(A50C!rq!{By={^g5HtDRLjr;tni5sG&%VF;apMM-?2R}>B7G917ePPFV`Crc;3LYHYcmVv& zUhzu#2J(1*mAeO8VAl)x1x$?w{W53SOAW;TlCnQIrlOzqZA-f(poeF~wD$IIWT+1% zY_3*O$cIQS=J$bJxVJrskjC>+T1}tj;1WD7C&^hi6Z@7cHFohcAphrHD~)EuPT3qH zKW;?aFlV-$(y%9^T6?`|f)VJam$iMtJuiy(n-mYfO671KU(JDj4j$0ho{D|~kBncM zjn8M!-SHq7@ql{gvJ;0uzqjt9>T3X#0)^U zU(J`Fj`raITXUr@2%-TJfB+_;@l1#p^nL}%!7a5RF`(e5%j)Z-~Evo&r{+B zUn}IgB#~#z6WF!bKzu6v5gk#t&czh+STSOpZ;yDuet_Lr2=?WiKJm`LIzq|ts!R!! zB2>icDmiV)GjZ4Fq@Ns!=lA8U4Sc0S^IQ*0-wb;(NOOvq1^lEg)GnT(N$6&#+oTfx zRz&X@)P>*l;HeR;#D3rF+vBKTb&;uE0w?s57b-oRXX9@L+}LTg@>kvQuF5wd$MEX- zu~abJ5OJgUhwc*Sf4bb8eP$ZCFH=9{z8-X2T_c-3%*)c*Y|al=hddul*uIQ`zNIIh zJClL_+v!WM_#yvo(!8P>QmB7czdlnKc6a&Fjk@y~_sf<#hZpc8UCYDh0r>0Ca9bth z-6)5d?zOM6j|^+>9I{6q+t$iKG%XnSijtaF-F9TGsl1VI+%(3$vvZwdF!rw`R{cwQS@ngVa4zR|_7_okc{w<7T4lQCmpGV0t-ZL5k>Vb{;L^iQlp|8_20 z7W3d9$z|IYGk@9pGRfQgA|bfnq^Nj43+s3x?AeApdyvQ8oBoXk|0(UK=^Lu@-u@`p)H@!nnVZI3kr9iGFP3o=RMV{?ko-`R8jZtDN_2yeJI2 z-Yb5*NgV6=aa6?6OAh;*A4bPLLEp6RO~L^5`GjU3r=uzEMF&QX%!-D-ZQbec82TU; zFyJDKyhYOsn@LKb-?CXceE&oOOccpQlINE!-+5372jcJ$HI+oZsEcsQ$Cx8EE@6pU?MxkMked#md&- z?Z$rphK2oqz5Q=40am*h!$+Y%csVwGX)8}Bdv^~j2V2{}NMrh_I@aJn`TD!AdK@(W z_urX6dOOxHs~#`;)2{8utiS#@){gr5`@JaJud3kx{kt1wjlcDJtXQJG1W)^@?-xY!Sz~#t+?1jqbl)Z^d!IyTOkKkx5%{d+$}|IzQUcC7mT zU+3um&2RoQ9AK5-e-zKQ@%;J~CFoy%BVm3IM&Zt z`*GCgzuHe9Pf?;E`j36^AH4pfJW;@(?~GyIKkMQjeK+t=WBz~kr9bq4^xa*5K4X;y zYghm1yR5&b=Dy>OaQ%lKQl-AS;VC^x+WGQ(P91C~N0a6Cf~MCH-f{X~oTEL&N7a@$ zX~!TjO{OPtK5HkAqx~jPcdNZm3U zT$X1PX4jJ-sk4q#n!1UIY=G&&@>*u?_@tY&tB0A~$dZ_GXM4y2o*TRK5(mlF@r>{Y z`qvJ#e&NtnLo#+w__6qQ4^iY-@J>B6NUB9f9jBMI6ZzK*k9boxi7gW) zFXA{zY<=WJ1J1V-o5G;VOwiSNursH}^X+Rf$f_(*}Q>b6~cv%BU$b4~DM{}6mX`F8#`?iP7=Ge^< zcdCMMT@dp9P***1s&5pT`@DyY4|{xjSKJ^;zT`PWm2M}tnI9C^3e}LF+!SNBmp$Z0 zm|fR=??H0?>;j?pL+xbgnf@h{9)Z6_l>N++9uii5a@=F^?-VfeX9`;f*-SS$I83M^ zt<6aWrniPjVPd&%bkl7{ZhY4_2l1m!STpzA=#X9_PFVj2xp|lzmMilrd)Gsn4BI4M7BftIYUxBXf&nDVbyUw)D;rIjMHIT%qPRb21>y z?daW1rp!QA=wx6o$?Q+Mbi8kf=$ljb{65}hN?RXXnepKW^Y&cqIup}g;?pJiS%2Ly zo`35m+s@HTj&Lanofu)5;jQx80g81*#Ub+C1>IpHIoM-v3^^ti@LAa3VHkDcHm$?u zb>w5t(MR4`-^b-fA5QV~lKvAGtK{ZYF(Et!_lq$nauT4&S~!410WT|0+JWl(`>y!jm_$WUzu&*Drb-u5t0)8<}Mms_i5KRiTU zol5@R`0O@QzQ1Aewk7EdpL}$*lWs4uiCI>bwPu*SsIqJ5n$}Bn9`cqKnJ~=G?4ujQ zA^-VRkH;NQ874zdGv(O0dP%xUpmy59y0v?#EYFFgCutP^})iD8!7VTIcPCh@6aUXk#PMzA& zKK@F^T~@YXc3M3to4I6iT{`&7sSsEn+|0OBqXw~u+L!_dE8KnvdoGr|oH0QPcd2LLIt=2MO z<0fKq%tXTQQxA!5r)Y7=_i^MqYvs&#;wQOVy>qylbR6}o&wkWHdiC>=~Eqz|p#J4kq%xr@lXcA{ADCa=h(hA4HJ45%9qld_-poyYa{5cLP_ z+v9gK%;!b6`#(LYBig+3d%|H~d+9e9!`XXD^rKy0&+At(r^?QAo>gifGm~$AN|YQX z119G8m4MS(d6I%^rz@GKPnTY7@Tn)R3O~+fWcLuaTwV>o>OnGVzODUYk9HEvIQL~+ z)DVZQJ|iE`1GmmBlQ{wX6;(MjDeNr#1K;$J>)ACV??(xjXLAqfk=x@+Am0F`^pyrL z+ljeQ+~R!k8sZwiXzDhlVG^smruq=oOO#j26s*}*!D!9ma5^sAfI5WxZH|y{;_^4! zTBr7sYD#gGpXy1!?q-!es>7sjZFzsm z_+FCG{`h8ndj&K7oag)&t9tSy{PX$(^DS?Nznr(K$IKa~=jgYA)u-ynL+{nGr?9>@?Xp9Yz+d!@q>6@jl?tLw=;b6l$GQ$-MD%a$mo^o=m!K(O`0Zh%7pk`oQUK zGqYJ+I?*z?jWOg&Q#k6^L}pe!{Q2|x5J_SVk62%5W7S(FKjw#CmV$J}&U5wk!5j=THyfebcG5*Mngu z-07e8Fu9JnDLf6@0sm*@yZLF);~w(NoxP^2q>?E+^rU)XPdy18?BPsXHB6o?d~Kus zvxl51;Y&ZVzmj<^cyMtn{1Y|7?ZUV#LuAXV7tKO`%}i@xp8lrlHfAJCBt6NhiHv(? z=Q41&hfI7GF>m~lL6UnsS|RgLI~lyp=OW@%LpVG4+t_sXkS`{tdlg{6`UYbC&#$zT zo3o8yJx;17K7oB?_NgB7K>f^KnX*Ars<$&g`anB*R-9L-wY-LKc#1gYLVo8JKXWDU zwlK+QPlHq@Kz@LlFqi{V`s?_S?OD0)8>w1ny4A^7jxT~X5XM7yNV{#DL&!^_tdxe1CV`<>Cc}ZA`{pm8CmK6NwmHBV+;m|2lntr4jgZS@%xLx1pUpxut#O zDPIlYe~~`W4ZnS8f??Mj*#FX#cBk^{+R4?)6NRNORg+W2HI|xp6XiXrgQViq z38~4c?PS`_@AdDe)DVeJ^XdlR1cGBOu+;@;{adl8w zat!#&=704P;ww`|UL|tFFzGF8TosQvtgmNwI`7^JX5*X2+Q(n($&;L;Qy#*;LN9&X z(ZbhDHssz6KOb7od|j6)F>_lz;e5Y+RZjj8d2KM)?|e}+GhO)fE48a_%!UD5uH|$S z@r~(yyY77tIoEn**H_CylJqRka1BQXac>v-HVXXWo?j^FXgN&A)!XSvwL*V)-(Jwc zQ^jbQIO(g!)RAjHq)YSEhRI;#yZ2w=-^Y2_LWX~*ht z?@Zpp<$4d19%jp^-ZMz%bgs1jg^$(`7mr8-KldCQ&@P32UVme}sbNPm6C5kE>WX(8 z)4L{3JQnkl8d4NkC^Jm9-*lO3!QV^DDwO9R_pD&%1nsEz`dLqu2drCK5Wg5qYWb25 ze033Q&s!c-!Q8M>y*%w^J?Y+>{A?ZYbIPnkO-tbid4KRaYZU@NY`5i~4z451M-@ZN zRWeDt=Mzt^{n<>%t^(N???!MBq^#{6okEVDKX!NSiA<8VKj{hwUk>9YVXiQO&%Z>C z7mrz=MBZ`E6qi{)Ox_&vey)HxHSP82s%KV}%&wAKY(|so$um`J9<_5rL~oVxHS_Xj zMqu^n>$d)FOzD#;T*E0%L|*c8)Lp}LV%iuZq0*GYtbQ}A`}O+~((7zqb#?jyLLV7T za+!XN^u*LVZ(eYc38eR>ZpG(bw`F|l(hd@r*q2>wC0Rt1%DtwgpU+H;<}{;Tj}R`s zo{d~*63L`MA@c*zGDuQPt*dYADQ3y-{&vr|Bcy~+Lm_x1o&+c~d`*Y_WS=5`qxgjKxzIt=+}AD;6>T{?>Fn7&>3dem`pHfPDOOGggV(R6Li9`N5% zQkvab8%uId8w$uC$sp^)$NOAz&tYyUHwYBt^UF`p$;xsaAa~j41z$chM1-f$viH0K z`<}AU>?`csX~(|IC*@6KQAVGF6XJU=?#DBqST-|;@?Wy+f&WqqRA%0DXd;S2lDFb& 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

    DC(|ds-t{E~${tLUe5*-(ALjjf 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 literal 0 HcmV?d00001 diff --git a/python/tests/test_Result.py b/python/tests/test_Result.py index 11395b23f..77f651b2a 100644 --- a/python/tests/test_Result.py +++ b/python/tests/test_Result.py @@ -20,6 +20,13 @@ def default(tmp_path,reference_dir): f.pick('times',20.0) return f +@pytest.fixture +def single_phase(tmp_path,reference_dir): + """Single phase Result file in temp location for modification.""" + fname = '6grains6x7x8_single_phase_tensionY.hdf5' + shutil.copy(os.path.join(reference_dir,fname),tmp_path) + return Result(os.path.join(tmp_path,fname)) + @pytest.fixture def reference_dir(reference_dir_base): """Directory containing reference results.""" @@ -296,3 +303,7 @@ class TestResult: def test_vtk(self,tmp_path,default,output): os.chdir(tmp_path) default.to_vtk(output) + + def test_XDMF(self,tmp_path,single_phase): + os.chdir(tmp_path) + single_phase.write_XDMF From 9732726cfa2ce649f1a321b078d1fa99cbb5c364 Mon Sep 17 00:00:00 2001 From: Sharan Roongta Date: Tue, 26 May 2020 11:46:28 +0200 Subject: [PATCH 121/136] editorial changes --- src/YAML_parse.f90 | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/src/YAML_parse.f90 b/src/YAML_parse.f90 index 75a59f342..1586d9169 100644 --- a/src/YAML_parse.f90 +++ b/src/YAML_parse.f90 @@ -1,3 +1,10 @@ +!---------------------------------------------------------------------------------------------------- +!> @author Martin Diehl, Max-Planck-Institut für Eisenforschung GmbH +!> @author Sharan Roongta, Max-Planck-Institut für Eisenforschung GmbH +!> @brief Parser for YAML files +!> @details module converts a YAML input file to an equivalent YAML flow style which is then parsed. +!---------------------------------------------------------------------------------------------------- + module YAML_parse use prec From 8ae7f8f9915d31f705fdd3775b2db5d369f0743d Mon Sep 17 00:00:00 2001 From: Sharan Roongta Date: Tue, 26 May 2020 20:56:53 +0200 Subject: [PATCH 122/136] polishing --- src/YAML_parse.f90 | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/YAML_parse.f90 b/src/YAML_parse.f90 index 1586d9169..5bbba8a4f 100644 --- a/src/YAML_parse.f90 +++ b/src/YAML_parse.f90 @@ -12,7 +12,9 @@ module YAML_parse use YAML_types implicit none + private + public :: YAML_init public :: parse_flow,to_flow From 31f72aa91259217b9816bb0ec72d7ba4fb10aa6b Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 27 May 2020 17:36:30 +0200 Subject: [PATCH 123/136] handle min/mid/max eigenvalues/vectors separately storing as matrix/vector is not favorable for paraview and in many cases, either min or max are of interest only --- python/damask/_result.py | 56 ++++++++++++++++++++++++------------- python/tests/test_Result.py | 22 ++++++++------- 2 files changed, 49 insertions(+), 29 deletions(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index d0f437d72..4dbff3736 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -568,9 +568,8 @@ class Result: 'label': 'sigma', 'meta': { 'Unit': P['meta']['Unit'], - 'Description': 'Cauchy stress calculated from {} ({}) '.format(P['label'], - P['meta']['Description'])+\ - 'and {} ({})'.format(F['label'],F['meta']['Description']), + 'Description': 'Cauchy stress calculated from {} ({}) and {} ({})'\ + .format(P['label'],P['meta']['Description'],F['label'],F['meta']['Description']), 'Creator': inspect.stack()[0][3][1:] } } @@ -638,17 +637,24 @@ class Result: @staticmethod - def _add_eigenvalue(T_sym): + def _add_eigenvalue(T_sym,eigenvalue): + if eigenvalue == 'max': + label,p = 'Maximum',2 + elif eigenvalue == 'mid': + label,p = 'Intermediate',1 + elif eigenvalue == 'min': + label,p = 'Minimum',0 + return { - 'data': mechanics.eigenvalues(T_sym['data']), - 'label': 'lambda({})'.format(T_sym['label']), + 'data': mechanics.eigenvalues(T_sym['data'])[:,p], + 'label': 'lambda_{}({})'.format(eigenvalue,T_sym['label']), 'meta' : { 'Unit': T_sym['meta']['Unit'], - 'Description': 'Eigenvalues of {} ({})'.format(T_sym['label'],T_sym['meta']['Description']), + 'Description': '{} eigenvalue of {} ({})'.format(label,T_sym['label'],T_sym['meta']['Description']), 'Creator': inspect.stack()[0][3][1:] } } - def add_eigenvalues(self,T_sym): + def add_eigenvalue(self,T_sym,eigenvalue='max'): """ Add eigenvalues of symmetric tensor. @@ -656,33 +662,46 @@ class Result: ---------- T_sym : str Label of symmetric tensor dataset. + eigenvalue : str, optional + Eigenvalue. Select from ‘max’, ‘mid’, ‘min’. Defaults to ‘max’. """ - self._add_generic_pointwise(self._add_eigenvalue,{'T_sym':T_sym}) + self._add_generic_pointwise(self._add_eigenvalue,{'T_sym':T_sym},{'eigenvalue':eigenvalue}) @staticmethod - def _add_eigenvector(T_sym): + def _add_eigenvector(T_sym,eigenvalue): + if eigenvalue == 'max': + label,p = 'maximum',2 + elif eigenvalue == 'mid': + label,p = 'intermediate',1 + elif eigenvalue == 'min': + label,p = 'minimum',0 + print('p',eigenvalue) return { - 'data': mechanics.eigenvectors(T_sym['data']), - 'label': 'v({})'.format(T_sym['label']), + 'data': mechanics.eigenvectors(T_sym['data'])[:,p], + 'label': 'v_{}({})'.format(eigenvalue,T_sym['label']), 'meta' : { 'Unit': '1', - 'Description': 'Eigenvectors of {} ({})'.format(T_sym['label'],T_sym['meta']['Description']), + 'Description': 'Eigenvector corresponding to {} eigenvalue of {} ({})'\ + .format(label,T_sym['label'],T_sym['meta']['Description']), 'Creator': inspect.stack()[0][3][1:] } } - def add_eigenvectors(self,T_sym): + def add_eigenvector(self,T_sym,eigenvalue='max'): """ - Add eigenvectors of symmetric tensor. + Add eigenvector of symmetric tensor. Parameters ---------- T_sym : str Label of symmetric tensor dataset. + eigenvalue : str, optional + Eigenvalue to which the eigenvector corresponds. Select from + ‘max’, ‘mid’, ‘min’. Defaults to ‘max’. """ - self._add_generic_pointwise(self._add_eigenvector,{'T_sym':T_sym}) + self._add_generic_pointwise(self._add_eigenvector,{'T_sym':T_sym},{'eigenvalue':eigenvalue}) @staticmethod @@ -819,9 +838,8 @@ class Result: 'label': 'S', 'meta': { 'Unit': P['meta']['Unit'], - 'Description': '2. Kirchhoff stress calculated from {} ({}) '.format(P['label'], - P['meta']['Description'])+\ - 'and {} ({})'.format(F['label'],F['meta']['Description']), + 'Description': '2. Piola-Kirchhoff stress calculated from {} ({}) and {} ({})'\ + .format(P['label'],P['meta']['Description'],F['label'],F['meta']['Description']), 'Creator': inspect.stack()[0][3][1:] } } diff --git a/python/tests/test_Result.py b/python/tests/test_Result.py index 77f651b2a..5ceebc1c4 100644 --- a/python/tests/test_Result.py +++ b/python/tests/test_Result.py @@ -132,21 +132,23 @@ class TestResult: in_file = default.read_dataset(loc['s_P'],0) assert np.allclose(in_memory,in_file) - def test_add_eigenvalues(self,default): + @pytest.mark.parametrize('eigenvalue,function',[('max',np.amax),('min',np.amin)]) + def test_add_eigenvalue(self,default,eigenvalue,function): default.add_Cauchy('P','F') - default.add_eigenvalues('sigma') - loc = {'sigma' :default.get_dataset_location('sigma'), - 'lambda(sigma)':default.get_dataset_location('lambda(sigma)')} - in_memory = mechanics.eigenvalues(default.read_dataset(loc['sigma'],0)) - in_file = default.read_dataset(loc['lambda(sigma)'],0) + default.add_eigenvalue('sigma',eigenvalue) + loc = {'sigma' :default.get_dataset_location('sigma'), + 'lambda':default.get_dataset_location('lambda_{}(sigma)'.format(eigenvalue))} + in_memory = function(mechanics.eigenvalues(default.read_dataset(loc['sigma'],0)),axis=1,keepdims=True) + in_file = default.read_dataset(loc['lambda'],0) assert np.allclose(in_memory,in_file) - def test_add_eigenvectors(self,default): + @pytest.mark.parametrize('eigenvalue,idx',[('max',2),('mid',1),('min',0)]) + def test_add_eigenvector(self,default,eigenvalue,idx): default.add_Cauchy('P','F') - default.add_eigenvectors('sigma') + default.add_eigenvector('sigma',eigenvalue) loc = {'sigma' :default.get_dataset_location('sigma'), - 'v(sigma)':default.get_dataset_location('v(sigma)')} - in_memory = mechanics.eigenvectors(default.read_dataset(loc['sigma'],0)) + 'v(sigma)':default.get_dataset_location('v_{}(sigma)'.format(eigenvalue))} + in_memory = mechanics.eigenvectors(default.read_dataset(loc['sigma'],0))[:,idx] in_file = default.read_dataset(loc['v(sigma)'],0) assert np.allclose(in_memory,in_file) From 85c6d751a86fbf4cff26e959c45662bdfda73c5f Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Wed, 27 May 2020 17:41:20 +0200 Subject: [PATCH 124/136] functionality available in HDF5/python --- processing/post/addSpectralDecomposition.py | 58 --------------------- 1 file changed, 58 deletions(-) delete mode 100755 processing/post/addSpectralDecomposition.py diff --git a/processing/post/addSpectralDecomposition.py b/processing/post/addSpectralDecomposition.py deleted file mode 100755 index 01371cede..000000000 --- a/processing/post/addSpectralDecomposition.py +++ /dev/null @@ -1,58 +0,0 @@ -#!/usr/bin/env python3 - -import os -import sys -from io import StringIO -from optparse import OptionParser - -import numpy as np - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - - -# -------------------------------------------------------------------- -# MAIN -# -------------------------------------------------------------------- - -parser = OptionParser(option_class=damask.extendableOption, usage='%prog options [ASCIItable(s)]', description = """ -Add column(s) containing eigenvalues and eigenvectors of requested symmetric tensor column(s). - -""", version = scriptID) - -parser.add_option('-t','--tensor', - dest = 'tensor', - action = 'extend', metavar = '', - help = 'heading of columns containing tensor field values') -parser.add_option('--no-check', - dest = 'rh', - action = 'store_false', - help = 'skip check for right-handed eigenvector basis') - -parser.set_defaults(rh = True, - ) - -(options,filenames) = parser.parse_args() -if filenames == []: filenames = [None] - -for name in filenames: - damask.util.report(scriptName,name) - - table = damask.Table.from_ASCII(StringIO(''.join(sys.stdin.read())) if name is None else name) - - for tensor in options.tensor: - - t = table.get(tensor).reshape(-1,3,3) - (u,v) = np.linalg.eigh(damask.mechanics.symmetric(t)) - if options.rh: v[np.linalg.det(v) < 0.0,:,2] *= -1.0 - - for i,o in enumerate(['Min','Mid','Max']): - table.add('eigval{}({})'.format(o,tensor),u[:,i], scriptID+' '+' '.join(sys.argv[1:])) - - for i,o in enumerate(['Min','Mid','Max']): - table.add('eigvec{}({})'.format(o,tensor),v[:,:,i],scriptID+' '+' '.join(sys.argv[1:])) - - table.to_ASCII(sys.stdout if name is None else name) From 1afa00a19c8a197bde2d8e19bf4c54c55c120d42 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Thu, 28 May 2020 08:05:02 +0200 Subject: [PATCH 125/136] testing systematically all possibilities --- python/tests/test_mechanics.py | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/python/tests/test_mechanics.py b/python/tests/test_mechanics.py index f7128401f..5fe79de28 100644 --- a/python/tests/test_mechanics.py +++ b/python/tests/test_mechanics.py @@ -63,25 +63,25 @@ class TestMechanics: assert np.allclose(np.matmul(R,U), np.matmul(V,R)) - def test_strain_tensor_no_rotation(self): + @pytest.mark.parametrize('m',[0.0,np.random.random()*10.,np.random.random()*-10.]) + def test_strain_tensor_no_rotation(self,m): """Ensure that left and right stretch give same results for no rotation.""" F = np.broadcast_to(np.eye(3),[self.n,3,3])*np.random.rand(self.n,3,3) - m = np.random.random()*20.0-10.0 assert np.allclose(mechanics.strain_tensor(F,'U',m), mechanics.strain_tensor(F,'V',m)) - def test_strain_tensor_rotation_equivalence(self): + @pytest.mark.parametrize('m',[0.0,np.random.random()*2.5,np.random.random()*-2.5]) + def test_strain_tensor_rotation_equivalence(self,m): """Ensure that left and right strain differ only by a rotation.""" F = np.broadcast_to(np.eye(3),[self.n,3,3]) + (np.random.rand(self.n,3,3)*0.5 - 0.25) - m = np.random.random()*5.0-2.5 assert np.allclose(np.linalg.det(mechanics.strain_tensor(F,'U',m)), np.linalg.det(mechanics.strain_tensor(F,'V',m))) - def test_strain_tensor_rotation(self): + @pytest.mark.parametrize('m',[0.0,np.random.random(),np.random.random()*-1.]) + @pytest.mark.parametrize('t',['V','U']) + def test_strain_tensor_rotation(self,m,t): """Ensure that pure rotation results in no strain.""" F = mechanics.rotational_part(np.random.rand(self.n,3,3)) - t = ['V','U'][np.random.randint(0,2)] - m = np.random.random()*2.0 - 1.0 assert np.allclose(mechanics.strain_tensor(F,t,m), 0.0) From 9aace811f05976dcbce08f367dba21c8539f3d02 Mon Sep 17 00:00:00 2001 From: Test User Date: Thu, 28 May 2020 16:23:41 +0200 Subject: [PATCH 126/136] [skip ci] updated version information after successful test of v2.0.3-2523-ge22e2cfe --- VERSION | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/VERSION b/VERSION index 6d4d1897c..f918509c7 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -v2.0.3-2514-g873b9fa8 +v2.0.3-2523-ge22e2cfe From 74907c933544d7c0ffe21bdd532751d84f30b4f1 Mon Sep 17 00:00:00 2001 From: Test User Date: Thu, 28 May 2020 18:58:21 +0200 Subject: [PATCH 127/136] [skip ci] updated version information after successful test of v2.0.3-2561-gf63e412b --- VERSION | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/VERSION b/VERSION index 6d4d1897c..7a175ca2d 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -v2.0.3-2514-g873b9fa8 +v2.0.3-2561-gf63e412b From 565b1eb51057c0a734ec083dcf6774c4a56dd94e Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 30 May 2020 15:39:36 +0200 Subject: [PATCH 128/136] not needed was just a wrapper around functionality in the python library --- processing/pre/seeds_check.py | 39 ----------------------------------- 1 file changed, 39 deletions(-) delete mode 100755 processing/pre/seeds_check.py diff --git a/processing/pre/seeds_check.py b/processing/pre/seeds_check.py deleted file mode 100755 index 6ef808a0a..000000000 --- a/processing/pre/seeds_check.py +++ /dev/null @@ -1,39 +0,0 @@ -#!/usr/bin/env python3 - -import os -import sys -from io import StringIO -from optparse import OptionParser - -import damask - - -scriptName = os.path.splitext(os.path.basename(__file__))[0] -scriptID = ' '.join([scriptName,damask.version]) - - -#-------------------------------------------------------------------------------------------------- -# MAIN -#-------------------------------------------------------------------------------------------------- - -parser = OptionParser(option_class=damask.extendableOption, usage='%prog [seedfile(s)]', description = """ -Writes vtk file for visualization. - -""", version = scriptID) - -(options, filenames) = parser.parse_args() -if filenames == []: filenames = [None] - -for name in filenames: - damask.util.report(scriptName,name) - - seeds = damask.Table.from_ASCII(StringIO(''.join(sys.stdin.read())) if name is None else name) - v = damask.VTK.from_polyData(seeds.get('pos')) - for label in seeds.shapes.keys(): - if label == 'pos': pass - v.add(seeds.get(label),label) - - if name: - v.write(os.path.splitext(name)[0]) - else: - sys.stdout.write(v.__repr__()) From 421b8f4268e5d4fcec6fee35b7ad5ea76a113716 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sat, 30 May 2020 17:31:50 +0200 Subject: [PATCH 129/136] documented function interfaces --- python/damask/_geom.py | 42 +++++++++++++++++++++++++++++++++++++----- 1 file changed, 37 insertions(+), 5 deletions(-) diff --git a/python/damask/_geom.py b/python/damask/_geom.py index 2609fe537..1ec89d8b2 100644 --- a/python/damask/_geom.py +++ b/python/damask/_geom.py @@ -533,8 +533,8 @@ class Geom: Parameters ---------- - grid : iterable of int - new grid dimension + grid : numpy.ndarray of shape (3) + number of grid points in x,y,z direction. """ #self.add_comments('geom.py:scale v{}'.format(version) @@ -584,7 +584,17 @@ class Geom: def rotate(self,R,fill=None): - """Rotate microstructure (pad if required).""" + """ + Rotate microstructure (pad if required). + + Parameters + ---------- + R : damask.Rotation + rotation to apply to the microstructure. + fill : int or float, optional + microstructure index to fill the corners. Defaults to microstructure.max() + 1. + + """ if fill is None: fill = np.nanmax(self.microstructure) + 1 dtype = float if np.isnan(fill) or int(fill) != fill or self.microstructure.dtype==np.float else int @@ -609,7 +619,19 @@ class Geom: def canvas(self,grid=None,offset=None,fill=None): - """Crop or enlarge/pad microstructure.""" + """ + Crop or enlarge/pad microstructure. + + Parameters + ---------- + grid : numpy.ndarray of shape (3) + number of grid points in x,y,z direction. + offset : numpy.ndarray of shape (3) + offset (measured in grid points) from old to new microstructue[0,0,0]. + fill : int or float, optional + microstructure index to fill the corners. Defaults to microstructure.max() + 1. + + """ if fill is None: fill = np.nanmax(self.microstructure) + 1 if offset is None: offset = 0 dtype = float if int(fill) != fill or self.microstructure.dtype==np.float else int @@ -629,7 +651,17 @@ class Geom: def substitute(self,from_microstructure,to_microstructure): - """Substitude microstructure indices.""" + """ + Substitude microstructure indices. + + Parameters + ---------- + from_microstructure : iterable of ints + microstructure indices to be substituted. + to_microstructure : iterable of ints + new microstructure indices. + + """ substituted = self.get_microstructure() for from_ms,to_ms in zip(from_microstructure,to_microstructure): substituted[self.microstructure==from_ms] = to_ms From d1e38d7b198bfefcd29057e7a1a3a9cb649ab558 Mon Sep 17 00:00:00 2001 From: Test User Date: Sat, 30 May 2020 22:46:31 +0200 Subject: [PATCH 130/136] [skip ci] updated version information after successful test of v2.0.3-2614-g4b6b9478 --- VERSION | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/VERSION b/VERSION index f918509c7..2ef4c00dd 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -v2.0.3-2523-ge22e2cfe +v2.0.3-2614-g4b6b9478 From bcb0ce5e5e58236ae77256e61b778470a24d65ee Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 31 May 2020 18:51:12 +0200 Subject: [PATCH 131/136] typo --- python/damask/_result.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/python/damask/_result.py b/python/damask/_result.py index 297566174..73a038c4c 100644 --- a/python/damask/_result.py +++ b/python/damask/_result.py @@ -36,7 +36,7 @@ class Result: Parameters ---------- fname : str - name of the DADF5 file to be openend. + name of the DADF5 file to be opened. """ with h5py.File(fname,'r') as f: From c791408fbded0f4a541d127218a576524b67ad3d Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 31 May 2020 18:57:09 +0200 Subject: [PATCH 132/136] updated tests --- PRIVATE | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/PRIVATE b/PRIVATE index 8dde2a685..2a0a64692 160000 --- a/PRIVATE +++ b/PRIVATE @@ -1 +1 @@ -Subproject commit 8dde2a68538b7cffbe9d370e2b60be90a31627ab +Subproject commit 2a0a646921c7537a3a47063405bc96b59ebc587a From 421046d98b5c1f1fc23cb51781085d95d2a459c0 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Sun, 31 May 2020 23:53:06 +0200 Subject: [PATCH 133/136] cleaned PRIVATE --- PRIVATE | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/PRIVATE b/PRIVATE index 2a0a64692..59c330195 160000 --- a/PRIVATE +++ b/PRIVATE @@ -1 +1 @@ -Subproject commit 2a0a646921c7537a3a47063405bc96b59ebc587a +Subproject commit 59c330195596b359355bb22d8cdc8cae9246992c From 9877eb746e150dfec4f0edaea1addf905c5a433f Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 1 Jun 2020 09:10:15 +0200 Subject: [PATCH 134/136] contains fixes for MSC.Marc-based tests --- PRIVATE | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/PRIVATE b/PRIVATE index 59c330195..33d320249 160000 --- a/PRIVATE +++ b/PRIVATE @@ -1 +1 @@ -Subproject commit 59c330195596b359355bb22d8cdc8cae9246992c +Subproject commit 33d320249d0955bbbcd0cf2fdcc6791ef20e066d From 789bb0fbcb726ce9cd1faef0813b9d35be281923 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 1 Jun 2020 10:45:11 +0200 Subject: [PATCH 135/136] still fixing MSC.Marc related errors hard to write proper code without being able to run it --- PRIVATE | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/PRIVATE b/PRIVATE index 33d320249..f65dbec66 160000 --- a/PRIVATE +++ b/PRIVATE @@ -1 +1 @@ -Subproject commit 33d320249d0955bbbcd0cf2fdcc6791ef20e066d +Subproject commit f65dbec66a4c961c7d30f58acffb0a806aef0f29 From 404c065923ac02cbd8be36da4954f2c063a56832 Mon Sep 17 00:00:00 2001 From: Martin Diehl Date: Mon, 1 Jun 2020 13:13:28 +0200 Subject: [PATCH 136/136] one more fix --- PRIVATE | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/PRIVATE b/PRIVATE index f65dbec66..a6109acd2 160000 --- a/PRIVATE +++ b/PRIVATE @@ -1 +1 @@ -Subproject commit f65dbec66a4c961c7d30f58acffb0a806aef0f29 +Subproject commit a6109acd264c683fd335b1d1f69934fc4a4078e3

    Gaile`@f3x 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ç^aa-|F)P=83wKEG{X~aA)Jm6U-M} z|5()+i{qkRqF12}y##SA#a!?6<3ZG*6hlTZVU%AKJymRnqe?9{G;xr;VXrUD!83^Ssi`4ic|94G!^Ik)AD#iOPr% z=|w`fKFN-Nb%Tn_IR$*AvFm6aqf7*eHpq}S#Q1*h=5e<`{LWRHoA>$f-ASdIcNXbO ze&oCIpU(gKqDa$T(iQ1L0l&~+@?o5rFgu}T|9!_nf9Zx80M$KDl@e#$HcyzLuiL^$PK`(5C%7sE;jBbP6N?Mw8U#x?-ngA9%a| zpVP>haJX^MUS-IJ0-_a%44$J-?r1enUu=l)3})KbD@{j&JA9 z+>H}^jd~sJN2*UV!2~#KbQaX3@EuQ&cm~9)rG@|9vQ2V^mH`L#-)G|pZ?#g+W4;Se zCmA^zfI5PpWx2P}F!qb)6|;$*v?n(s*mXV$*a4HgbjT-s=PIN6x<{rc>SJy9{3{-N z!2X=FsoUd$M4h4VQ>Csv5wssTJBRTC3&;P+An!?G$tz1Zy@PmjeWq;w7D58JIGUtd zJc&ly{Kn<87*ChQX6|vO!N%F<$1ev|$;A!PZ!OY^L?U1ttl)e!HD4SuLEdvD`Do9_ z`&qzoLY*nq$(LlmSoEDuS0XGjG9ZZYeSsxB!@tS~s{Xe59V?6j&f#8{sAW4MY^0O2 zhH-G)qonF(9qfZjYPA}0@`w9l1xitjZsg=)wfVeZFH+_3pMeJInbYsLJny2@0p^C) z3fska7*g&xk&?{-Vc#E|ymzqf!fGv1-wpNt;jc_1HBOM*6%@i0tVR?cSF>+T@+YpI zeyuyu|LoEbFCF@F3C{JMFu2@zmeiQ|jBnxyBO?8g7k43^yDpZwMD-E%zx%sp-`&-ALfbtKW55znn19w@sabNqsZK?PbWfn{7JvZ zXuCD~LyJM`(=p|4V0bxGP2r3T42~YxJ^ncxMv70!T|nMc7N&ZewPXoQi#<;(T#F|( z?RgfD?s$>q+YySIHOcVS%V8fc;=`bW&au&ZG+~r{<6YtOgdJ7x{ibf3V8Ws-9NvNc zVlwAI{9!zgH}l!|NCp$hDIWbz-@^%Gy2P=^souc#sP05d00sJ%cJ?a2)Q5!(gvu+4 zus6E=-*oOuoNF+&zwzj~23k7tM{eFz|lTWaS|I$wk%XAGI$B_d#=c+l7e z@v{>Ty@uvCS13PDm;NSL2?j2Cgv(lFk>E=nDSuH<0M63WOlHWxmIdj%?kT{xje_sH ztui2XZyJZ^2G%JI(9K5LQb5=!(lowa6b^cKD)BT0kx07h`n7g0a7aQV{~O{Ba;;@K zALDzX`4i?Z=8=#d_&%ZQu02_N#8OVt4k9e8HFop3U)L6<$fsk`03=woLp~TfYMSof zkoO=iO}yTJdXO(&PS);F^>F@*KTvP@pD;P?53l_h^{gH2NLhc7mZTvCWJ^7M zC@Lp_thkm8&o2i^`9@)6HB{eI)Z~e90cZJ#|IR7J z68gb!Qr$EZ@Y*T&XC3`wzwtS`pI7~ z_s71^`CVHDqG39>LyhKwJxFzAah7A;k&-aEBe;lp1HN#}-e)eb?sA`m3YZhWBtgYe zc6;(h2Wv_WQ{da~@$Yl{{9pi*H)o1_fLn!#^m?TSJUy<;`VGHR%*dlNSA^@lFm*u8 z(-_{+m)vTkGbG>ctzRmRvL#KF2SfXvDd2W3>eRsA1em^-s-g8jhG_mQ+%3323YuGf zE;wajKEUrD}{C8MQw0vtg@o#(k$Kg;MT$=hE8LJckm%5j{xjwFJaw|l9ge!|eU4SmgjZiRZ+z~J z#P^^-Ua;52ycPRqcc;}9XrkWqmy;!mY>8?m!@ zgmyZ^tbL^jb)+~o*2B*s7I=Mxwl<#fB2z*ZR=-OwkvYTfX$`6rC{*Hs`!_s*QZ9Am zHgzI+CypMHwvY@lJtAkc88Gf{$4rO@!{d~EyzXRg_oQg550|{YK-Vd0^n0qu$H*~>{oQEyC z4#TmKSRxc&1D@cQk;3&D^Z1H;FLh=tL;~}UyR-3anxtP1lJ5*y5yPJ+ZI1LIe(n_) zQ$t>O`TW984sJitKiI7^*wnaTlxdW zv7yHT5A2L1NX2W%$9(yIU`Tao#`%{PjF_5E+gV`#!U>v^`V5Ffy9~WbnKAtBtjW@v zvL@HtvbXKbN4~sQ&1||J_1YWth4I1B(Ad#_x#Mp*$iHIS)AvObbPfMzN8o-5GqP)b z7+Y@sG&ss%fbR|a@yyf)vYWwb#AmLhn@jM@{C%wB-6aU*E|7eXYXDr_nm27kyx~Y} za)R7v7cd`v;&Ivxu!BOi!@MExH`klc_BBx|Z&X*>;xv)al5 zWyJF#iu;5_pJP2y_WG*Yx6?2nR;X~fI}&F6IVE;VSc0nmi%s7Ec}m58X`R0Fgr(<+ z_K1Tiv~K^fGjq%Y7)qrSCZAzmc!r%==c0WG-FnvX$BCE~9P_z(NfH((OOz|OM395b zL3h~Dz9yfRJT!@kfw&^xOO9@)4PiCvbq7Bx!T+P~b^}a5- zS^cvh^`;nHYC5vWzh4_@Et!rN#vuOL*AVh~%@uKLuBV=qETM?${$5mzf^7$~cJg1t z_3>mmicOUuf85IS40|BaQdo%zQgi@*=D72FX(D0x9xX!&`VEFAS-$e^(oh;DnB_LWzo#szM$qhZ4OL9;VZK85Xitzid?5_-m2 z$SaGfrX!R;_>x`yRWqm5ya+Rshn}|bMYtvBHMR}U@fZioOLf%gWz9!tZd7XmNZ;Po zMa4`$Zsck^xA>8Gi@PuAWGL|EtS-avL3j9`7_o6p+=4vZOyci84J7oHhY!%AE}9-N zbD0)(jss7;VneKA;frJs(@UmsQu1`y7E2R%LNUu``;NGmYs6gpvA+zly)sp^cG(AJ zCbJwU!e-#PGq1s+0`rSHQf=BeE;sPyWNwdy)weEz_4mR_qv4!VP`n+ns^f|(JCFV_ zSbi@%Z2%mOGm@th@B>w&KlNMbjRBS`7Ey-XV77oOl2?pbT-&UyGJ%Of0Y zEw#SfXK^GZRq@wCQKu#MtOVO?jlm|mV98W6mPpO`)m8S{6E_cz2fKZN*1ftw$3G6P+&8ZE{f`5<8OG^$p#L!rF6nvn#RIlz$a%8PI+K-c@%u)X zJ&2Cz)o}Z2%zNI9%D;f;u+vl{>Cm1i@;A#%C3Sc+RBGDZQueinR*f?DYgpGrGIVRl zmF?jmZGak}%| zh_o^2hW^I-C@zl-(Ht5d5<)Y;!&D|sjY-(r1;CB6!YJ``?$B4&er5o52?LcV+xSCHgmtmerCCOYC~ExZ7A_8evzLxH zMxZ{jsM?GOIpLV?&{aDRr0llK*o{$ul zEMwgmPd1;iHqK=f2Hl>bClkoy-g5^Xn5h=ei8J_n_7La4>thz6 zd6H_2kJxddBS!!9!h{V8UQEuE#&}v;Bevc`Nr0PU+%{z|6JWPQVj=gMFJag(vAF{I zf11jKt#B3YzwIlYj?WG-{N9cxt1=LpKYiLbon}q+Uw6BfN>RYptz1w|R}9?du6+Jj z??Hwv?8jetdl9wg;}<$ne=Oo)?sP=lqQu^6ERvv0jz-(A(V_q1^>;`yND2qaJ4J`n z$lvR9_}xoe+(>2jZ$8~7UpO`VepWQWme9?54msj?M9r6eX5e_D>ebu&zAKZ-Q+0;h zGvZ)E*F$&lZYU&msCo+T1jYPY2YoR^C)|CHkiGxC{x{bb@3d-6cTcIa1|H_2pBR?zx_byn^>i_e5E zK}_Qh>paJ3@GyPdyH7g`29yjn-OQqhwqHy332_Q=aJ{Skvm{AM-|T8RttLl0-rYX` ziX(~abf;&Uq^H3B%RT4RFfKcAs8{5-p+1`u_JTb!5V)azv%?QP;HfHe=+~lvl+!`J z@r#}$#Ob~1@ab@n*ypr!zE=CkCH3juI&$$a|SE5H>!M=s!*gd{oukyo+aPG1p zB###`FJqi||Nbvtm%0SE;MaoKm?tbZFWvC}8Vk18{2vbm*pPKGHhCk|qeP?}p9X6A zK>gJLaiNSr@^aQex}M3K(7Znp8HYF{&+4OYBRr39S3voZ8F`$=v;p zUpyF3B}A;gcW2>wG~IK4;F2>Wm*`uDqTVN=e&nmLq$wz$WEqpe_$8ovGhNJ4iySUI zb=X$i6LKF_XMbl8CN+(F-I);=(&ZhBkaNMh>OP!mgXaO3x-)2iVx z{_XnRCx{REZ&^+CSSS$M$>uE#uTYn$tqWK>6G*m8ik8v8T*7-xdJpp8dS5AI>{vMv zMC^xti|%|SK&WUKSA6&d$*9M8i>(5*Rl)qDTbLqb3`?rs2>)IG^KZi=ilyb@(vS%e}$Z13K5UR2*-*i)7g;s$MrM5 zM+Fj-$8l`ciNGH5$608ugu9B{Vn4N?-zI*rDd?s|D5oX~#U z+x=545$w#^pC@WX5RQQJ9UqVn9;NxOB~#H3woOVtnq-wFO+FUhQlTbL9AMMPfZ-zQ3H#$2yY8Ow2I0gX(oMfD z$SGCtrPYR1aGEs#upRMXcGtrMmsHg23Qsk#>ROU9E}eQIHbY>w;>v21(}bX*9S2e` zQQ)9Z>wGzz6-iwXy}uFZ2>ZuBCPj80CRX~?`QN*+Ufts6-~5^-IMXL_=y0qf+zZq* za6RWl&ZIrF;!3b4tMLg;|L09Y6$?)p9D+$1Q(Rcheht{q6!%s3rz~m9D|HLO__xJ| zs`N72z2iXz6Dw{bc>G+`q0%4(?^#;e_Bh_2sA+ZvUqgKOPR3F9MTs^MR+HWKILMyx zo?CzS>a`Owkr1cm#Pjo&S$|(W+L!ksHtVDHK}7Y&*pGrd53ukgu`O0|#CvL5cnWpM zBt@pb#WF_Z1$~8V(X=)kH#Fq3VF-qu>+Mz_-Y!8+byLizyGzhjM~Z#s;z-P?N`QlGD2I+A|%d7s^o+RbMHlgeEZ!q`iK*pOXq^CfD>>sabH0^nBSY1jLRSF5WOsbB5z1hXBvR|ly~{vWA-R)|}Dol^2Q%*lxRQ>z20leCzZ z(+hkzBoR&pRJ(a2NP$P>mX=e&FnVo^NK3^Me52kSeq#u6_>kT!B{w%1%xUOS+%5z8 zx(nW~*MCaArDDA&j(R35pYqdoc2DxeZ*j$IREwClr{0)+;Y+UjxJH~t{?FaUq~Cye z{zLwy(N}BA#MQR8P5pQn*mrtwuYRlr_F5B)SKKL36eL-#RUA&}oD(a%RV|60N&cZT z{f0!0iBIQT9_kWuIzQO4u4%MCO#jn24d8Cywc_3g;Lmh&{1I~?p__R`%J4kjx&629 zQ>6)%H|$wc@rr_#Y{_Y^8{Ql)MvxqMHa+dN4?D=&dI?%m>h02;%VNoECo7? z)P2cn;J2py-vsWv4y%GX`&LhK@n!P@ZDb5|#Zq4vmP`OQ?>jI4ucsf|aklk0u8;1m zQv)0cdhj^eYK!NFBRO=1`d{rSJ20IIuFSK;e9Frs<3FVR$%h@k{2SvV$a@~~r{$j+TJA!kuf5#Eh5o1bpmwe{ zt1E1GcB!aA9YDd-wsUs7HxU`>9qFQvBB}GAO=qj^;n9oXN9QsT$J?F!){SxbT}JQ3 zk#mlazJ=!9p0_b@WO;hl)YAieZ%Z2lARp|xpSY}l&I;;FKAih8A_t{j8r`g{A!Iza z+F$~8I!3xJS#BX%SNY)T-2yjDV!VB;R>%7k@^I+33hnhkqFKcu^Be8mX{Iu4*}@W( zR&7oyC}jf67OGyI@6qt;*UXg@$Okx@I&-X%e_wd27nolZgZT&3pNlgog!+0&O6BI6 z=4rCcqtqXD(F;d3Z?8E)8fT=+*or@#R+)IxHSA6b$JI(AB9?%4L@nhc+Wq3w;f-6Y zj=<;gd+4{48&IMiE*=l}gHPEUXOAKt`*UABHv#*3!n2B%_hg5WDuFE#-9?w+#Kv#$ z2Z#?GwQFDgMP2I6Fn`jf$!M6DvKQnz=uR{k>}Bak1Hr8NGnYarj^|#Fa&LA3k@RNl z4Ev6KaRZklSxhUI)gfDQ^YKmDzgbQocc|gTcUS(~L-Z+>u`BGMZb-u3ueD3Sv zI=gd}a%?!DzA+;EUF=3G^c&2o@=RSI5`8EC6nG>Mwxe(MOJLsN4o#AT@p%{0;OV#M zCJ_(nCu-yVBxsX4_v_pD_h9|Th^S`A7}{6l_<@^pX|VR2(Sp-V1ImO(zsq7D(ve>6 zv(Nb{VDv#Fu5};QW4M2OX_tfg{-4V#V%;GiEHRW2h*xQg9pDiUg+@2+E0jDh~0D#HgAC~&iWRxORGt5&iepWSu39x z*2M|3@K#DOMUk898C!;BJV|xM(H9r3nR3t;|&X+?-~?6xO3g?~Q2XW1Rz zXJ1x#?e-_#6Emfs{vf{%m~61N#Jp3Tx9^)RQJ`y0m6G=|29z4K`>j)BiPMi(mpSBd zYftHhEgek2Q7g7Y?qLAg_O^*5KO&qcc3=DbWftrGSfY5GZ4u9Vy-hCW^MYY#l_8eX zeqgotb^DeW8K5u7>YhiQ`*&foEF#93{M)5WzY!b)*+%o(W{35_w1p}->=V{|U8tzk z#<)y#yI*}>GY0F|CghaXb%9B{StV3C7P2;ke_ufzvM2fYv`&Tt^o!?vHZ6Mrg?!xl zvJv~l_|2r-C$aBFC#-gQ8SzW*gBmHl5VFw9`R3zwO~T5aWrvKV?XsTe!R>khpMrO2jERl4CMGS1pz? z%^lw&bQ|p|^4xG;t{KMn93i3EkA9$icJW1ZT>x~goX9=N8A-nT68gKi&KeK7X&(t& zL01(+_FSV085fK_8l)LPsy>S(eVj&qQkyVAw6SiYCb4YD$p%>PA{>g?CGusf!-Pbo zIjJ!n8y`m;zFFS6t-sj=lJrz7Z`i~^UWWnWq543wGpcRM5yunA6W?!wd{B3SUWv|H zpNPM+bzcEz_~PxmCG@W*i1t*u`66#}IK|(*Yg7gNovl!7352UAFHPCcIKmFO#CaE7 z-zaCF_g8UTc^+!-q@sPuZezEu`A25Zbv2!V%RUtAto+J#TzXv%Kfe*uedb%Cl_LbaYKQ?n@)gqgYBLLQkA*0=w? z2tb}|BOx!kSZo1zt6G+NifrKJ=B<2tu+Gd>ywf`{2m60o+}Glokr%$O)4a77LDqcO z#`hQafLZR3_xpl<$q9qlSWEoQb&iP2CB0BW<<0$cHBAAuXPkIO8@-fXef}g?cQ)#1cLWICLoRyT2N>#QMV@PR;9)Q|02ny z1II0yTCGUb+ScyPn3u_mTWeu*N8I|EY5%{PSiHyeh+DFPAS68fkoB|92afK$oX=-X z0q^&Y&QAOFNyxoPmJc#9Ai3b^@^B~uI+up@+R^{W8YpkBH$)wJyJ=vUf()4q>X9A2 zYX$l<`^!hSIgvX%&HLEw5zn{pp~!E=e(Yld=~tH>;8Cl{Tw z?iihsC2B3BeIb{ZV79^itMU}$IuYyC(u*#H;&xt>>V7;ZsVBr41v@}$dM8*R9y|OZ zVXK}WcNVnj7+OSRwDEeo`py*-(`=modV$enPB*~^>o4_C$SniK3jhei1u}g>HwafYn}Z&4XEYG*Key2bud1U3sCRa(9$N? zVrx7c%ds!_;=83_)Umx)#szlB+mTQEZXW-UVM|U$4}!G4J>+$LT0Me%klnW+ZSJZ8 zIDOjx?oEUP#J}b|qI&8i$$f48))MD4N(nQ{#C5uHDP@0wOC;IW9>~q-rvtB*^7gVt z>XK?1x12WghuU0M|7H~%gI`)h$LlBIVC`4)YukYsXnQmAI|SqV+`o@UeqBTTkM)}1 zqrfbZ_E=etRU{e?b}4L_w41@;*Dp=NVc3`S<@8S$u_zesx=N!srcdTZQc46813=7~Tv@~YdU>ZYQ{YD=Se&7e>NhzDI zfxKKC-rLy3?{v$PYzw=Q=Q4zKJLiNa5-uXo{l|ayW{?(~@!a&sOw|ZJ^Xk626{AZ6 zn(zLtbHMr^!#_Xq=2lo;Q$Iaxi2VhUi?pP}klYyguUiiNd)4x3Yuyj{9sT1!GqVgJ zM$)^U{&gsvvuoin8L@*lnSknC)JYW0N7LDU1;MTg$$h^+MB%-Cze)>5UC8Bu^2_hg zt`;*3R_$?Io$nY}RVXnq*J&N$sT2iA25-;iRQZvh>5iOH)PI^CWW<%e>XW=F>8(2I z5hRW#Asl<$$?_BXsYdkA4_J2Iqwz)kxyR$-SLZpY;*F5;CB|qF%kMJu6OISPf-NUT zFz)=V-%)ARC%JPy~FN&)&1Abs^{1?qJi zuj6$;|2Ra1O)7sTDkp)zp8l@!FH$5U_juFagM2*bpG~iJh}yQrz|fVbz;!oK z;_kD4jyEuwTu{iLN=H0z#eUXs?Xn|0%FYfxkP=D8h98a`mvbilHYxIoHUsufvWuZN2TksAX({oO$GB!$Nxp#F0M-?AL-w?mZN>8vbdcx z=86K%OMfg5pj}b&eDc#UK3mpWzEU{o10==Um}$)9PL+#~9!aF*edeeJtneU&{aM&Fg5Qr?LkFz(9`rSbeZPNlrIn z(e?3%piQYkhPck-u}-#ESQA<|EW=i*O~#?&%wXF zUb-U#poU8SX<7pLD=p2Ult0Cm#tL$^ev(6x)<1ctD-XDA< zf43_6V?X0Fec9yah@VwXcKFT2!-B8L;~S^E5yxK^D104AXodJcw_!cWJ=23W+e|#j ze6Hc4)}4t^l6EL8yupr$YnntXVt(+E^H-Js_fPP!Xo)wPUIzWI>C9RgcBJIfx3;9L z4Dx8dEXyC%52p>9k}Ynjle?m7#&5oa5YgL0f6KpklYwqF4u8~V$CoP$eYBQfsZ#hK zo3RPms}cNTrOFjHcSLyo&9K5(Sg$+&MBS#EHUC7sgBY9+ZTxlOejxZ4w5wcI^(VUT z*=qJ8@A@y$Q{i+f^2(k)x*5ci7}Q@l=qRTPi(cbn9rk+gB=GW&7}TG~jcBB{@P&~M zQWDeDeIEMT)jH^VT_Gfs()AF}A%n2Z(}ee^Z=F0&>&_cX?ocGs|Mc2IXT-=X^H>Vj zcc}zP>S5fWzRmmVpgTBe*ME^0izb~sH>r(+qR7EIksH;h18_J+v*2CPcwf42a$1QI z;*BX@u~{EdLlYjg<*X(AyErd#7We&g4PUFUmksIrmm}|bMi2TkKbUPTr5b?Qj@b>8;nkXBtgc<_4C2xrlHit$!8g)x9sRe#zPhK#6Fox|i@5_FnUEIF(QI$hWhCGYN|NJZ$?;|K~+PdS|0myiCS-+zx4$E)@tKUI~u&HBIs+|LF5@nAF}doAnY|D^ap5WRe& zE{0S`fwh*5#ltx;6TTe=)b67lDlo@jfXPcXVn!m7LyPNe970<@+AY| z(C4B7%hp(uuQa=yg8JITx|>i@AnFpVf?WN7JP8w*U#gpb5PY=KoqBhz)? zW4y<@QQKn(@BBl2r+^l6IiBTGNBR-*zBDtc8SHEOoUpK4VF~u>E@ts*M-j$0&sD__ z9Psl8wPdihF9;tx#c>e%7o#g(+}TwhFjRSGVs$+NzIAc7@TVCQzNLjj4=`WwUN*4A z^#5`GD$kVN$!Nkb{+N%G&I_K`MjfFO&?m~R+m{`YzdtzQUAddf6YjSDX6Y~uCt}Tx zlui4hh(GUPU4lB)u8XYYJ2p|k*Xf>^^aZ@9ASrtn+;N1f`-?-aXn7DDgA30R5dZK> z^UH^8dy$Y&-kzbF!6aEpSHk{{7cf2v4f>0E@2M9t&jel~9*Zb0E#!zJ-)rZysE=Ae ztRL1I+@6g*k@~=T% zy@XXy@{M;S*;Sm>db&y<#vPKW(-n2e?XSl|=?w8+h>y=AnXC+neqZb11HJmh=(XtT zmri})l^M7Ed<%8jPi|@#?<4>2c5HY0kx86f6wga+5(ceZT4AOx{vg%NbN2!2V+CvK z-)C4O;KzSutLO3}U}$xu+vrFTIr{yHs1xROeseE1OrRbhxWn%JEUhb9iI-Wt#vKb@ zE@djo0p?(lsNiLT{Z?_78njZKZe&73^IUb57D${P6sR{2fd`ImuFct)uS)W~d=B-k zhqT?U7wO{RbVUx0kTKq8Au&2~*FsdI z1i-Jd;qU9KM@AjN51cB`TasQajXxXRdM4ZUP{$i_K;16g zBfbaoYs)Tqr}Istp)6$Cwx`Pgq8xVe(S}nXIx>vYV8Mg%?%K7vI9(drPcyadqf3VI zb)oB(##qO;`BmU<^waUaZoZd}CyEnOCZ?ipj0L_wLaygM_wtn=loG)D&+Z3o8Ktdc_SY<@%wN^A~4P0*uWwD?Ti9AoraGrfbRq$?wqMfB!ZC@!sLH=lMtEUCp;bE6{HY1vys! z*<=s*zUlOzs|baX+8%{Ffj)?fT%;bLj>Jake=ghX4;sS4wRr+5#HPObiR5{Gaz=^v ze-vGJAl2^|uB0I&l$Mp0uayxM$|)oi6(vQ=s!&2^cG*&7%T_YW-n{nS^WJOSxYl)V zs3@X-@9)q0?HyzOmqjDijP=DOqm zkh2*U5<6@uF?bk zFF(&(RbsopV-8eH#kzv!V~Y(+wy5IDf#1J;9Kl!PC`&Bu1$=jBa9qT7D~G&kR{zp% zs7pjMRpIC>n7{F3LVv&>#y&TCj^cH6N1v-zMPoe)$4)6m0~4^=an$w&u2+RFX*=CA zwL-skJUDdWJl5rwwaREewLlk)I423LTyQZ*wUq zH%BE%Icwa)eT@rvXD%(Z2ic;i(n0+ff_RQc%W;#(@zx;rF*fnsv?cO=wPow&qv+ZShYOsW|6==TfxrW33pAn z*?cf}oWTn2wF`tli!(xZ|0N5I;qSSv9c$ ze14wt>sc}<;ooP~5S8}D6IHl;cj$6+!}B@qirGJef${8rygM)+`x5joLD1P9m1n+- zFt>2V^~S;hHLfS{+E;eI6x&^-=d%4@yw6ICD%U1dJ<(U!Vs8>$g@HGjxrKWExQ-=h zU2KDOC(pLGy<;oAUr9DG&oj_Z{w1_WJw%&YM) zyth2&g6;&H*o>URIy+*k37+bhmy5dxpdAPbcDfUE}AQ9pCUf zQ|@IZOBk;{I9lQL7wdlKGI>^n z>qC&xi&2{238-vQqCds)%R&^;K?3Ic@5PBM@%qDoFQ1glL$RHlPZt&m2cy-8?6w-1 zKfLt5?arA6Yj`|VFCm2cH8Z+j8mT84BLgn7=_4FZYw-gF>vA}cOJLKVmeD~O#H)|rZ}&oN zTsOqWKR$_0rLv!Kkh&Bu|`YhRCq>K-I4rB!Y?Zbg#BmBBd9no zzu)${A@A;M7&x$EHHCHLN(+V`B$Ql{;<9BLY9ZHjLpz&8=ph#j63L}1JGurQi?oKX7D&RO6a-}8SBIq>49J=sJANvi% z-M``=z;nTNa)VSjZ-J^_;UW+;n$r8R#{F&wr#p`?TRWD#hEy z6@htio8}Lus;8l81a_TJe}yDx_&4jGdV*mg%XKo&OzVIT27e7To!%7~-ALW7Pw`{-Pf<0VsSLEgp!~K<) zdD{(cdqTeI=8EAcL-2hs{&c=L`6;d!U5{9@dEipIvX-?2re3pY3jHqRgxVv}dUsIu@Ei zTUM~pb-nw*<{eZK<$&{d!oC&qd2J;8!Tyo;*_`&>wz-ZG!$bo@3U%fAhHtU z`A-coKWFjWP3qILM(ev~s|UIJ8Fq-{erPfrsn%P9bN2g&)V4l_Gcx|44r5(7-~B%d zS5H_YImFjy)`#CY^_RTHh53Mh-0dwNpJ4s#g_|CRIykPFW)fI?^bz;VZ#o>(OAvjr zu`2S=b4UnikY%fXg96%?J^$gpKRcx>^kdWbUgWk~4|U=?SaG?~N1m5xz~;2y8rCIo z_{$wXymLkIJ&VSTJDC5WJ#LRFNwkC)@6~b&<%}VwYWbYP{=LXc?Y{;sjGtnb}TmqqI|p9hsEGP~%hW>;N1u?x&0#DcSiPN&b{o&r#P#VLiOs z2iHB&xBBm#2{ntbXC&y;)eno1m8%=7xzighq+QObR&qe3shs)02OJ>3nlF4E`$JC4 zTZ-LEH_%jjbF!!IWB6nH>H4DwX88T+kznOk-EB$r_Eb) z*p>5ciao~@_HUfNL;4TbVWno@i?ZE8r;-Ktrr5oJs=oZDUM@U0#J}>Oe#astTP=Pe zqaIG^CK_BdHr$xNjw#;En*vp=9pJZ;`wdS@lMG}wi8Ye6(pu$hkw_}WUt?T zxp@AlsOY%x1S|SkJRWi>)C<0hKfdmO^_llH8}_l_{4`ZvX+}TY6Lgy6>mL5Qfdme! z_}=Q&2iCU4!2%qYi;O=F?2B?lukT-T9+NRfdb@8gy4PMrKz{yH$sG4_JU*xxhI!x7 zL)RzkWgb9;_V(1MC>>NwoVQUrY=~~_EjllX;(8qE8y}ff7geyPjq4u4{ORc@=a`2s zAl-xJ&5|qlewNH=m%YTgo3@+pi}ZY82aA^OCa%+mdy7abm^z_?lye$4aUDdVUg_*) zcQ9gIRlhA5@e<{4&i4mZ-v=g9X_NEASpN)0M#h@|?~hcTuvJmT{j0Ae-%t9&TJ6D` zG3pM$kiSiRuMeJ2vR9PmV(y9#7s?D4XWK(ViQ~!`*6s9AO?0&|-u>`;Q;OLN+ZXWH5Z6nmRRY=iNf3bTMK1b07lqbt5hU%(IRK>jsJ{&a_q zN9!McxnkZ~{s$`+`{`l7u_qVCq_AIDbzoFFXZ#9s>Pz32Tv-G@rU`{YFA6OG$8=O?VFXTv4HdA9P$1J)_v@3$ zS)lIaIl}(B8g(-Zth(KuMiR9zP^Ei2x=hdM`4&h6nKI({ek&p}hz(nqP@#a+Ujc*v z>_#Ec@*=~`c?uNpJ!O?BoCU!*X%wZE3bgtnw?#{J8Yxcxc)R;s2eOVBGV6R!1J0bo zt%qHRXh-PqpFD92>a;pLEhxnmH-(+{V&= zR(%v`UlQ8dF;iqzzU&^zHV1u-uKQ*aYLNMLz0zNZf+`ih9&n|%B9Hzb18EOwP?W7+ zZD>nEUQg4a9-2{L)tm6M67SFJaUQ;ngA^e4w>M?y&w_WqQ-kWw8swPKg&M`CQ4aG> z#|71PlnvgQj|^$>r2c{Bo^vGhwvpST%aa0WHvgH8D2;;8c)KY1|KFEVSF-eM7PM}p zjPE{Lfqsf=8|A;7MzFR-yI5b+fc49h|7JG`$lQ${qo7HLyRtmYcZ!LK zEb=5(YuyV)oYu(u+}i-mVV8o@8UaN92#$&Gp(6<;&bPPxhT)Xbj$ct8RJeDV#QWe6 z2^b{XH+Su%gB9nf_JJu9I_gXQn_YqP%4*ev%ehSeTTbc*ycq`H)x-$43v?v+YkPE+gYaiHSoS=uuX?ZvxQ+@( zm2M7$lF`;YO$j=R-n`0j_=D73Bm=T*UW#K0k+vE7#j?Nutga*0F~ zIbpcc1r*SKcf{dC;3!<^lbI^P|K9Jcu_vZ<7ODa!Qt6|WNH^|*>La;n#4b>$5c{D6 zC2d|kVQx-?4=I}|XsT;BZIKMUmC1svuo zP>DB=B}b=Gq^R{#-GmObyt0rYX-xx<;4}@{Fe0i6m3vo}M1&pQ(oWj_3+S)qrqEuU zK2)%3vFaH^gATXhE~ab!kl57oaLsuT&R>7k?s}#TN%xK#jjs`qNR&b9vmzP@ac=*Y zvyTq;8uQr$StRtLP03orzy+O*7?;=?*a#=wKPzhAB!Gp_F7)g;9py8yXtX^hz^#>m zBL^+1pqqj`SA9qznpM)Hu0n@#o#`I)J|b%S?6+LL7>}yo$&EZ*tp%%rS2I2_1jumo z*vfpKj&AH074yAJ0M;>;?CT*^D4OcoeV&yB-&NoASj*7Cq`zEv>tPZq5D&T--w}!q zzBf*jimiu4nO%XTdjvR?d?7{VEFH;sI_RD`O8~JC178jXQ{i`XIDfhf2_jXFYB#*X z{-$DA)&0B?C|RA?a8{(?K7kwWq+@0wkm;U2^;|Wo%%%kpZcn4qV{JvIO6^F-*6B}R zEDi3?$ZJ?A5RoM5WP!ncIxM=kYRaaQQ1X+DZ;Z#SP!=sTbT6e5v@h`2d*~9N;*Rv? zyZm&tjM<(e*9p);I~jG#f(kvoW33DcByeS1u{)Da1UqTZH_kmxYK% zmjicj;lJm{Rm#YDjt++1cWa|4M5K53-BF9U1jO_8>#HM4wQ%uWm$4fVAa;MN(8zT< z>d~sJOn*dxA*!R-^%N@XOFLoztC$G(%sTBNLUedMEPw8lCJ7zh=rMuNSY&ffP>gfD z4kpXF`F6YF{qb0iHjtyEPU-cBs?h}C-zuE4{{g2yA^)rS`1M8eWi=7$?CWXhV~Ig!EHw*h6SW}F>;1m|`!Mi-yJD-SPe*z& z2Y253j{tnMtT@XWDlF_TLl0jO;nBrwjyM0K!%?|27Zk5!d;M;CvzX(BKF3hDp{EU4 zm(k#NjxdbhrJWhNs7^-;Ql{e5Y6MX0^pj#@(*yh@nUDtsU^@_iw>C<3~$KT<(c_P}P z%xcQrJc?uks0AmMYk=kAlcpq~p;lp0p9aDxIxcH?Q~fCoB}cZ*IcAiCn$VwfhS_uI zM-%x{snjS;h!H0g?u|j!ynuS*0XppE)&7(Aj)XQu;sql9Kkq(2)H?W4Bh<|BwKnY_ zfJS|K=rI`_PiquChP4TBTl3Abj~5l|ORx3>DPaHHqiZ52N`}GL%Vkrs-RM=F_FpAy zDstDWXEC*%gSW{$_9t3R0@Fm$&(YC7=;cVeJy}PDcIV8yz4SR$qH*_ZO3^rU-H8jL z`jg?LvYqV3*$z~@c77Yl62BWCasI}E|K>m}{Hib2V-g~^zPYV%U;wrrR`}12Mg*4U zZ?|?Fm`9P?ndAD5<1qW@FN^Lo3KSOa(V4{YG%Z`{^(-?5ZcSR+(~@U_)>^mlDhVNX zKcfKiOVj8QV~UjJJ3>!E1VL8<>54Kb)@3=2LPLs6_Qfn2v~=v3$>fzKTUFknY}+w)}(x$i%- zwN_*lj?7O=>gtUFOISijjrAzv9+Et#6kZPuyQ&j+o~NPnS*bh&Yxw`|+egElX{g5G z#A$({e6XFGeRZmQ4slsu{{COc2xJ(nx~`Ut!Pkd7js&jcYA7RzbFw1lW*UU7Uxiv-X8yR$0wlqLg1~m zEHb=)zb#z8vK`Iul^hE+qav2SLm`}hXCZhm2bV>}B%JSm9{eou7AoDLP)`J@p-lOH1a5379M-nflT=W|LfJIfzBjHgzEtk+QD>#k-miv zF$G~-t6N6UzJ;noyA8d-CN?8{eiq}yi;12)ZH6J|j!CSD5*@8?n?e*P0tjeTf8Xm% zg(i{2f0Nrtc)ndlrNc=Id}cA~4`&{O!OV{W9T#{HBh7*kq3GIS{~ELuw#Z?- zNkRX$mv9|O$NA1Xbwk2w8YsSeXeQE4LRCNAxoR~iaKJ{LcgcAa4h-B$3^+>xz53%? zxrA9b$K4_*)Ki1hN1q8CTce{n~IZ%|2 znqnzyson(me$v!T<0%#FZS& zkNkyV9GueKBWH1h9m zz+>NAktf#-c~*}G(uam-wh~CF`16D>zcvLX4>&pnoE(Mc@uG~2>J*q?`cp?6#rGn_ zymwr)7XA3rxC-AW=u^kiwL|T#$VEi+$uBb+9Jlwom1s{wtIt|a@twkXTv8<6-E$Oj z{|+UTV|$6{MO^f!Lp_)Q}x` zKQ1^=jxf?8wOm_ZE6|^qW(@T|@`tJid?-!E`EIHkQ+-r4r#zk+TJ-Bpp=${82VMK|;YddX#pK z$0M}+!_ej1b)fd3OD{8)0FWzbxPWo^z8{^1TS5p>z;GgI4dXiMGo3yrF%ldff8uQ| zO$T~ypveUh5<0X_IQz0b2(j?G{C%;z0dCCPI6tXOfb2aYm0cJgnsM;1jYtz9r&)ej z9OJs^Bg9}UQ4++P8T<^u`33J#SB%mi5&bz;wY&6PD0=O2S5oI?J(zqA{&+o<0JZ|Z z@$cM6N3k2@OuM3nVc+J->u3FNzEc*sH?E5W4k}`)$3*E6 zD)LTM2CwtC`v%+2*ET3qX?WlA&PIrK{j@w!8iqX^x@&Bg=t#)!Es=$f0D~N#MK}_u zaN*W?qupO3JUC_4^0}LpKh}t7->r)O?(;??BSw~wCC}>MYMbU-jsO7&SB-0U zZqQNuZ}qVMaD1ce$C43?M7++T$oaJLhXmMu`bkHBJkGz~TkjGsCxWPa#=|t67u;sr ztW8=bqT%1yZDsyOpoYIjDpy46!ML`;F(8Tn{(tnPdnD<|IMQG_`xpUCJgQR=&fizn znz@;-k>F6F533+PKTJp_PjxDx5Ed}^Zuh01OwhF+#3aobEHVPh7a zee^Yn$(n>{3Sa)mivuuZw`Y@sjRY^54O^Oi&Y=*OmBVxQ$00AN-{9;D8HlGB)vsOa zM90FbcBS!9(YgD55|^-lrcbgxVCbC$K@Y7xs}Bc2Btez!(pC}()T-1p_0OTqVy8AM z(m3?K<`iLkNr9?Dwbm||QLwAH&dT(63Kp!d{rVI)3peCEBUB4&&}~VVIE zq2f;}0eCu$h)9Z#_D5(&U${en&qBv`cVm8|&V0uGfC>pJV}yoXx8nTtVfj7%4H9yh z{~-KT+6!4_h<%;OX@t+MviHnP2tZ_BSG44#Bg68@NXKFVEK=$}r|D3^JV@OBbR6EV zwSnY)Omx_@cPKz*h=jCup7>ht{{rP2PMG;BH-c^A5g)7eVbF`doad=RM{|9u{liH}?9Mden>bAJzSDt( z2haDG8_-}-|JK#&Etr4ubkcq4L4nGXIv;LZkAmspNedsm&T4g@V*}>vj3v-DZ-qK! z?ct@Ph>ULPE(4WO!g|-nOREg|f(NrZH?( zv?!&YUn4e$Q)h;Dn%X2ZppPdDD+hpRR+z*yOu+N5OnJyh=aDWNG=kP~c%yCJpJYac zC%s5(?JnjBlSd0j@II%zFkB%E%)uT$t-?L^lK^*9l|PC1c%7i>^JA;@S%@+F#}%JE36CF~zbuq7 z0AoaDt>w!kxI687rt;uCIvQQ2VZ>v|OMpErMGYB36`VH$HEF>gG{zrNM6 zY8LlL1(1Te5qf1S?lU4djrK@3ZyX6~M+V(1j|)t3JiWioR2<{^?TUwFeqvtq>XV3l z4}3E>KzST#zl?#@}gGL2k6L^b@p+JWXt!EJ(g9sdR< z@#8Z@)LS{TKiG`|V`>|E%JQQy@{tLx?4!V+aFyJJlv!{ecO*-`twHbO>xUvSU-#%5 zn{@h08!8&QVUle@1IE$fsSfN%z0rk~>tDz~xZkpG#ueM^qn0%~h4UT#_?BNg=AcQK zq0$abLa~BZi&0%a9O@pQRs2bWD|_$kecn2UB<*#r4kHh%|y?$$+A)!yon=UHe6p+uFu{(wD>F!k% zNI5|PcJ{xfjXtw*;lsP=y>pdFxj*7$fbBH8^KJfU+m#Mf(Z^*o8$^T7FTO76CyB@w z+G9)h;`lCj=ub=q3C%e~j&tlZhMWDOo{rW{a5?z-Ei)DZJbd%x^N#=M$j66UjHHVB zC`-dXCiYa&dT6Po=}3arg0RSh3v^&;@vV49B_f|k``#V$c7m|^xVPb78ll>Lh|G{X z411MBTs|t((ch6)%MStg-|+$k)|e+bD04C6682;Hfi-^_+{y4X?&8ycr4Cg3*KS-C z=gXxA;rkn~-5oC##r&$8gc;{95$@W4co$0#baol`Fq<6)bvc%o_E(YnosmkoVnY9a`#{T zLC1Mhl*=*I=Qso${3x<)C`Jb--WMOeBuQw`oPfv(V-g~^tW9Y8)IrtV->qt( z!dz5=qsez7tXKB8R4LM-=-#Q!q9r2Q(<$hv;S`Qe1YYS)6|RSvZ7J2Q;n>a>f9?5$ z@dnS+UtPRH1aK3+9Aty@i+tUsiB9}IX9muzX!21Y+cT3rRAUra#a^2xV!tmh-!i4L zJ_}yM?u3(82>tDy>h&j6Q2udAJY%X2vFqFyIR2CdhF5q#I^p|XvsYMJ9Fak#F)f07 zUl-Epi+PtOLq!Rx?|ai{W?^-=-n%>BCV_=qc==c+wtKOSk-9bsawIeYoU`VTMVh>? z^6m*}zqJ0~FFPGxN9Xxu;ugY;$_=CK^ofsg3`N5Tz4a|$~2z@cf7*0Y@_iDdLvj2 zh!Z-hhCxS3mV5)~C`)|iSUJY8%}e~t3ZYbZ%p&|o5&Mz5!9CC1)#zYE`14+`4%ZvL=3+;4sdGHs5lilq&`3`NqRy zGpv)Y`C}t}wBZBfk{AR(3*;d^;b>H?lL9%#zpgx>ETUyD;p1Uaba=+h?s|zY3aVXB1QnS?Xwmk5mZq8=+$r!*By2> z{a$RzAcLI!8B5CBPDJ+}oIRmNMH|=7rhnKw2N`i~Pna;@vPDgeHH2XRS|TrKWPZbb zm3+-OW@!#Fe%4-<@*4+K9DE9PZjAv$8Xr8;B|&sUJTEqHq+6%LjDV=#-&L8U&Q9BT8DLC}bM?JyOu<4fd! zT)T+u;u$VSHI|`V^TS5xU*|#Iam)5Dp)%CJlsPbjbpwcv<+7Ab3XH#dmZ5Y%ADxxV zc`CLu0i46?PCml++Ql?|+PZBKxjDt8kL@o-Jt2QNS7biJpzQa4v4|4H{U-9Q*d*3l ze>qj|`8f%+;~(CtiT;9)pVpUHDt`}VGw1%?z~8eT$c$_g$?%yHOnq>?3$@kx+Eu7f z(ZO0lixnKdDm1^DT4WCFgcn>%$~?WT?9rXb!-qO@*l3W+J@SD0Ab& z{8)DI-%XzUaY#PEJO8(95zTRgaVmZ+M!diJFGZ{60C}g<@`8 zn77BkENe)x-nGx@pXWW4`z{=06W;WS(HBvOfs8#5KF_+u%AL2%3emSVQM=P@UqJuD z=Gi^i?&FJY@@-gG(f*{X?#^HW?Df6BVss!Encm1$=UeZ`k}I>S}w`GM7dlb76!#{mCAD|-YzWn?{n5TW9bgfD^U=l(NEaRoW z^+VA+%h!pyMEnlUrlt4F9J)(8X*-4Sp|Yvcw%K|ztOT{Y4E1&*Vra#m!_rhV&L1_M z**gol;(pwqucp+9+9`uA=M%sf>W(D^b8GAh?BGf!4yUJTX_;rxsI zb4K72r32{*C(%;WXwdNT7QqGk39Hn}H&-$Ki5CyzZZRB%dph2~_8h0cW``nLi}wb7+a&HtZY1gxzvccPTCCA$Sj8Wc3E8DG~XA}uDVGh)$XSa6n24J+wD zgs+ySJB+F5#n%rM0oFNi_P$=~l{g7MUcMIEes}=d9OisWg-8%4b+S-(+dNYHDRrry zXB-~n#_!pR^8(R~S#r>?HWV)UBWE1@pJKmf_F)dQ@b({Z$?f_SWR{3Ocey$Mmo|QK z9_zboJluL#v}u za$%e|`6vYfvbS7!#<~k1U8|YfVF;a>-DWDyGL4pDw1XniftdDMo0MFjL6)-G`EqX( zdQ)tfL$#$q@!6QMlF(7eJg0dkfq??GLITofqGo{$s;@0RMCktdi+mHz_gV?;H)h6m z=Nw9(aKb!)(V|s7=Pqn7x|;QdE{^9nC-#hP8HE51;en60C@>)>RNa^{3*m7_F>?DV z(EIGQ$}@PK$g>5G>meQJ)A~hEzEEs;M{8EgO#%uiD-u$$C&RIyReG|sok&wDl|9dh zidM+12S)hkAa=VfrS{7typ7%3NAv23MX&90v+^WRc3iU!nV3V3J|`O#y~bge*{SrR z8ZtOsyz^N zAU%&NR%O>q9*;p?MXY=PClShbopE?bT0pFl?@QPh`w(*w;tx-zK?uXIoH6A-u$9}= zuy|?+jL*pKnd@ywLtl07l2eJO-7Rp{7U#S9JK_r1evx7JMvDV^YbWZbcDMcDrK0^j z-vmoO&q96(lcE&M6sTBdQo=A#BD%%LQ`(CJEQXcYWtnqmhjY?RorQ7Oy|*uEu$l}* zis>^^<@h|O^~Er&Q_<+xZRHEUXTkS;$X$uFNw6Yq+nr!M0DL?mALW=yu)pzkrsn1x zT0cPfk*6{a&V4gJADb}W(w`M9fc-{WSmvppIB&Y#*VofcoP`q~L(RNbCPDf~#xQN5 zACm328+B6|Vp8e(wJO<3pA}elu4xsHVQq z2*1^d3Yo>vu=Z<{#T=8;f1 zdw-a~ILL()UPd~RfsvtXK)tFHc&@=EO z0`ri1*firjYFzdc?Tj3UZ9+LZR=tZTW^XWE>skp)8E=o)%l`!F&(4~T(~D8E$` zQ&{)*$@yv0SRzz#m{|<7XCU>l{=B_k-b38bO-}2@Mb!0&Hz%lP5q%&lr!GD&Mp~z9 z)l65iU|vM=2K8VuI`qZ$NHUJgZ$>#PSkt4yr!D6G@{epJH2indyC@8b7BqCtzbzsS z&WJEF#t9~Je1zj4JJ4t6%Hs-(RCK4co*=O}3swvJDNEUt`2F=AxgJgf5aB$LZ5!1>RHn)V5TPHNgQb`+zHfTH|FywBod3FIO9WT;`^c2Q9w1Emu# z@|Y+jK>Wtr90R=1gNCt>Y`%=Kbbv7{GXw8DH4 zcKOG`n&r|^7G6i9^Tx^J>tr~~!Qxkg`QF1T#!qDqQBhg2WYl$xH||d*8oj{y(40|A zS1f%1${3WKraoal-b2;X81u$k+v-fbE5|`7$kmk_|E`BygmCw5G5UCMA8j}<8>lDc z)j6*equ#f@!3gWEQzEJajvFRJkkgOxKRZflU#fU z9Aw(_J4=g5l}Tyv3jQ9Q_UYg!k4g}ykK_#=ybjyjZHG)&icwuIfhbK`1cvdhvW@H{ z&{&Pk%}hclbfV4K0Lm&xmNiH_8b336!&bw`}{9O;vUw+?0aJ}jjHF+k|5tc zmc(($kvHYA{YAv{ei&{Qzg|Gpo?7?!KK)2!Ic>H+ng%M}^skQ}^}~CO3fh?YAl$w3 ztjP993t|huzS+-5LOw?zFAD4Resx=?T)}xt)19OV=ipML_FF&xs!kR(@!MqRiw5ig1D)qYaaB4VWk z8DDdbCiCZj(5YP~_BfRwl5W=7By2D7+MDHN2}v-KJJ*}*{~39W?-U3xcn|H4ORbd{ z&#w$W^>oDcirUdw`*lYNdUJ40%VazYewswJ^(Gc$JnhBgjQ82Ww3~R(GZ9ucUPZB= z$w3__bbd8Hi-neZY+`u631Yc$P^umOuIqQ6pRoH`g3h*{i_toa^Asz>e1k^`GD}`G zpyKZliTakgH8vhP4&M5vp!XS(vR$T5h(rV1SkQVQK8GcztA+WPzJlD-atFtm4kW6$J>d&&Pk71Ymx*0Txzq7S^7qJhP8cwxOza9khDz0BkUTsJ~ z=;$d|Ng^tN{Y@{@XyBNX=iwSmgkIn8X2&}h&~0;7Wo^8UMTzx=zK=8*o_p!nCEpLW z&a+aL8iTN(^VE1`T`Ou%c^a1_jP+5cJdH0F(16eA(~B>ii|DymP}}dlCFsQYm`BX= zIgm6NeCEcdV$^&jp?*8=-^QrQzK$LT#+oIXA*P?v&A@>BBC%0m=&&Su2k*1)leKFH zu)RXgo{P+*7owdJl`1Uhxv($u?1i^xg=o%Jy^0&_{wo8@a<`sNh3%_<4~pH-L*8q9 zFZsSm0z8>yjC}^*3pTA4XIux_$yVd2OzJ?}0;~iaFt2Xw?f35M_$-XtcF0Bjn}i_} z`Fn9lKWs+%sJx)#&bMvGa;e30=*#WBVUKOb;bvg!ftwpdcymQrfVUU#vpcJb^JFjL zJW&{K?SOS|T}vDpZ~O5(C~Sm1>w};ZA)ecFwjI5Ht8l7zfPjYbYNN?tXpppX_0twy zCp;>%GiL}_S=eiOP@X3raYa}v5xGeQfuhI0{R!2L#w*fhwjDu_48sqG0QFHUKi$mFtT@; zke3*OW6L*6E@!u+46Aa^@1jJco!MG=D-!E>dTSqVx1c~&Mz(vg{wO5yb+`3n{_f@z z>koohucc}0F_`kS9F;%o(BSo%MiqDEU7rs!J+`E|epok-EPMTq1Z~eBOlRUe z_reaP-oC{#P&r;DaXSsyWxoFwW%uboMiWN8jQ23^CB1%~ymbyv|JN3mfa68lQNbSr zmj^)V=)i7 z?0kpo{YU#4OlW=Z-_23k3yXvB^G?otC&qSkY%TC(g98zTkLCQ4eM^IC-dI%!A`u#@ z-}Gc-ohN&<9pBlZK6JF@n9*Nshf$R$Q@0)Z;VfU^zh;9$P@Lj@6=~gy6n2`}9LDSX zIscWMgzs0Zdufe0_g6^fcPlybvkQ3!3+El8%%fdHA8R_6X5sacSAuH><})SMPiwpy zfZV|5v=(V1q_^vP6!gp?2UccwX5R^@;#@Mb|4jxTCxJhV?49TYV{GRbHx;p)Y`;{M zGYdRLu{I*?Q_vpzk@nx|0nl}QL!-PRL8)s0Q16F1)WMlkGO{`jtsZ4B7O)=4`19Uv zYbx#NQ5#F4_){v1>b`I2GBgXD5ue!fG46fW#m^yUF#rl*orReyNWgrQfB6~4V~H1( z5`NT!Gt2cvSd~1`ei8c(#rYzQBu(spEH-d6CJpWdT1FwAeu$ubY>=)W1l zp^f4;)ZV-jw9Z9DJtA7aX0e~**HLaA$|S>niqm&jpH37pe|>ib&byVCMtJ@I!A>Cb526tNzM^)wlcN}_;6Htara zYH)sPed=N9U_WqXgm4is4=URosV|*M@1IvGs8l=^8+)+fz@|b zzXIbi`O~FxQtTZ_U5rwwi+PC=^FIUMM`l6VH${UH*BO1w(x_io2jEy+YW6=e5u{?I zU4F96Baw2|WA^9Afl~L$OKuA1J6VwfO=Gx@v_G+HLxPH=G*~oaao)Wt+iG&-^CUza z9}pOSi`SXUJ=~A$U$U}sQRVo)8$?w^libH4ZbnYP-~}0&-3}b_x!r}jj0>-^>QRxz z{vSu)D9%Amj`;?c+a%muqrEIj>j#f^@7qVKiI7;nwfoD)9Qv@^*Up8kc35yeC zFxLg&yn;@2=~MfQqXJY!5_wXx57!I!do#c8Zl8qItIG5sZ1*b5)n%VeBJ7{pN@4Dv z!*jeI?dh2t2bV5|HS2ydG|aHdkZrqAgs-ER1RoV?9p|_7+&>5UW{V$kF<)oIouBzz zZ2;U7mmV0H5^nxXab}@znk_L$3b_Jfu$+VFWRji z5PwP(p%*7>T$3VmVC=ZuOVx%#WFoN~^$hdao00xt$D0U|hXk_1zkWt>jGEiFpNxfZ zE;IlC<4nQ6E#*INjUwwU-e#Wl_27N@a|E{%4SiscZW7u*h6-Oq$2C5up|@sJgEDsc zP-OT;`U=)V#@n-e_?9yQ%8x_K&t#5)d5nb`X<`H!X3~YPSl2_|j-TT1O=zfUwB6>Q z?HJNFV<@q@OGBSZY)mVU7eGTzo52AzhsH)&8e)!*;=e0bCnqol_Mc<4v;4@=rt<6B zVq_;ul8ddEx=%%0a}wR29i4-1WulY(k&~bp*CJLw-4A~AQOCw`{1ppP;^xM7pO`6) zPShEP7|r^Mvbsei$?<(lgKPz=ds4^S8=eJv9$PB^6qX~g(}^uSxc__S_Dxs5tI6C8+_3tH;p^ODbYjo0>s|M=;1DHT&`!7* zmFZZU?8W$SJzF#*$~PI*e|^`xPtHc68%9l%TN1!fmot+S+e^G>rXvyK!)8gQwj%~* z=;HUW$-1x%unO3H#G$nmiS8clOdZ8@KOYRKnfQHxdp!v0d1WCkW0QZ3E6MO?H`7j4 zY_C1LH}{Eu97VM^;^n`I)zG+?`V<^528E#x zsb1STWR_vk^eAE!99Rke#pjQK)t1AtY3ieBc!xvFY;_&h>$;u_y+K3eTn18&hsIEh z+siM%u>N^)yJbs;e<3{9yUN3l^8t0%VexbH5m+GE1{fKP!HApeK|{>X+YLEd6R5?= zcZ6ztYX28dQ#iZQYF3OSzc<^5;Qdh~JTNd`mL6hTpyT$Hf+U$Un~JQS}Vs!hOo z%Dy1^AGMg5;OX+AMTZn44dwat53X5|bTvu0`FJsUT|TDv|Gv`HZhKylwFJo12{@-+ zlZ~n-L~?n5#DJEswqGLNXY-f*Up_Q1qS;9cl?w`GD8=E>Hdf&raM-PDwk5h0L0TnK z65i+4o1#COg+F3l;@4Z-xW6Fny#Wv6FQq^OZ~239{5>O~GkQ8Li|AXhU3>D2GPEXf z^MRmw7BIPqB)#n~MRjQfc?mrmqzdNJ#w;#+!-Dqdn2SG0(;C~dI zc{tSV7se|pORG>q3uTGQQp$STghUHPC~K({rNS$eP?kz0WMA8?*(Dxp*=3&@GqPrw zv6MoH-}(LZURUqcH1l1a=RWtj&*x!Jlvk5IK0JC3JE>&<{6EocWw;L}zI^aip9ZcL zH6MJ^Sful5TX5Z}7BU~O{?AAB7j@(BFIgB^!oCT%PrBZ-pNz1JVh& zFL!)OS-bO2EfE>r`OVdfN)*;@E8qBv4c#~P-V(t3weBdjRTcGn4#n4_H#P6 zS{@NNlu2KL_iMM@2N&0mv0!$d(l^LXC6{`1X9oNupax!4f5Ye5ZXfrqll9}o%GiJM zJ7*r|zTNA0)?~t$m{aj)!MWtj-)ql9P|v%IC!g2Vj{+mDFP+TuA4zc1AhX{+6t14n zHL}L*Tv^i<#)0qqkLu4YJLrW(KjO*GBc7S?ZDaG%fK7$O$4}GTfT)C zpQPV!jr&N>E;-%R!<7WDKb8sSV;}9}%^N#L{!rneUkN=ck3~8{3XH;%TF9Zz?v0KQ z*dR7>JnRDMmdWq?3zGk0y|YuBKl@WHaXoYEu80Sfn4I-fx{Uhpd)IVn-y#(h1HyJj z7O{v_B;)ba)fTe&(~8gj`%gP$bWBcZ%Q|6AqRE+El!|L|9yx*j@P6W&!dWxQGV18 zN39>9w^gnsF{7Ee-pi?Ex$_O%XIOtptk>4{(WJt;|9oduu})dsZ|h^**Fq$(2FYoC zV8c{v*5i^-E$~%HATA)G9cHLkMxESi$>&|t5bBI`R)?r>rtshEF7(=zQ#ww1RllAb zI8i{RYuRPC8?y2I(j%6`PWj~VmBxMW9l1qAih~EwynzqeNhN=Ia>(QQ@n-==32=7q z;h*!}<7DL0&hA&}`#yPScfrb&Md&^2BBJ)SlCyIEsd2mDeB9qN;yd$O!TZr z{n>r;i)CaDS!$ag=fy`Omd~IZTtO z$x=0}m?=7qgG_UL_qYbnWZ!s3B3&Z=haW+rev=!#<`u*pf+M(q) z5w6RuA^!6{+?StVj)beeTqzdo!P=Y%${fz^tXaK|l3NZ^ol8U~t=ME&x`q9tJe-4g zcZX%~&n9a6)Kxu&S>QYMd`UX`*CCBAc_(jofpRwEmWdPt21_qR%f6tKQ!D&C^;=58 zMD3o*qtk36R-S3r<4z|f=bgpf{n#WrX=Q6lcs}&-WN)nRV3P3*&ANp(T_BYCvS)fX z11!|{ojLpp^Ni_677=kQa!TaCtY(cCQV^KuY2}D>it0j zJ$l&(HSNY`brG!~Kowag*-V9osmIHDnV8!tcU51^@5Vf&?QTBw!&i;zZ@4$uNVfeR zH|drhA*vAx0@f>;@OrXhJhHwI1Yh0JK8f|WMK*Bc6{^%$LR(EX9B2u2UBSrV@vvhc3=6WVPq?K=o%S2yV1bk zth#y`_D_L#G_gYXJ9Ji--Pc*$3u~3X*;?OhAkv*1T3>UI5bX{6zm*z?z;aUV^1h}% zNbcMHOf$R(&$8~``W|Zy`_*IE1Sfl z!zN3o*~y*43=+LzG3vP~o1ADLUW_p+1YzlO&dXw%B!^|CX6a3b5yIzOZo&UN>l+WWvdG$(gS{PidZ@?z^ zzBeABzGski1+TU`=&?y`)3|@JP8Nu|QbHBpqyApO8`OaFR>^@za)wtJaDJgF|%L(Xgi)qtJ`l-QbSmFq)y!s z=O`EVINpB8233*Xt4FYp(D7jFe~CEnxyg`!&g?@ADfWzrPrZ%(y5z)wE&8qS`huTP zf@TLe9M`SVlc*z%!O@EyQB?9`$r6DDFE-dFb4_}pp3m8??wul;PnKyt7oL2W3JU8s zTc-Qw5sPb20}i3D{`igI#n)Z&U?Hfs;q^=!*{N|`CGTboj8U)F;Q6qazv3(Fo2L_V znS6U`k1`0|FQ65=myL4=6D~@e45FVNL>0KgCeDfp3G40`K%HHG=xhL!j6A58*>su? zeHr0g$I}?F=gWmHdX98*!$~_FgC%e$k$Xq$SvH9Tv*q$43?dY@&-A4?~)ef#HZEz2R~&!y5#)RjFIdL8<^ z7-TLbMmz%b{fXUo%qtY~;8A&cXm>o5uvua~&O2}}X2vhIE`S03fj;RKH>ltkU((}_ zKBS>T>w#(C7LpWd?J|gcU+3nMsQ>C(;H--7BlWc%5Ttr<%Q3e)QgKG^qt8()p*S{a ztwUW>E-zPZihYM>W<Q01DQ*90ofDV zYY~tAlod-F)L};=NDBX2ch)qWm|Y%XzuXxIp)F?3i|8Ah7d#a1ETEG*hjXL4gB5VV zq59WeNnBSq#r{jV#vr6iOsmzHP3YOeJ6CSV0S}K{y$(+%xl?3O_Em@u=2=xEz6%Vv z7?3vCcm&sHNp2sN&T^;}`|rhG)ZsBD9A;Lh80324KzQgyHc8cUd*(Wq18;__^S)yL z^|x$I?pE=C{)A;S4<_UDtb6tM}H?0h|spMt(9L4(U7yU&9KZD#__@gb2 z&yQHZ9rhZve30l2%;`hlr(666W%>XeuJ;tY?XzRRSnG>l@pa?mNY{8?eop~0xe`;D zi`}PFGkJM;Z3;*p9;_UM`+JE;K9UBkgji~-d#X?&zpFJ;Qe|U zvTc=ZLp+3>=f3vuZyFg}xY1tJ8V!t#!`JHYer1bic-}yr>15Gv_NcRfWal@hZKeRau1YL|Qu>x3qb8_W{l&Mc&}f z4x$p}rOK*jV%Q)*9I!BdfQGs@(D!))i%i@9odZI^>&vKH_%r-6E}OK2v+=vV`+{o7;8+IB;0Tq(Icn6a^p`vHy_6=q-+Gg(Xe$v;vt9s7M}7bm*!jqS1-p17A^z zr#;7yVShIK*MHGtjWZRr!u3}<*R#m#6W)fQ-&)9D^PQJwqS%n(Wfps&wFT#oez?Cv zy}G5#Ak4P3mK^)+#b@`BN)GK|Ce~uT7abw_;~&oPT$qm7msEiL6#wffOS)T#ohg?u z!TaT)+P?A;)?Z3zPVE}1ZinkBZ;O{J4nY3`5X+}Ol_^OB}*1_hA%x~DF)mPw2nqIm6B(V_o` zX2FWh3}`*RQNQ#po!B`3{A1@<2K}f03+={rBeAQz&}k)u2)c&WZO3&(>L~w#p^|(M zyr}>13GT~MF5jBmHRy0;_Nx`2DFfmYe^_=6VBNHTpRH{boEGKOLRJj86+QA} zLws$MoH6zXe{$A&nH97{fRmx<nEOzCNN>q(LR`zieoxB(lL>#U(4N3+q#9UY;cM zjWZrK=p-t&kd+g;NmsCc5iZ%YyUn;2Cn~n$PZ#N|h%P(xtsM9_ zIj0ri{@MJ{e>6yuK`tJ5-Es0No3Q6N3ua$uLx${=fP@Anxjk|^QFyKkp80tzUlYao z<(gepeF}6E|MW+2tXT!Ht;*?nI0t<=d6q3H${=1Z-JEH*_{rHy zCUHA+JC#w^1zT$^&KKJ=kc+PO``F6?@Mu`<%KMD_h@tB~=azopDK9QbbsoaGuzN4o z?ucjHHi=UbvF)15hUF3*-AAi1*TVPdS&&{AT)+BTe3H(9 zn{=5EZpc4q&I=7Q%Vv=~p{up~R9i_+%)7}QgbhWG_g5T0kKBxq%CLROZP53TV;0s| z<2i(L((#^DlDnp&BpCe-cByg2ZeAKJ@jf9Xki#O}I@4*+4_e3*(J`l`_?{+yj69b# zjrG@1UD2kRHrRQ=L2lHpnn-+AUSc{&Az#+Hm2@|;A&qbOU-(9aC(CPRm@zD};aV zmec3VE>JJuyW;3J22l3M^Y17hfWVJ)aXJ_25Z|II5LnR<%BO8#{l1R(>*JH#S6a(R zbeC7vYs^Cy_$i2O9;hWXmQ`P`8?hlqrZnt7R~p&)Yl&L26P;|*)SS6yS`Layc73a~ zQ4fZ>z7FAG5chp5j)qtlyt3ibeV&sGC+p5T9>97@@uTW?2_8D;4a&HrFEc>a@CT=k zB%N43msWT~D~HFjzHdL_{QXOXY|CsWooozCbUKOakKWOrcjG6`W)4OMDpr;x&sb{rF4&{nl2} zdyVtokPq%}-Gws`AGE@i`~#-;S?IU$+;B zFI3D)?YNQU#s-G-Zi(_@I#JytUt#B24$RBXBVMCVJ6O>Z#5aWNv)fEXzZ07{Nu0G) zdX)?Db{UtG-Y`+OC$&^!-PCkdhMHBx0Fx{>V-o8x6T_r%vyL)Yzp^fuhFq*mD|DAf z{-YC}qvI|t^l8hI;?&11@_;s+qb`8{yotHyaT#3a$v#)^K?BS&jyIU^Dy0(x*E#1; zpUWXBvZ(WxBAeWKrhoaTDf;t?*=FjfS6i!`dKX0VfPcsC#!_GO(@nh(D*zn~ZduH3 zCJYF1(w0)1qr&37t5>d8vdDRL%_y1))=hfanSrQV^gJJ{jF`8=ZN8REjiMc3BU4CU zRH!36J6&rF)v08yQt*yI^pQrjq}BD-;{9q|`nenRk7vt{%Okw4*#9i!%yneL<8vD$ zwkhIu9-VV3KabaW`AMfm?mBXDQeWxWJaTd;iv+DgomC_J)Dh$r|qprKP zj^BO}eUb;B(fys9D_~<)?cwf&Y@)p&YQmw-Ad((BSClUyUm`T$f9h8b@XcJfav+jP z<^%$*N3egPe>zA#^)349lkby9AJR!5)4f<{p$ziaYm!Z|evg>lW?pceK`cyZ1OKqj zmF5t?C+Lz7XAMa1;}9mvGdryG(~pk2{Ok$2Qw+G}C^LM~nN9{mOpgQ$S3ra2-%igE08{zOBQ3+CwOAD4{$Tc(!qp9avxNk==9TW+)wh*S)w7e_U5Dt>-XC zf4)h-`f=0C0wQ+D_Q3SrRB(tru_&~%fZV;6s#e#HemL{A);p0zuo-O8*pK|tb z#AV{(=Zf&ZZ!oVOSJUC1S~*TaeyP065&A@6>A5qaOVVJQ(W_rYHw($95Pqe{=&yD? zPadCHmJA2$3+)PL(#c5PVehBQ5@7%PzzeQw#`u(Rb`YUAJ{k-a4}w z^M{VxOZ9w?h@| zJmE0##`u;o{w~*oA5UcPdA{)Cd)PPhwHztZfnQd&5}j-gHCwDZALq}j=6bh+`JpW# z-|X5UbrsLXb(%HA?bC{}*&He{;;bnTiNG98o5KW3C`= z#rRQM)O~WT9(AkR;7Fve`|=LtffR5gjhWUGo*9vi6C0`I^ihpLy>vDtt8b^wqOblX zLAN~jNG`eY(7nX}Y8seqKKV(1HisOXoh_EZzFvLbpVk_zYxjJDlxClF;xxi$MB0ag zMAY#I{8%?}NJV!kf5HC4;#w7j*M+3Zu2ep4E*+py@%N!Mg=B4G&RX~X*G(Jp*LwHH zL;ljM&FQByNm98(E<-39&i8kHh{pSsv^+`L8SBAVU&F@|Wd&rO<-L#3;sY43bTAO! zf%(7AIR8bgyTgc*js^BX5-m1u|KOZT`drOjPMl4G(Bk9`oOqp?zB5-gRG^-JG~K!h zK9PwNCEJ_#ro*Ahp;+$!3dsZYqd5fmzPzauZCRf0;YpEtE)%~`@F^bWm)GBb#hlj0 zPW0z@Zv1Q~E=&VMAww0)Cl-l0EX&i1xq^Sx597g@`*)x=43=W9ce7L7KuZ_q(B2L1 zH;JevuOgQyaVb)fnxY^*iTW^kXYMtx_n7Mzx%hl9m4)Y^k9_;4iunz{w)ESW-x%ZD z+WlUy6=dIwFRygP{6>nS7jZ9bg$8R@4GOK*+ddxf~~DE|m9N4?#Dv3R%L!E)Ho zMLDUU#wM~0IiKe7&tGl+l3nb>CSx?Ovvm7hxP8p@s(dk%+^h=Q5t`iv=L`)B#Nrw7 z>+ZpOw5cw_mBUdYn^g`UZTlj$P$#UA`x+69bv>pTHd+O;$$#pfButyLATz<{+Knm9 z88?U9tgz_GpOXMsZBYxavwCV889s+$Y$V3nfU9C{`Ftn(2~oxCByN<0Rc2;V zKKfBred>3E*jRUTuh#BB-FvW3&C?S7pB4Fc^!iiyCn*{ONtHPyzbxccIp#$i#F z&2?66uwS0XBU?=+H5T2xwJLNnF?6#~;y?w6DXR#opJWrm?7>?SW(*=clX1Nc`^#;; zr{5kK&W1#j*9{!#YsI{s@nquqT;h4+Z;}lI4*b`)_wz?O`C_R|y2~m+guTh#PMS@) zO#1i!-+znmyUlcWVUsW0%n>7z1ywU?rxtNvJ}>HZVl*0kb-~B$f|hkdgud<;$_+Z< z;?{R|maG83FDWXLxE>G3q&}LEVUT6(t5qIdW0SOTp~p!(b0FkS*1v;zovoJ$8V4Y^ zlYh^Yi*FDE%+@9@_2i?I@MqB*cb1hy|CAry6ZaV#MShP$tS|PrSZz3n{;KVbTL)|F zvO#snn6fkKs5h%O8lC=z{Lj8WbT>H$#0q>0n8taT-^JXzLtG5__f#~ZkKGTq@7Kpz zgbX2%H86YsaY7D1RH=(J93;1Q=C62$^Z&Paox8mO_54L+qlbDl@@d_5o@Sim5PSY# zuALwqj0^?82q5of)zU9%t~keG(EsRq#QM)fq^4;1n=^yN*tb02!ls@iZ@Roo4E597 zFFEI~DWERf67rePl>*8=r`v{?B1daB;Cf+o3#qYkDr)<|hR9WwyWg3$An#kjZXWe~ z8{NMw+pvaIJPwrQXHba0z+rji8aA{vYuxqLr^0oSmj!p2Eb?vL+ch_Iv0gsm{)PG; z|3BL)OJ`XtobzioI)r_+yE7X?KHRP)<)dM}<8>Q?^5L++TdMPCCTWe`a8F&24*way z+Hj4B0UbUGtj~x4f1SO&6hi3W$W6X;?i+yPn>hNf&kwNIRTR$A$sq@xk6iX_V&AT2XvNHf#l59z2k;{{IT9~8{GfY1^ZUN<=#7#jAPC!kjnd~ zv6}ok)n&&S;0W+VS5so?24<(OUhxKl)nrTN2_>AD&H^m0FKE!1DHtV;vqWB3wI? zy=fYCco=)jio0x>=v%#$Q?Lz`E-H`7A(wBN!^O?b+iJ*-nIf5x8eHeMFJC$Nnhj>5 zQ|)W>24HEa0lKqYu;zVXsw&RWODSyeQ1KmtDDE;%LzglVIx}K3jl6=y+q+&5F0Ca7 zvA33=#r|SMii6DHB9(}JUluVGIRI|gvMW?MQCCNKzUsiwsp`B{ej2%0x3?M1rXDLJ zQk(`=D#$CiJ%3E#@7Y=cnjD$dH`$=_UW7fQL?avp#tCaWy2u#=4)ZN3Wib8zkaZuf zHw_jw7gB#~n=P=1?ox)^hKo+pE<>Zx!e=}NCZMgrk9|EcSEq)VJ}TH;FJEMbut;LH|LOyeT8Y`( zj%iL$HXIQPJCVrI3Q_a#u5rkBz?1F4EmKLgM2^2`nKJTu9y(u4$*@MQ@Z|$`NyuG^ zZnh3Rvz|s`Xe)V)+@eUiiI^?Vx^mde@80?dd55FshDsB<$g3<;{9Wrwfk<&mc<##) zIND3`%d4is#kNaEPq&SN;lh`y46N+o=Ga1PZu}RSx^$+A`%Pe(otrW@_mC8>s+oca1o56z9JrU;T7Kew1>}r(DWz3Ito78J9zTltcZ)E60#$ z_gX`9vPF0l4h5XOwjl`lJ9@*ytB(Cg9(YS!64_M+M?#JnY}yc#@%I5nKFM*a0BYEGaCaQWYI}feO0WQJDV(Pt1!(;$%iXOeP#Ck zOwyI%{;Q#@3)a>}8r{LUHk*GB?*55K4)*SvYlZxk@W7z@$R-&!IXUu9_BGb0PO6uZ z-O*1BTH$nW8GklB)H_I#3TG1ie~zc3sF>4p6K4AUV!(r|`Ui^6&GzE#iYW^73FdaTMsB*?B%2o;|rb)`Wgko6MbaVduKw=H2bnHyjxd zDE2_O4LMzo`HiCX1~j7PB_kUyahE*T*3EZ#TnSBGwlrahlUFvEGmp+~7Zw2}uxl?Ge{7*{5c^MoGF0PI-&+3?MhrOnX^R z6wdh`GVX1UxJ8FZk6msy>yei&Jmq%x(-2&euq0A%%E-{ajrj%Z2FXFDVszArT4Hrv zAnomG!!ptFWMK(y?z3$DAx+}!Z|D?Da@|*lys)cE&Gk31~GA1wp zawQ)WmK!3cM|pY1__YR-t?@EyHR^2t6(T1Yzl%r!-*HwMexKK~4>I42qF(Dc;#d1< zknrU>URrvLMi}&{I$xlZZNUPaGR_RbQk=Y~o{U`8kJOx+`Z72sb;U~619@|jbFaNx zyWrB=&n?b3S;Rqb1&LFqjA+$pgEXl&;)($Qo>zp31Yzut9tj!JKs z8VB+;C8;;UUX&6V-}X_jb{25x|L!!x`S@<9RoYF(I7gxSR%VY7jZj#JB)U8!Y^fx%SzXiCj)DrIi96M;E6h|z3G@ojo>`zyAtyg zp2lh3_5+~TF`^mpd60CDbPV)pQAvMRXQ1dm%=z@U9?p!bL_SuT{H%K?C^>JbvvEQG z`WdU;vUS*Rnan9zrauCe@-J)!H9QHgPVC;EPUH)h8eJ_$ZhTaV(6MAwHu#)W4w_x4 z1on70^KVlp_$E&*j?^JvuVa9J={w{~#syI?DvyBsux5ADlrK@tySwz|jWLoJ^B~Sg zkp?z3lInt}D=5k@bw{f!Vbhhk{-57F!N%qtXN@2}r_Vp}o%5oAdO*_8Lga}mY?A7) zxxSBxf0V2r{X0seqetCcF;AaOgQEB@mvCOrcTs<{Npl!&re|3 z-A>ywvdD70dUFXI-n+092R02r%g`w<534~^)>16Gzky2Xv;GeBsSN;S$I^@-%nf-8 zUq1N%dHciSVXqDD(m_*}J}l={Lgp2gn@JpCgJo4tq7U-UqtqJ)&uR}6Q~vF=Wh^SW z`LLY+Ky?7x=D%l5VLpAYcS8Q%Gxdba^wMnAK04elIQDA+xd%zNURK^&#fBbPj!PQI zvz)e(U%D%NkWd1j3U2&FC4x_%&lg+Mpy!D7#Cw}jpu8ex@tM^`+tTUcO&W4II1@fo zy4t{1G4{IAaSBO)PJL}H*+Pn5DsNJ#?SSA+FRsg|C&Yhit$L6D%|9bIf4Zg$z7L<` zmtBUOR;?PtJNSL$m$&MR^ibf>ebH^dO-GO~Cc5~J;5n?WXE?)ukCM%)y+5sPA=h!h z*RX8WC^T_JSlfk^!+_XW!iBO3Nqy&Let;L98v`p-Ix&z!D=nw1@o1vXP4?>diE(^4AI*>Ka>(-%3` z!CRD`x{rX_WvPch4)|jK-J|WojZt!d#Tja8h1{;R-CPk^w+->d>CV>=L5_j|%j{}B zF;#S5n6sk8<8S}8ju@8^v7_HN-Iqjebm;Stg#!byLt^6E(>sGCTq%8B>S`L{dRo?6 z9*=#e-CA#cf2;(P9-SLrKRV%goA55$2P)w@-EfW)i28KcSUpM)pJ&b}otpbk$f|~4 zrNbM>kY}&e8iW1mmSNVGe{X2;!}OHig4ig$9m^@acDI@oeLJ@1=V2CEyC+&!SELQ3 z1nI29mK3r%|Bl(Wo)&WEW5nZU*w0Wuc{fGNg$;%hLlu!A2jFY@ZfT(1`5cqCWXYFh^^{k4or#eCHH;@O9k zUhJ1`lbk>Jpd6f(#rdBmcfy7FpAS6o{gQ4TFkFG}SL9&e+Y)@gtd_4?F;x7598__w z%BmP8JtrblzGFQ=9~^(|ihTYbHNn#FqAI|wqr>Fdatf@<9&FCuP9wFpKfGcBfM6Y4?P{TGFSpA5}d{xE)JtQI1o6Wyf2Y6o(7d04C#8)!a}Zj=qkg>CKE_=vwR;*yk)vSJOXH9TN< zHGoBU6F$DU_PiCIi>s^@;lR1E*J~TiF?XOR?B2fy=QamfD-7h&&(!xDY)<~hhQFs0 zUl?P36TV_Tr54xKTe==x=E%)@K3r$_A%Ft=21nLz!20ICN{fL<=@arisIpu;Ym_*I zL*G5@pAChK@m~0eb)Qy5xnl|HxULLdwOz>f%3XN!V*&dv5#Q=~@p&E;cta7yb44ts z&+fA7c|;Bl309Y09VKErY+j_@#dAi)*k<9m$Y-?kY?&ylgjWH%`L0WmQ@^p?P8<8i z=Mt?qsx%|Fta*g{tP%3hMFrx!~ z;RaWIb_rP)C|TyT8|$pqvdU-V24Itkn!+0ML83$QuWUxn?iZC&Lpu#R@y>Ow8NbCK zzk6i)wcasFbGzkj&#*GcXg_kn=MS4~Enw6$kW1HGC8E@i`JR|dej?&u^Wjop_kFL6 z*w-6!o$Ey%Jn(vla&a?q{ZqA$rEpRp$WvzG&j}g<{!=LrOR-+QV7OrVXasB{1b1y| z)`y#NYBbuwDDm8XZo>Z{4Z}y4CybI6tc3LVE4pKsWO;*xCoxy==?K~2ux|@x5BB9n^Bh|3yCF7D`&)M|)?XtMhF7klu3NoY za%C?Sf{0>o>FP%E!<0TRO8UV1`tAd}(FcDi%XHD)I6{ht!;{9kkaIMURpx5d4H7e< zW9cgBLkj)XSr{BbUGgV7&ZVC4-PGFeqeutATx&7g8A4uED|Mb;U_p%Qz6c8Hu8EH1 zJ8h2#kzYKi#>BcHFK}(v-8};!%cuRV_aE{yXT!=lo9an}aCrBT`7ZGK9DIv;rj*2T zWqQ1?V1ah}>*Pe_Agw%ZVKrDaNW{;yPH{BT$SZL{heJ3oW68U(t=5e}3LA43GT$P< z_K&h{=0Z7`+*Ol6I5uq+nQJNy`DVMV(c#1+z-W@ zSB4%h#5t=U)|E-{l$g>=L)R$OpJ4jx&9r1DAL?asgVbMw|5&<5Xq+3p+%i6;HIAnGivMyt7Tr@Yi9?E z75~i#)mAieLP%7(`QiX%?VMjBk3PixY%6^ZNR;_Hk=^$xd`Brl`=EzF;^#=CVp-)&O z;^k0}{ifdHQ_)X5p`Rh0#04}`^DuAxN;K*`8SPS;+avIHBN;yTH<;KhmfzhswMAZins3DOoyf4opNdyN{RH*o7?vGv*6AS1#@{Ntcw#R(;RdLiB!1j zz!G6*KyD`Rtazc(Qr=7br$^zD( zs)l^rUyR<4Iv#s~oZ?l7bPmi=$@x*fZNE-oJ+=L#Z}ti%tdHGo6<$#sAN~H-u`0`*bscbZ+q8R z6$-{KOGDgGj|L2L7V}WSFRQxl9bO-WJr33`Ef0yzhj*V}l#h~{g+rcJ zIJY2E{=?EVoDE79af07Dsz8;P9=wAbNonPsXn#=2I+I@Q+u{FzY?Mh zzcE)S9Nmg$k+pklGyzDI%ceqq( zklY_|I04U_SmwsEnV+u!AMSe@eIuQ4SGbPb5d8+={`p7}_0N+bpUVM`BS78scv+cf z0O2%D9*hqdC3PL$fAZ96plKhz_E$dg7BWpbFM51|eqHsw-|;zocu3xT@(|Y3Izzu* z#wj4opIv)abp*COHT^jzrVeZMpY5((K1Mzq?9@7jx-jEH)?Vob72Ifix0KwU%N@@pf|uxV|{wfSxr0#!F%Cq_|l&h;84A5 zna(OaZ>+xWxX3yh+3}L9hGAA80Q$@ z+p-2-sCb=4>L1K+s)Apa|Gir;K>=0y`L%S+WASfpk&D6mzBe5qA-MjWcitRNlYB(> z-GAjf^<CVtqk*K4AA0(|q7M!i+N@~$&ctNz+aNwOE0y&dbFi0l zSD(`!fClrLRMW*F;7dLKdCk8%G8iv9%!|6^@h3NbU*%HLIHoH>!S%URW9;8snE~K^ zZ~nOG#vr*-5h4HZ5RHWH{k(8u*(eBgFBUx%sf5aP^*Kts6gaOz8=slRdMBwNr{ysP z*4`DW<8~f_G8ch5(iA|pn%Q}E-Ww&l3ZYXx#x$sq5%T5X0f6|`t|o$SE+ z-SNS3jff%|QMKM-{X~EY)s&aH|343;)GjnoQOTP~>#`iJuch*^9!WM> zH-$BJavxQzf~t3`<*7eALGByJu6Q#V5u9}9dOuA8+KADL7A538^Y!m*40uI;g{Xu$ z@Qx9k-P|#!v}iEG>E|_R*8`#)3qgmRnb7RO?UI7;@9S#X^e6rXoXh@E-m%aJ2ROfv zuV_VIH6>;%-`p@cvT5J0+($UawO^+};{odVvcr;FO$WflC+l@GuJg(U`a#!@){)IJ z%1zPeclYSM<~I>3BMzoQQHQ5kV16V1-4t@3ktJFd=rBlHTZdQP!}riWoykqGuFqfm z%ec+Y1iy%mq-5uM;+~@JT`<-KWz$>{N3NEV>#GAsU*xi2TKdl+C;Xff{a3d=t;BP5 z9ApIV<6>ks`ZC(}i#lA#Lx=gO z*E-#HrKD(6r_$Xv78G!S<#zPhR$HhzF%k#KnwJl+eh;G&xkfIpFNg5_%rfQb^~;#h zt7P$n9IPi28tX!(@Vw8`b!X;ZyeT2!E{>f&s1Fb1mR|dZ`+Mi-+R3BX-#u?Eb@=&8 z8VUHjjD~s4wa}`8EDyP^ z#f#7LsM&F2gGl7n$x;Gya4yhxt>d!KSKHueE$2R+lx`^OY2hD6-o;y;M1z0AOxSOj zpiqPF#lJoJthcx7$kr^**<9y-kO^11W{dsc{j2xCd76iOQpF$L)cH1OxbpRmpKUjA z?rIplkNlQZDh(!_TF8+NW!?kqZ#`d6u`||3{?1C5ZYxo|UxBfvWAei!L(JFpcJVOL zz1Q;Pa7-KWRXzO{U*dUEo_gh?=qoO0zT`8|Wx@r*my-3Sj;OC44zl^%1zU5bTGjBp zw*B&fReMWVuy9{^_y_9nE+OWswfB+h>bU3U6(j6-JN=XJ#5(RbSH06e2A=n|g?ERH zM?Km2S$ka}<`1k+y*_H(_=(J}T$5Ei&jLv)-&>04d$&NX@wzhfpLuw#&Z3VNdVdTA2@h38Td%zSYZ%jq+Pl~%(! zlZ~UKh*4~P`ZVr4Y?;rJU)a!RPF9xtRKQW+*PafwolujSvd#tf)BaZ7-%HTf`hNV6 z$p3vU!6W&eyPLepVdV?)i(f_w3~z9Lhv!m_AHB3tfSk$2ldBJ0+Q@{5llEUkG-)tX z=6&^@dIK>@K7HC^un&~R*JrD94igKm!Zku)}{)@ zK_cJCd&sztO1vyCPi$T>3bco=dCE5`LGT0bb%Pxg_~_R0sUN%#WIi6 zz;iEU&99fXbG{(r;{QhduH$)x;oD>s!Z7z7XeBZ6j18>|FJ@zqU%s7N^vl2otOK@? z^((k&D7pQgVZQfryzg=rOeL(pwCatFl*O4~|MuTjufug@V`!M1 zG0w4=$n{ekz7q1e@g(;e9^_xCUG=TN^{e5BLBjm9_fJc&88w@;g z6=KeIgLCTF%-a9h_&IsHDFc(r5eZe0cXN2PEan=@giYy7s;FeL z^W*h^ND9oKTx^@O8i9)ERx0UCL!vxIiF&zhj6B|XThSVI!g?0}^-|7JfM45sOb%9n zORd1XV1Fl^wUSuXhPv)=>5fiCa|)QnEzOWX{k+v_{q_SI!6e4E@!+e7QKI0&zg>6} z?(ZSim(OJ2oZOWdP2t`7#GzvOg(94vq(o##Ra)kdlmoY|p6E}&Jl*T_oAE@b{4yX` zqM8ZQ7e{`_bteHOaLV}a>2adjAnmq3Yn-Hh?Aohinop4Gsn54PgHTug6QPdF(N2wRFjAK zn3Qwp%>P4P?$5x9OaADOv9pg$brw*8tUui2DuX=wC<){4Uwx2{uEqb)W7N_c6Yt0w zCZD;|_SNjd^?7+h%wQ7(oQJ4O^Eh(u4(k56z@1Ol4R}%6 z8WV7LZ`{TFkKwSVqyF5COBxW0X5L2R#_M`+UR1&B!XxNc?(|@stjJeBDvDgmV5uOZ z9PxDGD8*6nv^Jj@Hcf1Am7Rdpn}5Pp>l48F*oFOa0_m_xMdsY}R6HcEUin4^^V0@z z#2rI1C;XGe&QZUVPhRG&yf!GDK{}MV^$y(6Cr>&kZhu85U}-Gt6iX-$_B-np&$Xw6 z`;||_fno`;H2BrgufgNwk#(|^W6(G`@cx*D`lmdi;G~-v&z(k0`5p}w2j>%M+6kGn z5)(kR-(uW@bDAH;ISOK?(?RVOXSmi_Jn#qEJ8k$hPTq@1{*G%w{+Qd_H+=S}=U<1f zJX=Wx?PucK|8X~xh@0{9I>?K2F@86-tcgihX8q8=$T>n-Jk*m_qHRDqsuUZ;-woxl z;?FkYT)+F>XEp~eGQs8Rh%I*7A*oW_M;7^Lv@R~9`?n9C^yjRIwUF58--+eHzhXLD6Rwq0(8z=AhK|f-7J~?BUr(DvSL4@puE^VXbk=lB`h!&j* z(AU0U&t(<``YlVYX3nL8guZzTk6t`9tclA$o;prE|2&G?VT!z_Pco+3*?A7;Fw^=}fLu`7@6V(zPC$D2h`yFnGDNO(dpB#84n03J7A%bu;7k3xYQM+hRH&guP`UhmVjlX#xY_QfB3l(pE-uPEFaK&v-qUyA}A{@t3jwe=_X zRVwsWllL~`k0F_Pe9&*FWUch$&9iD;XQ!L-9Q0xBip%d0Q1>r?W@iC_S6uux(l;G= z=80{Ovodx-zD4)6+S&=IpI%jW))Z;Rl}QYzr2q0;{ty(2OYf+G4bnw zuj}+>T7LmJhN#nG)RwIeKQ$N6PJ_Nzj<%|0*^w`(-ug)8DIW048kC{4@vR(*b7ChdO2@Pt}~pu+LTF$60V3b6)@OkHDGaIyp9Y?9~L?_G!K3 z2ykJZ`wL##TF`>aul(#>(>07jZz$ET?wG*)=TrUX7bdYPzL9td<{Zaa%)UDSuX|)) zo5||bLEr)}Zwk3Nfwpi~Bueo1qg$ud>&`7VVV_HEcDi2Rv&io_Ok4y$uIy8xA4!vV z@Y}%8-i^S8;Z}=ol^H-UQA|)<71K^m~mq0e48$%783(RC;VpeOFU8R7fe zUp!}EXY+d${0e$6JS^dC#^!`Y<$i5A?_=pvp)KGG!*L_Vi4W#=jhdQzfO}s(>+bp< z>N4HK7HnEVeYn2;;yyNrzru13F9<^2yqIl=yVR>@%)#_2E(hkIc;!-sI66u&@7>TY z?%y<|ddgg)?dB*tD0TauT;CWLF?>)mz6X4v&#%qz1pShA{luF zTMrv-Y{5S}4$oO^96|QOy#lp)6Zo0ZF>3ob#5=d0xPG~Gp=qlJLc2l-(Ciz(O4VnB zXrs)ugg^8ZFbZ2-x3c%4_mu1XJ`QPbG&u>^r_iqvAKv>;dw#kBWNyYhvn`<;7S}@x#m$l3BD)47r&Nvq2?6luDjoK zI?=JN)$)^$1L&hhsIJ2s;J_HV`J9iNKrOTE^S;G>NPS)_b)Q5lW@g@YbPZz|eXV+z z!oxp-9|{`{weWq#qaUkIRRiC1l;3IB6mZ%z_e-okdXtW}%9%+dslP+pY)#+5lr3^H z?y>F$f4Ozhx1jxdwwSwY#KL^+ zzW1e0k>dkME6<)HA2*1SwRRq!yfT5>0v3*RK%Ubx^4WT~?q(cdqBbTkJ%Uu{YUfpp zCh$eqQvuYjNz9tPbH95+7jk=M`7L1k0Q&Xzc2v+c2IP4j`1F|oS9`Fx$#io8&MbX= zBLpwww6?e$L!X{tjPgxnyj;5A$J)*lOoUk8+4``=UbJ4V=vI7 z8qPL1*L1WgPW7hDp=apw%Dp4Qu?)irZqf+2mg2hH*AZK$0mR zd2~TvYFqOaZ}VYbecSEte}itauy2>UaUvf-tBRlg!U6M*3=eTz&|_8;m96{5U>?ry zY*77^EVM2^{A#^>5}F#Vin<@dzz>*M4lrngDBC4t?MUDRN)Y}a#rz8Vyiy&EtelE z#V%)qd!x4GV}HrbHHERoIJGY)s99|W?KYa^^GJwC_tvbj-N2lUenw=}dcb_8RE(zu zBMf|n?qj~47Z`YJU+wAl8%yyz@yd+{ObW2*zSRYZze}*;iJlodSf8x4qBLGT(3x6% zdCiL1Naq@j^}0+V5=nbzBm_QE@7Ch*NM{C~dZv5mK~gEcB$UVDAdrt)cl_E)RV%~# zCzkLT{TURtyQn-)|0VdN9^MxDC<|R_la*)}OG3qOLe?5OF>nR%j>d(jaQ&Q&KCOAN z6uZ5BvsF+t58v(;{(cAI6hiBr^2qraG~3RH5-SqXrD~t864lvg-KAT%o|q<~!A%*j zT8v?i(RruDrL;jr(h9QaxiEq56|JbxUhP9c7j@!=a0_PpPE~CCI*hc^>$IqXO@7siYvWX*3&<6^`{P8TzYvFmGo)s4c4ptsB;IJyi$7(2FkM7LHbu`J7l2c`PV2olcr8R@%g&U?j>SDp) zbZSOWI~NtMY89v`PC`yZ*9}?_1E0y%zfe$ZDUt?n}#Z>B%UzvGuzRa86i-UiG z!>zDu>&0f!=|Jhhh1nQnZu^+;DmfGJUT->!kG??u`_9~EEdU>l{w)Q&&47Q{%4r+5 zw-gsz}N zR_77VCb9q2Rkhukz?V68I%odn0BS4<9d3I{M%z8C{X@Yw@=?r$)FbgmY=6{T*}{zm zeDor_h@ei?|C;`peLvKR!=|N6JUVbeg=D`#M>mq^ZvHXmLPsB`9<2JD0zBvEi>pOA z!AJKO@0J;u7y1=^Nn;r1^Y`|OeT$UuL?71|G?EE2aP)HHILkV)z=^9`;ep*~;Amn- zq&4KTeA^s8!}X}s^t!)5x)d)sK9bmRFBiY8o?4XORfdHI(!VIfI{#c_ZrKO(4VLhhi*J z{P^Yu=^2##rFk3oxkR)oad)`k&0Lh#`mpBdLNam)Ca?C4fq2lsWRB`Fh_15hv!wV< zpdF%De=*hep{lhnbM$Yv;4Mce&sG7qSzh?bcVX)Zyhzz~{~Pe_9BPlPjJ9_I58{xY zRn-8J^Y6ZM2j*C{F8LmF10TY}L&5UC&W+ghnDpyQ1~gpz;g^j4KqsmqF6@5GOoq9h zP20zHJMfMDYqylj^q};2Q5VG_e`J(Xc)BQ@jH2eA=X=8ZP1w6|7aG z>Jp-c8FV6IR)4oG)MY1MtshlR>%drb-zfv&usqyyG0XWh^apDgOUu3_qqOSkSe6+& zy6ejtJ}=#b{jEc)Rjp{a(M`FOo#@%WLnUj`mTlK;v#R?l+YVr$8MoSV;f&oK88u`b8*03G)2ewRP6! zmZK;-X>jyr=@|YQ#Fl!=6y~bu{;dCzJcu0qgH7}FCQz$OQ$-HsIZx}H6xmtRf;~6n zoRfg({Acw}#*w56oLUvUlmXoImcTx-qx4Qh(LL|w3qGN0msCCMa|V%WPfDdE^r4BA zR{lBzd3BG2Aq$eApN*;U$L1ABkXq$xOTKNBSY>R$E+z%I*h=>~c1?i(G4glgg?|2G zW#+YRZe*k-g<~a1GF_EYFjACHj&6FcEnV`l(F?gI62s zjv(Rfy50QHe|6`A7>8WvB;GG%=9L3{e7BmF8&;6FA?W9MR^26|t2yc8JE87v*QMuw z^JF7VjFOht38Z1>=lf{RKAmXurV~PD8sO8Vw2(UL4DjJq;yV0hj<%Y!Hdgr6A zMGkl#N^-G^j2TTJ-utc(W`PS+)|<;CDcgeAm4#%8PYfg5w$%8&;ImYD^~EbL>LliT z`$9&~tP5#(d>PXHKt&Zr{u!4W29dO(5Kq7L1d4fi)G+KD85vL3;wpm{Jl)$D-}D9e z>deObU4|xbv?G5@%n-ztX%6QGjKMekaNDQ=g^Hdm2d^OTgXVkpNxKJh3*T^3Mv_q< zGO^wv=}_2$kDc5<;5|8vN?jXj$E_ytiQi{xxqeOJkv~{%_d*xC`axP_7V@hq(sumS za2;NfZhI}@4my0_$KgK6(<-Ca9%P~g$E@}o$5X>-&T#Fur(Y)U-61FThz9UmxIx{) z8r_9#1-srPK|kBh7kd_cppQ|DVOg)9IDvSsD>_F2htyVPRkqQO7OW^wwplD6M*OQS zKL!m>;24)5QAXbG19)DI1AbNpT>(0VKR9k$wwB-B*3V1zsqY}82 zzmnb@5@c_|H7+IO9Xun5ykTvRaqJ8pOkWVPi&siu0 z9hF;Wd|DsQm$Kbdt??%^@>yN&r!~}q1&8AUbn1uE<4+Rb`Wq&2Xb!Vrwa8b@j}&@3 zfIC6{SCEZm*<&;0xKgjHo*IjOS@Njn>Yj4cPvVX&K2W?MCVMcz9Kw$ zJtop;z64jCRNI~jI$S@r$9m>)EK>3L9yL>ujdDxdBi6JgBF8(2w|wYl;6u@oevT(# z{yp@R;%5gczTQ6dTpRjen=}MUE=Sj*q6c?H0(VT|=%Mn?HwpbP$J>|@*-pb#_lqUy zmkW?wkY(?g3GkW3<0s~UpYUnrp(L9Z74MRHbD1Mz0_UdbJ&1~^L9ycT6`m4P*koDo zqz^L%=}RpfuLVxoEiEiuRalG$mklRpT>ul@?-a%!JtO)q#Ig$+{Y{5UEPD3m~0P63*KbxJ7fjDsHn=Wd_NxOqcU0#-cTMbT9u&%tf6{lE%mW zBq9!v<9m*P4*z^?A~(eYc;sHmspn1><1E(i#i6wYcrN-{aYsc7W?wLm)`h&fuN2vD zXXI1V+L66um0vcReRO6tB{CW9{-86x&8`GMq1Eo=->ksYqUTV#XMLu0z$@ohDhOSll?czwdZ1ezX#D zr&_fXdvd?%4kTs}TW+%YwvlM0Let*Me=!$biH`CkX(b~m&)pee5LbSaA}p`N=jTG1 z9QlC~eBAOv`A25(MRrq9vf?ep)^>&0M8#*&b9Uc0v@r(VyzROaUY?ESnt3W~%#sj$ z!K3_1IHu!=ImLXn5O22B*a4F0>(Tf3p0;Ui{XpncMtr2OeH(Hsu3OA6saZ z^Y3`zH7)DiaXHY33Til{%&5@UCJ?M!Al-mXc^#O|Y=E=2pUGH8wF_M-Q|0QoO2(4n z8>D56I`Fr>yhk@5??FBDSHE-W(jh*qOkSG?Iy2Gbi4p4*x^S~D-Y26GA3DY@n*D-? zlXad*Zq({Tmo~jHQqhNbsAZ|`O3fYEwDP(Cfvj$1`;MFts7OaL^emtD>kJ(FQnP+O zz65*ep1rzeDG&F0?Gb5a9#v-w;z40A5$ zCXRd4#yimjyVz#^Kr*gdKYm9lwgc1T|C}+F??Dm0;7+!Wj^YEJJPuNax`#5J2sku_ zc3ZD>Fyb1p`ewt2m3}mA^|IotK5#s=g<>M9Fi)3R$GTqNSqJVQ^%r&D?MC7!KCjEs z1HMR#q!GUNx*S}GE>7R7QbAt~KOtpsNKK*h z#Q`6>L1)f5_BAHoqhW@Xt8a#KClYtz$mtda{{-n9X0`7-Fq83}OW&iwkH>T={W);u z)VtTHeu2Icx!?QvQv;_^4l}17NxlK6yzFP3Lp1De+d9qX+liW9H<*8<_2RLcuRq;y z>A+JJUs?i6x>2*?WpBNM&?l;KTzJKUT;go<3lln zxxhOeEwS8V+0~09KKQ;ehB>ml`&OA>`XIi@bzqH!e(ucqrkBxj6kMWbLQV>!;=H7y z42ult|JRZDz7FQbeSgP{FR@Nx!PLF9VroBnvRSU;4DjIA(yuPObS^^bHG&@Bc&X^@ z>G!vUPEl}SE1BVci;CUaZ^<-+Zr2$P3iP@ITs*-_+x;R_SYMXUm35#WSxQ@*^5)X; zn3GhYYx--%E2}JkH&PLQ*_t0YoBL4dC=)$rh>kcLvnK~af%jo>`Nebq_-a^(K06lz zeEzh#AmR0J{fxX@+W=hEO!^vS<22y@b6Y2*dqe+_z5CpEh~r55tHioN&l7{ul=3Oy zMHIF@cg%0WlkSgeG@*YZvc9b6Xx{{8y?rR{ub&dvey;5)-#XEsQ?$yoLj%Z>VLbnW zI*86!llQmzPoUD@e)Fy1-$u=prHOI2;+aenhe_~p)@k%_&PtrX+kQ^;U4^=y{W{$< z)db8)bS%Z^rgvFbcA11i7J+ z(!U(W*c+jp9fOlNy}q#XhjJG(f59J->N$X{&JbJk*oV+Won1?OGWe@gZ^oRyPDV^x z^hdnyEx4)tUHm+G7%eIv8S{MkH=p1eh9Qm%WSEvpfX{U1;`o?2)Gy{2e$rj{Q1E!g zw9Jc}z>Vgt(3?#HKK-pj`GKrxtU;|)udof(T)K1w^aPdGxpG3s83lw<|SRa zS%daZB-m_ao5I3L4{8b1ED^nB{O*QkllB+-bSicGm!lJf`(W?tX7 z=cOwZPwvTGVg;QUSD$;$bW1IgG92b*dr!v^8LU#uzx&a{cW>fU=D}y>z8Y7;k0R7L zyGBh#m5R3PQ<(e%-2Q~K*x98A{GW$j^5ws6#2>y0u8n^M^I0z<1@-_Z=e&1mSt9g{ zxBa=H&^p#Q;&U5HrErB^p#-y^{Y+J89RpdvO0MJcT}aRlz$ z!pS8HF!%A6rC5^|AqxKZR|oSJ4B1B5}^V-Jw)0JLsQAgSk9%zCW?* zGYN@H%1GwJ{r*l?DelHv3Ti9r2p#*dZ~6nggD0mps7y%Y-AX$$-Wn?Dyr z&cJ!!wT}Cz5%eMSBv0>cK3{`YJz@XDO{U}fxu;T>1;L+iyeL2ZH4V4#Z~1O2T8gG^ zJv(;;UsN+Y=*tGk(_EHUyvW5ig_1MIJ(++<8J8Dlu|9%^7g_C~}eKX2Y4>%wq3 z9y7PF-YqqQYRl5ih1y>rb>sc3fA(b{#hnX@yboR?nckW9Q=n6a%emylKz9iH9)0=h zNeO<}VljJEEFVuteXc)&%kk!x)u-4Yf2c3M>o5@>gD%^waD8RTMv5zS?(2UgBjEbJ z*_#2rM7km0zkol;g-w-e`FE%|^L1YPXW&Tc?tVOUm#r2l$>qAoH3K&+Wwc%jcqAG1 zZ#9SMz)=dk^x#i*F*@^cxn+k173ne(va58UtBz1I|G;6AOC-#n7HrxdX#(F=AT zfqAs}k_yoj25{@oo}3je#RYSjmizN_uzq#ycy3WCPL11}P;ht#jfR;%5*STH;?~Yy zW=Hdpx8)RplEGi`HUEGO z_;y|HRO*8GY1pt743JClHiHQ-35k4My0^69UUV6rkpCH*EkA>#hObck*ptCO`R51y zt}Nu`UbSJ-8+@G4u3zMYyz#o7^4(c(pj+O_zt(`h$Wxn=58Ig6W7}`rVmwu8cLC+ymXBu%nebC#MtDh^ibr=|#p560gOwGbiDrs6~623#FJYCEq(!%;>@(+_R||J2{d%PfBNVkMq-KLmc8 z`g@0S6dbydnO$GMx+y&Wj(78NnS*cFMF}ej{!(nH^XurT(|K5R*Gx)KTM2%y5&Aju z#0+9pPbmAy@&bJg&}}d>%RwdIgTL}dB_Up|BLa&MH@*AO@Zc!aWiF4eI?@VpQhf#Y zTK^LTn4dq3;OlsUV_xk%eGuX}@_^(Ze`5*~VP9OWXOo3)9scrT@Ix|^_@lm^5BlPY zPi0CNLOsQ@g;F&AqZChX89zce=7ZmHUGAb<1%4eOaB0M121Q=Z%V+OSMe&d0!hYCg zqL^ic3?4&>pD!8baT_wQFISyiRvU2RSKlvb?}WT<1KIP)?M7_e?z+bn-WPLnW`+Co zJJI%An~VH4VeZ9uq&{G%1E(hL>`Ed*{B>nW@#{746*50oClpUcz2%KeXIQ4ti`qs9 z$LvPT5-wnDlmbOQws4%Pp>-AMWX#y1DZ<>|fj@Sh%<%gFeqi*Oc~45uYLH_o=^$v1KL zp}y11F~6o@on7{g%WQAJHmh}ia{IvhrDxx*;M7j!=pjhbJPp2TUv=$efN!V$R%!lN zCFty+OFqb~n0alB#`GhmPuU0UW_XMhsiV-ZuRygzs$-&$!uuB`@F6 zqB+oT8vCNs`{fR#(Vu5|m zJ{{1bC{vMW^|b3%CGc~RBpVd^Q?W%ww*Obik1^Hs?=BOnMHZr?)6?*rHx)L@ssKGd zX2knhe1wJ#WI32V&laLDMW?fdw5cdFdR6kqdlbCm$7rn_yqD=^4J!8VUe@_M8T6^3 z7J09K*zdk>3hTVkDt1ZlN5*r3Roqb5An0Ft-F*wutVCbO(i8>l93K(p0$vThA=Ld4 z_`PF2LxvtxGk(SUtZy20B~RJhxd~?Yt*;c%v#%2n=vb?w`5!HZGO_ib*F46E% z`K8V;DxE0eLs^&47MMr1n%6%CeO3w*R?-O!q?aZD|U_bVWz{eZj zA(>^BnjM3595(aqH)k%)!#}EU-Li%b93<0om+%@{+t0Qm^s^o(8 zHwgCOZ$a_)*MYO-`CRF_u?zSJ(I*5_ARg4Wv+ObZLqcNdyLQ|>HibX4emUhk(~mk` z`PGib(y-ejnO`wI#pqg}xK=R_6;U)Fw^mX5@yYJ-BU6v4SRjSCC=ByZrW-l8PJ+z>a4_{7WIfA?32NcyhQCEw-D{o~e?t(2Xrt1+hW-nBXIFkUp#>J|oJ%T;RRP)m!_iZ{-d06!Qus8)js4+P{YeU5` zQ~Puf#9!-|)g6;UYfw>06Nkn(;Mv{d7tQ6OpidrilGlL$D63aEdqJ}pIS$nCbR?+g zC(pHv0Rsx&;ApY?;tMKXTbsD267Da#RC9w}oh0<;L4YDfU<$`y^=SCSK|v99B}K}Q z!Dr>IRf#A^DKfpw(X)L&75!>et}o*UUx0k}u&5|1zHpUUP$X^wR~Y{hO{9}hu*bU$ zRd{YZx)bq81D^AV`o4=xAHdJ%(TR*_!hkAt3Enm#LPa!7@9}rgKSH-llZrn!g>(kEv4Z}VB``@!)})cIt{ULv^{FNx$ufBDvdJulUl&+zo1%;hUb^>+iu zi6pVJ5_Ah~-MxJ=Fb^%cmTq#1uMvNu5&Em@Y52CZGQWa9_&4W`Sx!SAuTy)H9tXVx z;wnphy`gUOr)EQz@)FMBd`smPysZ3{pnv10>(*k0H(0~v#yvfm z8IS^q+?1SeRukz5) zX;|lXylo%DPS>ELwmBR2{-opW>}{ThHc()0>C?&w$hS=1W{q2&RE%0AJ%&e*Q_-4y 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

    wDYN>Y@KUWqYGDC$_|8<1hN*9u9ZjG?3KIN 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