170 похожих чатов

Коллеги, похоже у меня затык с обучением gpt2 на собственных

данных с валидационной выборкой
прошу помочь

1. дообучить gpt2 на собственных данных без валидационной выборки я в целом умею
применяю так

# Сохраним обучающие данные в .txt файл
train_path = 'train.txt'
with open(train_path, "w") as f:
f.write(text)

# создание объекта для обработки данных
data_collator = DataCollatorForLanguageModeling(
tokenizer=tokenizer, mlm=False
)

# создание аргументов для тренировки
training_args = TrainingArguments(
output_dir='./results',
overwrite_output_dir=True,
num_train_epochs=100,
per_device_train_batch_size=32,
prediction_loss_only=True,
)

# создание тренера и запуск тренировки
trainer = Trainer(
model=model,
args=training_args,
train_dataset=dataset,
data_collator=data_collator,
)

trainer.train()

2. разделять данные на 2 выборки в целом тоже умею
применяю так

# Считываем текстовый документ в список предложений
with open('train.txt', 'r') as f:
sentences = f.readlines()

# Разделяем данные на тренировочную и валидационную выборки
train_sentences, val_sentences = train_test_split(sentences, test_size=0.2, random_state=42)

—-
Что конкретно нужно поменять/добавить в training_args и trainer,
чтобы обучение проходило с учетом валидационной выборки?

5 ответов

7 просмотров

Выступлю в жанре "угадаю исправление вслепую", но если я не ошибаюсь, вы привели фрагмент кода с использованием библиотеки PytorchLightning? Если да, и мне не изменяет память, то у Trainer должен быть параметр validation_dataset, но я могу ошибаться. Самый лучший вариант - открыть репозиторий с фреймворком, который вы используете и от туда скопировать пример. Ну или в документацию посмотреть, но это для отчаянных ))

нужно всего лишь в trainer добавить параметр eval_dataset и в нем указать свой датасет для валидации

Ivan A
Выступлю в жанре "угадаю исправление вслепую", но ...

тут trainer из transformers но вот про документацию читать это согласен, у transformers хорошая документация)

Anatoly-Belov Автор вопроса
Anatoly-Belov Автор вопроса

Похожие вопросы

Обсуждают сегодня

Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
55
Привет, нужен совет старших товарищей. Есть глобальная переменная var DefaultDataFolder:string; инициализируем DefaultDataFolder:='a:\_OUT\'; есть примитивная процедур...
Max Otto
14
Вопрос. Теоретический. Есть список команд. Команды отправляю в обработку некой функции, по очереди. Разные команды могут давать разные результаты после обработки. В зависимос...
Serjone
7
Всем вечера. Подскажите как лучше сделать. делаю на Д10 Например будет база данных на SQLite. в ней будет много таблиц. более 50шт Типа справочник. Содержать ID Name Id p...
Андрей Т 🐎
10
Я короче решил скомпилировать Nim в js, я думал он сработает как обычный транслятор. По итогу он мне создал файл с расширением js, и туда поместил кучу кода Вопрос, что это з...
𝕾𝖍𝖆𝖉𝖊 <suspense>
9
это группа токсиков или тех кто помогает?
Ибрагим
9
подскажите пожалуйста, как мне освободить результат записанный в переменную result? в чем проблема подскажите если МОЖЕТЕ?
Михаил Helper
28
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
мы пытаемся подменить функцию, которая имеет меньше инструкций относительно функции, которой подменяем. https://www.reddit.com/r/jailbreakdevelopers/comments/w06ujy/mshookfun...
Óðinn
6
У кого-нибудь есть под рукой функция кодирования юникода, которая из фразы На русском сделает \u041d\u0430\u0020\u0440\u0443\u0441\u0441\u043a\u043e\u043c ?
Daniil Smolyakov
7
Карта сайта