Skip to content

Commit

Permalink
Make node.higher_nodes a list, instead of a set
Browse files Browse the repository at this point in the history
This way the model provides that, e.g. for each face there can be a principal
neighbouring volume (master/owner) and a secondary neighbouring volume (slave).
  • Loading branch information
TheBB committed Apr 20, 2017
1 parent 2584379 commit 95461eb
Showing 1 changed file with 5 additions and 5 deletions.
10 changes: 5 additions & 5 deletions splipy/SplineModel.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
from splipy.utils import *
import splipy.state as state
import numpy as np
from collections import Counter
from collections import Counter, defaultdict
from itertools import chain, product, permutations

try:
Expand Down Expand Up @@ -284,7 +284,7 @@ def __init__(self, catalogue, obj, lower_nodes):
self.catalogue = catalogue
self.obj = obj
self.lower_nodes = lower_nodes
self.higher_nodes = {}
self.higher_nodes = defaultdict(list)

for dim_nodes in self.lower_nodes:
for node in dim_nodes:
Expand All @@ -296,7 +296,7 @@ def pardim(self):

def assign_higher(self, node):
"""Add a link to a node of higher dimension."""
self.higher_nodes.setdefault(node.pardim, set()).add(node)
self.higher_nodes[node.pardim].append(node)

def view(self, other_obj=None):
"""Return a `NodeView` object of this node.
Expand Down Expand Up @@ -402,7 +402,7 @@ def __init__(self, pardim, interior=True):
self.pardim = pardim

# Internal mapping from tuples of lower-order nodes to lists of nodes
self.internal = {}
self.internal = defaultdict(list)

# Function for computing orientations
self.make_orientation = (
Expand Down Expand Up @@ -474,7 +474,7 @@ def lookup(self, obj, add=False):
# nodes. This is slight overkill since some of these permutations
# are invalid, but c'est la vie.
for p in permutations(lower_nodes[-1]):
self.internal.setdefault(p, []).append(node)
self.internal[p].append(node)
return node.view()

def add(self, obj):
Expand Down

0 comments on commit 95461eb

Please sign in to comment.