Безопасность платежей / Fotoshkola.net
Безопасность платежей
Платежи. Оплата банковской картой онлайн
Наш сайт подключен к интернет-эквайрингу и Вы можете оплатить Товар банковской картой Visa или Mastercard. После подтверждения выбранного Товара откроется защищенное окно с платежной страницей процессингового центра CloudPayments, где Вам необходимо ввести данные Вашей банковской карты. Для дополнительной аутентификации держателя карты используется протокол 3D Secure. Если Ваш Банк поддерживает данную технологию, Вы будете перенаправлены на его сервер для дополнительной идентификации. Информацию о правилах и методах дополнительной идентификации уточняйте в Банке, выдавшем Вам банковскую карту.
Гарантии безопасности
Процессинговый центр CloudPayments защищает и обрабатывает данные Вашей банковской карты по стандарту безопасности PCI DSS 3.0. Передача информации в платежный шлюз происходит с применением технологии шифрования SSL.
Безопасность онлайн платежей
Предоставляемая Вами персональная информация (имя, адрес, телефон, e-mail, номер кредитной карты) является конфиденциальной и не подлежит разглашению. Данные Вашей кредитной карты передаются только в зашифрованном виде и не сохраняются на нашем Web-сервере.%d0%be%d0%bd%d0%bb%d0%b0%d0%b9%d0%bd %d0%be%d0%b1%d1%83%d1%87%d0%b5%d0%bd%d0%b8%d1%8f PNG, векторы, PSD и пнг для бесплатной загрузки
естественный цвет bb крем цвета
1200*1200
green environmental protection pattern garbage can be recycled green clean
2000*2000
схема бд электронный компонент технологии принципиальная схема технологическая линия
2000*2000
be careful to slip fall warning sign carefully
2500*2775
blue series frame color can be changed text box streamer
1024*1369
black and white train icon daquan free download can be used separately can be used as decoration free of charge
2000*2000
Косметический bb Крем Дизайн Плаката косметический Косметика постер Реклама косметики Плакат
3240*4320
3d модель надувной подушки bb cream
2500*2500
be careful to fall prohibit sign slip careful
2300*2600
logo design can be used for beauty cosmetics logo fashion
1024*1369
Креативное письмо bb дизайн логотипа черно белый вектор минималистский
1202*1202
2022 календарь bd с фоторамкой
2500*2500
в первоначальном письме bd логотипа
1200*1200
black and white eco friendly pattern garbage can be recycled green clean
2000*2000
black key that can be hung on the body car key key
2000*2000
элегантный серебряный золотой bb позже логотип значок символа
1200*1200
bb крем ню макияж косметика косметика
1200*1500
цвет перо на воздушной подушке bb крем трехмерный элемент
1200*1200
облака комиксов
5042*5042
номер 83 золотой шрифт
1200*1200
prohibited use mobile phone illustration can not be used
2048*2048
be careful of potholes warning signs warning signs caution
2000*2000
простая инициализация bb b геометрическая линия сети и логотип цифровых данных
2276*2276
глюк числа 87 вектор на прозрачном фоне
1200*1200
be careful warning signs warning signs be
2000*2000
желтые глаза напуганы комикс мультфильм
5000*5000
flowering in summer flower buds flowers to be placed lotus
2000*2000
3d золотые числа 87 с галочкой на прозрачном фоне
1200*1200
attention be careful cut icon danger
2500*2000
аэрозольный баллончик увлажняющий лосьон bb cream парфюм для рук
3072*4107
bd письмо логотип
1200*1200
Красивая розовая и безупречная воздушная подушка bb крем косметика постер розовый красивый розовый Нет времени На воздушной
3240*4320
две бутылки косметики жидкая основа белая бутылка крем bb
2000*2000
be careful of electric shock safety icon caution
2240*2856
крем крем вв вв на воздушной подушке иллюстрация
2000*2000
bb крем ню макияжа постер Новый список преимущественный колос День святого
3240*4320
bd письмо логотип
1200*1200
номер 83 3d рендеринг
2000*2000
bb логотип градиент с абстрактной формой
1200*1200
red bb cream cartoon cosmetics
2500*2500
латинский алфавит буква bb из расплавленной лавы скачать бесплатно png
3000*3000
bb логотип дизайн шаблона
2223*2223
три группы 3d реалистичное декоративное яйцо с золотым цветом на гнезде bd с золотым всплеском текстовый баннер
5000*5000
3d золотые числа 83 с галочкой на прозрачном фоне
1200*1200
витамин b1 логотип значок
1200*1200
номер 87 золотой шрифт
1200*1200
серые облака png элемент для вашего комикса bd
5042*5042
в первоначальном письме вв логотипа
1200*1200
flowering in spring flower buds flowers to be placed rhododendrons
2000*2000
safety slogan be careful pay attention to safety caution
2000*2000
Доступный учебник по работе программе ФотоМАСТЕР
Как правильно обрабатывать фотографии
Узнайте об ошибках начинающих фотографов и научитесь их исправлять.
ЧитатьКак улучшить качество фотографии
Создавайте из обычных фотографий качественные красочные снимки.
ЧитатьКак обрезать фото на компьютере за 3 шага
Узнайте о простых правилах кадрирования фотографий.
ЧитатьКак исправить заваленный горизонт
Выровняйте горизонт и улучшите качество фотографии за 3 шага.
ЧитатьНа фотографии много дефектов? Избавьтесь от них в редакторе!
ЧитатьПрограмма для ретуши фотографий
Хотите отретушировать фото? Сделайте это за 5 минут в ФотоМАСТЕРе!
ЧитатьКак оцифровать фотопленку в домашних условиях
Нужно оцифровать фотопленку? Читайте о данном процессе в статье.
ЧитатьСделайте акцент на главном! Размойте фон буквально за минуту в программе.
ЧитатьКак осветлить фотографию легко и быстро
Темные фото — не приговор! Исправьте досадный дефект за пару щелчков мыши.
ЧитатьКак сделать фотомонтаж из своих фотографий
Освойте секреты профессионального и качественного фотомонтажа!
ЧитатьКак убрать задний фон с картинки
С легкостью уберите фон с фотографии или сделайте его белым.
ЧитатьКадрируйте фото и изменяйте его размер за пару кликов мыши!
ЧитатьПрограмма для фотомонтажа в домашних условиях
Сделать интересный фотомонтаж теперь может даже новичок!
ЧитатьКак сделать постер на компьютере
Создавайте яркие постеры быстро и просто в программе ФотоМАСТЕР!
ЧитатьУдобный редактор фото на документы для дома
Подготовьте снимки на любые документы без помощи специалистов!
ЧитатьУзнайте, как красиво обработать снимки ребенка самостоятельно.
ЧитатьПростой фоторедактор: только полезные инструменты
Ищете редактор для новичков? Скачайте ФотоМАСТЕР! Узнайте больше из статьи.
ЧитатьКак на фото добавить картинку или вставить клипарт
Хотите дополнить фото клипартом или сделать коллаж? Прочитайте эту статью!
Читать50+ готовых стилей!
Добавляйте на фото оригинальные надписи! Узнайте больше из статьи.
ЧитатьФоторедактор тела:
стройная фигура за минуту!
Скорректируйте талию и лицо на фото за пару простых кликов мыши.
ЧитатьУдобный фоторедактор
без водяных знаков
Редактируйте фото и сохраняйте их в любом формате без водяных знаков!
ЧитатьУдобный редактор фото
Создайте стильную обложку для канала на YouTube и миниатюры для видео!
ЧитатьПрофессиональный фоторедактор
Разобраться с инструментами в ФотоМАСТЕРЕ может даже новичок!
ЧитатьПрактичный фоторедактор
на ноутбук
Обрабатывайте фото когда и где угодно, установив ФотоМАСТЕР на ноутбук!
ЧитатьКрасивая обработка снимков в фоторедакторе
Узнайте, как преобразить любой снимок всего за пару минут!
Фоторедактор для создания коллажей из фото
Объедините снимки в красочные коллажи! Узнайте больше из статьи.
ЧитатьФоторедактор для быстрой ретуши лица
Улучшите портрет или замените лицо на любом фото за пару кликов мыши!
ЧитатьКак убрать любую надпись с картинки
Удалите лишний текст, водяной знак и другие надписи с фото.
Как изменить погоду на любой фотографии
Меняйте погоду на фотографии легко и быстро в редакторе!
ЧитатьКак увеличить разрешение изображения
Измените разрешение фото, сохранив его исходное качество!
ЧитатьКак быстро убрать пиксели
на фотографии
Удалите нежелательный эффект пикселизации на фото быстро и просто!
ЧитатьКак отзеркалить фотографию за пару кликов мыши
Узнайте, как за отразить фото зеркально в фоторедакторе за минуту!
ЧитатьКак поставить водяной знак на фотографию за 5 минут
Защитите свое авторство, поставив водяной знак на снимки!
ЧитатьКак сделать обложку для видео на YouTube
Создайте эффектную обложку для видео на ютубе за 5 минут!
ЧитатьКак составить генеалогическое древо своей семьи
Расскажите об истории семьи красиво с помощью семейного древа!
ЧитатьСоздайте стильное оформление для своего паблика!
Читатьобучение фото, онлайн обучение фото, онлайн уроки по фото, онлайн уроки по фотографии, он-лайн обучение фото, он-лайн обучение по фотографии, он-лайн обучение по фотографии
Занимаетесь фотографией и хотите успешно развивать своё фотодело?
Снимаете для себя и не знаете, как сделать это профессией?
Хотите избежать шаблонных ошибок (а их совершают 90% фотографов)?
Снимать так, как видите именно вы, а не как диктует мода, увидеть себя как фотографа, свою уникальность, обрести, наконец, свободу в творчестве, и — получать за это деньги.
На внутреннем строится внешнее — на том сомоосознании, которое вы получите во время коучинга, будет строиться техническая часть обучения (вопросы света, обработки, приёмов съёмки и т.д.).
Как проходит мой коучинг — главное, что прорабатывается не одна задача, а несколько, параллельно — маркетинговая (клиенты, как рекламироваться и т.д.), техническая и частные вопросы (их много, они индивидуальные).
Я обучаю не теории, а т.к. я именно практик — то рассказываю о том, что проверено, что работает, а что — нет. И самое главное — что вы начнёте сами ориентироваться, куда вам дальше идти в фотографии, куда развиваться, без опоры, найдя опору внутри себя.
Задания: конкретные, практические (без «воды»). Я буду смотреть на все стороны вашего фотодела — начиная от того, как выглядит ваш сайт/группа/площадка и до отдачи готового материала. Т.е по сути — «прокачиваются» разные стороны, в том числе и такая важная, как обретение своего почерка и подхода.
Вы увидите и научитесь, прежде всего — понимать себя как фотографа, видеть, куда вы идёте, а также как продвигать свои фотографии, как привлечь тех, кого вам бы хотелось снимать (по общности вкусов, по стоимости съёмки), как сделать портфолио цельным и работающим на эти цели. Плюс неочевидные вещи, но очень помогающие в работе. И всё — на основе моей практики и опыта. Только то — что надо делать. И отдельно — о том, что не надо, но что делает большинство.
И (внимание!) — если мы начинаем такой формат обучения, то я буду вести вас к результату, и вам действительно нужно действовать. Это формат для тех, кто готов взять всё в свои руки и получить реальный результат. Отсидеться и просто послушать информацию не получится.
Сроки: обучение идет блоками по 2- 3 мес. Т.е. 2-3 месяца — только конкретные задачи и информация.
Внимание! На июнь и июль 2018 г. есть одно место. На август — сентябрь 2018 г.два места.
Заявки на следующие наборы принимаются на почту [email protected] (тема письма «Индивидуальный коучинг») или можно оставить вашу заявку по этой ссылке https://goo.gl/Mt390H
Курсы фотографии онлайн с сертификатом
Цена по возрастаниюВаш первый текст: как сделать его хорошим
Дата начала курса
Срок обучения
Для начинающих
Условия
Формат обучения
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Нет
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Нет
Пожизненный доступ к материалам
Нет
Возможность сделать перерыв во время курса обучения
Не предусмотрена.
Наличие куратора
Нет
Секреты хороших текстов
Дата начала курса
Срок обучения
Для начинающих
Условия
Формат обучения
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Сертификат Stepik
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Нет
Пожизненный доступ к материалам
Да
Наличие куратора
Нет
Adobe Photoshop. Коллажирование
Дата начала курса
Срок обучения
Для начинающих
Условия
Формат обучения
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Нет
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Да
Примерная учебная нагрузка
Пара часов в день.
Пожизненный доступ к материалам
Нет
Наличие куратора
Нет
Основы Adobe Photoshop
Дата начала курса
Срок обучения
Для начинающих
Условия
Формат обучения
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Нет
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Да
Примерная учебная нагрузка
2-3 занятия в неделю.
Пожизненный доступ к материалам
Нет
Наличие куратора
Нет
Основы Adobe Illustrator
Дата начала курса
Срок обучения
Для начинающих
Условия
Формат обучения
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Нет
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Да
Примерная учебная нагрузка
1-2 занятия в неделю.
Пожизненный доступ к материалам
Нет
Наличие куратора
Нет
Визуальный язык и его элементы
Дата начала курса
Срок обучения
Для начинающих
Условия
Формат обучения
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Нет
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Да
Примерная учебная нагрузка
1-2 занятия в неделю.
Пожизненный доступ к материалам
Нет
Наличие куратора
Нет
Основы скетчинга
Дата начала курса
Срок обучения
Для начинающих
Условия
Формат обучения
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Нет
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Да
Примерная учебная нагрузка
1-2 занятия в неделю.
Пожизненный доступ к материалам
Нет
Наличие куратора
Нет
Как писать научные статьи
Дата начала курса
Срок обучения
Для начинающих
Условия
Формат обучения
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Сертификат Stepik
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Да
Пожизненный доступ к материалам
Нет
Наличие куратора
Нет
Основы видеоблогинга
Дата начала курса
Срок обучения
Для начинающих
Условия
Формат обучения
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Нет
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Да
Пожизненный доступ к материалам
Нет
Наличие куратора
Нет
Создание курса на Stepik
Дата начала курса
Срок обучения
Для начинающих
Условия
Формат обучения
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Сертификат Stepik
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Да
Пожизненный доступ к материалам
Нет
Наличие куратора
Нет
Публикационный процесс от и до — руководство для молодых ученых
Дата начала курса
Срок обучения
Для начинающих
Условия
Формат обучения
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Сертификат Stepik
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Да
Пожизненный доступ к материалам
Нет
Наличие куратора
Нет
Шаг к писательскому мастерству. Фанфикшн
Дата начала курса
Срок обучения
Условия
Формат обучения
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Нет
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Да
Пожизненный доступ к материалам
Нет
Наличие куратора
Нет
Дата начала курса
Срок обучения
Для начинающих
Условия
Формат обучения
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Нет
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары, Онлайн занятия с преподавателем
Домашние задания
Да
Пожизненный доступ к материалам
Нет
Наличие куратора
Да
Заработок на Яндекс.Дзен
Дата начала курса
Срок обучения
Для начинающих
Условия
Формат обучения
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Нет
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары, Онлайн занятия с преподавателем
Домашние задания
Да
Пожизненный доступ к материалам
Нет
Наличие куратора
Да
Текстик, не болей: редакторская реанимация материалов
Дата начала курса
Срок обучения
Для начинающих
Условия
Формат обучения
Рассрочка
Включает программу трудоустройства
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Да
Документ об окончании курса
Нет
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Да
Пожизненный доступ к материалам
Нет
Наличие куратора
Нет
Перспектива. Основы изобразительной грамоты для начинающих
Дата начала курса
Срок обучения
Для начинающихДля детей
Условия
Формат обучения
Рассрочка
Включает программу трудоустройства
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Да
Документ об окончании курса
Сертификат Stepik
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Да
Пожизненный доступ к материалам
Нет
Наличие куратора
Нет
Дата начала курса
Срок обучения
Пробный периодДля начинающих
Условия
Формат обучения
Бесплатный пробный период
3 дня
Включает программу трудоустройства
нет
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Нет
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Нет
Примерная учебная нагрузка
1-2 часа в день
Пожизненный доступ к материалам
Да
Наличие куратора
Нет
Дата начала курса
Срок обучения
Для продвинутых
Условия
Формат обучения
Рассрочка
Включает программу трудоустройства
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Нет
Документ об окончании курса
Нет
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Нет
Примерная учебная нагрузка
1-2 часа в день
Пожизненный доступ к материалам
Да
Наличие куратора
Нет
Модуль 1. Животные и птицы
Дата начала курса
Срок обучения
Для начинающихДля детей
Условия
Формат обучения
Рассрочка
Включает программу трудоустройства
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Да
Документ об окончании курса
Сертификат
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Да
Пожизненный доступ к материалам
Нет
Наличие куратора
Да
Модуль 2. Люди и монстры
Дата начала курса
Срок обучения
Для начинающихДля детей
Условия
Формат обучения
Рассрочка
Включает программу трудоустройства
Гарантия трудоустройства
нет
Возможность прервать обучение и вернуть деньги за непройденную часть курса
Да
Документ об окончании курса
Сертификат
График прохождения обучения
Свободный. Пройти курс можно в любой момент
Учебный процесс
Запись лекций или вебинары
Домашние задания
Да
Пожизненный доступ к материалам
Нет
Наличие куратора
Да
Показать ещё 20
Битрикс — Сервис онлайн-обучения фотографии Nikon School
Школа фотографии онлайн: в мире Nikon
Интернет-агентство «Инфоспайс» разработало сервис онлайн-курсов для владельцев камер Nikon — уникального среди фотопроизводителей образовательного проекта Nikon School.
Nikon School — это образовательный проект, который создан в 2009 году для тех, кто уже пользуется и интересуется зеркальными фотокамерами.
«Если раньше начинающие фотографы могли пройти курс только находясь в Москве или Санкт-Петербурге, то теперь не привязываясь к месту и времени курсы доступны на сайте nikonschool.ru. Таким образом, компания Nikon сильно увеличила свою российскую аудиторию» — рассказал Константин Обухов, генеральный директор интернет-агентства «Инфоспайс».
Первый курс владельцы камер Nikon могут пройти бесплатно, введя серийный номер своей камеры. Затем пользователь может купить и получить доступ к одному из продвинутых курсов, которые содержат видеолекции, практические занятия и домашние задания. Работы проверяют профессиональные преподаватели и выставляют оценки. После успешного прохождения всего курса ученики онлайн-школы получают сертификат.
В ходе работы над проектом, сайт nikonschool.ru был существенно модернизирован и переведен на новую версию «1С-Битрикс». Была настроена система интеграции с поставщиками учебного контента, партнером Nikon — Fotoshkola.net, создана система создания и хранения данных по курсам и возможность их онлайн-продажи через сайт. Специально для удобства студентов реализована система уведомлений, позволяющая оперативно получать сообщения о выполненных проверенных заданиях.
Задача
- Создать онлайн-сервис обучения в фотошколе Nikon.
- Проектирование интерактивных прототипов.
- Подготовка технического задания.
- Верстка.
- Программирование.
- Интеграция с API.
- Тестирование.
недавний прогресс в распознавании изображений / Хабр
В 1998 году, когда появилась база MNIST, требовались недели для обучения самых передовых компьютеров, достигавших гораздо худших результатов, чем сегодняшние, на получение которых при помощи GPU уходит менее часа. Поэтому MNIST уже не является задачей, раздвигающей границы возможностей технологий; скорость обучения говорит о том, что эта задача хорошо подходит для изучения данной технологии. Тем временем, исследования идут дальше, и в современной работе изучаются гораздо более сложные для решения задачи. В данном разделе я кратко опишу некоторые примеры текущей работы, связанной с распознаванием изображений при помощи нейросетей.
Этот раздел отличается от остальной части книги. В книге я фокусировался на предположительно долгоживущих идеях – обратном распространении, регуляризации, свёрточных сетях. Я пытался избегать результатов, считающихся модными на момент написания, чья долговременная ценность представлялась сомнительной. В науке подобные результаты чаще всего оказываются однодневками, быстро исчезают и не оказывают долговременного влияния. Учитывая это, скептик сказал бы: «Разумеется, недавний прогресс в распознавании изображений можно считать примером такой однодневки? Через два-три года всё поменяется. Так что эти результаты наверняка будут интересны небольшому числу специалистов, конкурирующих на переднем плане? К чему вообще их обсуждать?»
Такой скептик будет прав в том, что мелкие детали недавних работ постепенно утеряют воспринимаемую важность. Однако за последние несколько лет произошли невероятные улучшения в деле решения особенно сложных задач распознавания изображений при помощи глубоких нейросетей (ГНС). Представьте себе историка науки, пишущего материал о компьютерном зрении в 2100 году. Они определят 2011-2015 годы (и, вероятно, несколько лет после этого) как период значимых прорывов, ведомых глубокими свёрточными сетями (ГСС). Это не значит, что ГСН всё ещё будут использоваться в 2100 году, не говоря уже о таких деталях, как исключение, ReLU и прочее. Но это всё равно означает наличие в истории идей важного перехода в текущий момент. Это похоже на наблюдение за открытием атома, за изобретением антибиотиков: изобретение и открытие исторического масштаба. Поэтому, не вдаваясь в детали, стоит получить какое-то представление об интересных открытиях, совершаемых сегодня.
Работа 2012 LRMD
Позвольте мне начать с
работы 2012 года, за авторством группы исследователей из Стэнфорда и Google. Я буду называть её LRMD, по первым буквам фамилий первых четырёх авторов. В LRMD использовали НС для классификации изображений из базы ImageNet, что является очень сложной задачей распознавания образов. Используемые ими данные из 2011 ImageNet включали 16 млн полноцветных изображений, разделённых на 20 000 категорий. Изображения были скачаны из интернета и классифицированы работниками сервиса Amazon’s Mechanical Turk. Вот некоторые из них:
Они принадлежат к категориям, соответственно: калёвка, коричневый грибок корней, пастеризованное молоко, аскариды. Если вам хочется поупражняться, рекомендую вам посетить список ручных инструментов от ImagNet, где делаются различия между калёвками, торцовыми рубанками, рубанками для снятия фасок и десятками других видов рубанков, не говоря уже о других категориях. Не знаю, как вы, но я не могу с уверенностью различить все эти инструменты. Это, очевидно, куда как более сложная задача, чем MNIST! Сеть LRMD получила приличный результат в 15,8% точности распознавания изображений из ImageNet. Это может не казаться таким впечатляющим результатом, однако это было огромным улучшением по сравнению с предыдущим результатом в 9,3%. Такой скачок говорит о том, что НС могут предложить эффективный подход к очень сложным задачам распознавания изображений, таким, как ImageNet.
Работа 2012 KSH
За работой LRMD в 2012 году последовала
работаКрижевского, Суцкевера и Хинтона (KSH). KSH обучали и проверяли ГСС при помощи ограниченного подмножества данных ImagNet. Это подмножество задано популярным соревнованием по машинному обучению — ImageNet Large-Scale Visual Recognition Challenge (ILSVRC). Использование такого подмножества дало им удобный способ сравнения их подхода с другими лидирующими техниками. В наборе ILSVRC-2012 содержится порядка 1,2 млн изображений из 1000 категорий. Проверочный и подтверждающий наборы содержат 150 000 и 50 000 изображений соответственно, из тех же 1000 категорий.
Одна из трудностей соревнования ILSVRC заключается в том, что на многих изображениях из ImageNet содержится несколько объектов. Допустим, на изображении лабрадор-ретривер бежит за футбольным мячом. Т.н. «правильная» классификация от ILSVRC может соответствовать метке «лабрадор-ретривер». Нужно ли отбирать очки у алгоритма, если он пометить изображение, как футбольный мяч? Из-за такой многозначности работу алгоритма считали правильной, если классификация от ImageNet находилась среди 5 наиболее вероятных догадок алгоритма по поводу содержания картинки. По этому критерию из 5 лучших, ГСС от KSH достигла точности в 84,7%, гораздо лучше предыдущего соперника, достигшего точности в 73,8%. При использовании более строгой метрики, когда метка должна точно совпадать с прописанной, точность KSH достигла 63,3%.
Стоит кратко описать сеть KSH, поскольку она вдохновила столько последовавших за ней работ. Она также, как мы увидим, тесно связана с сетями, которые мы обучали в этой главе, хотя и является более сложной. KSH использовала ГСС, обучавшуюся на двух GPU. Они использовали два GPU, поскольку у их конкретной карты (NVIDIA GeForce GTX 580) не было достаточно памяти для хранения всей сети целиком. Поэтому они разбили сеть на две части.
У сети KSH 7 слоёв скрытых нейронов. Первые пять скрытых слоёв свёрточные (некоторые используют макс-пулинг), а следующие 2 – полносвязные. Выходной softmax слой состоит из 1000 нейронов, соответствующих 1000 классов изображений. Вот набросок сети, взятый из работы KSH. Детали описаны ниже. Отметьте, что многие слои разбиты на 2 части, соответствующие двум GPU.
Во входном слое 3х224х224 нейрона, обозначающих значения RGB для изображения размером 224х224. Вспомните, что в ImageNet содержатся изображения различного разрешения. Это представляет проблему, поскольку входной слой сети обычно имеет фиксированный размер. KSH справились с этим, масштабируя каждую картинку так, чтобы у её короткой стороны была длина 256 пикселей. Потом они вырезают область 256х256 пикселей из середины изменённого изображения. Наконец, KSH извлекают случайные куски изображения размером 224х224 (и их горизонтальные отражения) из изображений размером 256х256. Это случайное вырезание – способ расширения обучающих данных с целью уменьшения переобучения. Особенно это помогает обучать такую большую сеть, как у KSH. И, наконец, эти изображения 224х224 используются в качестве входных для сети. В большинстве случаев вырезанное изображение содержит главный объект из первоначальной картинки.
Переходим к скрытым слоям сети KSH. Первый скрытый слой – свёрточный, с шагом макс-пулинга. Он использует локальные рецептивные поля размером 11х11, и шаг в 4 пикселя. В сумме получается 96 карт признаков. Карты признаков разбиты на две группы по 48 штук, при этом первые 48 карт находятся на одном GPU, а вторые – на другом. Макс-пулинг в этом и последующих слоях проводится участками размера 3х3, но участки пулинга могут накладываться, и находятся на расстоянии всего в 2 пикселя друг от друга.
Второй скрытый слой тоже свёрточный, с макс-пулингом. Он использует локальные рецептивные поля 5х5, и в нём 256 карт признаков, разбитых по 128 штук для каждого из GPU. Карты признаков используют только 48 входящих каналов, а не все 96 выходов из предыдущего слоя, как обычно. Это потому, что любая карта признаков получает на вход информацию с того GPU, на котором она хранится. В этом смысле сеть отходит от свёрточной архитектуры, описанной нами ранее в этой главе, хотя, очевидно, основная идея остаётся той же.
Третий, четвёртый и пятый слои свёрточные, но без макс-пулинга. Их параметры: (3) 384 карты признаков, локальные рецептивные поля 3х3, 256 входящих каналов; (4) 384 карты признаков, локальные рецептивные поля 3х3, 192 входящих канала; (5) 256 карт признаков, локальные рецептивные поля 3х3, 192 входящих канала. На третьем слое происходит обмен данными между GPU (как показано на картинке), чтобы карты признаков могли использовать все 256 входящих каналов.
Шестой и седьмой скрытые слои полносвязные, по 4096 нейронов.
Выходной слой – софтмакс, состоит из 1000 единиц.
Сеть KSH пользуется преимуществами многих техник. Вместо использования сигмоиды или гиперболического тангенса в качестве функции активации, она использует ReLU, значительно ускоряющие обучения. В сети KSH содержится порядка 60 млн обучаемых параметров, и поэтому она, даже при большом наборе обучающих данных, подвержена переобучению. Чтобы справиться с этим, авторы расширили обучающий набор при помощи случайной обрезки картинок, как описано выше. Далее они использовали вариант L2-регуляризации и исключение. Сеть обучалась при помощи стохастического градиентного спуска на основе импульса и с мини-пакетами.
Это краткий обзор многих ключевых идей работы KSH. Некоторые детали я опустил, их ищите в статье самостоятельно. Также можете посмотреть на проект Алекса Крижевского cuda-convnet (и его последователей), содержащий код, реализующий многие из описанных идей. Разработана и версия этой сети на основе Theano. В коде можно узнать идеи, сходные с теми, что мы разработали в этой главе, хотя использование нескольких GPU усложняет дело. В фреймворке Caffe есть своя версия сети KSH, для подробностей смотрите их «зоопарк моделей».
Соревнование 2014 ILSVRC
С 2012 года прогресс идёт довольно быстро. Возьмём соревнование 2014 ILSVRC. Как и в 2012 году, участникам нужно было обучать сети на 1,2 млн изображений из 1000 категорий, и критерием качества было попадание одного из 5 вероятных предсказаний в правильную категорию.
Выигравшая команда, состоящая в основном из сотрудников Google, использовала ГСС с 22 слоями нейронов. Они назвали свою сеть GoogLeNet, в честь LeNet-5. По критерию попадания пяти лучших вариантов GoogLeNet достигла показателя в 93,33% точности, что серьёзно улучшило результат победителя 2013 года (Clarifai, с 88,3%) и победителя 2012 года (KSH, с 84,7%).
Насколько точность GoogLeNet в 93,33% хороша? В 2014 году команда исследователей написала обзорную работу соревнования ILSVRC. Одним из рассматриваемых вопросов было то, насколько хорошо смогут справиться с задачей люди. Для эксперимента они создали систему, позволяющую людям классифицировать изображения с ILSVRC. Как поясняет один из авторов работы, Андрей Карпаты, в информативной записи в своём блоге, было очень трудно довести эффективность работы людей до показателей GoogLeNet:
Задача разметки изображений пятью категориями из 1000 возможных быстро стала чрезвычайно сложной, даже для тех из моих друзей в лаборатории, что уже некоторое время работали с ILSVRC и её категориями. Сначала мы хотели отправить задачу в Amazon Mechanical Turk. Потом мы решили попробовать нанять студентов за деньги. Потому я организовал разметочную вечеринку среди экспертов в своей лаборатории. После этого я разработал изменённый интерфейс, использовавший предсказания GoogLeNet для уменьшения количества категорий с 1000 до 100. И всё равно задача была сложной – люди пропускали категории, выдавая ошибки порядка 13-15%. В итоге я понял, что для того, чтобы хотя бы приблизиться к результату GoogLeNet, наиболее эффективным подходом будет мне самому сесть и пройти через невозможно долгий процесс обучения и последующий процесс тщательной разметки. Сначала разметка шла со скоростью порядка 1 штуки в минуту, но со временем ускорялась. Некоторые изображения было легко распознать, иные же (допустим, определённые породы собак, виды птиц или обезьян) требовали нескольких минут концентрации. Я очень хорошо наловчился различать породы собак. На основе моей выборки изображений получились следующие результаты: GoogLeNet ошибалась в 6,8% случаев; мой процент ошибок составил 5,1%, что было примерно на 1,7% лучше.
Иначе говоря, эксперт, работавший очень тщательно, лишь приложив серьёзные усилия, смог ненамного опередить ГНС. Карпаты сообщает, что второй эксперт, обученный на меньшем количестве изображений, сумел уменьшить ошибку лишь до 12% при выборе до 5 меток на изображение, что гораздо меньше показателей GoogLeNet.
Потрясающие результаты. А с момента появления этой работы несколько команд сообщали о разработке систем, чей уровень ошибок при выборе 5 лучших меток был даже меньше, чем 5,1%. Иногда в СМИ эти достижения освещались, как появление систем, способных распознавать изображения лучше людей. И хотя в целом результаты поражают, существует много нюансов, из-за которых нельзя считать, что у этих систем компьютерное зрение работает лучше, чем у человека. Во многих смыслах соревнование ILSVRC является очень ограниченной задачей – результаты поиска изображений в открытой сети не обязательно будут соответствовать тому, что встретится программе в практической задаче. И, естественно, критерий «одна из пяти лучших меток» достаточно искусственный. Нам ещё предстоит долгий путь к решению задачи распознавания изображений, не говоря уже о более общей задаче компьютерного зрения. Но всё же очень здорово смотреть, какого большого прогресса удалось достичь в решении такой сложной задачи всего за несколько лет.
Другие задачи
Я сконцентрировался на ImageNet, однако существует достаточно много других проектов, использующих НС для распознавания изображений. Позвольте кратко описать несколько интересных результатов, полученных за последнее время, просто чтобы составить представление о современных работах.
Один вдохновляющий практический набор результатов получила команда из Google, применившая ГСС к задаче распознавания адресных табличек в Google Street View. В их работе они сообщают о том, как обнаружили и автоматически распознали почти 100 млн адресных табличек с точностью, сравнимой с работой человека. И их система работает быстро: она смогла расшифровать данные со всех изображений Google Street View во Франции меньше, чем за час! Они пишут: «Получение этого нового набора данных значительно увеличило качество геокодирования Google Maps в нескольких странах, особенно там, где не было других источников геокодирования». Далее они делают и более общее заявление: «Мы считаем, что, благодаря этой модели, мы решили задачу оптического распознавания коротких последовательностей способом, применимым во многих практических приложениях».
Возможно, я создал у вас впечатление парада победных и вдохновляющих результатов. Конечно, самые интересные отчёты касаются фундаментальных вещей, нам пока непонятных. К примеру, в работе 2013 года было показано, что у НС имеются, по сути, слепые пятна. Посмотрите на изображения ниже. Слева – изображение из ImageNet, которое сеть исследователей классифицировала правильно. Справа – немного изменённое изображение (в середине показаны различия), которое сеть уже не смогла правильно распознать. И авторы обнаружили, что подобные «состязательные» изменения можно подобрать для любого изображения из базы, а не только для избранных.
Неприятный результат. В работе использовалась сеть на основе того же кода, что и сеть KSH – то есть, именно такая сеть, которую всё больше используют. И хотя такие НС вычисляют, в принципе, непрерывные функции, подобные результаты говорят о том, что они, вероятно, вычисляют почти дискретные функции. Что хуже, они оказываются дискретными таким образом, что нарушают наше интуитивное представление о разумном поведении. Это проблема. Кроме того, пока не очень ясно, что именно приводит к дискретности, в чём заключается проблема: в функции потерь? В том, какие функции активации использовать? В архитектуре сети? В чём-то другом? Мы не знаем.
Но эти результаты не настолько уж плохи, как кажется. Хотя подобные состязательные изменения довольно распространены, их вряд ли получится встретить на практике. Как указано в работе:
Существование состязательных негативов противоречит способности сети достигать высоких показателей обобщаемости. Ведь если бы сеть умела хорошо обобщать, как бы её можно было обмануть такими состязательными негативами, неотличимыми от обычных примеров? Объяснение заключается в том, что набор состязательных негативов имеет чрезвычайно малую вероятность, и потому не наблюдается (или почти не наблюдается) в обучающем наборе данных, однако он обладает большой плотностью (примерно как рациональные числа), и потому его можно найти практически для любого случая.
Тем не менее, неприятно, что мы так плохо понимаем работу НС, что этот результат был обнаружен совсем недавно. Конечно, главным преимуществом таких результатов будет то, что они стимулировали появление последующих работ по этой теме. В недавней работе 2014 года показано, что для обученной сети возможно создать изображения, которые для человека будут выглядеть, как белый шум, а сеть будет классифицировать их в известные категории с большой долей уверенности. Это ещё одна демонстрация того, что нам ещё многое предстоит понять в работе НС и в их использовании для распознавания изображений.
Но, несмотря на наличие подобных результатов, общая картина вдохновляет. Мы наблюдаем быстрый прогресс в выполнении чрезвычайно сложных тестов, типа ImageNet. Мы также наблюдаем быстрый прогресс в решении задач из реального мира, типа распознавания табличек с адресами в StreetView. Но, несмотря на вдохновение, недостаточно лишь наблюдать за улучшениями в выполнении тестов на скорость или даже задач реального мира. Существуют фундаментальные явления, суть которых мы до сих пор понимаем плохо, к примеру, существование состязательных изображений. И пока такие фундаментальные проблемы ещё открываются (не говоря уже о том, чтобы решать их), преждевременно было бы говорить о приближении к решению задачи распознавания изображений. Но в то же время такие проблемы являются прекрасными стимулами к дальнейшей работе.
Другие подходы к глубоким нейросетям
В данной книге мы сфокусировались на одной задаче: классификации цифр MNIST. Отличная задача, заставившая нас понять множество эффективных идей: стохастический градиентный спуск, обратное распространение, свёрточные сети, регуляризация, и т.д. Однако это также довольно узкая задача. Почитав литературу по нейросетям, вы встретитесь со множеством идей, которые мы не обсуждали: рекуррентные НС, машины Больцмана, генеративные модели, перенос обучения, обучение с подкреплением, и так далее, и тому подобное! Нейросети – обширная область. Однако многие важные идеи являются вариациями тех идей, которые мы уже обсудили, и их довольно легко понять. В данном разделе я приоткрою завесу над этими необъятными просторами. Их обсуждение будет не подробным и не всеобъемлющим – это бы чрезвычайно раздуло книгу. Оно будет импрессионистским, попыткой показать концептуальное богатство этой области, и связать некоторые понятия с теми, что мы уже видели. В тексте я дам несколько ссылок на другие источники, как на материалы для дальнейшего обучения. Конечно, многие из них скоро будут вытеснены другими, и вам, возможно, захочется поискать более свежую литературу. Тем не менее, я считаю, что многие базовые идеи останутся интересными ещё продолжительное время.
Рекуррентные нейросети (РНС)
В сетях с прямым распространением, которые мы использовали, существует один вход, полностью определяющий активацию всех нейронов в последующих слоях. Это очень статичная картина: всё в сети фиксировано, и имеет замороженный, кристаллический характер. Но, допустим, мы разрешим элементам сети меняться динамически. К примеру, поведение скрытых нейронов может определяться не только активациями в предыдущих слоях, но и активациями, случившимися ранее во времени. Активацию нейрона может частично определять его же более ранняя активация. В сетях с прямым распространениям такого однозначно не происходит. Или, возможно, активации скрытых и выходных нейронов будут определяться не только текущими входными данными в сеть, но и предыдущими.
Нейросети с такого типа поведением, меняющимся во времени, известны, как рекуррентные нейросети, или РНС. Существует множество способов математически формализовать неформальное описание предыдущего параграфа. Вы можете получить представление о них, почитав статью в Википедии. На момент написания книги в англоязычной версии статьи описано не менее 13 разных моделей [на момент перевода в 2019 году уже 18 / прим. перев.]. Но, если отставить в сторону математические детали, то общая идея РНС состоит в наличии динамических изменений в сети, происходящих со временем. И, что неудивительно, они особенно полезны для анализа данных или процессов, меняющихся со временем. Такие данные и процессы естественным образом появляются в таких задачах, как анализ речи или естественного языка.
Один из текущих способов использования РНС – более тесное объединение нейросетей с традиционными способами представления алгоритмов, с такими концепциями, как машина Тьюринга и обычные языки программирования. В работе от 2014 года была разработана РНС, способная принять на вход побуквенное описание очень простой программы на python, и предсказать результат её работы. Неформально говоря, сеть учится «понимать» определённые программы на python. Вторая работа от 2014 года использовала РНС как отправную точку для разработки «нейромашины Тьюринга» (НМТ). Это универсальный компьютер, всю структуру которого можно обучить при помощи градиентного спуска. Они обучили свой НМТ строить алгоритмы для нескольких простых задач, типа сортировки или копирования.
Это, конечно, очень простые, игрушечные модели. Обучение выполнению программы на python вида print(398345+42598) не делает нейросеть полноценным интерпретатором языка! Неясно, насколько сильнее получится развить эти идеи. И всё же результаты оказываются довольно интересными. Исторически нейросети хорошо справлялись с задачами распознавания закономерностей, на которых спотыкались обычные алгоритмические подходы. И наоборот, обычные алгоритмические подходы хорошо справляются с решением задач, сложных для НС. Сегодня никто не пытается реализовать веб-сервер или базу данных на базе НС! Было бы здорово разработать объединённые модели, интегрирующие сильные стороны как НС, так и традиционных алгоритмических подходах. РНС, и идеи, вдохновлённые ими, могут помочь нам сделать это.
В последние годы РНС использовали и для решения множества других задач. Они были особенно полезными в распознавании речи. Подходы на основе РНС ставят рекорды по качеству распознавания фонем. Их также использовали для разработки улучшенных моделей используемого людьми языка речи. Улучшенные модели языка помогают распознавать неоднозначности в речи, звучащие похожим образом. Хорошая модель языка сможет сказать нам, что фраза «вперёд к бесконечности» куда как более вероятна, чем фраза «вперёд без конечности», хотя они и звучат похожим образом. РНС использовали для получения рекордных достижений на определённых языковых тестах.
Эта работа является частью более обширного использования НС всех видов, не только РНС, для решения задачи распознавания речи. К примеру, подход на основе ГНС показал прекрасные результаты в распознавании непрерывной речи с большим словарём. Ещё одна система на основе ГНС реализована в ОС Android от Google.
Я немного рассказал о том, на что способны РНС, но не объяснил, как они работают. Возможно, вы не удивитесь, узнав, что многие идеи из мира сетей с прямым распространением можно использовать и в РНС. В частности, мы можем обучить РНС, модифицировав в лоб градиентный спуск и обратное распространение. Также пригодятся и многие другие идеи, используемые в сетях прямого распространения, от техник регуляризации до свёрток и функций активации и стоимости. Также многие идеи, разработанные нами в рамках книги, можно адаптировать для использования в РНС.
Модули долгой краткосрочной памяти (ДКП)
Одна из проблем РНС в том, что ранние модели было очень сложно обучать, сложнее, чем даже ГНС. Причина содержалась в проблем нестабильного градиента, которую мы обсуждали в главе 5. Вспомним, что обычным проявлением этой проблемы было то, что градиент всё время уменьшается при распространении через слои в обратную сторону. Это чрезвычайно замедляет обучение ранних слоёв. В РНС эта проблема становится ещё хуже, поскольку градиенты распространяются не только в обратную сторону по слоям, но и в обратную сторону по времени. Если сеть работает довольно долго, градиент может стать чрезвычайно нестабильным и на его основе будет очень тяжело обучаться. К счастью, в РНС можно включить идею, известную, как модули
долгой краткосрочной памяти(ДКП). Впервые этим модули представили
Хохрейтер и Шмидгубер в 1997 году, специально для того, чтобы помочь решить проблему нестабильного градиента. ДКП облегчают получение хороших результатов при обучении РНС, и многие недавние работы (включая и те, на которые я уже проставил ссылки) используют ДКП или сходные идеи.
Глубокие сети доверия, генеративные модели и машины Больцмана
В наши дни интерес к глубокому обучению получил второе дыхание в 2006 году, после выхода работ (
1,
2), объяснявших, как обучать особый вид НС под названием глубокая сеть доверия (ГСД). ГСД несколько лет влияли на область исследований, но потом их популярность пошла на спад, а модными стали уже сети прямого распространения и рекуррентные НС. Несмотря на это, некоторые свойства ГСД делают их весьма интересными.
Во-первых, ГСД являются примером генеративной модели. В сети прямого распространения мы задаём входные активации, и они определяют активации нейронов признаков дальше по сети. Генеративную модель можно использовать сходным образом, однако в неё можно задать значения нейронов, а затем запустить сеть «в обратную сторону», генерируя значения входных активаций. Более конкретно, ГСД, обученная на изображениях рукописных цифр, сама может генерировать изображения, похожие на рукописные цифры (потенциально, и после определённых действий). Иначе говоря, ГСД в некотором смысле может учиться писать. В этом смысле генеративные модели похожи на мозг человека: они не только могут читать цифры, но и писать их. Известное высказывание Джеффри Хинтона гласит, что для распознавания форм сначала нужно научиться генерировать изображения.
Во-вторых, они способны на обучение без учителя и почти без учителя. К примеру, при обучении на изображения ГСД могут научиться признакам, полезным для понимания и других изображений, даже если на обучающих изображениях не было никаких меток. Способность к обучению без учителя чрезвычайно интересна как с фундаментальной научной точки зрения, так и с практической – если её можно будет заставить достаточно хорошо работать.
Учитывая все эти привлекательные моменты ГСД как моделей для глубокого обучения, почему же их популярность пошла на спад? Частично из-за того, что другие модели, например, прямого распространения и рекуррентные сети, достигли потрясающих результатов, в частности, прорывов в областях распознавания изображений и речи. Неудивительно, что эти модели удостоились такого внимания, и весьма заслуженного. Однако из этого следует неприятный вывод. Рынок идей часто работает по схеме «победитель получает всё», и практически всё внимание уходит на то, что сейчас в данной области наиболее модно. Людям может оказаться чрезвычайно сложно работать над непопулярными в настоящее время идеями, даже если очевидно, что те могут представлять долгосрочный интерес. Моё личное мнение – ГСД и другие генеративные модели заслуживают большего внимания, чем получают. Не удивлюсь, если ГСД или сходная модель когда-нибудь обгонит сегодняшние популярные модели. Почитайте эту статью для введения в область ГСД. Также может оказаться полезной вот эта статья. Она не совсем про ГСД, но в ней есть много полезного по поводу ограниченных машин Больцмана, ключевого компонента ГСД.
Другие идеи
Что ещё происходит в области НС и ГО? Огромное количество интересной работы. Среди активных областей исследования – использование НС для
обработкиестественного
языка,
машинного перевода, и более неожиданных применений, к примеру,
музыкальной информатики. Существует и множество других областей. Во многих случаях после прочтения данной книги вы сможете понимать недавние работы, хотя, конечно, вам может потребоваться заполнить какие-то пробелы в знаниях.
Закончу этот раздел упоминанием особенно интересной работы. Она комбинирует глубокие свёрточные сети с техникой под названием «обучение с подкреплением», чтобы учиться играть в видеоигры (и ещё одна статья об этом). Идея в том, чтобы использовать свёрточную сеть для упрощения пиксельных данных с игрового экрана, превратить его в более простой набор признаков, которые затем можно использовать для принятия решений о дальнейшем действии: «идти влево», «идти вправо», «стрелять», и т.п. Особенно интересно то, что одна сеть довольно неплохо обучилась играть в семь различных классических видеоигр, опередив экспертов в трёх из них. Это, конечно, похоже на трюк, и работа активно рекламировалась, под заголовком «Игра в игры Atari при помощи обучения с подкреплением». Однако за поверхностным лоском стоит рассмотреть тот факт, что система берёт сырые пиксельные данные – ей даже неизвестны правила игры – и на их основе обучается принимать решения хорошего качества в нескольких очень различных и очень конкурентных ситуациях, в каждой из которых имеется свой сложный набор правил. Довольно неплохо.
Будущее нейросетей
Интерфейсы на основе намерений пользователя
В старой шутке нетерпеливый профессор говорит запутавшемуся студенту: «Не слушайте мои слова, слушайте, что я имею в виду». Исторически компьютеры часто не понимали, подобно запутавшемуся студенту, что имеет в виду пользователь. Однако ситуация меняется. Я всё ещё помню, как впервые удивился, когда я с ошибкой написал запрос в Google, а поисковик сказал мне в ответ «Возможно, вы имели в виду [правильный запрос]?» Директор Google Ларри Пейдж
однажды описалидеальный поисковик, как систему, понимающую, что именно означают ваши запросы, и дающий вам именно то, что вы хотите.
Такова идея интерфейса на основе намерений пользователя. В ней вместо того, чтобы реагировать на буквальные запросы пользователя, поисковик будет использовать МО, чтобы, взяв туманный запрос пользователя, понять точно, что он означает, и действовать на основе этого.
Идею интерфейса на основе намерений пользователя можно применять и более широко, чем просто в поиске. В следующие несколько десятилетий тысячи компаний будут создавать продукты, в которых МО будет использоваться для интерфейсов пользователя, спокойно относящихся к неточным действиям пользователей, и угадывающих их истинные намерения. Мы уже видим ранние примеры подобных интерфейсов на основе намерений: Apple Siri; Wolfram Alpha; IBM Watson; системы, автоматически размечающие фото и видео, и прочее.
Большая часть из них провалится. Разработка интерфейсов – штука сложная, и подозреваю, что вместо вдохновляющих интерфейсов многие компании создадут на основе МО безжизненные интерфейсы. Лучшее МО в мире не поможет вам, если ваш интерфейс – отстой. Однако часть продуктов ждёт успех. Со временем это приведёт к серьёзному изменению наших взаимоотношений с компьютерами. Не так давно, — допустим, ещё в 2005, — пользователи считали само собой разумеющимся, что для взаимодействия с компьютерами требуется высокая точность. Буквальность работы компьютера послужила распространению идеи о том, что компьютеры – очень буквальны; единственная забытая точка с запятой могла совершенно поменять природу взаимодействия с компьютером. Но я полагаю, что в следующие несколько десятилетий мы разработаем несколько успешных интерфейсов на основе намерений пользователя, и это кардинально изменит наши ожидания при работе с компьютерами.
Машинное обучение, наука о данных и непорочный круг инноваций
Конечно, МО используется не только для создания интерфейсов на основе намерений пользователя. Ещё одно интересное применение МО – наука о данных, где оно используется для поиска «известных неизвестных», скрытых в полученных данных. Это уже модная тема, о которой написано много статей, поэтому я не будут долго на неё распространяться. Хочу упомянуть одно последствие этой моды, которое не часто отмечают: в дальней перспективе возможно, что крупнейшим прорывом в МО будет не какой-то один концептуальный прорыв. Крупнейшим прорывом будет то, что исследования в области МО станут приносить доход, посредством применения в науке од данных и других областях. Если компания может инвестировать доллар в исследования МО и получить доллар и десять центов выручки довольно быстро, тогда в область МО будут вливать много денег. Иначе говоря, МО – это двигатель, движущий нас к появлению нескольких крупных рынков и областей роста технологий. В итоге появятся большие команды людей-экспертов в данной области, у которых будет доступ к невероятным ресурсам. Это продвинет МО ещё дальше, создаст ещё больше рынков и возможностей, что и будет непорочным кругом инноваций.
Роль нейросетей и глубокого обучения
Я описывал МО общими словами, как способ создания новых возможностей для развития технологий. Какова же будет конкретная роль НС и ГО во всём этом?
Для ответа на вопрос полезно обратиться к истории. В 1980-х наблюдалось активное радостное оживление и оптимизм, связанный с нейросетями, особенно после популяризации обратного распространения. Но оживление спало, и в 1990-х эстафетную палочку МО передали другим технологиям, к примеру, методу опорных векторов. Сегодня НС снова на коне, устанавливают всяческие рекорды, и обгоняют многих соперников в различных проблемах. Но кто гарантирует, что завтра не будет разработан новый подход, который снова затмит собою НС? Или, возможно, прогресс в области НС начнёт буксовать, и ничто не придёт им на смену?
Поэтому гораздо проще размышлять о будущем МО в целом, чем конкретно о НС. Часть проблемы в том, что мы очень плохо понимаем НС. Почему НС так хорошо умеют обобщать информацию? Каким образом они так хорошо избегают переобучения, учитывая огромное количество параметров? Почему стохастический градиентный спуск так хорошо работает? Насколько хорошо сработают НС при масштабировании наборов данных? К примеру, если мы расширим базу ImageNet в 10 раз, от этого эффективность работы НС улучшится больше или меньше, чем эффективность других технологий МО? Всё это простые, фундаментальные вопросы. И пока что мы очень плохо понимаем ответы на эти вопросы. В связи с этим сложно сказать, какую роль НС сыграют в будущем МО.
Сделаю одно предсказание: думаю, что ГО никуда не денется. Возможность изучать иерархии концепций, строить разные слои абстракций, судя по всему, фундаментальны для познавания мира. Это не значит, что сети ГО завтрашнего дня не будут радикально отличаться от сегодняшних. Мы можем столкнуться с серьёзными изменениями составляющих их частей, архитектур или алгоритмов обучения. Эти изменения могут оказаться достаточно драматичными для того, чтобы мы перестали считать получившиеся системы нейросетями. Однако они всё равно будут заниматься ГО.
Приведут ли НС и ГО в скором времени к появлению искусственного интеллекта?
В данной книге мы концентрировались на использовании НС в решении конкретных задач, например, классификации изображений. Давайте расширим наши запросы: что насчёт думающих компьютеров общего назначения? Могут ли НС и ГО помочь нам решить задачу создания ИИ общего назначения? А если так, учитывая большую скорость прогресса в области ГО, увидим ли мы появление ИИ в ближайшее время?
Для подробного ответа на такой вопрос потребовалась бы отдельная книга. Вместо этого позвольте мне предложить вам одно наблюдение, основанное на законе Конвея:
Организации, проектирующие системы, ограничены дизайном, копирующим структуру коммуникаций в этой организации.
То есть, к примеру, закон Конвея утверждает, что схема самолёта Boeing 747 будет отражать расширенную структуру компании Boeing и её подрядчиков в то время, когда разрабатывалась модель 747. Или другой, простой и конкретный пример: рассмотрим компанию, разрабатывающую сложное ПО. Если управляющая панель ПО должна быть связана с алгоритмом МО, то разработчик панели должен общаться с экспертом компании по МО. Закон Конвея просто формализует это наблюдение.
Впервые услышав закон Конвея, многие люди говорят либо «Ну разве это не банальная очевидность?», либо «Разве это так?». Начну с замечания о его неверности. Давайте подумаем: как наличие у компании Boeing бухгалтерии отражается в схеме модели 747? Что насчёт департамента уборки? А кормления сотрудников? Ответ состоит в том, что эти части организации, скорее всего, не появляются нигде в схеме 747-го явным образом. Поэтому нужно понимать, что закон Конвея относится лишь к тем частям организации, которые непосредственно заняты проектированием и инженерной разработкой.
Что насчёт замечания о банальности и очевидности? Возможно, это и так, но я так не считаю, поскольку организации часто работают, отвергая закон Конвея. Команды, разрабатывающие новые продукты, часто раздуваются из-за чрезмерного количества сотрудников, или, наоборот, им не хватает человека с критически важными знаниями. Вспомните обо всех продуктах с бесполезными и усложняющими их особенностями. Или вспомните о продуктах с очевидными недостатками – к примеру, с ужасным интерфейсом пользователя. В обоих классах программ проблемы часто возникают из-за несоответствия команды, необходимой для выпуска хорошего продукта, и той командой, которая реально собралась. Закон Конвея, возможно, и очевиден, но это не значит, что люди не могут его регулярно игнорировать.
Закон Конвея применим к разработке и созданию систем в случаях, когда мы с самого начала представляем себе, из каких составных частей будет состоять продукт, и как их сделать. Его нельзя применять напрямую к разработке ИИ, поскольку ИИ такой задачей (пока) не является: мы не знаем, из каких частей он состоит. Мы даже не уверены, какие базовые вопросы можно задавать. Иначе говоря, в данный момент ИИ является больше проблемой науки, чем инженеров. Представьте, что вам нужно начать разработку 747-го, ничего не зная о реактивных двигателях или принципах аэродинамики. Вы бы не знали, каких экспертов надо нанимать в свою организацию. Как написал Вернер фон Браун, «базовые исследования – это то, чем я занят, когда я не знаю, чем я занят». Есть ли вариант закона Конвея, применимый к задачам, которые больше относятся к науке, чем к инженерам?
Чтобы найти ответ на этот вопрос, вспомним историю медицины. В ранние дни медицина была областью практиков, таких, как Гален или Гиппократ, изучавших всё тело человека. Но с ростом объёма наших знаний приходилось специализироваться. Мы открыли множество глубоких идей – вспомним микробную теорию болезней, или понимание принципа работы антител, или того, что сердце, лёгкие, вены и артерии формируют сердечно-сосудистую систему. Такие глубокие идеи сформировали фундамент для более узких дисциплин, таких, как эпидемиология, иммунология, и скопление пересекающихся областей, касающихся сердечно-сосудистой системы. Вот так структура нашего знания сформировала социальную структуры медицины. Особенно заметно это в случае с иммунологией: идея о существовании иммунной системы, достойной отдельного изучения, была весьма нетривиальной. Так что у нас есть целая область медицины – со специалистами, конференциями, наградами, и так далее – организованная вокруг чего-то не просто невидимого, а, возможно, даже не являющегося чем-то отдельным.
Такое развитие событий часто повторялось во многих установившихся научных дисциплинах: не только в медицине, но и в физике, математике, химии, и других. Области рождаются монолитными, имея в запасе лишь несколько глубоких идей. Первые эксперты способны охватить их все. Но с течением времени монолитность меняется. Мы открываем множество новых глубоких идей, и их становится слишком много для того, чтобы кто-то сумел по-настоящему овладеть ими всеми. В итоге социальная структура области реорганизуется и делится, концентрируясь вокруг этих идей. Вместо монолита у нас возникают поля, делящиеся на поля, делящиеся на поля,- сложная, рекурсивная социальная структура, ссылающаяся сама на себя, чья организация отражает связи между самыми глубокими идеями. Вот так структура наших знаний формирует социальную организацию науки. Однако эта социальная форма в свою очередь ограничивает и помогает определить то, что мы можем обнаружить. Это и есть научный аналог закона Конвея.
Но какое отношение всё это имеет к глубокому обучению или ИИ?
Ну, с ранних дней разработки ИИ идут споры о том, что всё пойдёт либо «не слишком сложно, благодаря имеющемуся у нас сверхоружию», либо «сверхоружия будет недостаточно». Глубокое обучение – последний из примеров сверхоружия, который использовался в виденных мною спорах. В ранних версиях таких споров использовалась логика, или Prolog, или экспертные системы, или какая-то ещё технология, которая тогда была самой мощной. Проблема таких споров в том, что они не дают вам возможности сказать точно, насколько мощным будет любой из кандидатов на сверхоружие. Конечно, мы только что целую главу потратили на рассмотрение свидетельств того, что ГО может решать чрезвычайно сложные задачи. Оно определённо выглядит очень интересно и многообещающе. Но так было и с такими системами, как Prolog, или Eurisko, или с экспертными системами. Поэтому лишь тот факт, что набор идей выглядит многообещающе, ничего особенного не означает. Откуда нам знать, что ГО на самом деле отличается от этих ранних идей? Есть ли способ измерить, насколько мощным и многообещающим является набор идей? Из закона Конвея следует, что в качестве грубой и эвристической метрики мы можем использовать сложность социальной структуры, связанной с этими идеями.
Поэтому у нас возникает два вопроса. Во-первых, насколько мощным является набор идей, связанный с ГО, согласно этой метрике социальной сложности? Во-вторых, насколько мощная теория нам нужна, чтобы создать ИИ общего назначения?
По первому вопросу: когда мы сегодня смотрим на ГО, это поле выглядит интересным и быстро развивающимся, но относительно монолитным. В нём есть несколько глубоких идей, и проводится несколько основных конференций, причем некоторые из них сильно пересекаются. Работа за работой используют один и тот же набор идей: стохастический градиентный спуск (или его близкий аналог) для оптимизации функции стоимости. Прекрасно, что эти идеи настолько успешны. Что чего мы пока не наблюдаем, так это большого количества хорошо развитых более мелких областей, каждая из которых исследовала бы свой набор глубоких идей, что двигало бы ГО во многих направлениях. Поэтому, согласно метрике социальной сложности, глубокое обучение, простите за каламбур, пока остаётся весьма неглубокой областью исследований. Один человек всё ещё способен овладеть большинством глубоких идей из этой области.
По второму вопросу: насколько сложный и мощный набор идей понадобится для создания ИИ? Естественно, ответом будет: никто точно не знает. Но в послесловии к книге я изучил некоторые из существующих свидетельств по этому вопросу. Я заключил, что даже по оптимистичным оценкам, для создания ИИ потребуется много, очень много глубоких идей. По закону Конвея, для того, чтобы дойти до этой точки, мы должны увидеть появление множества взаимосвязанных дисциплин, со сложной и неожиданной структурой, отражающей структуру наших глубочайших идей. Мы пока не наблюдаем такой сложной социальной структуры при использовании НС и ГО. Поэтому, я считаю, что мы, по крайней мере, находимся в нескольких десятилетиях от использования ГО для разработки ИИ общего назначения.
Я много сил потратил на создание умозрительного аргумента, который, возможно, кажется довольно очевидным, и не ведёт к определённому заключению. Это наверняка разочарует любящих определённость людей. В онлайне я встречаю множество людей, во всеуслышание объявляющих о своих очень определённых и уверенных мнениях по поводу ИИ, часто базирующихся на шатких аргументах и несуществующих свидетельствах. Я могу честно сказать: думаю, что пока ещё судить рано. Как в старом анекдоте: если спросить учёного, сколько нам ещё нужно ждать какого-либо открытия, и он скажет «10 лет» (или больше), то на самом деле он имеет в виду «понятия не имею». До появления ИИ, как и в случае с контролируемым ядерным синтезом и некоторыми другими технологиями, уже более 60 лет остаётся «10 лет». С другой стороны, что у нас точно есть в области ГО – так это эффективная технология, пределы возможностей которой мы пока не обнаружили, и множество открытых фундаментальных задач. И это открывает потрясающие творческие возможности.
Политика конфиденциальности | ОНЛАЙН-ОБУЧЕНИЕ YETI PITURES
Политика конфиденциальности
Настоящая Политика конфиденциальности регулирует порядок сбора, использования, хранения и раскрытия информации, полученной от пользователей (каждый из которых именуется «Студент») Школы. Настоящая Политика конфиденциальности распространяется на Школу и все Курсы, предлагаемые Школой.
Личная идентификационная информация
Мы можем собирать личную идентификационную информацию от Учащихся различными способами, включая, помимо прочего, когда Учащиеся записываются в Школу или на Курс в Школе, подписываются на информационный бюллетень и в связь с другими видами деятельности, услугами, функциями или ресурсами, которые мы предоставляем в нашей Школе. Студенты могут посещать Школу анонимно. Мы будем собирать личную идентификационную информацию от Студентов только в том случае, если они добровольно предоставят нам такую информацию. Учащиеся могут отказаться предоставлять личную идентификационную информацию, но это может помешать им участвовать в определенных мероприятиях, связанных со школой.
Как мы используем собранную информацию
Школа может собирать и использовать личную идентификационную информацию учащихся для следующих целей:
- Для улучшения обслуживания клиентов
Информация, которую вы предоставляете, помогает нам более эффективно реагировать на ваши запросы в службу поддержки и потребности в поддержке. - Для персонализации пользовательского опыта
Мы можем использовать информацию в совокупности, чтобы понять, как наши Учащиеся как группа используют услуги и ресурсы, предоставляемые в нашей Школе. - Для отправки периодических электронных писем
Мы можем использовать адреса электронной почты учащихся для отправки им информации и обновлений, касающихся их заказов. Адреса электронной почты учащихся также могут использоваться для ответов на запросы, вопросы и другие запросы учащихся.
Передача вашей личной информации
Мы не продаем, не обмениваем и не сдаем в аренду личную идентификационную информацию студента другим лицам.
Сторонние веб-сайты
Учащийся может найти рекламу или другой контент в нашей Школе, который ссылается на веб-сайты и услуги наших партнеров, поставщиков, рекламодателей, спонсоров, лицензиаров и других третьих лиц. Мы не контролируем контент или ссылки, которые появляются на этих веб-сайтах, и не несем ответственности за практику, используемую веб-сайтами, на которые есть ссылки на нашу Школу или с нее. Кроме того, эти веб-сайты или службы, включая их содержание и ссылки, могут постоянно меняться.Эти веб-сайты и службы могут иметь свои собственные политики конфиденциальности и политики обслуживания клиентов. Просмотр и взаимодействие на любом другом веб-сайте, включая веб-сайты, на которых есть ссылка на нашего Студента, регулируются собственными условиями и политикой этого веб-сайта.
Изменения в настоящей Политике конфиденциальности
Школа может по своему усмотрению обновлять настоящую Политику конфиденциальности в любое время. Мы призываем студентов часто проверять эту страницу на предмет любых изменений. Вы признаете и соглашаетесь с тем, что вы обязаны периодически просматривать настоящую Политику конфиденциальности и узнавать об изменениях.
Ваше согласие с этими условиями
Регистрируясь в Школе, вы подтверждаете свое согласие с настоящей Политикой конфиденциальности. Если вы не согласны с настоящей Политикой конфиденциальности, не регистрируйтесь в Школе. Ваше дальнейшее зачисление в Школу после публикации изменений в настоящей Политике конфиденциальности будет считаться вашим согласием с этими изменениями.
4. Рекламируйте и продавайте больше онлайн-тренировок с фотографиями и видео • Блог о фитнес-бизнесе
Люди не поймут, насколько это просто, пока вы им не покажете.
Вот как вы можете рекламировать и продавать больше онлайн-обучения с помощью изображений и видео.
В наши дни кажется, что почти все увлечены технологиями. Я понял это, когда даже мои родители начали подписываться на меня в Instagram и присылать твиты вместо того, чтобы звонить мне! Вы думаете, что в «технически подкованном» мире было бы легко продавать онлайн-обучение, потому что, ну, давайте посмотрим правде в глаза — очень редко в течение дня у нас нет смартфона под рукой, верно? Я знаю, что виноват в этом.
А как насчет «технических скептиков»?
А как насчет тех людей, которые, кажется, боятся технологий или почти напуганы идеей онлайн-обучения через приложение или веб-сайт? Звонки по скайпу? Или тренировался у кого-то на другом конце света? Как нам превратить этих людей из испуганных хотя бы в то, чтобы попробовать?
Переманить этих «техноскептиков» с темной стороны — непростая задача, но я скажу вам, что сработало для меня:
1.
Создать видеоВидео должно точно показывать, как выглядит приложение, как оно работает, и примеры того, как будут выглядеть их тренировки, включая ваши видеоролики с тренировками. Посмотрите видео, которое я создал для продвижения моего онлайн-обучения, здесь:
2. Скриншоты приложения
Добавляйте изображения или публикуйте в своих социальных сетях изображения графиков прогресса клиентов (конечно, с их разрешения) или завершенных тренировок и т. д. Это может заинтересовать других ваших подписчиков, потому что в наши дни никто не хочет читать ничего, вы должны быстро привлечь внимание изображениями и короткими подписями .Предоставьте людям ссылки, по которым они могут щелкнуть и прочитать, если они заинтересованы в дополнительной информации.
3. Покажите им лично
Если вы пытаетесь продать свое приложение Trainerize текущим клиентам группового фитнеса, членам тренажерного зала или клиентам персональных тренировок, достаньте свой телефон и покажите им, как именно оно работает.
4. Предложите бесплатную пробную версию!
Предоставьте им доступ на одну неделю и предоставьте им несколько готовых «формальных» тренировок, которые вы уже создали в своем приложении, чтобы дать им представление о том, как это может им помочь.В большинстве случаев, как только они на самом деле используют его, чтобы провести тренировку, им это в конечном итоге нравится.
Предыдущий урок
Бесплатный доступ | Онлайн-обучение по безопасности | Обучение OSHA
Ku-dos : похвала или уважение
Hasina A., МадагаскарНоябрь 2021 г.
«Мне действительно нравится учиться и расширять мой технический словарь в культуре безопасности словесного класса, и я убежден в высокой важности наличия образованного, обученного и эффективного комитета по безопасности, не только для спасения жизней, но и для экономии тысяч долларов руководству.»Дэйв М. , Тринидад и ТобагоАвгуст 2021 г.
«Я новичок в области охраны здоровья и безопасности, и знакомство с этим курсом (Курс 625: Обучение конфиденциальности HIPAA) превысило мои ожидания в первую очередь из-за того, что это имеет прямое отношение к моей текущей работе. Все, что я здесь узнал, было напрямую связано с тем, с чем я сталкиваюсь ежедневно на работе. Этот курс до сих пор «открыт» мой взгляд на совершенно новый «мир» в области здравоохранения и безопасности.»Kenneth Z., United StatesМарт 2021 г.
«Академия OSHA подготовила меня с навыками и знаниями, необходимыми для того, чтобы стать более эффективным в области безопасности. Курсы и программы превосходны и дают всем, кто в них участвует, передовые знания в конкретных областях. области интересов. OSHAcademy, безусловно, лучшая из тех, с которыми мне приходилось сталкиваться, и я горжусь тем, что достиг того, что у меня есть. Спасибо OSHAcademy!»Д. Скот Г., ЯпонияЯнварь 2021
«Я был очень мотивирован пройти ваши курсы, и я благодарен за их доступность. Общий опыт был потрясающим. Структура вашей программы и презентации очень просты для понимания и ориентироваться. Отличные возможности для тренировок».Ричард Д., СШАДекабрь 2020 г.
«Я был вынужден написать вам, чтобы рассказать вам, как мне нравится посещать OSHAcademy. Я получил свой 132-часовой сертификат специалиста по охране труда вместе с некоторыми другими дополнительными сертификатами.я буду очень скоро вернусь в академию для дополнительной подготовки. Я бывший член Вооруженных сил и пожарный в отставке. Я рекомендовал ваш сайт другим, как я, которые знакомы с безопасностью и заинтересованы в повышении квалификации и повышении квалификации. Ваша платформа предлагает отличную информацию без бремени кирпича и раствора и некоторых других трудностей, с которыми мы сталкиваемся, особенно в эти времена. Это простое обучение взрослых по очень важным вопросам, которое разъясняется за пределами практики на рабочем месте.Безопасность – это повседневная тема, которая актуальна в все аспекты жизни, и ваш сайт учит этому».Джоэтта В., СШАСентябрь 2020 г.
«Курс (638 Подготовка рабочих мест к COVID-19) был четко изложен, с большим количеством информации, которая абсолютно помогает студентам как в понимание и применение необходимых действий для борьбы с COVID-19. Экзамен закрепляет шаги, необходимые для эффективной борьбы с пандемией, такой как коронавирус.»David C., United StatesФевраль 2020 г.
«Мне понравилось работать на ваших курсах. Я многому научился на этих курсах, и это отличный способ быть в курсе изменений в требованиях безопасности для каждой области. строительства. Мне очень нравится, что все доступно бесплатно, и это позволяет многим другим получать информацию, необходимую им для безопасного выполнения своей работы. я думаю Было бы здорово, если бы больше агентств, разрабатывающих стандарты, разрешали свободный доступ к информации, а не брали бы целое состояние только за то, чтобы получить информацию.»Festus M., ZambiaЯнварь 2020 г.
«Самое главное, что мне нравится в учебной платформе OSHAcademy, — это ее щедрость с точки зрения предоставления контента, когда можно пройти экзамен бесплатно и использовать его материалы, не платя ни копейки. Это заставляет даже любого «безбилетника» отказаться от самоанализа из-за отсутствия лучшего термина и понять, что это обязанность придавать значение образованию. Я обязательно порекомендую друзьям записаться на программы OSHAcademy, сдать экзамены и получить сертификаты.Стоимость сертификатов настолько низка по сравнению с получаемой от них ценностью/выгодой. На самом деле, вы, ребята, заслуживаете гораздо большего и миллион раз спасибо!»Agidiogun S. , NigeriaФевраль 2019 г.
«Материал, предоставленный OSHAcademy, является бесценным и бесценным материалом, который значительно улучшил мои навыки и знания в области лучших отраслевых практик. Он фокусируется на OSHA. Стандарт, который, конечно, принят большинством нефтегазовой и строительной промышленности, работающих в Нигерии.Я просто хочу сказать спасибо за поддержку и за предоставление такой платформы который обеспечивает обучение, ценность которого намного превышает цену курса. Продолжайте улучшать здоровье и безопасность путем обмена знаниями».Уэсли С., менеджер по охране труда и промышленной безопасности, American Furniture WarehouseДекабрь 2018 г.
«Академия OSHA не только научила меня быть успешным менеджером по охране труда, но и позволила компании, в которой я работаю, получить признание OSHA и опубликовать статья на сайте OSHA о снижении штаммы… Учебные модули актуальны и содержат всю информацию, необходимую для того, чтобы стать профессионалом в области безопасности. Я призываю всех, кто работает в бизнесе, который делает безопасность приоритетом, использовать обучение, которое проводит OSHAcademy… Все сотрудники должны понимать важность безопасности, и OSHAcademy помогает в этом».Брайан В., СШАОктябрь 2018 г.
«Я поражен щедростью OSHAcademy. Я очень ценю возможность учиться в этом учреждении.Я всегда рекомендовал этот тренинг работодателям и сотрудникам, которые хотят построить свои знания. Спасибо за поддержку наших замечательных ветеранов, особенно в эти трудные времена, когда ветеранам нужны замечательные сторонники, такие как OSHAcademy. Я уверен, что ваша щедрость, возможно, была просто перерыв, в котором нуждались некоторые из наших великих ветеранов. Я снова искренне благодарен. Я с нетерпением жду возможности порекомендовать OSHAcademy многим другим будущим специалистам по безопасности».
Джеймс В., США май 2018 г.
«Я бывший менеджер EHS с двадцатилетним стажем. Я не работал в отрасли, восстанавливался, а затем реабилитировался после серьезной травмы. Я выздоровел и готов вернуться в поле. Мое первое собеседование на должность охранника за десять лет состоится завтра. Я провел последние две недели, обновляя свои знания и изучая, что изменилось, принимая несколько ваших курсы и читать многие из ваших материалов, все бесплатно. Ничто из этого не было бы мне по карману, если бы мне пришлось платить, и процесс изучения CFR, чтобы освежить мои знания. у меня бы ушло несколько месяцев.Я вспомню о вашей службе, когда придет время получать сертификат. Я хочу поблагодарить вас за предоставление этой услуги бесплатно. Содействие обучению тех, кто хочет работать безопасно и предотвращать несчастные случаи на рабочем месте, но не может позволить себе платить, — это замечательное усилие, я приветствую вас. Большое тебе спасибо! »
Классификация изображений | Ядро TensorFlow
В этом уроке показано, как классифицировать изображения цветов. Он создает классификатор изображений, используя tf.keras.Sequential
и загружает данные, используя tf.keras.utils.image_dataset_from_directory
. Вы получите практический опыт работы со следующими понятиями:
- Эффективная загрузка набора данных с диска.
- Выявление переобучения и применение методов для его устранения, включая увеличение и отсев данных.
В этом руководстве используется базовый рабочий процесс машинного обучения:
- Изучение и понимание данных
- Построить входной конвейер
- Построить модель
- Обучить модель
- Испытание модели
- Улучшите модель и повторите процесс
Импорт TensorFlow и других библиотек
импортировать matplotlib.pyplot как plt
импортировать numpy как np
импорт ОС
импорт PIL
импортировать тензорный поток как tf
из тензорного потока импортировать керас
из слоев импорта tensorflow.keras
из tensorflow.keras.models импортировать последовательно
Загрузите и изучите набор данных
В этом руководстве используется набор данных из примерно 3700 фотографий цветов. Набор данных содержит пять подкаталогов, по одному на класс:
. цветок_фото/
ромашка /
одуванчик/
розы/
подсолнухи/
тюльпаны/
библиотека пути импорта
dataset_url = "https://хранилище.googleapis.com/download.tensorflow.org/example_images/flower_photos.tgz"
data_dir = tf.keras.utils.get_file('flower_photos', origin=dataset_url, untar=True)
data_dir = pathlib.Path(data_dir)
После загрузки у вас должна быть доступна копия набора данных. Всего 3670 изображений:
image_count = len(list(data_dir.glob('*/*.jpg')))
печать (количество_изображений)
3670
Вот розы:
розы = список(data_dir.шар('розы/*'))
PIL.Image.open (ул (розы [0]))
PIL.Image.open(str(розы[1]))
И несколько тюльпанов:
тюльпаны = список (data_dir.glob ('тюльпаны/*'))
PIL.Image.open (ул (тюльпаны [0]))
PIL.Image.open(str(тюльпаны[1]))
Давайте загрузим эти образы с диска с помощью полезной утилиты tf.keras.utils.image_dataset_from_directory
.Это приведет вас из каталога изображений на диске к tf.data.Dataset
всего за пару строк кода. Если хотите, вы также можете написать собственный код загрузки данных с нуля, посетив руководство Загрузка и предварительная обработка изображений.
Создать набор данных
Определить некоторые параметры для загрузчика:
размер_пакета = 32
img_height = 180
img_width = 180
При разработке модели рекомендуется использовать разделение проверки. Давайте используем 80% изображений для обучения и 20% для проверки.
train_ds = tf.keras.utils.image_dataset_from_directory(
data_dir,
валидация_сплит = 0,2,
подмножество = "обучение",
семя=123,
image_size=(img_height, img_width),
batch_size=размер_пакета)
Найдено 3670 файлов, принадлежащих 5 классам. Использование 2936 файлов для обучения.
val_ds = tf.keras.utils.image_dataset_from_directory(
data_dir,
валидация_сплит = 0,2,
подмножество = "проверка",
семя=123,
image_size=(img_height, img_width),
batch_size=размер_пакета)
Найдено 3670 файлов, принадлежащих 5 классам.Использование файлов 734 для проверки.
Имена классов можно найти в атрибуте class_names
этих наборов данных. Они соответствуют именам каталогов в алфавитном порядке.
class_names = train_ds.class_names
печать (имя_класса)
['ромашка', 'одуванчик', 'розы', 'подсолнухи', 'тюльпаны']
Визуализация данных
Вот первые девять изображений из обучающего набора данных:
импортировать matplotlib.pyplot как plt
plt.figure(figsize=(10, 10))
для изображений метки в train_ds.take(1):
для я в диапазоне (9):
топор = plt.subplot (3, 3, я + 1)
plt.imshow(изображения[i].numpy().astype("uint8"))
plt.title(class_names[метки[i]])
плт.ось("выкл")
Вы обучите модель, используя эти наборы данных, передав их в Model.fit
через мгновение. Если хотите, вы также можете вручную перебирать набор данных и получать пакеты изображений:
для image_batch, labels_batch в train_ds:
печать (изображение_пакет.форма)
печать (labels_batch.shape)
ломать
(32, 180, 180, 3) (32,)
image_batch
представляет собой тензор формы (32, 180, 180, 3)
. Это пакет из 32 изображений формы 180x180x3
(последнее измерение относится к цветовым каналам RGB). label_batch
— это тензор формы (32,)
, это соответствующие метки для 32 изображений.
Вы можете вызвать .numpy()
для тензоров image_batch
и labels_batch
, чтобы преобразовать их в numpy.ндаррай
.
Настройка набора данных для повышения производительности
Обязательно используйте предварительную выборку с буферизацией, чтобы вы могли получать данные с диска, не блокируя ввод-вывод. Вот два важных метода, которые вы должны использовать при загрузке данных:
-
Dataset.cache
сохраняет изображения в памяти после их загрузки с диска в течение первой эпохи. Это гарантирует, что набор данных не станет узким местом при обучении вашей модели. Если ваш набор данных слишком велик, чтобы поместиться в память, вы также можете использовать этот метод для создания производительного кэша на диске. -
Dataset.prefetch
перекрывает предварительную обработку данных и выполнение модели во время обучения.
Заинтересованные читатели могут узнать больше об обоих методах, а также о том, как кэшировать данные на диск, в разделе Prefetching руководства Повышение производительности с помощью API tf.data.
АВТОНАСТРОЙКА = tf.data.АВТОНАСТРОЙКА
train_ds = train_ds.cache().shuffle(1000).prefetch(buffer_size=AUTOTUNE)
val_ds = val_ds.cache().prefetch(buffer_size=AUTOTUNE)
Стандартизировать данные
Значения канала RGB находятся в диапазоне [0, 255]
.Это не идеально для нейронной сети; в общем, вы должны стремиться к тому, чтобы ваши входные значения были небольшими.
Здесь вы будете стандартизировать значения, чтобы они находились в диапазоне [0, 1]
, используя tf.keras.layers.Rescaling
:
normalization_layer = слои. Масштабирование (1./255)
Существует два способа использования этого слоя. Вы можете применить его к набору данных, позвонив по номеру Dataset.map
:
normalized_ds = train_ds.map (лямбда x, y: (normalization_layer (x), y))
image_batch, labels_batch = следующий (iter (normalized_ds))
первое_изображение = пакетное_изображение[0]
# Обратите внимание, что значения пикселей теперь находятся в `[0,1]`.печать (np.min (first_image), np.max (first_image))
0,0 1,0
Или вы можете включить слой в определение вашей модели, что может упростить развертывание. Здесь воспользуемся вторым подходом.
Примечание: Ранее вы изменяли размер изображений, используя аргумент image_size
для tf.keras.utils.image_dataset_from_directory
. Если вы хотите включить логику изменения размера в свою модель, вы можете использовать слой tf.keras.layers.Resizing
. Последовательная модель состоит из трех блоков свертки ( tf.keras.layers.Conv2D
) с максимальным объединяющим слоем ( tf.keras.layers.MaxPooling2D
) в каждом из них. Есть полносвязный слой ( tf.keras.layers.Dense
) со 128 единицами поверх него, который активируется функцией активации ReLU ( 'relu'
). Эта модель не была настроена на высокую точность — цель этого руководства — показать стандартный подход.
num_classes = len(class_names)
модель = последовательный([
слои.Изменение масштаба (1./255, input_shape = (img_height, img_width, 3)),
слои.Conv2D(16, 3, padding='same', активация='relu'),
слои.MaxPooling2D(),
слои.Conv2D(32, 3, padding='same', активация='relu'),
слои.MaxPooling2D(),
слои.Conv2D(64, 3, padding='same', активация='relu'),
слои.MaxPooling2D(),
слои.Свести(),
слои. Плотность (128, активация = 'relu'),
слои.Dense(num_classes)
])
Скомпилируйте модель
Для этого урока выберите tf.keras.оптимизаторы. Оптимизатор Adam
и функция потерь tf.keras.losses.SparseCategoricalCrossentropy
. Чтобы просмотреть точность обучения и проверки для каждой эпохи обучения, передайте аргумент метрики
в Model.compile
.
model.compile(optimizer='адам',
потеря = tf.keras.losses.SparseCategoricalCrossentropy (from_logits = True),
метрики=['точность'])
Обзор модели
Просмотрите все слои сети, используя Модель модели.резюме
метод:
модель.резюме()
Модель&двоеточие; "последовательный" _________________________________________________________________ Слой (тип) Выходная форма Параметр # ================================================== =============== rescaling_1 (Изменение масштаба) (Нет, 180, 180, 3) 0 conv2d (Conv2D) (Нет, 180, 180, 16) 448 max_pooling2d (MaxPooling2D (Нет, 90, 90, 16) 0 ) conv2d_1 (Conv2D) (Нет, 90, 90, 32) 4640 max_pooling2d_1 (MaxPooling (Нет, 45, 45, 32) 0 2D) conv2d_2 (Conv2D) (нет, 45, 45, 64) 18496 max_pooling2d_2 (MaxPooling (Нет, 22, 22, 64) 0 2D) сгладить (сгладить) (нет, 30976) 0 плотный (плотный) (нет, 128) 3965056 плотности_1 (Плотные) (Нет, 5) 645 ================================================== =============== Всего параметров & двоеточие; 3 989 285 Обучаемые параметры & двоеточие; 3 989 285 Необучаемые параметры & двоеточие; 0 _________________________________________________________________
Обучить модель
эпох=10
история = модель.соответствовать(
поезд_дс,
validation_data=val_ds,
эпохи = эпохи
)
Эпоха 1/10 92/92 [===============================] - 3 с 16 мс/шаг - потеря&двоеточие; 1.2769 - точность&двоеточие; 0,4489 - val_loss: 1.0457 - val_accuracy: 0,5804 Эпоха 2/10 92/92 [==============================] - 1 с 11 мс/шаг - потеря&двоеточие; 0,9386 - точность&двоеточие; 0,6328 - val_loss: 0,9665 - val_accuracy: 0,6158 Эпоха 3/10 92/92 [==============================] - 1 с 11 мс/шаг - потеря&двоеточие; 0.7390 - точность&двоеточие; 0.7200 - val_loss: 0,8768 - val_accuracy: 0,6540 Эпоха 4/10 92/92 [==============================] - 1 с 11 мс/шаг - потеря&двоеточие; 0,5649 - точность&двоеточие; 0,7963 - val_loss: 0,9258 - val_accuracy: 0,6540 Эпоха 5/10 92/92 [==============================] - 1 с 11 мс/шаг - потеря&двоеточие; 0,3662 - точность&двоеточие; 0,8733 - val_loss: 1.1734 - val_accuracy: 0,6267 Эпоха 6/10 92/92 [==============================] - 1 с 11 мс/шаг - потеря&двоеточие; 0.2169 - точность и двоеточие; 0.9343 - val_loss: 1.3728 - val_accuracy: 0,6499 Эпоха 7/10 92/92 [==============================] - 1 с 11 мс/шаг - потеря&двоеточие; 0,1191 - точность&двоеточие; 0,9629 - val_loss: 1.3791 - val_accuracy: 0,6471 Эпоха 8/10 92/92 [==============================] - 1 с 11 мс/шаг - потеря&двоеточие; 0,0497 - точность&двоеточие; 0,9871 - val_loss: 1.8002 - val_accuracy: 0,6390 Эпоха 9/10 92/92 [==============================] - 1 с 11 мс/шаг - потеря&двоеточие; 0.0372 - точность&двоеточие; 0,9922 - val_loss: 1.8545 - val_accuracy: 0,6390 Эпоха 10/10 92/92 [==============================] - 1 с 11 мс/шаг - потеря&двоеточие; 0,0715 - точность&двоеточие; 0,9813 - val_loss: 2.0656 - val_accuracy: 0,6049
Визуализация результатов тренировки
Создание графиков потерь и точности на обучающих и проверочных наборах:
акк = история.история['точность']
val_acc = history.history['val_accuracy']
потеря = история.история['потеря']
val_loss = history.history['val_loss']
epochs_range = диапазон (эпохи)
plt.figure(figsize=(8, 8))
plt.subplot(1, 2, 1)
plt.plot(epochs_range, acc, label='Точность обучения')
plt.plot(epochs_range, val_acc, label='Точность проверки')
plt.legend(loc='внизу справа')
plt.title('Точность обучения и проверки')
plt.subplot(1, 2, 2)
plt.plot(epochs_range, loss, label='Потери при обучении')
plt.plot(epochs_range, val_loss, label='Потеря проверки')
plt.legend(loc='вверху справа')
plt.title('Потеря при обучении и проверке')
пл.показывать()
Графики показывают, что точность обучения и точность проверки сильно отличаются друг от друга, и модель достигла только около 60% точности на проверочном наборе.
Давайте проверим, что пошло не так, и попробуем повысить общую производительность модели.
Переоснащение
На приведенных выше графиках точность обучения линейно увеличивается с течением времени, в то время как точность проверки останавливается примерно на 60 % в процессе обучения. Кроме того, заметна разница в точности между точностью обучения и проверкой — признак переобучения.
При небольшом количестве обучающих примеров модель иногда учится на шумах или нежелательных деталях обучающих примеров — до такой степени, что это негативно влияет на производительность модели на новых примерах. Это явление известно как переоснащение. Это означает, что модели будет трудно обобщить новый набор данных.
Есть несколько способов борьбы с перетренированностью в тренировочном процессе. В этом руководстве вы будете использовать дополнение данных и добавить Dropout в свою модель.
Увеличение данных
Переобучение обычно происходит при наличии небольшого количества обучающих примеров. Расширение данных использует подход создания дополнительных обучающих данных из ваших существующих примеров путем их увеличения с использованием случайных преобразований, которые дают правдоподобные изображения. Это помогает представить модель большему количеству аспектов данных и лучше обобщить.
Вы будете реализовывать увеличение данных, используя следующие слои предварительной обработки Keras: tf.keras.layers.RandomFlip
, tf.keras.layers.RandomRotation
и tf.keras.layers.RandomZoom
. Они могут быть включены в вашу модель, как и другие слои, и работать на графическом процессоре.
data_augmentation = keras.Sequential(
[
слои.RandomFlip ("горизонтальный",
input_shape = (img_height,
img_width,
3)),
слои.RandomRotation(0.1),
слои.RandomZoom(0,1),
]
)
Давайте представим, как выглядят несколько дополненных примеров, несколько раз применив дополнение данных к одному и тому же изображению:
пл.фигура (фиг. размер = (10, 10))
для изображений _ в train_ds.take(1):
для я в диапазоне (9):
augmented_images = data_augmentation(изображения)
топор = plt.subplot (3, 3, я + 1)
plt.imshow(дополненные_изображения[0].numpy().astype("uint8"))
плт.ось("выкл")
Скоро вы будете использовать дополнение данных для обучения модели.
Отключение
Еще один способ уменьшить переобучение — ввести в сеть регуляризацию отсева.
Когда вы применяете выпадение к слою, оно случайным образом выбрасывает (путем установки активации на ноль) количество выходных единиц из слоя в процессе обучения.Dropout принимает дробное число в качестве входного значения, например, 0,1, 0,2, 0,4 и т. д. Это означает случайное удаление 10%, 20% или 40% выходных единиц из примененного слоя.
Давайте создадим новую нейронную сеть с tf.keras.layers.Dropout
перед ее обучением с использованием дополненных изображений:
модель = последовательная([
data_augmentation,
слои. Масштабирование (1./255),
слои.Conv2D(16, 3, padding='same', активация='relu'),
слои.MaxPooling2D(),
слои.Conv2D(32, 3, заполнение='такое же', активация='relu'),
слои.MaxPooling2D(),
слои.Conv2D(64, 3, padding='same', активация='relu'),
слои.MaxPooling2D(),
слои. Выпадение (0,2),
слои.Свести(),
слои. Плотность (128, активация = 'relu'),
слои.Dense(num_classes)
])
Скомпилируйте и обучите модель
model.compile(optimizer='адам',
потеря = tf.keras.losses.SparseCategoricalCrossentropy (from_logits = True),
метрики=['точность'])
модель.резюме()
Модель&двоеточие; "последовательный_2" _________________________________________________________________ Слой (тип) Выходная форма Параметр # ================================================== =============== sequence_1 (Последовательно) (Нет, 180, 180, 3) 0 rescaling_2 (Изменение масштаба) (Нет, 180, 180, 3) 0 conv2d_3 (Conv2D) (Нет, 180, 180, 16) 448 max_pooling2d_3 (MaxPooling (Нет, 90, 90, 16) 0 2D) conv2d_4 (Conv2D) (Нет, 90, 90, 32) 4640 max_pooling2d_4 (MaxPooling (Нет, 45, 45, 32) 0 2D) conv2d_5 (Conv2D) (Нет, 45, 45, 64) 18496 max_pooling2d_5 (MaxPooling (Нет, 22, 22, 64) 0 2D) выпадение (выпадение) (нет, 22, 22, 64) 0 flatten_1 (Свести) (Нет, 30976) 0 плотности_2 (Плотные) (Нет, 128) 3965056 плотности_3 (Плотные) (Нет, 5) 645 ================================================== =============== Всего параметров & двоеточие; 3 989 285 Обучаемые параметры & двоеточие; 3 989 285 Необучаемые параметры & двоеточие; 0 _________________________________________________________________
эпох = 15
история = модель.соответствовать(
поезд_дс,
validation_data=val_ds,
эпохи = эпохи
)
Эпоха 1/15 92/92 [===============================] - 2 с 14 мс/шаг - потеря&двоеточие; 1,3840 - точность&двоеточие; 0,3999 - val_loss: 1.0967 - val_accuracy: 0,5518 Эпоха 2/15 92/92 [===============================] - 1 с 12 мс/шаг - потеря&двоеточие; 1.1152 - точность&двоеточие; 0,5395 - val_loss: 1.1123 - val_accuracy: 0,5545 Эпоха 3/15 92/92 [===============================] - 1 с 12 мс/шаг - потеря&двоеточие; 1.0049 - точность&двоеточие; 0,6052 - val_loss: 0,9544 - val_accuracy: 0,6253 Эпоха 4/15 92/92 [===============================] - 1 с 12 мс/шаг - потеря&двоеточие; 0,9452 - точность&двоеточие; 0,6257 - val_loss: 0,9681 - val_accuracy: 0,6213 Эпоха 5/15 92/92 [===============================] - 1 с 12 мс/шаг - потеря&двоеточие; 0,8804 - точность&двоеточие; 0,6591 - val_loss: 0,8450 - val_accuracy: 0,6798 Эпоха 6/15 92/92 [===============================] - 1 с 12 мс/шаг - потеря&двоеточие; 0.8001 - точность&двоеточие; 0,6945 - val_loss: 0,8715 - val_accuracy: 0,6594 Эпоха 7/15 92/92 [===============================] - 1 с 12 мс/шаг - потеря&двоеточие; 0,7736 - точность&двоеточие; 0,6965 - val_loss: 0,8059 - val_accuracy: 0,6935 Эпоха 8/15 92/92 [===============================] - 1 с 12 мс/шаг - потеря&двоеточие; 0,7477 - точность&двоеточие; 0,7078 - val_loss: 0.8292 - val_accuracy: 0,6812 Эпоха 9/15 92/92 [===============================] - 1 с 12 мс/шаг - потеря&двоеточие; 0.7053 - точность&двоеточие; 0,7251 - val_loss: 0,7743 - val_accuracy: 0,6989 Эпоха 10/15 92/92 [===============================] - 1 с 12 мс/шаг - потеря&двоеточие; 0,6884 - точность&двоеточие; 0.7340 - val_loss: 0,7867 - val_accuracy: 0,6907 Эпоха 11/15 92/92 [===============================] - 1 с 12 мс/шаг - потеря&двоеточие; 0,6536 - точность&двоеточие; 0,7469 - val_loss: 0,7732 - val_accuracy: 0,6785 Эпоха 12/15 92/92 [===============================] - 1 с 12 мс/шаг - потеря&двоеточие; 0.6456 - точность&двоеточие; 0.7500 - val_loss: 0.7801 - val_accuracy: 0,6907 Эпоха 13/15 92/92 [===============================] - 1 с 12 мс/шаг - потеря&двоеточие; 0,5941 - точность&двоеточие; 0,7735 - val_loss: 0,7185 - val_accuracy: 0,7330 Эпоха 14/15 92/92 [===============================] - 1 с 12 мс/шаг - потеря&двоеточие; 0,5824 - точность&двоеточие; 0,7735 - val_loss: 0.7282 - val_accuracy: 0,7357 Эпоха 15/15 92/92 [===============================] - 1 с 12 мс/шаг - потеря&двоеточие; 0.5771 - точность&двоеточие; 0,7851 - val_loss: 0.7308 - val_accuracy: 0,7343
Визуализация результатов тренировки
После применения увеличения данных и tf.keras.layers.Dropout
переобучение меньше, чем раньше, а точность обучения и проверки более тесно согласована:
акк = история.история['точность']
val_acc = history.history['val_accuracy']
потеря = история.история['потеря']
val_loss = history.history['val_loss']
epochs_range = диапазон (эпохи)
пл.фигура (фиг. размер = (8, 8))
plt.subplot(1, 2, 1)
plt.plot(epochs_range, acc, label='Точность обучения')
plt.plot(epochs_range, val_acc, label='Точность проверки')
plt.legend(loc='внизу справа')
plt.title('Точность обучения и проверки')
plt.subplot(1, 2, 2)
plt.plot(epochs_range, loss, label='Потери при обучении')
plt.plot(epochs_range, val_loss, label='Потеря проверки')
plt.legend(loc='вверху справа')
plt.title('Потеря при обучении и проверке')
plt.show()
Прогноз по новым данным
Наконец, давайте воспользуемся нашей моделью для классификации изображения, которое не было включено в наборы для обучения или проверки.
Примечание. Слои увеличения и исключения данных неактивны во время вывода. sunflower_url = "https://storage.googleapis.com/download.tensorflow.org/example_images/592px-Red_sunflower.jpg"
sunflower_path = tf.keras.utils.get_file('Red_sunflower', origin=sunflower_url)
img = tf.keras.utils.load_img(
sunflower_path, target_size=(img_height, img_width)
)
img_array = tf.keras.utils.img_to_array(img)
img_array = tf.expand_dims(img_array, 0) # Создать пакет
предсказания = модель.предсказать (img_array)
оценка = tf.nn.softmax (прогнозы [0])
Распечатать(
«Это изображение, скорее всего, принадлежит {} с достоверностью {:.2f} процентов».
.format (class_names [np.argmax (оценка)], 100 * np.max (оценка))
)
Загрузка данных из https://storage.googleapis.com/download.tensorflow.org/example_images/592px-Red_sunflower.jpg 122880/117948 [===============================] - 0s 0us/шаг 131072/117948 [=================================] - 0s 0us/шаг Это изображение, скорее всего, принадлежит подсолнухам с номером 89.13 процентов уверенности.
Интернет-ресурсы для компьютерного обучения
|
- Ratatype Ratatype – это социальный онлайн-тренажер по набору текста, который позволяет пользователям совершенствовать свои навыки набора текста, соревноваться со своими друзьями в скорости и точности набора текста или зарабатывать сертификаты набора текста.
- FreeTypingGame.Net Проверьте свои навыки набора текста.
- Ten Key Test Практикуйте десятиклавишный набор текста (используя цифровую клавиатуру).
- Основы работы с компьютером — начало работы с настольными и портативными компьютерами.
- Интернет 101 – Советы по просмотру и стратегиям поиска в Интернете.
- Интернет-безопасность. Избегайте наиболее распространенных угроз и узнайте, как защитить свои данные и конфиденциальность.
- Электронное письмо 101 – Введение в основы электронной почты, этикет и безопасность.
- Помимо электронной почты – чат, Skype, ведение блога и многое другое.