multi-sentencefix-byt5 / finetune_large_BS64_byt5_sentencefix.gin
pere's picture
support for batch size 64
d6576ed
from __gin__ import dynamic_registration
import tasks
import __main__ as train_script
from t5.data import mixtures
from t5x import models
from t5x import partitioning
from t5x import utils
include "t5x/examples/t5/byt5/large.gin"
include "t5x/configs/runs/finetune.gin"
MIXTURE_OR_TASK_NAME = "sentencefix"
TASK_FEATURE_LENGTHS = {"inputs": 256, "targets": 256}
TRAIN_STEPS = 1_200_000 # 1000000 pre-trained steps + 100000 fine-tuning steps.
USE_CACHED_TASKS = False
DROPOUT_RATE = 0.0
RANDOM_SEED = 0
BATCH_SIZE = 64
# `LOSS_NORMALIZING_FACTOR`: When fine-tuning a model that was pre-trained
# using Mesh Tensorflow (e.g. the public T5 / mT5 / ByT5 models), this should be
# set to `pretraining batch_size` * `target_token_length`. For T5 and T5.1.1:
# `2048 * 114`. For mT5: `1024 * 229`. For ByT5: `1024 * 189`.
LOSS_NORMALIZING_FACTOR =193536
INITIAL_CHECKPOINT_PATH = "gs://t5-data/pretrained_models/byt5/large/model.ckpt-1000000"
train_script.train:
eval_period = 500
partitioner = @partitioning.ModelBasedPjitPartitioner()
# `num_decodes` is equivalent to a beam size in a beam search decoding.
models.EncoderDecoderModel.predict_batch_with_aux.num_decodes = 4
partitioning.ModelBasedPjitPartitioner.num_partitions = 2
#from t5.models import mesh_transformer
#import t5.models
#mesh_transformer.learning_rate_schedules.constant_learning_rate.learning_rate = 0.0005
#run.learning_rate_schedule = @learning_rate_schedules.constant_learning_rate