2019-11-23 17:29:41 +05:30
|
|
|
import copy
|
|
|
|
import os
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
import numpy as np
|
|
|
|
|
|
|
|
from damask import Geom
|
|
|
|
|
|
|
|
|
|
|
|
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())
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def default():
|
|
|
|
"""Simple geometry."""
|
|
|
|
x=np.concatenate((np.ones(40,dtype=int),
|
|
|
|
np.arange(2,42),
|
|
|
|
np.ones(40,dtype=int)*2,
|
2020-03-17 16:52:48 +05:30
|
|
|
np.arange(1,41))).reshape(8,5,4)
|
2019-11-23 17:29:41 +05:30
|
|
|
return Geom(x,[8e-6,5e-6,4e-6])
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def reference_dir(reference_dir_base):
|
2019-11-27 17:49:58 +05:30
|
|
|
"""Directory containing reference results."""
|
2019-11-23 17:29:41 +05:30
|
|
|
return os.path.join(reference_dir_base,'Geom')
|
|
|
|
|
|
|
|
|
|
|
|
class TestGeom:
|
2020-03-29 23:37:09 +05:30
|
|
|
|
2019-11-23 17:29:41 +05:30
|
|
|
def test_update(self,default):
|
|
|
|
modified = copy.deepcopy(default)
|
|
|
|
modified.update(
|
|
|
|
default.get_microstructure(),
|
|
|
|
default.get_size(),
|
|
|
|
default.get_origin()
|
|
|
|
)
|
|
|
|
assert geom_equal(modified,default)
|
|
|
|
|
|
|
|
|
|
|
|
def test_write_read_str(self,default,tmpdir):
|
|
|
|
default.to_file(str(tmpdir.join('default.geom')))
|
|
|
|
new = Geom.from_file(str(tmpdir.join('default.geom')))
|
|
|
|
assert geom_equal(new,default)
|
|
|
|
|
|
|
|
def test_write_read_file(self,default,tmpdir):
|
|
|
|
with open(tmpdir.join('default.geom'),'w') as f:
|
|
|
|
default.to_file(f)
|
|
|
|
with open(tmpdir.join('default.geom')) as f:
|
|
|
|
new = Geom.from_file(f)
|
|
|
|
assert geom_equal(new,default)
|
|
|
|
|
2019-11-25 16:34:57 +05:30
|
|
|
@pytest.mark.parametrize('pack',[True,False])
|
|
|
|
def test_pack(self,default,tmpdir,pack):
|
|
|
|
default.to_file(tmpdir.join('default.geom'),pack=pack)
|
2019-11-25 13:58:59 +05:30
|
|
|
new = Geom.from_file(tmpdir.join('default.geom'))
|
|
|
|
assert geom_equal(new,default)
|
|
|
|
|
2019-11-23 18:32:59 +05:30
|
|
|
@pytest.mark.parametrize('directions,reflect',[
|
2019-11-25 18:31:40 +05:30
|
|
|
(['x'], False),
|
|
|
|
(['x','y','z'],True),
|
|
|
|
(['z','x','y'],False),
|
|
|
|
(['y','z'], False)
|
|
|
|
]
|
|
|
|
)
|
2019-11-23 18:32:59 +05:30
|
|
|
def test_mirror(self,default,update,reference_dir,directions,reflect):
|
2019-11-23 17:29:41 +05:30
|
|
|
modified = copy.deepcopy(default)
|
2019-11-23 18:32:59 +05:30
|
|
|
modified.mirror(directions,reflect)
|
|
|
|
tag = 'directions={}_reflect={}'.format('-'.join(directions),reflect)
|
|
|
|
reference = os.path.join(reference_dir,'mirror_{}.geom'.format(tag))
|
|
|
|
if update: modified.to_file(reference)
|
|
|
|
assert geom_equal(modified,Geom.from_file(reference))
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('stencil',[(1),(2),(3),(4)])
|
|
|
|
def test_clean(self,default,update,reference_dir,stencil):
|
|
|
|
modified = copy.deepcopy(default)
|
|
|
|
modified.clean(stencil)
|
|
|
|
tag = 'stencil={}'.format(stencil)
|
|
|
|
reference = os.path.join(reference_dir,'clean_{}.geom'.format(tag))
|
2019-11-23 17:29:41 +05:30
|
|
|
if update: modified.to_file(reference)
|
|
|
|
assert geom_equal(modified,Geom.from_file(reference))
|
2019-11-25 18:31:40 +05:30
|
|
|
|
|
|
|
@pytest.mark.parametrize('grid',[
|
|
|
|
((10,11,10)),
|
|
|
|
([10,13,10]),
|
|
|
|
(np.array((10,10,10))),
|
|
|
|
(np.array((8, 10,12))),
|
|
|
|
(np.array((5, 4, 20))),
|
|
|
|
(np.array((10,20,2)) )
|
|
|
|
]
|
|
|
|
)
|
|
|
|
def test_scale(self,default,update,reference_dir,grid):
|
|
|
|
modified = copy.deepcopy(default)
|
|
|
|
modified.scale(grid)
|
|
|
|
tag = 'grid={}'.format('-'.join([str(x) for x in grid]))
|
|
|
|
reference = os.path.join(reference_dir,'scale_{}.geom'.format(tag))
|
|
|
|
if update: modified.to_file(reference)
|
|
|
|
assert geom_equal(modified,Geom.from_file(reference))
|
2020-03-29 22:42:23 +05:30
|
|
|
|
|
|
|
@pytest.mark.parametrize('periodic',[(True),(False)])
|
2020-03-29 23:58:54 +05:30
|
|
|
def test_tessellation_approaches(self,periodic):
|
2020-03-29 22:42:23 +05:30
|
|
|
grid = np.random.randint(10,20,3)
|
|
|
|
size = np.random.random(3) + 1.0
|
|
|
|
N_seeds= np.random.randint(10,30)
|
|
|
|
seeds = np.random.rand(N_seeds,3) * np.broadcast_to(size,(N_seeds,3))
|
|
|
|
Voronoi = Geom.from_Voronoi_tessellation( grid,size,seeds, periodic)
|
|
|
|
Laguerre = Geom.from_Laguerre_tessellation(grid,size,seeds,np.ones(N_seeds),periodic)
|
|
|
|
assert geom_equal(Laguerre,Voronoi)
|
|
|
|
|
2020-03-29 23:58:54 +05:30
|
|
|
def test_Laguerre_weights(self):
|
2020-03-29 22:42:23 +05:30
|
|
|
grid = np.random.randint(10,20,3)
|
|
|
|
size = np.random.random(3) + 1.0
|
|
|
|
N_seeds= np.random.randint(10,30)
|
|
|
|
seeds = np.random.rand(N_seeds,3) * np.broadcast_to(size,(N_seeds,3))
|
|
|
|
weights= np.full((N_seeds),-np.inf)
|
|
|
|
ms = np.random.randint(1, N_seeds+1)
|
|
|
|
weights[ms-1] = np.random.random()
|
|
|
|
Laguerre = Geom.from_Laguerre_tessellation(grid,size,seeds,weights,np.random.random()>0.5)
|
|
|
|
assert np.all(Laguerre.microstructure == ms)
|
2020-03-29 23:58:54 +05:30
|
|
|
|
|
|
|
@pytest.mark.parametrize('approach',[('Laguerre'),('Voronoi')])
|
|
|
|
def test_tessellate_bicrystal(self,approach):
|
|
|
|
grid = np.random.randint(5,10,3)*2
|
|
|
|
size = grid.astype(np.float)
|
|
|
|
seeds = np.vstack((size*np.array([0.5,0.25,0.5]),size*np.array([0.5,0.75,0.5])))
|
|
|
|
microstructure = np.ones(grid)
|
|
|
|
microstructure[:,grid[1]//2:,:] = 2
|
|
|
|
if approach == 'Laguerre':
|
|
|
|
geom = Geom.from_Laguerre_tessellation(grid,size,seeds,np.ones(2),np.random.random()>0.5)
|
|
|
|
elif approach == 'Voronoi':
|
|
|
|
geom = Geom.from_Voronoi_tessellation(grid,size,seeds, np.random.random()>0.5)
|
|
|
|
assert np.all(geom.microstructure == microstructure)
|