xax 0.1.4__py3-none-any.whl → 0.1.6__py3-none-any.whl
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.
- xax/__init__.py +6 -2
- xax/nn/export.py +8 -1
- xax/task/mixins/train.py +1 -1
- xax/utils/jax.py +22 -0
- xax/utils/tensorboard.py +30 -2
- {xax-0.1.4.dist-info → xax-0.1.6.dist-info}/METADATA +1 -1
- {xax-0.1.4.dist-info → xax-0.1.6.dist-info}/RECORD +10 -10
- {xax-0.1.4.dist-info → xax-0.1.6.dist-info}/WHEEL +1 -1
- {xax-0.1.4.dist-info → xax-0.1.6.dist-info}/licenses/LICENSE +0 -0
- {xax-0.1.4.dist-info → xax-0.1.6.dist-info}/top_level.txt +0 -0
xax/__init__.py
CHANGED
@@ -12,7 +12,7 @@ and running the update script:
|
|
12
12
|
python -m scripts.update_api --inplace
|
13
13
|
"""
|
14
14
|
|
15
|
-
__version__ = "0.1.
|
15
|
+
__version__ = "0.1.6"
|
16
16
|
|
17
17
|
# This list shouldn't be modified by hand; instead, run the update script.
|
18
18
|
__all__ = [
|
@@ -97,6 +97,8 @@ __all__ = [
|
|
97
97
|
"save_config",
|
98
98
|
"stage_environment",
|
99
99
|
"to_markdown_table",
|
100
|
+
"HashableArray",
|
101
|
+
"hashable_array",
|
100
102
|
"jit",
|
101
103
|
"save_jaxpr_dot",
|
102
104
|
"ColoredFormatter",
|
@@ -251,6 +253,8 @@ NAME_MAP: dict[str, str] = {
|
|
251
253
|
"save_config": "utils.experiments",
|
252
254
|
"stage_environment": "utils.experiments",
|
253
255
|
"to_markdown_table": "utils.experiments",
|
256
|
+
"HashableArray": "utils.jax",
|
257
|
+
"hashable_array": "utils.jax",
|
254
258
|
"jit": "utils.jax",
|
255
259
|
"save_jaxpr_dot": "utils.jaxpr",
|
256
260
|
"ColoredFormatter": "utils.logging",
|
@@ -404,7 +408,7 @@ if IMPORT_ALL or TYPE_CHECKING:
|
|
404
408
|
stage_environment,
|
405
409
|
to_markdown_table,
|
406
410
|
)
|
407
|
-
from xax.utils.jax import jit
|
411
|
+
from xax.utils.jax import HashableArray, hashable_array, jit
|
408
412
|
from xax.utils.jaxpr import save_jaxpr_dot
|
409
413
|
from xax.utils.logging import (
|
410
414
|
LOG_ERROR_SUMMARY,
|
xax/nn/export.py
CHANGED
@@ -9,7 +9,14 @@ import jax
|
|
9
9
|
import tensorflow as tf
|
10
10
|
from jax.experimental import jax2tf
|
11
11
|
from jaxtyping import Array, PyTree
|
12
|
-
|
12
|
+
|
13
|
+
try:
|
14
|
+
from orbax.export import ExportManager, JaxModule, ServingConfig
|
15
|
+
except ImportError as e:
|
16
|
+
raise ImportError(
|
17
|
+
"Please install the package with `orbax` as a dependency, using "
|
18
|
+
"'xax[export]` to install the required dependencies."
|
19
|
+
) from e
|
13
20
|
|
14
21
|
logger = logging.getLogger(__name__)
|
15
22
|
|
xax/task/mixins/train.py
CHANGED
@@ -122,7 +122,7 @@ class ValidStepTimer:
|
|
122
122
|
|
123
123
|
# Step-based validation.
|
124
124
|
valid_every_n_steps = self.valid_every_n_steps
|
125
|
-
if valid_every_n_steps is not None and state.num_steps
|
125
|
+
if valid_every_n_steps is not None and state.num_steps >= valid_every_n_steps + self.last_valid_step:
|
126
126
|
self.last_valid_step = state.num_steps
|
127
127
|
return True
|
128
128
|
|
xax/utils/jax.py
CHANGED
@@ -138,3 +138,25 @@ def jit(
|
|
138
138
|
return wrapped
|
139
139
|
|
140
140
|
return decorator
|
141
|
+
|
142
|
+
|
143
|
+
class HashableArray:
|
144
|
+
def __init__(self, array: np.ndarray | jnp.ndarray) -> None:
|
145
|
+
if not isinstance(array, (np.ndarray, jnp.ndarray)):
|
146
|
+
raise ValueError(f"Expected np.ndarray or jnp.ndarray, got {type(array)}")
|
147
|
+
self.array = array
|
148
|
+
self._hash: int | None = None
|
149
|
+
|
150
|
+
def __hash__(self) -> int:
|
151
|
+
if self._hash is None:
|
152
|
+
self._hash = hash(self.array.tobytes())
|
153
|
+
return self._hash
|
154
|
+
|
155
|
+
def __eq__(self, other: object) -> bool:
|
156
|
+
if not isinstance(other, HashableArray):
|
157
|
+
return False
|
158
|
+
return bool(jnp.array_equal(self.array, other.array))
|
159
|
+
|
160
|
+
|
161
|
+
def hashable_array(array: np.ndarray | jnp.ndarray) -> HashableArray:
|
162
|
+
return HashableArray(array)
|
xax/utils/tensorboard.py
CHANGED
@@ -258,12 +258,40 @@ class TensorboardWriter:
|
|
258
258
|
fps: int = 30,
|
259
259
|
) -> None:
|
260
260
|
assert value.ndim == 4, "Video must be 4D array (T, H, W, C)"
|
261
|
-
|
261
|
+
|
262
|
+
images = [PIL.Image.fromarray(frame).convert("RGB") for frame in value]
|
263
|
+
width, height = images[0].size
|
264
|
+
big_image = PIL.Image.new("RGB", (width, height * len(images)))
|
265
|
+
for i, im in enumerate(images):
|
266
|
+
big_image.paste(im, (0, i * height))
|
267
|
+
|
268
|
+
quantized_big = big_image.quantize(method=PIL.Image.Quantize.MAXCOVERAGE, dither=PIL.Image.Dither.NONE)
|
269
|
+
palette = quantized_big.getpalette()
|
270
|
+
|
271
|
+
processed = []
|
272
|
+
for im in images:
|
273
|
+
q = im.quantize(
|
274
|
+
method=PIL.Image.Quantize.MAXCOVERAGE,
|
275
|
+
palette=quantized_big,
|
276
|
+
dither=PIL.Image.Dither.NONE,
|
277
|
+
)
|
278
|
+
processed.append(q)
|
279
|
+
|
280
|
+
if palette is not None:
|
281
|
+
palette[0:3] = [255, 255, 255]
|
282
|
+
for im in processed:
|
283
|
+
im.putpalette(palette)
|
262
284
|
|
263
285
|
# Create temporary file for GIF
|
264
286
|
temp_file = tempfile.NamedTemporaryFile(suffix=".gif", delete=False)
|
265
287
|
try:
|
266
|
-
|
288
|
+
processed[0].save(
|
289
|
+
temp_file.name,
|
290
|
+
save_all=True,
|
291
|
+
append_images=processed[1:],
|
292
|
+
duration=int(1000 / fps),
|
293
|
+
loop=0,
|
294
|
+
)
|
267
295
|
with open(temp_file.name, "rb") as f:
|
268
296
|
video_string = f.read()
|
269
297
|
|
@@ -1,4 +1,4 @@
|
|
1
|
-
xax/__init__.py,sha256=
|
1
|
+
xax/__init__.py,sha256=rjqydWhxQVUAj3lXgFpzj4iLFOdDJGHArfAH7_QSkhk,13504
|
2
2
|
xax/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
3
3
|
xax/requirements-dev.txt,sha256=qkscNkFzWd1S5fump-AKH53rR65v2x5FmboFdy_kKvs,128
|
4
4
|
xax/requirements.txt,sha256=9LAEZ5c5gqRSARRVA6xJsVTa4MebPZuC4yOkkwkZJFw,297
|
@@ -8,7 +8,7 @@ xax/core/state.py,sha256=y123fL7pMgk25TPG6KN0LRIF_eYnD9eP7OfqtoQJGNE,2178
|
|
8
8
|
xax/nn/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
9
9
|
xax/nn/embeddings.py,sha256=bQGxBFxkLwi2MQLkRfGaHPH5P_KKB21HdI7VNWTKIOQ,11847
|
10
10
|
xax/nn/equinox.py,sha256=1Ck6ycz76dhit2LHX4y2lp3WJSPsDuRt7TK7AxxQhww,4837
|
11
|
-
xax/nn/export.py,sha256=
|
11
|
+
xax/nn/export.py,sha256=bu2m-4FDnadEhXDb9zM6SgOZvsf5p4xiee1sFZyNF7c,5510
|
12
12
|
xax/nn/functions.py,sha256=CI_OmspaQwN9nl4hwefIU3_I7m6gBZwJ9aGK1JGUgr0,2713
|
13
13
|
xax/nn/geom.py,sha256=eK7I8fUHBc3FT7zpm5Yf__bXFQ4LtX6sa17-DxojLTo,3202
|
14
14
|
xax/nn/norm.py,sha256=cDmYf5CtyzmuCiWdSP5nr8nZKQOmaZueDQXMPnThg6c,548
|
@@ -39,22 +39,22 @@ xax/task/mixins/logger.py,sha256=6oXsJJyNUx6YT3q58FVXMZBUpMgjVkGre6BXFN20cVI,280
|
|
39
39
|
xax/task/mixins/process.py,sha256=d1opVgvc6bOFXb7R58b07F4P5lbSZIzYaajtE0eBbpw,1477
|
40
40
|
xax/task/mixins/runnable.py,sha256=IYIsLd2k09g-_y6o44EhJqT7E6BpsyEMmsyLSuzqjtc,1979
|
41
41
|
xax/task/mixins/step_wrapper.py,sha256=-Yu5Nft2CRw1JvZt6J_94SM1vqX8fk08IDK95Pmd2ew,1648
|
42
|
-
xax/task/mixins/train.py,sha256=
|
42
|
+
xax/task/mixins/train.py,sha256=vsH_QpyrThlh9AzWnyvDJv58Y8U_516oi8gmMq_0iMg,22333
|
43
43
|
xax/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
44
44
|
xax/utils/debugging.py,sha256=9WlCrEqbq-SVXPEM4rhsLYERH97XNX7XSYLSI3sgKGk,1619
|
45
45
|
xax/utils/experiments.py,sha256=5CUja1H_cx4dnVqTGQekOpIhqISwHtAgLxZ34GV7cwM,29229
|
46
|
-
xax/utils/jax.py,sha256=
|
46
|
+
xax/utils/jax.py,sha256=eObvWt2DraCs2IMDZSdQ0rRk8tA3P5XBlF_UeVq7Aro,5480
|
47
47
|
xax/utils/jaxpr.py,sha256=S80nyEkv188RInzq3kCAdkQCU-bf6s0oPTrCE_LjkRs,2298
|
48
48
|
xax/utils/logging.py,sha256=GAhTne2rdB4Fa1lzk06DMO15U8MTejn6XTClShC-ZtU,6622
|
49
49
|
xax/utils/numpy.py,sha256=_jOXVi-d2AtJnRftPkRK5MDMzsU8slgw-Jjv4GRm6ns,1197
|
50
50
|
xax/utils/profile.py,sha256=-aFdWpgYFvBsBZXSLL4zXrFe3zzsDqzmx4q5f2WOtpQ,1628
|
51
51
|
xax/utils/pytree.py,sha256=7GjQoPc_ZSZt3QS_9qXoBWl1jfMp1qZa7aViQoWJ0OQ,8864
|
52
|
-
xax/utils/tensorboard.py,sha256=
|
52
|
+
xax/utils/tensorboard.py,sha256=21czW8WC2SAmwEhz6RLJc_q5HFvNKM4iR1ZycSO5qPE,17058
|
53
53
|
xax/utils/text.py,sha256=zo1sAoZe59GkpcpaHBVOQ0OekSMGXvOAyNa3lOJozCY,10628
|
54
54
|
xax/utils/data/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
55
55
|
xax/utils/data/collate.py,sha256=Rd9vMomr_S_zCa_Hi4dO-8ntzAfVwndIUtuXFA3iNcc,7066
|
56
|
-
xax-0.1.
|
57
|
-
xax-0.1.
|
58
|
-
xax-0.1.
|
59
|
-
xax-0.1.
|
60
|
-
xax-0.1.
|
56
|
+
xax-0.1.6.dist-info/licenses/LICENSE,sha256=HCN2bImAzUOXldAZZI7JZ9PYq6OwMlDAP_PpX1HnuN0,1071
|
57
|
+
xax-0.1.6.dist-info/METADATA,sha256=vKxhuOt02ALjFV9fAt-rPVTwvqX4uNr_shL1DGEotA4,1877
|
58
|
+
xax-0.1.6.dist-info/WHEEL,sha256=CmyFI0kx5cdEMTLiONQRbGQwjIoR1aIYB7eCAQ4KPJ0,91
|
59
|
+
xax-0.1.6.dist-info/top_level.txt,sha256=g4Au_r2XhvZ-lTybviH-Fh9g0zF4DAYHYxPue1-xbs8,4
|
60
|
+
xax-0.1.6.dist-info/RECORD,,
|
File without changes
|
File without changes
|