-
Notifications
You must be signed in to change notification settings - Fork 40
/
Copy pathSimpleArray.py
110 lines (82 loc) · 3.1 KB
/
SimpleArray.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
from DeepJetCore.compiled.c_simpleArray import simpleArrayF, simpleArrayI
import numpy as np
class SimpleArray(object):
def __init__(self, nparr=None, nprs=np.array([],dtype='int64'), dtype='float32', name=""):
assert nparr is not None or dtype is not None
self.dtype=None
if nparr is not None:
dtype = str(nparr.dtype)
self._setDtype(dtype)
if nparr is not None:
self.createFromNumpy(nparr, nprs)
self.setName(name)
def __eq__(self,other):
if self.sa.dtypeI() != other.sa.dtypeI():
return False
return self.sa == other.sa
def _setDtype(self,dtype):
assert dtype=='float32' or dtype=='int32'
if dtype=='float32':
self.sa = simpleArrayF()
elif dtype=='int32':
self.sa = simpleArrayI()
self.dtype = dtype
#now pass through all the other member functions transparently
def set(self,*args):
self.sa.set(*args)
def setName(self, namestr: str):
self.sa.setName(namestr)
def setFeatureNames(self, names: list):
self.sa.setFeatureNames(names)
def name(self):
return self.sa.name()
def featureNames(self):
return self.sa.featureNames()
def shape(self):
return self.sa.shape()
def hasNanOrInf(self):
return self.sa.hasNanOrInf()
def readFromFile(self,filename):
dt = self.sa.readDtypeFromFile(filename)
self._setDtype(dt)
return self.sa.readFromFile(filename)
def writeToFile(self,*args):
return self.sa.writeToFile(*args)
def assignFromNumpy(self,*args):
return self.sa.assignFromNumpy(*args)
def createFromNumpy(self, nparr, nprs=np.array([],dtype='int64')):
name = self.name()
fnames = self.featureNames()
self._setDtype(str(nparr.dtype))
if nprs.dtype == 'int32':
self.sa.createFromNumpy(nparr, nprs.as_type('int64'))
else:
self.sa.createFromNumpy(nparr, nprs)
self.setName(name)
self.setFeatureNames(fnames)
def copyToNumpy(self, pad_rowsplits=False):
return self.sa.copyToNumpy(pad_rowsplits)
def transferToNumpy(self, pad_rowsplits=False):
return self.sa.transferToNumpy(pad_rowsplits)
def isRagged(self,*args):
return self.sa.isRagged(*args)
def split(self,*args):
spl = SimpleArray()
spl._setDtype(self.dtype)
spl.sa = self.sa.split(*args)
return spl
def getSlice(self,*args):
spl = SimpleArray()
spl._setDtype(self.dtype)
spl.sa = self.sa.getSlice(*args)
return spl
def append(self,other):
assert self.sa.dtypeI() == other.sa.dtypeI()
return self.sa.append(other.sa)
def cout(self,*args):
return self.sa.cout(*args)
def size(self,*args):
return self.sa.size(*args)
def copy(self):
arr,rs = self.sa.copyToNumpy(False)
return SimpleArray(arr,rs)