Как стать автором
Обновить

Бот в Telegram использует IBM Watson для определения котиков

Время на прочтение2 мин
Количество просмотров16K
Привет!

В этой статье я расскажу, как у меня получилось написать бота, использующего всю мощь нейросетей IBM Watson для определения присутствия котиков на картинке.

image


Еще в апреле, узнав про конкурс BotPrize я решил попробовать написать несколько ботов.
Языком программирования я выбрал C# и замечательную библиотеку от MrRoundRobin
В качестве БД использовал PostgreSql.

Мой первый бот был на тему загрузки файлов на известный файлообменник mega.nz.

А вот в качестве следующей темы я выбрал котиков. С помощью бота можно ставить лайк\дизлайк уже имеющимся в базе котикам а также отправлять свои фото котиков на модерацию. Также в Inline режиме можно отправить друзьям самых отлайканных котиков.

И вот, после того, как я реализовал модерацию вручную, я подумал, что это скучно, и можно использовать нейросеть, которая сама будет определять, есть котик на картинке или нет.

После недолгих поисков я узнал, что это умеет делать IBM Watson и его Visual Recognition API.

image

Оказалось все довольно просто — отправляете картинку на обработку и в ответ вам приходит JSON массив того, что IBM Watson нашел на этой картинке.

Пример Json
[
{
«classes»: [
{
«class»: «animal»,
«score»: 0.997762,
«type_hierarchy»: "/animals"
},
{
«class»: «mammal»,
«score»: 0.995504,
«type_hierarchy»: "/animals/mammal"
},
{
«class»: «cat»,
«score»: 0.990987,
«type_hierarchy»: "/animals/pets/cat"
},
{
«class»: «kitten»,
«score»: 0.668188,
«type_hierarchy»: "/animals/pets/kitten"
}
],
«classifier_id»: «default»,
«name»: «default»
}
]

Соответственно, если в JSON есть котик с вероятностью более 0.75 то эта картинка автоматически проходит модерацию. Если нет, то она отправляется в топку на ручную модерацию. Начальное заполнение базы я делал с помощью сайта thecatapi и обработка около 400 котиков заняла не больше 5 минут.

Вы можете сами попробовать отправить IBM Watson разные картинки по ссылке.

Единственная сложность возникла у меня с регистрацией в Bluemix-консоли, она все время зависала.

Получилось зарегистрироваться через сайт developerworks, поставив галочку «I want to use IBM Bluemix».

Далее я получил ключ от Visual Recognition API и потренировался делать запросы в API Explorer

Месяц использования Visual Recognition API дается бесплатно, а дальше включается дневной лимит в 250 картинок в день. Однако, цена оплаты в 2$ за 1000 картинок внушает большой оптимизм.

Мне очень понравилась идея заставить суперкомпьютер Watson определять котиков на картинке вместо меня.

У IBM есть еще большое количество других API и сервисов и тут заложен огромный простор для интеграции с Telegram.
Теги:
Хабы:
Всего голосов 20: ↑14 и ↓6+8
Комментарии8

Публикации

Истории

Ближайшие события

7 – 8 ноября
Конференция byteoilgas_conf 2024
МоскваОнлайн
7 – 8 ноября
Конференция «Матемаркетинг»
МоскваОнлайн
15 – 16 ноября
IT-конференция Merge Skolkovo
Москва
22 – 24 ноября
Хакатон «AgroCode Hack Genetics'24»
Онлайн
28 ноября
Конференция «TechRec: ITHR CAMPUS»
МоскваОнлайн
25 – 26 апреля
IT-конференция Merge Tatarstan 2025
Казань