Skip to main content

Grain: A library for loading and transforming data for ML training.

Project description

Grain - Feeding JAX Models

Continuous integration PyPI version

Installation | Quickstart | Reference docs | Change logs

Grain is a Python library for reading and processing data for training and evaluating JAX models. It is flexible, fast and deterministic.

Grain allows to define data processing steps in a simple declarative way:

import grain

dataset = (
    grain.MapDataset.source([0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
    .shuffle(seed=42)  # Shuffles elements globally.
    .map(lambda x: x+1)  # Maps each element.
    .batch(batch_size=2)  # Batches consecutive elements.
)

for batch in dataset:
  # Training step.

Grain is designed to work with JAX models but it does not require JAX to run and can be used with other frameworks as well.

Installation

Grain is available on PyPI and can be installed with pip install grain.

Supported platforms

Grain does not directly use GPU or TPU in its transformations, the processing within Grain will be done on the CPU by default.

Linux Mac Windows
x86_64 yes no yes
aarch64 yes yes n/a

Quickstart

Citing Grain

To cite this repository:

@software{grain2023github,
  author = {Marvin Ritter and Ihor Indyk and Aayush Singh and Andrew Audibert and Anoosha Seelam and Camelia Hanes and Eric Lau and Jacek Olesiak and Jiyang Kang and Xihui Wu},
  title = {{Grain} - Feeding JAX Models},
  url = {http://github.com/google/grain},
  version = {0.2.12},
  year = {2023},
}

The version number is intended to be that from pyproject.toml, and the year corresponds to the project's open-source release.

Existing users

Grain is used by MaxText, Gemma, kauldron, maxdiffusion and multiple internal Google projects.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

grain_nightly-0.2.15.dev20251201-cp314-cp314-win_amd64.whl (463.8 kB view details)

Uploaded CPython 3.14Windows x86-64

grain_nightly-0.2.15.dev20251201-cp314-cp314-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl (517.0 kB view details)

Uploaded CPython 3.14manylinux: glibc 2.24+ x86-64manylinux: glibc 2.28+ x86-64

grain_nightly-0.2.15.dev20251201-cp314-cp314-manylinux_2_24_aarch64.manylinux_2_28_aarch64.whl (516.1 kB view details)

Uploaded CPython 3.14manylinux: glibc 2.24+ ARM64manylinux: glibc 2.28+ ARM64

grain_nightly-0.2.15.dev20251201-cp314-cp314-macosx_11_0_arm64.whl (465.9 kB view details)

Uploaded CPython 3.14macOS 11.0+ ARM64

grain_nightly-0.2.15.dev20251201-cp313-cp313-win_amd64.whl (457.6 kB view details)

Uploaded CPython 3.13Windows x86-64

grain_nightly-0.2.15.dev20251201-cp313-cp313-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl (517.1 kB view details)

Uploaded CPython 3.13manylinux: glibc 2.24+ x86-64manylinux: glibc 2.28+ x86-64

grain_nightly-0.2.15.dev20251201-cp313-cp313-manylinux_2_24_aarch64.manylinux_2_28_aarch64.whl (516.1 kB view details)

Uploaded CPython 3.13manylinux: glibc 2.24+ ARM64manylinux: glibc 2.28+ ARM64

grain_nightly-0.2.15.dev20251201-cp313-cp313-macosx_11_0_arm64.whl (465.8 kB view details)

Uploaded CPython 3.13macOS 11.0+ ARM64

grain_nightly-0.2.15.dev20251201-cp312-cp312-win_amd64.whl (457.5 kB view details)

Uploaded CPython 3.12Windows x86-64

grain_nightly-0.2.15.dev20251201-cp312-cp312-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl (516.8 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.24+ x86-64manylinux: glibc 2.28+ x86-64

grain_nightly-0.2.15.dev20251201-cp312-cp312-manylinux_2_24_aarch64.manylinux_2_28_aarch64.whl (516.0 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.24+ ARM64manylinux: glibc 2.28+ ARM64

grain_nightly-0.2.15.dev20251201-cp312-cp312-macosx_11_0_arm64.whl (465.8 kB view details)

Uploaded CPython 3.12macOS 11.0+ ARM64

grain_nightly-0.2.15.dev20251201-cp311-cp311-win_amd64.whl (457.3 kB view details)

Uploaded CPython 3.11Windows x86-64

grain_nightly-0.2.15.dev20251201-cp311-cp311-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl (518.9 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.24+ x86-64manylinux: glibc 2.28+ x86-64

grain_nightly-0.2.15.dev20251201-cp311-cp311-manylinux_2_24_aarch64.manylinux_2_28_aarch64.whl (517.7 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.24+ ARM64manylinux: glibc 2.28+ ARM64

grain_nightly-0.2.15.dev20251201-cp311-cp311-macosx_11_0_arm64.whl (468.5 kB view details)

Uploaded CPython 3.11macOS 11.0+ ARM64

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp314-cp314-win_amd64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp314-cp314-win_amd64.whl
Algorithm Hash digest
SHA256 904f82044392484d952d24c8d498fcd0c1a207347870bc31c9502cee59316431
MD5 c8ea659ac1842f9371d78f15ad6c66cf
BLAKE2b-256 c45cc6d456f67e5257b782212d7853a504aee224b311da46383a094ec4e57758

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp314-cp314-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp314-cp314-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 76f85550f897f8e2fb500c0e18bd832227282f28e41504eac3166c75c2352859
MD5 0b66cdbef195f13cd9a9d571d072c56d
BLAKE2b-256 73f8c4237ee1ff1b11f90b327d8946591abf4e06aa3587b902711a56b32b0c9b

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp314-cp314-manylinux_2_24_aarch64.manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp314-cp314-manylinux_2_24_aarch64.manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 a7cfb3a7df367f7791e74e61ae39994519bc4d9e2d9a6dc02f086e55bd6a4012
MD5 433c105165d5e629f9bef6a634200278
BLAKE2b-256 ae04d8398d797efda4c0ced1acffbe6359e5d6a17db179b4897be23b03202db4

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp314-cp314-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp314-cp314-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 c23de6b11f580ce0512367b780f7860ee62e8eed185b83280e89ed8429fad8a2
MD5 21c5df230fc13f94e03c7b0004aba6bd
BLAKE2b-256 f6ef79879b1ac4e77809ca2c5facf703ebaf52986884ebc64fc8324c1c6b2d9f

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp313-cp313-win_amd64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 ea73ab1dafb7385ea0ae3e569d86c4d1363a54af636465e263db70340870d5c0
MD5 87509bbc77ec48c863b866f2e8e93d7e
BLAKE2b-256 9893ba9187babfdf614312d89791bfe2655bd6f6401e4e9df915d73a4c2aab42

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp313-cp313-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp313-cp313-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 a146bcb08eca37084608fc08379416626147175ae1ba77663d5bb900d827676d
MD5 000dc5c319bafb775db0d0b733fd5e6f
BLAKE2b-256 401dd21825e65e059a0e87722044152fe64bbfdb73a8eebbb2c4bc8b38894387

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp313-cp313-manylinux_2_24_aarch64.manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp313-cp313-manylinux_2_24_aarch64.manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 a62875cd4f3f06effe5a5350dd8ef80a57bdbe206b3ee054f5e225b7e13df7a0
MD5 90ecffb05efc8fda49aff72ed78cb7b4
BLAKE2b-256 3c94b1f1d64f6773b3f5a7cebab6befca78f294dd2521c39d2174b96b545b028

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp313-cp313-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp313-cp313-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 4d912943942cd974ea4ca786b0f18067d7809c3b2c6a7237e0a4ba4cc61c86b6
MD5 49b65a11756451990f48192fd2913074
BLAKE2b-256 7cb1c035da4cd0f64d3538b6824cf0fd0b78f5cf34db218794cc91a58cbebfa5

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 b8fbcd620779d955cc2a4e089ce83653dd144cd6f1cf132d8a46bb9e3071cabb
MD5 241c94d8550e500a51a2841fc8caa2d4
BLAKE2b-256 33bbf97fb322d2311828d9f8403f49e4f03f38d2a5de304cf636973b116be7d7

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp312-cp312-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp312-cp312-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 fdf001ec8433d7847fea3d0140065935f9a2316ef651ed1cdc786ef955803c71
MD5 f0d19cbb48f734cb87812e79dee5b6ea
BLAKE2b-256 bd4059af0732c4cb230ccadb6cf308c0daf792a5689adefbf49ea17e5abcb962

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp312-cp312-manylinux_2_24_aarch64.manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp312-cp312-manylinux_2_24_aarch64.manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 1992f8be2983147d430f1bf83c59ff8fbdeac4c427faa0df04554e51b8830b96
MD5 d37b3c32c7309db4f6113acc6041600d
BLAKE2b-256 964f37ccb72d0643b99e601b4de975abba9aecf6e640bcf537a304acb569a890

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp312-cp312-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp312-cp312-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 63ce6f2e6593cf91d0c30d5f8bd772783ac2b3ffc7b4c0e693d45b311af52b3b
MD5 22321e19b8eb1975db6a1ec725dad69a
BLAKE2b-256 281ec654a5577bbb25c11d9539c764a2dd5fecd4f9330927ea19c67beeaea0c6

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp311-cp311-win_amd64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 5bd7d2eda849e6c00f9fae2ff86a1d9e7d0aad885989f13d03250e39e8d6b165
MD5 31e94906dc8b0154b06c24969289b089
BLAKE2b-256 62e7db84da06c4799934cc8cc9ac6c05a4be13d49c0e1d0a3e9d3ef5934cea47

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp311-cp311-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp311-cp311-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 2770e42e15d4c7449ed25303ddb555e57590666491226882617ec5f12b063893
MD5 b2e753662e2890498e8a4dae0b1e593e
BLAKE2b-256 e20fb04b6e623c553a9045d55758ed4cd09b4e6a8dd66ff04102f1fbeb262035

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp311-cp311-manylinux_2_24_aarch64.manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp311-cp311-manylinux_2_24_aarch64.manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 8fe7395511c46fb942ca788b49a7b0eb7bb3be4b4d21ea571f80925a196a9c03
MD5 1ea5dcab9010483727f19f001f4cfaca
BLAKE2b-256 c5865cf9e0fb79a4ac9139f102b3ca9dabdea99de0ab16303ce03ef706ef38e4

See more details on using hashes here.

File details

Details for the file grain_nightly-0.2.15.dev20251201-cp311-cp311-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for grain_nightly-0.2.15.dev20251201-cp311-cp311-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 ede0535142a0d2529fb01247326c922e0edf452a7131a84c60c672d95184d086
MD5 4814bd6a496d2ab0fb9f82aae14d819e
BLAKE2b-256 297deca52ba9c628fe0825d098f92d05172b4ffb57e642c9e3c03030445b0475

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page