Хобрук: Ваш путь к мастерству в программировании

BCEWithLogitsLoss в Керасе

Как реализовать BCEWithLogitsLoss в keras и использовать его как настраиваемую функцию потерь при использовании Tensorflow в качестве бэкэнда.

Я использовал BCEWithLogitsLoss в PyTorch, который был определен в torch.

Как реализовать то же самое в Керасе.?


Ответы:


1

В TensorFlow вы можете напрямую вызывать tf.nn.sigmoid_cross_entropy_with_logits который работает как в TensorFlow 1.x, так и в 2.0.

Если вы хотите придерживаться Keras API, используйте tf.losses.BinaryCrossentropy < / a> и установите from_logits=True в вызове конструктора.

В отличие от PyTorch, в API нет явных весов для каждого примера. Вместо этого вы можете установить reduction=tf.keras.losses.Reduction.NONE для потерь, выполнить взвешивание с помощью явного умножения и уменьшить потери с помощью tf.reduce_mean.

xent = tf.losses.BinaryCrossEntropy(
    from_logits=True,
    reduction=tf.keras.losses.Reduction.NONE)
loss = tf.reduce_mean(xent(targets, pred) * weights))
15.04.2019
  • На самом деле я хочу сделать что-то вроде этого def custom_loss(data, targets): bce_loss_1 = nn.BCEWithLogitsLoss(weight=targets[:,1:2])(data[:,:1],targets[:,:1]) bce_loss_2 = nn.BCEWithLogitsLoss()(data[:,1:],targets[:,2:]) return (bce_loss_1 * loss_weight) + bce_loss_2 15.04.2019
  • Потери Keras не имеют явного веса, как PyTorch. Что вы можете сделать, установите reduction='NONE' в построении потерь, чтобы потери не суммировались или не усреднялись в партии, примените ваши веса и явно уменьшите потери для каждого примера с помощью tf.reduce_mean. 15.04.2019
  • Можете ли вы показать использование того же самого в ответе на игрушечном примере? 15.04.2019
  • Я получаю ValueError с Invalid Reduction Key NONE 15.04.2019
  • Извините, это должно быть: tf.keras.losses.Reduction.NONE 15.04.2019
  • Новые материалы

    Не зря же это называют интеллектом
    Стек — C#, Oracle Опыт — 4 года Работа — Разведывательный корпус Мне пора служить Может быть, я немного приукрашиваю себя, но там, где я живу, есть обязательная военная служба на 3..

    LeetCode Проблема 41. Первый пропущенный положительный результат
    LeetCode Проблема 41. Первый пропущенный положительный результат Учитывая несортированный массив целых чисел, найдите наименьшее пропущенное положительное целое число. Пример 1: Input:..

    Расистский и сексистский робот, обученный в Интернете
    Его ИИ основан на предвзятых данных, которые создают предрассудки. Он словно переходит из одного эпизода в другой из серии Черное зеркало , а вместо этого представляет собой хронику..

    Управление состоянием в микрофронтендах
    Стратегии бесперебойного сотрудничества Микро-фронтенды — это быстро растущая тенденция в сфере фронтенда, гарантирующая, что удовольствие не ограничивается исключительно бэкэнд-системами..

    Декларативное и функциональное программирование в стиле LINQ с использованием JavaScript с использованием каррирования и генератора ...
    LINQ - одна из лучших функций C #, которая обеспечивает элегантный способ написания кода декларативного и функционального стиля, который легко читать и понимать. Благодаря таким функциям ES6,..

    Структуры данных в C ++ - Часть 1
    Реализация общих структур данных в C ++ C ++ - это расширение языка программирования C, которое поддерживает создание классов, поэтому оно известно как C с классами . Он используется для..

    Как я опубликовал свое первое приложение в App Store в 13 лет
    Как все началось Все началось три года назад летом после моего четвертого класса в начальной школе. Для меня, четвертого класса, лето кажется бесконечным, пока оно не закончится, и мой отец..