Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Representations #867

Draft
wants to merge 41 commits into
base: master
Choose a base branch
from
Draft
Changes from 1 commit
Commits
Show all changes
41 commits
Select commit Hold shift + click to select a range
377e65b
fix error messages
gertjanvanzwieten Apr 18, 2024
bd6444b
introduce _util.reentrant_iter
gertjanvanzwieten Feb 23, 2024
1ae23a6
introduce _util.iter_product
gertjanvanzwieten Mar 13, 2024
21c87b7
introduce util.iter_many
gertjanvanzwieten Apr 19, 2024
ce780d3
introduce Pointwise linear, zero_preserving attrs
gertjanvanzwieten Apr 18, 2024
f996885
add representations
gertjanvanzwieten Mar 13, 2024
ec3d180
add helper methods
gertjanvanzwieten Apr 18, 2024
291eedd
reimplement shape_str using representations
gertjanvanzwieten Mar 5, 2024
ed5d8c2
reimplement unalign using representations
gertjanvanzwieten Mar 5, 2024
624969f
separate optimize from simplify
gertjanvanzwieten Apr 10, 2024
2e54014
temporarily add Transpose._rinflate
gertjanvanzwieten Apr 19, 2024
ed580eb
remove _takediag
gertjanvanzwieten Apr 18, 2024
de700f6
remove _take, _rtake
gertjanvanzwieten Apr 18, 2024
e72b445
remove _sum
gertjanvanzwieten Apr 18, 2024
6779093
remove _determinant
gertjanvanzwieten Apr 18, 2024
0b314b0
remove _product
gertjanvanzwieten Apr 18, 2024
40537da
remove _unravel
gertjanvanzwieten Apr 18, 2024
7b90979
remove _inverse
gertjanvanzwieten Apr 18, 2024
8a257f7
remove _power
gertjanvanzwieten Apr 18, 2024
e8db610
remove _sign
gertjanvanzwieten Apr 18, 2024
f367c06
remove _loopsum
gertjanvanzwieten Apr 18, 2024
786ee3a
remove _add
gertjanvanzwieten Apr 18, 2024
6f5cdc5
remove _multiply
gertjanvanzwieten Apr 18, 2024
c5a50de
remove _transpose
gertjanvanzwieten Apr 18, 2024
e7d63ac
remove _diagonalize
gertjanvanzwieten Apr 18, 2024
d608030
remove _inflate, _rinflate
gertjanvanzwieten Apr 18, 2024
c20a341
remove _insertaxis
gertjanvanzwieten Apr 18, 2024
a23abce
remove _ravel
gertjanvanzwieten Apr 18, 2024
d52dc0f
remove _real, _imag, _conjugate
gertjanvanzwieten Apr 18, 2024
c44e56f
remove _eig
gertjanvanzwieten Apr 18, 2024
b85caed
streamline LoopConcatenate._simplified
gertjanvanzwieten Apr 18, 2024
b759efa
streamline Polyval._simplified
gertjanvanzwieten Apr 18, 2024
849a6e9
streamline Pointwise._simplified
gertjanvanzwieten Apr 18, 2024
16ab248
streamline Legendre._simplified
gertjanvanzwieten Apr 19, 2024
b6931ee
enhance PolyMul._simplified
gertjanvanzwieten Apr 19, 2024
38e44c5
enhance PolyGrad._simplified
gertjanvanzwieten Apr 19, 2024
6a6add4
add RavelIndex._simplified
gertjanvanzwieten Apr 18, 2024
182378a
remove Multiply._factors
gertjanvanzwieten Apr 18, 2024
ab7183b
remove Add._terms
gertjanvanzwieten Apr 18, 2024
5b671f6
remove unused methods, attributes
gertjanvanzwieten Mar 4, 2024
01cf78a
remove defunct diagnostics
gertjanvanzwieten Apr 18, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
remove _diagonalize
gertjanvanzwieten committed Apr 19, 2024
commit e7d63ac4bf2aa77b86bc93260e0cc3f23a14bb3b
26 changes: 4 additions & 22 deletions nutils/evaluable.py
Original file line number Diff line number Diff line change
@@ -852,7 +852,6 @@ def _node(self, cache, subgraph, times):

# simplifications
_insertaxis = lambda self, axis, length: None
_diagonalize = lambda self, axis: None
_eig = lambda self, symmetric: None
_inflate = lambda self, dofmap, length, axis: None
_rinflate = lambda self, func, length, axis: None
@@ -1116,10 +1115,6 @@ def evalf(func, length):
def _derivative(self, var, seen):
return insertaxis(derivative(self.func, var, seen), self.ndim-1, self.length)

def _diagonalize(self, axis):
if axis < self.ndim - 1:
return insertaxis(diagonalize(self.func, axis, self.ndim - 1), self.ndim - 1, self.length)

def _inflate(self, dofmap, length, axis):
if axis + dofmap.ndim < self.ndim:
return InsertAxis(_inflate(self.func, dofmap, length, axis), self.length)
@@ -1321,11 +1316,6 @@ def _inflate(self, dofmap, length, axis):
def _rinflate(self, func, length, axis):
return Inflate(transpose(func, (*range(axis), *(axis+i for i in self.axes), *range(axis+self.ndim, func.ndim))), self.func, length)

def _diagonalize(self, axis):
trydiagonalize = self.func._diagonalize(self.axes[axis])
if trydiagonalize is not None:
return Transpose(trydiagonalize, self.axes + (self.ndim,))

def _insertaxis(self, axis, length):
return Transpose(InsertAxis(self.func, length), self.axes[:axis] + (self.ndim,) + self.axes[axis:])

@@ -3007,9 +2997,6 @@ def _node(self, cache, subgraph, times):
cache[self] = node = DuplicatedLeafNode('0', (type(self).__name__, times[self]))
return node

def _diagonalize(self, axis):
return Zeros(self.shape+(self.shape[axis],), dtype=self.dtype)

def _insertaxis(self, axis, length):
return Zeros(self.shape[:axis]+(length,)+self.shape[axis:], self.dtype)

@@ -3104,10 +3091,6 @@ def _inflate(self, dofmap, length, axis):
def _derivative(self, var, seen):
return _inflate(derivative(self.func, var, seen), self.dofmap, self.length, self.ndim-1)

def _diagonalize(self, axis):
if axis != self.ndim-1:
return _inflate(diagonalize(self.func, axis), self.dofmap, self.length, self.ndim-1)

@cached_property
def _assparse(self):
chunks = []
@@ -3233,9 +3216,12 @@ def _inflations(self):
if axis < self.ndim-2)

def _simplified(self):
if isinstance(self.func, Zeros):
return zeros_like(self)
if self.shape[-1] == 1:
return InsertAxis(self.func, 1)
return self.func._diagonalize(self.ndim-2)
if simple := self._as_any(ravel, insertaxis, _inflate):
return simple

@staticmethod
def evalf(arr):
@@ -3509,10 +3495,6 @@ def _inflate(self, dofmap, length, axis):
else:
return _inflate(self.func, Unravel(dofmap, *self.func.shape[-2:]), length, axis)

def _diagonalize(self, axis):
if axis != self.ndim-1:
return ravel(diagonalize(self.func, axis), self.ndim-1)

def _insertaxis(self, axis, length):
return ravel(insertaxis(self.func, axis+(axis == self.ndim), length), self.ndim-(axis == self.ndim))