last changes

This commit is contained in:
2026-02-21 10:58:05 +01:00
parent 841bc7c805
commit 0902732f60
136 changed files with 10387 additions and 2015 deletions

View File

@@ -6,6 +6,42 @@ log = logging.getLogger(__name__)
class Sensor(Actor):
"""
Sensor actor that produces an input vector for the network and forwards it
to downstream actors (fanout).
A Sensor is an *input node* in the actor-based neural architecture. It does
not compute from other neurons; instead, it generates observations either
from:
- a local source (e.g., random numbers), or
- an external scape/environment actor.
When the cortex triggers a sensor with a ("sync",) message, the sensor:
1) calls `_sense()` to obtain a vector,
2) broadcasts that vector to all downstream targets in `fanout` via
("forward", sid, vec).
Supported sensor types (controlled by `sname`):
- "rng":
Produces `vl` random floats in [0, 1).
- "xor_GetInput" (requires `scape`):
Requests an input vector from the scape and expects a ("percept", vec)
reply on its own inbox.
- "car_GetFeatures" (requires `scape`):
Requests a feature vector from the scape and normalizes it:
* clamps values to [-1, 1],
* pads with zeros or truncates to exactly `vl` elements.
- default:
Returns a zero vector of length `vl`.
Inbox message protocol:
- ("sync",):
Trigger sensing and forwarding to fanout.
- ("percept", vec):
Scape reply to a previous ("sense", sid, self) request (handled inside `_sense()`).
- ("terminate",):
Stop the actor.
"""
def __init__(self, sid, cx_pid, name, vector_length, fanout_pids, scape=None):
super().__init__(f"Sensor-{sid}")
self.sid = sid