Named Entities#

Named entities are an EnvironmentContext and NamedUpstageEntity enabled feature where you can store instances in particular “entity groups” to gather them from later. UPSTAGE’s Actor inherits from NamedUpstageEntity, giving all Actors the feature. Similarly, the SelfMonitoring<> resources do the same to enable quick access to recorded simulation data.

All Actors are retrievable with the get_actors() method if they inherit from Actor.

Entities are retrievable with get_all_entity_groups() and get_entity_group().

Defining a named entity is done in the class definition:

class Car(UP.Actor, entity_groups=["vehicle"]):
    ...

class Plane(UP.Actor, entity_groups=["vehicle", "air"]):
    ...

class FastPlane(Plane):
    ...

class NoSpecificGroup(UP.Actor):
    ...

class Different(UP.NamedUpstageEntity, entity_groups=["separate"]):
    ...

Once you are in an environment context you can get the actual instances.

with UP.EnvironmentContext():
    manage = UP.UpstageBase()

    c1 = Car(name="car1")
    c2 = Car(name="car2")
    p = Plane(name="plane")
    fp = FastPlane(name="fast plane")
    other = NoSpecificGroup(name="all alone")
    d = Different()

    actor_entities = manage.get_actors()
    print(actor_entities)
    >>> [Car: car1, Car: car2, Plane: plane, FastPlane: fast plane, NoSpecificGroup: all alone]

    vehicles = manage.get_entity_group("vehicle")
    print(vehicles)
    >>> [Car: car1, Car: car2, Plane: plane, FastPlane: fast plane]

    air = manage.get_entity_group("air")
    print(air)
    >>> [Plane: plane, FastPlane: fast plane]

    different = manage.get_entity_group("separate")
    print(different)
    >>> [<__main__.Different object at 0x000001FFAB28BE10>]

Note that entity groups are inheritable and that you can inherit from NamedUpstageEntity and retrieve the instance without needing an Actor. You may also create an instance of UpstageBase to get access to the required methods.