From fb7f8019a91acb6b478d0c9f996b9829abb098b9 Mon Sep 17 00:00:00 2001 From: Tianyu Liu Date: Thu, 12 Dec 2024 14:04:54 -0800 Subject: [PATCH] Update on "PYTHONHASHSEED needs to be in the range of [0,2**32 - 1]" Otherwise it complaints: > Fatal Python error: config_init_hash_seed: PYTHONHASHSEED must be "random" or an integer in range [0; 4294967295] Reference: https://docs.python.org/3/using/cmdline.html#envvar-PYTHONHASHSEED [ghstack-poisoned] --- torchtitan/utils.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/torchtitan/utils.py b/torchtitan/utils.py index 277f12e3..88113ae8 100644 --- a/torchtitan/utils.py +++ b/torchtitan/utils.py @@ -91,7 +91,7 @@ def set_determinism( if c10d.get_world_size() > 1 and "pp" in world_mesh.mesh_dim_names: pp_mesh = world_mesh["pp"] seed += pp_mesh.get_local_rank() - seed %= 2**64 - 1 + seed %= 2**64 logger.debug( f"PP rank {pp_mesh.get_local_rank()}, Global rank {c10d.get_rank()} using seed: {seed}" @@ -106,8 +106,8 @@ def set_determinism( # The native RNGs and python RNG may not be important, except for the 1-D PP case, but we seed them for consistency. torch.manual_seed(seed) - # PYTHONHASHSEED can be a decimal number in the range [0,2**32 - 1] - os.environ["PYTHONHASHSEED"] = str(seed % (2**32 - 1)) + # PYTHONHASHSEED can be a decimal number in the range [0, 2**32 - 1] + os.environ["PYTHONHASHSEED"] = str(seed % 2**32) # As long as we are not in the 1-D (PP-only) case, we will have a seed to use for all ranks of the SPMD mesh. # IF PP is also used, this seed is unique per PP rank.