diff options
author | Nao Pross <np@0hm.ch> | 2024-06-17 13:05:48 +0200 |
---|---|---|
committer | Nao Pross <np@0hm.ch> | 2024-06-17 13:05:48 +0200 |
commit | d0df0d7aded2747416ff739bdb7b1e46cfe9fc75 (patch) | |
tree | d110c215045b9dc1b7508ce9c64ffba8a2a7c4ad | |
parent | Add HessianExpr (diff) | |
download | polymatrix-d0df0d7aded2747416ff739bdb7b1e46cfe9fc75.tar.gz polymatrix-d0df0d7aded2747416ff739bdb7b1e46cfe9fc75.zip |
Fix bug in PolyMatrixAsAffineExpression.monomials_eval_all
-rw-r--r-- | polymatrix/polymatrix/mixins.py | 14 |
1 files changed, 4 insertions, 10 deletions
diff --git a/polymatrix/polymatrix/mixins.py b/polymatrix/polymatrix/mixins.py index 44f1e07..bb971b9 100644 --- a/polymatrix/polymatrix/mixins.py +++ b/polymatrix/polymatrix/mixins.py @@ -6,6 +6,7 @@ import math import numpy as np from abc import ABC, abstractmethod +from collections import Counter from numpy.typing import NDArray from typing import Iterable, Sequence, Callable, cast, TYPE_CHECKING from typing_extensions import override @@ -445,15 +446,8 @@ class PolyMatrixAsAffineExpressionMixin(PolyMatrixMixin, ABC): for key, val in compute_with_triangles(self.degree, x).items(): # See comment above for structure of key # Count occurrences to convert to MonomialIndex - new_key: dict[int, int] = {} - for e in key: - if e in new_key: - new_key[e] += 1 - else: - new_key[e] = 1 - - index = MonomialIndex(VariableIndex(self.variable_indices[k], v) - for k, v in new_key.items()) + index = MonomialIndex(sorted(VariableIndex(self.variable_indices[k], v) + for k, v in Counter(key).items())) monomial_values[index] = val # Sort the values by monomial index, which have a total order @@ -530,7 +524,7 @@ class PolyMatrixAsAffineExpressionMixin(PolyMatrixMixin, ABC): # efficiency gain is useless if most of the computed terms are not # used. # TODO: tune heuristic - if len(self.slices) > n: + if len(self.slices) > 0: # Compute all powers of x up to degree d all_monomials = self.monomials_eval_all(x) monomials = { |