PVNet 5.3.6__tar.gz → 5.3.7__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.
Files changed (36) hide show
  1. {pvnet-5.3.6 → pvnet-5.3.7}/PKG-INFO +1 -1
  2. {pvnet-5.3.6 → pvnet-5.3.7}/PVNet.egg-info/PKG-INFO +1 -1
  3. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/utils.py +13 -17
  4. {pvnet-5.3.6 → pvnet-5.3.7}/LICENSE +0 -0
  5. {pvnet-5.3.6 → pvnet-5.3.7}/PVNet.egg-info/SOURCES.txt +0 -0
  6. {pvnet-5.3.6 → pvnet-5.3.7}/PVNet.egg-info/dependency_links.txt +0 -0
  7. {pvnet-5.3.6 → pvnet-5.3.7}/PVNet.egg-info/requires.txt +0 -0
  8. {pvnet-5.3.6 → pvnet-5.3.7}/PVNet.egg-info/top_level.txt +0 -0
  9. {pvnet-5.3.6 → pvnet-5.3.7}/README.md +0 -0
  10. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/__init__.py +0 -0
  11. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/datamodule.py +0 -0
  12. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/load_model.py +0 -0
  13. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/__init__.py +0 -0
  14. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/base_model.py +0 -0
  15. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/ensemble.py +0 -0
  16. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/late_fusion/__init__.py +0 -0
  17. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/late_fusion/basic_blocks.py +0 -0
  18. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/late_fusion/encoders/__init__.py +0 -0
  19. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/late_fusion/encoders/basic_blocks.py +0 -0
  20. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/late_fusion/encoders/encoders3d.py +0 -0
  21. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/late_fusion/late_fusion.py +0 -0
  22. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/late_fusion/linear_networks/__init__.py +0 -0
  23. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/late_fusion/linear_networks/basic_blocks.py +0 -0
  24. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/late_fusion/linear_networks/networks.py +0 -0
  25. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/late_fusion/site_encoders/__init__.py +0 -0
  26. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/late_fusion/site_encoders/basic_blocks.py +0 -0
  27. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/models/late_fusion/site_encoders/encoders.py +0 -0
  28. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/optimizers.py +0 -0
  29. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/training/__init__.py +0 -0
  30. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/training/lightning_module.py +0 -0
  31. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/training/plots.py +0 -0
  32. {pvnet-5.3.6 → pvnet-5.3.7}/pvnet/training/train.py +0 -0
  33. {pvnet-5.3.6 → pvnet-5.3.7}/pyproject.toml +0 -0
  34. {pvnet-5.3.6 → pvnet-5.3.7}/setup.cfg +0 -0
  35. {pvnet-5.3.6 → pvnet-5.3.7}/tests/test_datamodule.py +0 -0
  36. {pvnet-5.3.6 → pvnet-5.3.7}/tests/test_end2end.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: PVNet
3
- Version: 5.3.6
3
+ Version: 5.3.7
4
4
  Summary: PVNet
5
5
  Author-email: Peter Dudfield <info@openclimatefix.org>
6
6
  Requires-Python: <3.14,>=3.11
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: PVNet
3
- Version: 5.3.6
3
+ Version: 5.3.7
4
4
  Summary: PVNet
5
5
  Author-email: Peter Dudfield <info@openclimatefix.org>
6
6
  Requires-Python: <3.14,>=3.11
@@ -129,26 +129,22 @@ def validate_batch_against_config(
129
129
 
130
130
  # Satellite validation
131
131
  if model.include_sat:
132
- if "satellite_actual" not in batch:
133
- raise ValueError(
134
- "Model uses satellite data but 'satellite_actual' missing from batch."
135
- )
132
+ if (sat_data := batch.get("satellite_actual")) is None:
133
+ raise ValueError("Model uses sat data but 'satellite_actual' missing from batch.")
136
134
 
137
135
  enc = model.sat_encoder
138
- expected_channels = enc.in_channels - int(model.add_image_embedding_channel)
139
-
140
- expected_shape = (
141
- batch["satellite_actual"].shape[0],
142
- enc.sequence_length,
143
- expected_channels,
144
- enc.image_size_pixels,
145
- enc.image_size_pixels,
146
- )
147
- actual_shape = tuple(batch["satellite_actual"].shape)
148
- if actual_shape != expected_shape:
149
- raise ValueError(
150
- f"Satellite shape mismatch: expected {expected_shape}, got {actual_shape}"
136
+ exp_ch = enc.in_channels - int(model.add_image_embedding_channel)
137
+ _, actual_seq, actual_ch, h, w = sat_data.shape
138
+
139
+ if actual_ch != exp_ch or h != enc.image_size_pixels or w != enc.image_size_pixels:
140
+ msg = (
141
+ f"Sat mismatch: Exp {exp_ch}ch, {enc.image_size_pixels}px. "
142
+ f"Got {actual_ch}ch, {h}x{w}px"
151
143
  )
144
+ raise ValueError(msg)
145
+
146
+ if actual_seq < enc.sequence_length:
147
+ raise ValueError(f"Sat too short: exp {enc.sequence_length}, got {actual_seq}")
152
148
 
153
149
  key = "generation"
154
150
  if key in batch:
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes