fix: Reorder initialization - create transducers before SyncLayer
SyncLayer needs master and emissary as positional arguments. Create them first, then pass to SyncLayer, then update their sync_layer reference.
This commit is contained in:
+13
-5
@@ -187,9 +187,6 @@ def init_engine(
|
|||||||
dampening=0.995,
|
dampening=0.995,
|
||||||
)
|
)
|
||||||
|
|
||||||
# Create sync layer
|
|
||||||
sync_layer = SyncLayer(sync_config)
|
|
||||||
|
|
||||||
# Create witnessing layer
|
# Create witnessing layer
|
||||||
witnessing_layer = WitnessingLayer(
|
witnessing_layer = WitnessingLayer(
|
||||||
mode=WitnessingMode.HUMAN if witnessed_by_human else WitnessingMode.SELF,
|
mode=WitnessingMode.HUMAN if witnessed_by_human else WitnessingMode.SELF,
|
||||||
@@ -221,20 +218,31 @@ def init_engine(
|
|||||||
action_delay=0.0,
|
action_delay=0.0,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# Create master first (without sync_layer)
|
||||||
master = MasterTransducer(
|
master = MasterTransducer(
|
||||||
config=master_config,
|
config=master_config,
|
||||||
sync_layer=sync_layer,
|
|
||||||
witnessing_layer=witnessing_layer,
|
witnessing_layer=witnessing_layer,
|
||||||
temporal_memory=temporal_memory,
|
temporal_memory=temporal_memory,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# Create emissary first (without sync_layer)
|
||||||
emissary = EmissaryTransducer(
|
emissary = EmissaryTransducer(
|
||||||
config=emissary_config,
|
config=emissary_config,
|
||||||
sync_layer=sync_layer,
|
|
||||||
witnessing_layer=witnessing_layer,
|
witnessing_layer=witnessing_layer,
|
||||||
temporal_memory=temporal_memory,
|
temporal_memory=temporal_memory,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# Create sync layer (needs master and emissary)
|
||||||
|
sync_layer = SyncLayer(
|
||||||
|
master=master,
|
||||||
|
emissary=emissary,
|
||||||
|
config=sync_config,
|
||||||
|
)
|
||||||
|
|
||||||
|
# Now update the master and emissary with sync_layer
|
||||||
|
master.sync_layer = sync_layer
|
||||||
|
emissary.sync_layer = sync_layer
|
||||||
|
|
||||||
# Create main engine
|
# Create main engine
|
||||||
engine = KAIROSTemporalEngine(
|
engine = KAIROSTemporalEngine(
|
||||||
master=master,
|
master=master,
|
||||||
|
|||||||
Reference in New Issue
Block a user