code-loader 1.0.184.dev3__tar.gz → 1.0.184.dev4__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/PKG-INFO +1 -1
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/leaploader.py +47 -13
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/pyproject.toml +1 -1
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/LICENSE +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/README.md +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/__init__.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/contract/__init__.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/contract/datasetclasses.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/contract/enums.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/contract/exceptions.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/contract/mapping.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/contract/responsedataclasses.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/contract/sim_config.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/contract/visualizer_classes.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/default_losses.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/default_metrics.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/experiment_api/__init__.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/experiment_api/api.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/experiment_api/cli_config_utils.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/experiment_api/client.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/experiment_api/epoch.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/experiment_api/experiment.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/experiment_api/experiment_context.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/experiment_api/types.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/experiment_api/utils.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/experiment_api/workingspace_config_utils.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/inner_leap_binder/__init__.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/inner_leap_binder/leapbinder.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/inner_leap_binder/leapbinder_decorators.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/leaploaderbase.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/mixpanel_tracker.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/plot_functions/__init__.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/plot_functions/plot_functions.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/plot_functions/visualize.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/utils.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/visualizers/__init__.py +0 -0
- {code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/visualizers/default_visualizers.py +0 -0
|
@@ -7,7 +7,7 @@ import sys
|
|
|
7
7
|
from contextlib import redirect_stdout
|
|
8
8
|
from functools import lru_cache
|
|
9
9
|
from pathlib import Path
|
|
10
|
-
from typing import Dict, List, Iterable, Union, Any, Type, Optional, Callable, Tuple
|
|
10
|
+
from typing import Dict, List, Iterable, Set, Union, Any, Type, Optional, Callable, Tuple
|
|
11
11
|
|
|
12
12
|
import numpy as np
|
|
13
13
|
import numpy.typing as npt
|
|
@@ -197,20 +197,48 @@ class LeapLoader(LeapLoaderBase):
|
|
|
197
197
|
# `_synthetic_lookup`, so subsequent lookups for sibling sample_ids skip the hook.
|
|
198
198
|
self._synthetic_populator = populator
|
|
199
199
|
|
|
200
|
-
def
|
|
200
|
+
def _user_additional_ids_set(self) -> Set[str]:
|
|
201
|
+
# Membership-test helper for distinguishing user-defined additional samples
|
|
202
|
+
# from synthetic ones. In consumer pods, the populator passes
|
|
203
|
+
# extend_preprocess=False to run_simulation, so additional.sample_ids stays
|
|
204
|
+
# uncontaminated and direct membership check is reliable.
|
|
205
|
+
additional = self._preprocess_result().get(DataStateEnum.additional)
|
|
206
|
+
if additional is None:
|
|
207
|
+
return set()
|
|
208
|
+
return set(additional.sample_ids)
|
|
209
|
+
|
|
210
|
+
def _resolve_synthetic(self, sample_id: Union[int, str],
|
|
211
|
+
state: Optional[DataStateEnum] = None
|
|
212
|
+
) -> Optional[Tuple[PreprocessResponse, Any]]:
|
|
213
|
+
# Resolution flow for state==additional:
|
|
214
|
+
# 1. already-replayed synthetic ID (member of _synthetic_lookup) → cached synthetic flow
|
|
215
|
+
# 2. user-defined ID (member of preprocess[additional].sample_ids) → return None
|
|
216
|
+
# so caller falls through to normal preprocess flow (no recipe lookup built)
|
|
217
|
+
# 3. populator: builds recipe index lazily on first call, replays the missing
|
|
218
|
+
# recipe, populates _synthetic_lookup. Loud-raises on unresolvable IDs.
|
|
219
|
+
#
|
|
220
|
+
# Order rationale: _synthetic_lookup check sits before the user-response check
|
|
221
|
+
# to be robust against `_extend_additional_preprocess` mutation (producer side
|
|
222
|
+
# calls run_simulation with extend_preprocess=True, which appends synthetic IDs
|
|
223
|
+
# into preprocess[additional]). Once an ID is in _synthetic_lookup, that wins
|
|
224
|
+
# regardless of contamination in the preprocess response.
|
|
201
225
|
if not isinstance(sample_id, str):
|
|
202
226
|
return None
|
|
227
|
+
if state != DataStateEnum.additional:
|
|
228
|
+
return None
|
|
203
229
|
if sample_id in self._synthetic_lookup:
|
|
204
230
|
return self._synthetic_lookup[sample_id]
|
|
205
|
-
if self.
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
231
|
+
if sample_id in self._user_additional_ids_set():
|
|
232
|
+
return None
|
|
233
|
+
if self._synthetic_populator is None:
|
|
234
|
+
return None
|
|
235
|
+
self._synthetic_populator(sample_id)
|
|
236
|
+
return self._synthetic_lookup.get(sample_id)
|
|
209
237
|
|
|
210
238
|
def get_sample(self, state: DataStateEnum, sample_id: Union[int, str], instance_id: int = None) -> DatasetSample:
|
|
211
239
|
self.exec_script()
|
|
212
240
|
|
|
213
|
-
resolved = self._resolve_synthetic(sample_id)
|
|
241
|
+
resolved = self._resolve_synthetic(sample_id, state=state)
|
|
214
242
|
if resolved is not None:
|
|
215
243
|
sim_preprocess, original_local_id = resolved
|
|
216
244
|
return self._get_sample_from_preprocess(
|
|
@@ -417,8 +445,13 @@ class LeapLoader(LeapLoaderBase):
|
|
|
417
445
|
result_payloads.append(test_result)
|
|
418
446
|
return result_payloads
|
|
419
447
|
|
|
420
|
-
def run_simulation(self, sim_name, params=None, n_samples=1, seed=0,
|
|
421
|
-
|
|
448
|
+
def run_simulation(self, sim_name, params=None, n_samples=1, seed=0,
|
|
449
|
+
sample_ids=None, extend_preprocess=True):
|
|
450
|
+
# type: (str, Optional[Dict[str, Any]], int, int, Optional[List[str]], bool) -> Dict[str, Any]
|
|
451
|
+
# extend_preprocess=True (default): also extend preprocess_result[additional] with the
|
|
452
|
+
# new synthetic sample_ids (producer-side behavior — synthetic worker needs this for
|
|
453
|
+
# enumeration / data_length tracking). Pass False from consumer-side populators that
|
|
454
|
+
# only need _synthetic_lookup filled, so user's additional response stays uncontaminated.
|
|
422
455
|
self.exec_script()
|
|
423
456
|
sim = next(
|
|
424
457
|
(s for s in global_leap_binder.setup_container.simulations if s.name == sim_name),
|
|
@@ -456,7 +489,8 @@ class LeapLoader(LeapLoaderBase):
|
|
|
456
489
|
)
|
|
457
490
|
for synth_id, original_local_id in zip(sample_ids, original_sample_ids):
|
|
458
491
|
self._synthetic_lookup[synth_id] = (sim_preprocess, original_local_id)
|
|
459
|
-
|
|
492
|
+
if extend_preprocess:
|
|
493
|
+
self._extend_additional_preprocess(list(sample_ids))
|
|
460
494
|
returned_sample_ids = list(sample_ids)
|
|
461
495
|
else:
|
|
462
496
|
returned_sample_ids = original_sample_ids
|
|
@@ -694,7 +728,7 @@ class LeapLoader(LeapLoaderBase):
|
|
|
694
728
|
state: DataStateEnum, sample_id: Union[int, str]) -> Dict[str, npt.NDArray[np.float32]]:
|
|
695
729
|
result_agg = {}
|
|
696
730
|
preprocess_result = self._preprocess_result()
|
|
697
|
-
resolved = self._resolve_synthetic(sample_id
|
|
731
|
+
resolved = self._resolve_synthetic(sample_id, state=state)
|
|
698
732
|
if resolved is not None:
|
|
699
733
|
sim_preprocess, original_local_id = resolved
|
|
700
734
|
preprocess_state = sim_preprocess
|
|
@@ -714,7 +748,7 @@ class LeapLoader(LeapLoaderBase):
|
|
|
714
748
|
if instance_id is None:
|
|
715
749
|
return None
|
|
716
750
|
preprocess_result = self._preprocess_result()
|
|
717
|
-
resolved = self._resolve_synthetic(sample_id
|
|
751
|
+
resolved = self._resolve_synthetic(sample_id, state=state)
|
|
718
752
|
if resolved is not None:
|
|
719
753
|
sim_preprocess, original_local_id = resolved
|
|
720
754
|
preprocess_state = sim_preprocess
|
|
@@ -780,7 +814,7 @@ class LeapLoader(LeapLoaderBase):
|
|
|
780
814
|
result_agg = {}
|
|
781
815
|
is_none = {}
|
|
782
816
|
preprocess_result = self._preprocess_result()
|
|
783
|
-
resolved = self._resolve_synthetic(sample_id
|
|
817
|
+
resolved = self._resolve_synthetic(sample_id, state=state)
|
|
784
818
|
if resolved is not None:
|
|
785
819
|
sim_preprocess, original_local_id = resolved
|
|
786
820
|
preprocess_state = sim_preprocess
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/contract/datasetclasses.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/contract/responsedataclasses.py
RENAMED
|
File without changes
|
|
File without changes
|
{code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/contract/visualizer_classes.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/experiment_api/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
{code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/experiment_api/cli_config_utils.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/experiment_api/experiment.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/inner_leap_binder/__init__.py
RENAMED
|
File without changes
|
{code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/inner_leap_binder/leapbinder.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/plot_functions/__init__.py
RENAMED
|
File without changes
|
{code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/plot_functions/plot_functions.py
RENAMED
|
File without changes
|
{code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/plot_functions/visualize.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{code_loader-1.0.184.dev3 → code_loader-1.0.184.dev4}/code_loader/visualizers/default_visualizers.py
RENAMED
|
File without changes
|