1 | import numpy
|
---|
2 | import os
|
---|
3 | #from basinzoom import *
|
---|
4 | from ContourToMesh import *
|
---|
5 | from MatlabFuncs import *
|
---|
6 |
|
---|
7 | def FlagElements(md,region):
|
---|
8 | """
|
---|
9 | FLAGELEMENTS - flag the elements in an region
|
---|
10 |
|
---|
11 | The region can be given with an exp file, a list of elements.
|
---|
12 |
|
---|
13 | Usage:
|
---|
14 | flag=FlagElements(md,region);
|
---|
15 |
|
---|
16 | Example:
|
---|
17 | flag=FlagElements(md,'all');
|
---|
18 | flag=FlagElements(md,'');
|
---|
19 | flag=FlagElements(md,'Domain.exp');
|
---|
20 | flag=FlagElements(md,'~Domain.exp');
|
---|
21 | flag=FlagElements(md,md.mask.elementongroundedice);
|
---|
22 | """
|
---|
23 |
|
---|
24 | if isinstance(region,(str,unicode)):
|
---|
25 | if not region:
|
---|
26 | flag=numpy.zeros(md.mesh.numberofelements,'bool')
|
---|
27 | invert=0
|
---|
28 | elif strcmpi(region,'all'):
|
---|
29 | flag=numpy.ones(md.mesh.numberofelements,'bool')
|
---|
30 | invert=0
|
---|
31 | else:
|
---|
32 | #make sure that we actually don't want the elements outside the domain outline!
|
---|
33 | if strcmpi(region[0],'~'):
|
---|
34 | region=region[1:]
|
---|
35 | invert=1
|
---|
36 | else:
|
---|
37 | invert=0
|
---|
38 |
|
---|
39 | #does the region domain outline exist or do we have to look for xlim,ylim in basinzoom?
|
---|
40 | if not os.path.exists(region):
|
---|
41 | if len(region)>3 and not strcmp(region[-4:],'.exp'):
|
---|
42 | raise IOError("Error: File 'region' not found!" % region)
|
---|
43 | raise RuntimeError("FlagElements.py calling basinzoom.py is not complete.")
|
---|
44 | xlim,ylim=basinzoom('basin',region)
|
---|
45 | flag_nodes=numpy.logical_and(numpy.logical_and(md.mesh.x<xlim[1],md.mesh.x>xlim[0]),numpy.logical_and(md.mesh.y<ylim[1],md.mesh.y>ylim[0])).astype(float)
|
---|
46 | flag=numpy.prod(flag_nodes[md.mesh.elements],axis=1)
|
---|
47 | else:
|
---|
48 | #ok, flag elements
|
---|
49 | [flag,dum]=ContourToMesh(md.mesh.elements[:,0:3].copy(),md.mesh.x.reshape(-1,1),md.mesh.y.reshape(-1,1),region,'element',1)
|
---|
50 |
|
---|
51 | if invert:
|
---|
52 | flag=numpy.logical_not(flag)
|
---|
53 |
|
---|
54 | elif isinstance(region,numpy.ndarray) or isinstance(region,bool):
|
---|
55 | if not numpy.size(region,0)==md.mesh.numberofelements:
|
---|
56 | raise TypeError("Flaglist for region must be of same size as number of elements in model.")
|
---|
57 | flag=region
|
---|
58 |
|
---|
59 | else:
|
---|
60 | raise TypeError("Invalid region option")
|
---|
61 |
|
---|
62 | return flag
|
---|
63 |
|
---|