Skip to content

Commit

Permalink
Issue #72: Fixed data_storage_valid check killing simulation
Browse files Browse the repository at this point in the history
  • Loading branch information
LorenzzoQM committed Sep 27, 2023
1 parent c1c3cae commit b564c58
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 6 deletions.
22 changes: 19 additions & 3 deletions bsk_rl/envs/general_satellite_tasking/simulation/dynamics.py
Original file line number Diff line number Diff line change
Expand Up @@ -684,13 +684,16 @@ def _set_transmitter_power_sink(
)
self.powerMonitor.addPowerNodeToModel(self.transmitterPowerSink.nodePowerOutMsg)

@default_args(dataStorageCapacity=20 * 8e6, bufferNames=None)
@default_args(
dataStorageCapacity=20 * 8e6, bufferNames=None, storageUnitValidCheck=True
)
def _set_storage_unit(
self,
dataStorageCapacity: int,
transmitterNumBuffers: Optional[int] = None,
bufferNames: Optional[Iterable[str]] = None,
priority: int = 699,
storageUnitValidCheck: bool = True,
**kwargs,
) -> None:
"""Configure the storage unit and its buffers.
Expand All @@ -701,12 +704,15 @@ def _set_storage_unit(
given.
bufferNames: List of buffer names to use. Named by number if None.
priority: Model priority.
storageUnitValidCheck: If True, check that the storage level is below the
storage capacity.
"""
self.storageUnit = partitionedStorageUnit.PartitionedStorageUnit()
self.storageUnit.ModelTag = "storageUnit" + self.satellite.id
self.storageUnit.storageCapacity = dataStorageCapacity # bits
self.storageUnit.addDataNodeToModel(self.instrument.nodeDataOutMsg)
self.storageUnit.addDataNodeToModel(self.transmitter.nodeDataOutMsg)
self.storageUnitValidCheck = storageUnitValidCheck
# Add all of the targets to the data buffer
if bufferNames is None:
for buffer_idx in range(transmitterNumBuffers):
Expand All @@ -733,7 +739,13 @@ def _set_storage_unit(
@aliveness_checker
def data_storage_valid(self) -> bool:
"""Check that the buffer has not run out of space."""
return self.storage_level <= self.storageUnit.storageCapacity
storage_check = self.storageUnitValidCheck
if storage_check or None:
return self.storage_level < self.storageUnit.storageCapacity or np.isclose(
self.storage_level, self.storageUnit.storageCapacity
)
else:
return True

@default_args(
groundLocationPlanetRadius=orbitalMotion.REQ_EARTH * 1e3,
Expand Down Expand Up @@ -809,24 +821,28 @@ def _set_instrument(
self.task_name, self.instrument, ModelPriority=priority
)

@default_args(dataStorageCapacity=20 * 8e6)
@default_args(dataStorageCapacity=20 * 8e6, storageUnitValidCheck=True)
def _set_storage_unit(
self,
dataStorageCapacity: int,
priority: int = 699,
storageUnitValidCheck: bool = True,
**kwargs,
) -> None:
"""Configure the storage unit and its buffers.
Args:
dataStorageCapacity: Maximum data to be stored [bits]
priority: Model priority.
storageUnitValidCheck: If True, check that the storage level is below the
storage capacity.
"""
self.storageUnit = simpleStorageUnit.SimpleStorageUnit()
self.storageUnit.ModelTag = "storageUnit" + self.satellite.id
self.storageUnit.storageCapacity = dataStorageCapacity # bits
self.storageUnit.addDataNodeToModel(self.instrument.nodeDataOutMsg)
self.storageUnit.addDataNodeToModel(self.transmitter.nodeDataOutMsg)
self.storageUnitValidCheck = storageUnitValidCheck

# Add the storage unit to the transmitter
self.transmitter.addStorageUnitToTransmitter(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -210,12 +210,20 @@ def test_storage_properties(self):
assert dyn.storage_level_fraction == 0.5

@pytest.mark.parametrize(
"level,valid",
[(10, True), (0, True), (110, False)],
"level,valid_check,valid",
[
(10, True, True),
(0, True, True),
(110, True, False),
(100.001, True, True),
(10, False, True),
(110, False, True),
],
)
def test_data_storage_valid(self, level, valid):
def test_data_storage_valid(self, level, valid_check, valid):
dyn = ImagingDynModel(MagicMock(simulator=MagicMock()), 1.0)
dyn.storageUnit = MagicMock()
dyn.storageUnitValidCheck = valid_check
dyn.storageUnit.storageUnitDataOutMsg.read.return_value.storageLevel = level
dyn.storageUnit.storageCapacity = 100.0
assert dyn.data_storage_valid() == valid
Expand Down

0 comments on commit b564c58

Please sign in to comment.