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 ответов

22 просмотра

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

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

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

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

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

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

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
как быть с принтером? такой подход прокатит?
zamtmn
12
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
А вот это что за конструкция? Вернее, она тут нафига?
Serjone
10
Привет. Подскажите, как правильно сматчить лист фиксированного размера, чтобы компилятор не говорил мне о неполном паттерне? Допустим что-то такое [x', y'] = sort [x, y]?
Arseny
8
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
Мужики. привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных элементов...
Kraszx
2
Карта сайта