Машинное обучение - Категории
Машинное обучение подразделяется на следующие категории:
Машинное обучение развивалось слева направо, как показано на диаграмме выше.
Первоначально исследователи начали с контролируемого обучения. Это уже обсуждавшийся ранее случай прогнозирования цен на жилье.
За этим последовало обучение без учителя, когда машина учится сама по себе, без какого-либо контроля.
Ученые далее обнаружили, что может быть хорошей идеей вознаградить машину, если она выполняет свою работу ожидаемым образом, и наступило обучение с подкреплением.
Очень скоро данные, доступные в наши дни, стали настолько огромными, что традиционные методы, разработанные до сих пор, не смогли проанализировать большие данные и дать нам прогнозы.
Таким образом, пришло глубокое обучение, при котором человеческий мозг моделируется в искусственных нейронных сетях (ИНС), созданных в наших двоичных компьютерах.
Теперь машина обучается сама, используя доступную сегодня высокую вычислительную мощность и огромные ресурсы памяти.
Сейчас наблюдается, что глубокое обучение решило многие из ранее неразрешимых проблем.
В настоящее время эта техника получила дальнейшее развитие, благодаря поощрению сетей глубокого обучения в качестве наград, и, наконец, наступило глубокое обучение с подкреплением.
Давайте теперь изучим каждую из этих категорий более подробно.
Контролируемое обучение
Обучение с учителем аналогично обучению ребенка ходить. Вы будете держать ребенка за руку, показывать ему, как ставить ногу вперед, ходить самостоятельно для демонстрации и так далее, пока ребенок не научится ходить самостоятельно.
Регресс
Точно так же в случае обучения с учителем вы даете компьютеру конкретные известные примеры. Вы говорите, что для данного значения функции x1 на выходе будет y1, для x2 это y2, для x3 это y3 и так далее. На основе этих данных вы позволяете компьютеру вычислить эмпирическую связь между x и y.
Как только машина обучена таким образом с достаточным количеством точек данных, теперь вы должны попросить машину предсказать Y для данного X. Предполагая, что вы знаете реальное значение Y для этого данного X, вы сможете вывести верен ли прогноз машины.
Таким образом, вы проверите, обучилась ли машина, используя известные тестовые данные. Когда вы убедитесь, что машина способна делать прогнозы с желаемым уровнем точности (скажем, от 80 до 90%), вы можете прекратить дальнейшее обучение машины.
Теперь вы можете безопасно использовать машину для прогнозирования неизвестных точек данных или попросить машину предсказать Y для данного X, для которого вы не знаете реальное значение Y. Это обучение проходит в рамках регрессии, о которой мы говорили. ранее.
Классификация
Вы также можете использовать методы машинного обучения для решения задач классификации. В задачах классификации вы классифицируете объекты схожей природы в одну группу. Например, в группе из 100 учеников вы можете сгруппировать их в три группы в зависимости от их роста - короткие, средние и длинные. Измеряя рост каждого ученика, вы поместите его в соответствующую группу.
Теперь, когда приходит новый ученик, вы помещаете его в соответствующую группу, измеряя его рост. Следуя принципам регрессионного обучения, вы научите тренажер классифицировать ученика по его характеристике - росту. Когда машина узнает, как формируются группы, она сможет правильно классифицировать любого неизвестного нового ученика. Еще раз, вы должны использовать тестовые данные, чтобы убедиться, что машина изучила вашу технику классификации, прежде чем запускать разработанную модель в производство.
Обучение с учителем - вот где ИИ действительно начал свой путь. Эта методика успешно применялась в нескольких случаях. Вы использовали эту модель при распознавании рукописного текста на своем компьютере. Для обучения с учителем было разработано несколько алгоритмов. Вы узнаете о них в следующих главах.
Неконтролируемое обучение
При обучении без учителя мы не указываем машине целевую переменную, а спрашиваем машину: «Что вы можете сказать мне о X?». В частности, мы можем задать вопросы, например, учитывая огромный набор данных X: «Какие пять лучших групп мы можем составить из X?» или «Какие функции чаще всего встречаются вместе в X?». Чтобы получить ответы на такие вопросы, вы можете понять, что количество точек данных, которые потребуются машине для вывода стратегии, будет очень большим. В случае обучения с учителем машину можно обучить даже с несколькими тысячами точек данных. Однако в случае обучения без учителя количество точек данных, которые разумно принимаются для обучения, начинается с нескольких миллионов. В наши дни данных, как правило, предостаточно. В идеале данные требуют кураторства. Тем не менее, объем данных, которые постоянно передаются в социальной сети, в большинстве случаев является невыполнимой задачей.
На следующем рисунке показана граница между желтыми и красными точками, определенная с помощью машинного обучения без учителя. Вы можете ясно видеть, что машина сможет определить класс каждой из черных точек с довольно хорошей точностью.
Источник:
https://chrisjmccormick.files.wordpress.com/2013/08/approx_decision_boun dary.png
Обучение без учителя показало большой успех во многих современных приложениях искусственного интеллекта, таких как обнаружение лиц, обнаружение объектов и т. Д.
Обучение с подкреплением
Подумайте о том, чтобы дрессировать собаку, мы дрессируем нашего питомца, чтобы он приносил нам мяч. Кидаем мяч на определенное расстояние и просим собаку вернуть его нам. Каждый раз, когда собака делает это правильно, мы награждаем собаку. Постепенно собака узнает, что правильное выполнение работы дает ей вознаграждение, и тогда собака начинает выполнять ее правильно каждый раз в будущем. Именно это понятие применяется в обучении типа «подкрепление». Изначально эта техника была разработана для игровых автоматов. Машине дан алгоритм анализа всех возможных ходов на каждом этапе игры. Машина может выбрать одно из ходов наугад. Если ход правильный, машина награждается, в противном случае она может быть оштрафована. Постепенно машина начнет различать правильные и неправильные ходы и после нескольких итераций научится решать головоломку с большей точностью. Точность выигрыша в игре повысится, поскольку автомат будет играть все больше и больше игр.
Весь процесс можно изобразить на следующей диаграмме -
Этот метод машинного обучения отличается от контролируемого обучения тем, что вам не нужно предоставлять помеченные пары ввода / вывода. Основное внимание уделяется поиску баланса между изучением новых решений и использованием изученных решений.
Глубокое обучение
Глубокое обучение - это модель, основанная на искусственных нейронных сетях (ИНС), а точнее на сверточных нейронных сетях (CNN). В глубоком обучении используется несколько архитектур, таких как глубокие нейронные сети, сети глубоких убеждений, рекуррентные нейронные сети и сверточные нейронные сети.
Эти сети успешно применяются для решения задач компьютерного зрения, распознавания речи, обработки естественного языка, биоинформатики, дизайна лекарств, анализа медицинских изображений и игр. Есть несколько других областей, в которых активно применяется глубокое обучение. Глубокое обучение требует огромной вычислительной мощности и огромных данных, которые в наши дни обычно легко доступны.
Мы поговорим о глубоком обучении более подробно в следующих главах.
Глубокое обучение с подкреплением
Глубокое обучение с подкреплением (DRL) сочетает в себе методы как глубокого обучения, так и обучения с подкреплением. Алгоритмы обучения с подкреплением, такие как Q-Learning, теперь объединены с глубоким обучением для создания мощной модели DRL. Этот метод имел большой успех в области робототехники, видеоигр, финансов и здравоохранения. Многие ранее не решаемые проблемы теперь решаются созданием моделей ДХО. В этой области ведется множество исследований, которые очень активно проводятся в различных отраслях.
Итак, у вас есть краткое введение в различные модели машинного обучения, теперь давайте немного глубже исследуем различные алгоритмы, доступные в этих моделях.