Berichtsmodi

Sensoren können Ereignisse auf unterschiedliche Weise generieren, die als Berichtsmodi bezeichnet werden. Jedem Sensortyp ist genau ein Berichtsmodus zugeordnet. Es gibt vier Berichtsmodi.

Kontinuierlich

Ereignisse werden mit einer konstanten Rate generiert, die durch den Parameter sampling_period_ns definiert wird, der an die Funktion batch übergeben wird. Beispielsensoren, die den Modus für kontinuierliche Berichte verwenden, sind Beschleunigungsmesser und Gyroskope.

On-change

Ereignisse werden nur generiert, wenn sich die Messwerte geändert haben. Wenn der Sensor auf HAL-Ebene aktiviert wird (activate(..., enable=1) wird darauf aufgerufen), wird auch ein Ereignis ausgelöst. Das bedeutet, dass die HAL sofort ein Ereignis zurückgeben muss, wenn ein Sensor mit der Funktion „Bei Änderung“ aktiviert wird. Beispielsensoren, die den Berichtsmodus bei Änderungen verwenden, sind Schrittzähler-, Näherungs- und Herzfrequenzsensoren.

Mit dem Parameter sampling_period_ns, der an die batch-Funktion übergeben wird, wird die Mindestzeit zwischen aufeinanderfolgenden Ereignissen festgelegt. Das bedeutet, dass ein Ereignis erst generiert werden sollte, wenn seit dem letzten Ereignis sampling_period_ns Nanosekunden vergangen sind, auch wenn sich der Wert seitdem geändert hat. Wenn sich der Wert geändert hat, muss ein Ereignis generiert werden, sobald sampling_period_ns seit dem letzten Ereignis verstrichen ist.

Angenommen, folgende Bedingungen sind erfüllt:

  • Wir aktivieren den Schrittzähler mit sampling_period_ns = 10 * 10^9 (10 Sekunden).
  • Wir gehen 55 Sekunden und bleiben dann eine Minute lang still.
  • Die Ereignisse werden in der ersten Minute etwa alle 10 Sekunden generiert (einschließlich der Zeit t=0 aufgrund der Aktivierung des Sensors und t=60 Sekunden), insgesamt also sieben Ereignisse. In der zweiten Minute wird kein Ereignis generiert, da sich der Wert der Schrittzahl nach t=60 Sekunden nicht geändert hat.

One-Shot

Wird ein Ereignis erkannt, deaktiviert sich der Sensor selbst und sendet dann ein einzelnes Ereignis über den HAL. Die Reihenfolge ist wichtig, um Race-Bedingungen zu vermeiden. (Der Sensor muss deaktiviert werden, bevor das Ereignis über den HAL gemeldet wird.) Weitere Ereignisse werden erst gesendet, wenn der Sensor wieder aktiviert ist. Wichtige Bewegungen ist ein Beispiel für diese Art von Sensor.

One-Shot-Sensoren werden manchmal auch als Triggersensoren bezeichnet.

Die Parameter sampling_period_ns und max_report_latency_ns, die an die Funktion batch übergeben werden, werden ignoriert. Ereignisse aus einmaligen Ereignissen können nicht in Hardware-FIFOs gespeichert werden. Sie müssen gemeldet werden, sobald sie generiert werden.

Specials

Einzelheiten dazu, wann die Ereignisse generiert werden, finden Sie in den Beschreibungen der einzelnen Sensortypen.