DimensionUniverse

class lsst.daf.butler.DimensionUniverse(config: Optional[Config] = None, *, version: Optional[int] = None, builder: Optional[DimensionConstructionBuilder] = None)

Bases: object

Self-consistent set of dimensions.

A parent class that represents a complete, self-consistent set of dimensions and their relationships.

DimensionUniverse is not a class-level singleton, but all instances are tracked in a singleton map keyed by the version number in the configuration they were loaded from. Because these universes are solely responsible for constructing DimensionElement instances, these are also indirectly tracked by that singleton as well.

Parameters
configConfig, optional

Configuration object from which dimension definitions can be extracted. Ignored if builder is provided, or if version is provided and an instance with that version already exists.

versionint, optional

Integer version for this DimensionUniverse. If not provided, a version will be obtained from builder or config.

builderDimensionConstructionBuilder, optional

Builder object used to initialize a new instance. Ignored if version is provided and an instance with that version already exists. Should not have had finish called; this will be called if needed by DimensionUniverse.

Attributes Summary

skypix

All skypix systems known to this universe.

Methods Summary

expandDimensionNameSet(names)

Expand a set of dimension names in-place.

extract(iterable)

Construct graph from iterable.

get(name[, default])

Return the DimensionElement with the given name or a default.

getDatabaseElements()

Return set of all DatabaseDimensionElement instances in universe.

getDimensionIndex(name)

Return the position of the named dimension.

getElementIndex(name)

Return the position of the named dimension element.

getEncodeLength()

Return encoded size of graph.

getGovernorDimensions()

Return a set of all GovernorDimension instances in this universe.

getStaticDimensions()

Return a set of all static dimensions in this universe.

getStaticElements()

Return a set of all static elements in this universe.

makePacker(name, dataId)

Make a dimension packer.

sorted(elements, *[, reverse])

Return a sorted version of the given iterable of dimension elements.

Attributes Documentation

skypix

All skypix systems known to this universe.

(NamedValueAbstractSet [ SkyPixSystem ]).

Methods Documentation

expandDimensionNameSet(names: Set[str])None

Expand a set of dimension names in-place.

Includes recursive dependencies.

This is an advanced interface for cases where constructing a DimensionGraph (which also expands required dependencies) is impossible or undesirable.

Parameters
namesset [ str ]

A true set of dimension names, to be expanded in-place.

extract(iterable: Iterable[Union[lsst.daf.butler.Dimension, str]])lsst.daf.butler.DimensionGraph

Construct graph from iterable.

Constructs a DimensionGraph from a possibly-heterogenous iterable of Dimension instances and string names thereof.

Constructing DimensionGraph directly from names or dimension instances is slightly more efficient when it is known in advance that the iterable is not heterogenous.

Parameters
iterable: iterable of `Dimension` or `str`

Dimensions that must be included in the returned graph (their dependencies will be as well).

Returns
graphDimensionGraph

A DimensionGraph instance containing all given dimensions.

get(name: str, default: Optional[lsst.daf.butler.DimensionElement] = None)Optional[lsst.daf.butler.DimensionElement]

Return the DimensionElement with the given name or a default.

Parameters
namestr

Name of the element.

defaultDimensionElement, optional

Element to return if the named one does not exist. Defaults to None.

Returns
elementDimensionElement

The named element.

getDatabaseElements()lsst.daf.butler.NamedValueAbstractSet[lsst.daf.butler.DatabaseDimensionElement]

Return set of all DatabaseDimensionElement instances in universe.

This does not include GovernorDimension instances, which are backed by the database but do not inherit from DatabaseDimensionElement.

Returns
elementsNamedValueAbstractSet [ DatabaseDimensionElement ]

A frozen set of DatabaseDimensionElement instances.

getDimensionIndex(name: str)int

Return the position of the named dimension.

This position is in this universe’s sorting of all dimensions.

Parameters
namestr

Name of the dimension.

Returns
indexint

Sorting index for this dimension.

Notes

The dimension sort order for a universe is consistent with the element order (all dimensions are elements), and either can be used to sort dimensions if used consistently. But there are also some contexts in which contiguous dimension-only indices are necessary or at least desirable.

getElementIndex(name: str)int

Return the position of the named dimension element.

The position is in this universe’s sorting of all elements.

Parameters
namestr

Name of the element.

Returns
indexint

Sorting index for this element.

getEncodeLength()int

Return encoded size of graph.

Returns the size (in bytes) of the encoded size of DimensionGraph instances in this universe.

See DimensionGraph.encode and DimensionGraph.decode for more information.

getGovernorDimensions()lsst.daf.butler.NamedValueAbstractSet[lsst.daf.butler.GovernorDimension]

Return a set of all GovernorDimension instances in this universe.

Returns
governorsNamedValueAbstractSet [ GovernorDimension ]

A frozen set of GovernorDimension instances.

getStaticDimensions()lsst.daf.butler.NamedValueAbstractSet[lsst.daf.butler.Dimension]

Return a set of all static dimensions in this universe.

Non-static dimensions that are created as needed may also exist, but these are guaranteed to have no direct relationships to other elements (though they may have spatial or temporal relationships).

Returns
dimensionsNamedValueAbstractSet [ Dimension ]

A frozen set of Dimension instances.

getStaticElements()lsst.daf.butler.NamedValueAbstractSet[lsst.daf.butler.DimensionElement]

Return a set of all static elements in this universe.

Non-static elements that are created as needed may also exist, but these are guaranteed to have no direct relationships to other elements (though they may have spatial or temporal relationships).

Returns
elementsNamedValueAbstractSet [ DimensionElement ]

A frozen set of DimensionElement instances.

makePacker(name: str, dataId: DataCoordinate)DimensionPacker

Make a dimension packer.

Constructs a DimensionPacker that can pack data ID dictionaries into unique integers.

Parameters
namestr

Name of the packer, matching a key in the “packers” section of the dimension configuration.

dataIdDataCoordinate

Fully-expanded data ID that identfies the at least the “fixed” dimensions of the packer (i.e. those that are assumed/given, setting the space over which packed integer IDs are unique). dataId.hasRecords() must return True.

sorted(elements: Iterable[Union[E, str]], *, reverse: bool = False)List[E]

Return a sorted version of the given iterable of dimension elements.

The universe’s sort order is topological (an element’s dependencies precede it), with an unspecified (but deterministic) approach to breaking ties.

Parameters
elementsiterable of DimensionElement.

Elements to be sorted.

reversebool, optional

If True, sort in the opposite order.

Returns
sortedlist of DimensionElement

A sorted list containing the same elements that were given.