mirror of
https://git.intern.spaceteamaachen.de/ALPAKA/SPATZ.git
synced 2025-12-16 17:28:04 +00:00
Updated sensors
This commit is contained in:
@@ -1,21 +1,30 @@
|
||||
import numpy as np
|
||||
|
||||
from numpy.typing import ArrayLike
|
||||
from typing import List
|
||||
|
||||
from spatz.sensors import Sensor
|
||||
from spatz.transforms import Transform
|
||||
from spatz.dataset import Dataset
|
||||
from spatz.simulations.data_source import DataSource
|
||||
from spatz.logger import Logger
|
||||
|
||||
|
||||
class Gyroscope(Sensor):
|
||||
def __init__(self, dataset: DataSource, logger: Logger, offset: float = 0, transforms: List[Transform] = []):
|
||||
def __init__(self, dataset: DataSource, logger: Logger, orientation=np.identity(3), transforms: List[Transform] = []):
|
||||
super().__init__(dataset, logger, transforms)
|
||||
|
||||
self._offset = offset
|
||||
self._orientation = orientation
|
||||
|
||||
def calibrate(self, n_samples):
|
||||
return np.sum(self() for i in range(n_samples)) / n_samples
|
||||
|
||||
def _get_data(self) -> ArrayLike | float:
|
||||
# Rotation in rad/sec
|
||||
x = self._dataset.get_angular_velocity()
|
||||
omegas = self._dataset.get_angular_velocity()
|
||||
omegas = self._orientation @ omegas
|
||||
|
||||
return x
|
||||
self._log('ox', omegas[0])
|
||||
self._log('oy', omegas[1])
|
||||
self._log('oz', omegas[2])
|
||||
|
||||
return omegas
|
||||
|
||||
Reference in New Issue
Block a user