Add autocropper

This commit is contained in:
Guilhem Lavaux 2024-04-05 09:11:23 +02:00
parent 4939c50378
commit 8203ca36f3
3 changed files with 37 additions and 1 deletions

35
map2map/cropper.py Normal file
View File

@ -0,0 +1,35 @@
import click
import numpy as np
import h5py as h5
import pathlib
from tqdm import tqdm
def _extract_3d_tile_periodic(arr, tile_size, start_index):
periodic_indices = map(
lambda a: a[0] + a[1],
zip(np.ogrid[:tile_size, :tile_size, :tile_size], start_index),
)
periodic_indices = map(
lambda a: np.mod(a[0], a[1]), zip(periodic_indices, arr.shape)
)
return arr[tuple(periodic_indices)]
@click.command()
@click.option("--input", required=True, type=click.Path(exists=True), help="Input file")
@click.option("--output", required=True, type=click.Path(), help="Output directory")
@click.option(
"--tiles", required=True, type=click.Tuple([int]), help="Size of the tiles"
)
@click.option("--fields", required=True, type=click.Tuple([str]), help="Fields to crop")
@click.option("--num_tiles", required=True, type=int, help="Number of tiles to crop")
def cropper(input, output, tiles, fields, num_tiles):
output = pathlib.PosixPath(output)
with h5.File(input, mode="r") as f:
for i in tqdm(range(num_tiles)):
a, b, c = np.random.randint(0, high=1024, size=3)
for field in fields:
tile = _extract_3d_tile_periodic(f[field], Q, (a, b, c))
np.save(output / "tiles" / field / "{:04d}.npy".format(i), tile)

View File

@ -1,4 +1,3 @@
from .args import get_args
from . import train from . import train
from . import test from . import test
import click import click

View File

@ -18,6 +18,7 @@ dependencies = [
'scipy', 'scipy',
'matplotlib', 'matplotlib',
'tensorboard', 'tensorboard',
'h5py','tqdm',
'click','pyyaml'] 'click','pyyaml']
authors = [ authors = [
@ -31,6 +32,7 @@ maintainers = [
[project.scripts] [project.scripts]
m2m = "map2map:main.main" m2m = "map2map:main.main"
mapcropper = "map2map:cropper.cropper"
[project.urls] [project.urls]
#Homepage = "https://example.com" #Homepage = "https://example.com"