Skip to content

Commit

Permalink
Added Sheaf.consistentStarCollection
Browse files Browse the repository at this point in the history
  • Loading branch information
kb1dds committed Jul 19, 2018
1 parent f73d04c commit 923b3e4
Showing 1 changed file with 27 additions and 1 deletion.
28 changes: 27 additions & 1 deletion pysheaf/pysheaf.py
Original file line number Diff line number Diff line change
Expand Up @@ -652,7 +652,9 @@ def consistentPartition(self,assignment,threshold,testSupport=None,consistencyGr
return {frozenset(s) for s in cdd.values()}

def consistentCollection(self,assignment,threshold,testSupport=None,consistencyGraph=None,ord=np.inf,tol=1e-5):
"""Construct a maximal collection of open sets such that each subset is consistent to within the given threshold. Note: the assignment must be supported on the entire space."""
"""Construct a maximal collection of open sets such that each subset is consistent to within the given threshold.
Note: the Assignment must be supported on the entire space.
Note: consistentStarCollection is usually faster, with more concise output. Unless you need *open sets* -- and not just stars -- use that method!"""
# First obtain a collection of consistent open sets. These are disjoint
initial_collection={frozenset(self.interior(s)) for s in self.consistentPartition(assignment,threshold,testSupport,consistencyGraph,ord=ord,tol=tol)}

Expand All @@ -676,6 +678,30 @@ def consistentCollection(self,assignment,threshold,testSupport=None,consistencyG
collection=set()

return initial_collection

def consistentStarCollection(self,assignment,threshold,ord=np.inf,start_cell=None):
"""Construct a maximal collection of elements such that their stars are consistent to within the given threshold.
Note: the Assignment must be supported on the entire space."""

if start_cell is None:
# Starting collection of cells are those that are not cofaces of any other cells
next_cells=set(range(len(self.cells))).difference({cf.index for c in self.cells for cf in c.cofaces})
else:
# Otherwise check the given start_cell's star for consistency...
if self.consistencyRadius(assignment,testSupport=self.starCells([start_cell]),ord=ord) < threshold:
return set([start_cell])

# ... if that cell is not consistent, then check all of its children
next_cells=[cf.index for cf in self.cells[start_cell].cofaces]

# Recurse through the rest of the sheaf diagram
collection=set()
for i in next_cells:
col=self.consistentStarCollection(assignment,threshold,ord,start_cell=i)
if col:
collection.update(col)

return collection

def assignmentMetric(self,assignment1,assignment2, testSupport=None, ord=np.inf):
"""Compute the distance between two assignments"""
Expand Down

0 comments on commit 923b3e4

Please sign in to comment.