{
    "version": "https:\/\/jsonfeed.org\/version\/1",
    "title": "Блог Антона Репушко: заметки с тегом анализ данных",
    "_rss_description": "Блог Антона Репушко",
    "_rss_language": "ru",
    "_itunes_email": "",
    "_itunes_categories_xml": "",
    "_itunes_image": "",
    "_itunes_explicit": "",
    "home_page_url": "https:\/\/repushko.com\/tags\/analiz-dannyh\/",
    "feed_url": "https:\/\/repushko.com\/tags\/analiz-dannyh\/json\/",
    "icon": "https:\/\/repushko.com\/user\/userpic@2x.jpg?1608852798",
    "author": {
        "name": "Антон Репушко",
        "url": "https:\/\/repushko.com\/",
        "avatar": "https:\/\/repushko.com\/user\/userpic@2x.jpg?1608852798"
    },
    "items": [
        {
            "id": "49",
            "url": "https:\/\/repushko.com\/all\/openeds2020\/",
            "title": "Дневник соревнования OpenEDS 2020",
            "content_html": "<p>Мы со <a href=\"https:\/\/www.linkedin.com\/in\/sviatoslav-skoblov\">Святославом Скобловым<\/a> 2 месяца решали <a href=\"https:\/\/research.fb.com\/programs\/openeds-2020-challenge\/\">OpenEDS 2020 Challenge<\/a>, где в одном треке заняли первое место, а во втором восьмое. Про второй трек тут не будет, потому что он скучный и не очень интересный. И ещё нас изредка консультировал Вова Михеюшкин по всяким CV-вопросам. Может быть кому-то тоже будет интересно почитать, как проходят соревнования по ML.<\/p>\n<h2>Про соревнование<\/h2>\n<p>На основе <a href=\"https:\/\/arxiv.org\/abs\/2005.03876\">датасета OpenEDS2020<\/a>, собранного <a href=\"https:\/\/research.fb.com\/category\/augmented-reality-virtual-reality\/\">Facebook Reality Labs<\/a>, запустили два трека. Оба связаны с VR\/AR, Oculus и всем таким. Треки шли в рамках <a href=\"https:\/\/openeyes-workshop.github.io\/\">воркшопа к ECCV 2020<\/a>.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/099.png\" width=\"640\" height=\"400\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Один из тысяч кадров<\/div>\n<\/div>\n<p><b>В первом треке<\/b> даны последовательности по 100 (трейн) и 55 (валидация) фотографий глаз с gaze-векторами каждого кадра. Представьте, что вы умеет стрелять лазерами из глаз. Вот отнормированный вектор из вашего зрачка до объекта на VR\/AR экране и есть gaze-vector.<br \/>\nЧастота записи последовательности — 100Гц. В тесте были те же последовательности по 50 кадров, но уже без настоящих векторов. Общая задача — научиться предсказывать по 50 кадрам последовательности в тесте следующие 5 кадров (т.e. 50мс). Нужно это для <a href=\"https:\/\/en.wikipedia.org\/wiki\/Foveated_rendering\">foveated rendering<\/a>.<\/p>\n<p><b>Во втором треке<\/b> нужно было сегментировать части глаза (бэкграунд, склеру, радужку и зрачок) по кривой разметке 5% данных в каждой последовательности из 200 кадров. Многие (по отзывам других участников) боролись именно с кривой разметкой, мы же начали решать второй трек за 2 недели до конца и не слишком преуспели, хотя разрыв между топом очень маленький. Важнее и интереснее для нас был именно первый трек.<\/p>\n<h2>Технические особенности<\/h2>\n<p>Соревнование проводилось на платформе <a href=\"https:\/\/evalai.cloudcv.org\/\">EvalAI<\/a>. Там можно скрывать свои сабмиты, но перед этим на какую-то долю секунды они попадают на общую таблицу. Поэтому было решено написать своего бота, который бы мониторил изменения лидерборда, генерировал красивые картинки и присылал их в наш общий диалог. С помощью него мы могли трекать и отслеживать настоящих лидеров, а не те результаты, которые были показаны вручную.<br \/>\nБыл только 1 сабмит в день, каждую ночь предыдущая возможность сабмита сгорала.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/lb.jpg\" width=\"1280\" height=\"897\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Команда BTSD скрыла свой сабмит<\/div>\n<\/div>\n<p>Своего железа у нас было не очень много, поэтому мы время от времени арендовали машины на <a href=\"https:\/\/vast.ai\/\">vast.ai<\/a>. Потратили на это около 230 долларов за 2 месяца соревнования.<\/p>\n<h2>Дневник<\/h2>\n<p><i>1 июня<\/i><br \/>\nСоздан чат в Телеграме, начали разбираться в предметной области, с платформой, читать правила. Выяснили, как части глаза называются на английском. Создали репозиторий на Гитхабе и настроили всем доступы.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/eye.jpg\" width=\"500\" height=\"239\" alt=\"\" \/>\n<\/div>\n<p><i>3 июня<\/i><br \/>\nВыкачиваются данные, визуально посмотрели gaze-вектора. Появляется идея классическими CV-методами поисков контуров искать зрачок на изображении и смотреть на изменение его положение внутри склеры. Разбираемся в типах движения глаза (саккады, скольжения, статичное положение и т. д.). Наконец-то понимаем вообще в чём суть трека.<\/p>\n<p><i>4 июня<\/i><br \/>\nНашли <a href=\"https:\/\/pupil-labs.com\/\">pupil-labs<\/a>, с помощью оборудования которых Facebook генерировал свой датасет. Ничего полезного, но очень интересно.<br \/>\nНаучились находить зрачок обычными CV методами. В итоге это потом использовалось только в визуализациях.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/pupil_center.jpg\" width=\"399\" height=\"133\" alt=\"\" \/>\n<\/div>\n<p>Пытались добавить ещё всяких контуров, но ничего не получилось.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/countur_orig.jpg\" width=\"640\" height=\"400\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Оригинальный кадр<\/div>\n<\/div>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/countur.jpg\" width=\"657\" height=\"417\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Посчитанный контур<\/div>\n<\/div>\n<p><b>Важное решение<\/b>: посчитали правильным разделить пайплайн на две части: gaze-estimator (модель, которая по кадру предсказывает его gaze-вектор) и gaze-predictor (модель, которая по истории gaze-векторов предсказывает gaze-вектора следующих 5 кадров).<\/p>\n<p><i>6 июня<\/i><br \/>\nНачали визуализировать вектора, чтобы посмотреть на всю последовательность целиком. Нам нужен gaze-predictor, но насколько сложным он будет? Если в данных в основном статичное положение глаза, то тогда сложная модель тут не нужна (так в итоге и оказалось).<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/static_gaze.jpg\" width=\"518\" height=\"281\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Глаз практически неподвижен<\/div>\n<\/div>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/saccade.jpg\" width=\"423\" height=\"358\" alt=\"\" \/>\n<div class=\"e2-text-caption\">А тут уже двигается<\/div>\n<\/div>\n<p>Где-то тут было решено для обучения эстиматора (модели, которая будет по кадру предсказывать gaze-вектор) использовать <a href=\"https:\/\/habr.com\/ru\/company\/smartengines\/blog\/264677\/\">аугментации<\/a>. Но проблема в том, что при изменении изображения нужно будет менять и изначальный вектор: вращаешь изображение -> вращаешь вектор. Решили патчить <a href=\"https:\/\/github.com\/albumentations-team\/albumentations\">albumentations<\/a>.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/vector_visualize.jpg\" width=\"391\" height=\"251\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Проекция вектора<\/div>\n<\/div>\n<p><i>11 июня<\/i><br \/>\nНачали гонять первые модели, оптимизировать параметры. Стали разбираться с предиктором. Попробовали всякие стандартные штуки для форкаста временных рядов типа <a href=\"https:\/\/facebook.github.io\/prophet\/\">prophet<\/a>, но они предсказуемо не зашли из-за специфики данных: нельзя вытащить сезонность (которой нет), другие фичи вроде дней недели, времени и прочего, что активно эксплуатируется в таких местах.<br \/>\nОбучили первый resnet для эстиматора.<\/p>\n<p><i>12 июня<\/i><br \/>\nСкор первого трека: <b>0.1556<\/b><\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/submit.jpg\" width=\"949\" height=\"355\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Сделали первый сабмит (команда baccaddes)<\/div>\n<\/div>\n<p>Начали глубже разбираться с метрикой и сравнивать предикты модели с реальными данными, чтобы понять, где косяк. Настроили честную локальную валидацию эстиматора.<\/p>\n<p><i>15 июня<\/i><br \/>\nСкор первого трека: <b> 0.0786<\/b><\/p>\n<p>Засабмитили улучшенную модель (VAR поверх хорошего эстиматора).<br \/>\nЭто приблизило нас к остальным на ЛБ.<\/p>\n<p><i>16 июня<\/i><br \/>\nСкор первого трека: <b>0.0747<\/b><\/p>\n<p>Написан и запущен Big Brother — бот, который следит за ЛБ. С этого момента до конца соревнования он работал с одним перебоем на полдня, после без ошибок.<br \/>\nЗасабмитили скользящее среднее по 5 последним кадрам.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/submit_bot.jpg\" width=\"1280\" height=\"708\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Бот отрабатывает как надо<\/div>\n<\/div>\n<p><i>17 июня<\/i><\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/ezgif.com-video-to-gif.gif\" width=\"256\" height=\"160\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Начали смотреть глазами на глаза (это анимация одной последовательности)<\/div>\n<\/div>\n<p>Посмотрели на статические генераторы таких данных (NVGaze и UnityEyes). В итоге для сореванования их так и не использовали.<\/p>\n<p><i>22 июня<\/i><br \/>\nПредикт эстиматора очень грязный: колбасит вектора между кадрами и получается, что между ними как будто бы сильное движение глаза.<\/p>\n<p><i>28 июня<\/i><br \/>\nПодумали, что было бы классно научиться группировать авторов одних и тех же последовательностей (количество участников при сборе датасета на порядки меньше числа последовательностей), чтобы вытаскивать оттуда какие-то фичи специфичные для конкретного участника. Эту идею так и не доделали.<\/p>\n<p>Начали думать про классическое CV снова: хотели вытаскивать крайние точки глаз и прочее.<\/p>\n<p>Обучили LSTM для предиктора. Сработало чуточку хуже средних по 5 кадрам.<\/p>\n<p><i>29 июня<\/i><br \/>\nЗакончили патчить albumentations.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/orig.jpg\" width=\"387\" height=\"251\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Оригинальный кадр<\/div>\n<\/div>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/flipped.jpg\" width=\"385\" height=\"249\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Сработавший Vertical Flip (и пересчитанный вектор)<\/div>\n<\/div>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/shift_scale_rotate.jpg\" width=\"380\" height=\"247\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Живой ShiftScaleRotate<\/div>\n<\/div>\n<p><i>1 июля<\/i><br \/>\nНачали подозревать, что в тесте всё таки в основном статика. И что самый большой буст тут даст улучшение эстиматора, а не предиктора.<\/p>\n<p>Нафигачили для эстиматора аугментаций.<\/p>\n<p><i>4 июля<\/i><br \/>\nСкор первого трека: <b>0.0613<\/b><\/p>\n<p>Стали думать, как сделать интереснее предиктор. Взяли потыкать <a href=\"https:\/\/github.com\/unit8co\/darts\">darts<\/a> — это такой враппер над всякими стандартными моделями для форкаста.<\/p>\n<p>Запустили старый метод среднего по кадрам (или какую-то оч простую эвристику) над данными нового эстиматора. Очень сильно улучшились.<\/p>\n<p><i>5 июля<\/i><br \/>\nСкор первого трека: <b>0.0570<\/b><\/p>\n<p>Выучили пачку effnet’ов (до этого был resnet). Начали дробить на фолды и мешать предикты с разных фолдов.<\/p>\n<p>Сняли тачку на <a href=\"https:\/\/vast.ai\">vast.ai<\/a>.<\/p>\n<p>Посмотрели на тестовые данные на основе более-менее нормальных предиктов эстиматора. Оказалось, что какая-то динамика в последних 10 кадрах последовательности есть всего в 600-700 последовательностях из 6400.<\/p>\n<p>Засабмитил старые методы предикта на среднем фолдов effnet’а. Почти до самого конца это было нашим лучшим результатом и первым местом на ЛБ.<\/p>\n<p><i>9 июля<\/i><br \/>\nОбучили mobnet. Стали экспериментировать с предиктором: ExponentialSmoothing, VAR, ARIMA и т. д.<br \/>\nМетоды ничего не докинули, а некоторые и ухудшили скор относительно просто среднего.<br \/>\nСкор самого предиктора при этом был очень хороший, около 0.000400+ на кадр по их метрике.<\/p>\n<p>Первый раз открыли данные второго трека, порисовали маски.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/mask.jpg\" width=\"1098\" height=\"1034\" alt=\"\" \/>\n<\/div>\n<p><i>10 июля<\/i><br \/>\nЗасабмитили скользящее среднее по 3 кадрам на куче разных фолдов — не сработало.<\/p>\n<p>Постарались достраивать вектора регрессией. Тоже не сработало.<\/p>\n<p><i>11 июля<\/i><br \/>\nНачали играться с фильтрами над сигналом, чтобы сгладить разницу предиктов эстиматора между соседними кадрами. Получалось хорошо, использовали <a href=\"https:\/\/en.wikipedia.org\/wiki\/Savitzky%E2%80%93Golay_filter\">фильтр Савицки-Голая<\/a>. Кажется, что всякие неровности эстиматора очень красиво сглаживаются.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/savgol_2.jpg\" width=\"751\" height=\"558\" alt=\"\" \/>\n<\/div>\n<p><i>12 июля<\/i><br \/>\nРазбирались с предиктором. Выяснили, что наша регрессия багованная и искали ошибку в разнице валидаций друг у друга. Нашли. Смотрели глазами на фильтрованные предикты и думали, что делать дальше.<\/p>\n<p><i>14 июля<\/i><br \/>\nНарисовали красивые картинки градиентов по разным осям между двумя соседними кадрами по предиктам на всём тесте. Выяснили, что у нас действительно всё — статика. Поэтому опять же нет смысла во всяких сложных моделях предиктора.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/gradient_x.jpg\" width=\"664\" height=\"422\" alt=\"\" \/>\n<\/div>\n<p>Выяснили, что локальная метрика эстиматора напрямую коррелирует с результатами на ЛБ и что результат одного хорошего фолда лучше, чем его же со смесью фолдов чуть-чуть хуже. Опять упёрлись в то, что надо дотюнивать эстиматор. Вернулись к resnet’у.<\/p>\n<p><i>14 июля — 23 июля<\/i><br \/>\nСкор первого трека: <b>0.0552<\/b><\/p>\n<p>Разбирались с сегментацией, удивлялись кривой разметке, сложным случая с закрытыми глазами и т. д.<\/p>\n<p>Вытюнили 1 фолд для эстиматора до ошибки 0.000197 (в 3 раза лучше прошлых). В предиктор засунули простую эвристику: если статика, то скользящее среднее по 2 последним кадрам, а если была динамика в последних 5 кадрах, то добавляем градиент дальше до упора (из-за особенностей движения глаза, там бОльшая часть движений — линейная).<\/p>\n<p><i>23 июля — 29 июля<\/i><br \/>\nТюнили и думали над сегментацией. Смотрели на то, как нам применить синтетические данные в сегментаци. Генерировали синтетику.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/unity_eye.jpg\" width=\"1148\" height=\"648\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Типичный несуществующий глаз<\/div>\n<\/div>\n<p>Из интересного: один сабмит пропустили, потому что кое-кто заснул от усталости и не слышал звонков с просьбой прислать данные. Два сабмита в два дня были сделаны за 30 и 20 секунд до сгорания.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/sega.png\" width=\"720\" height=\"720\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Кусочек каких-то сравнений моделей по сегментации<\/div>\n<\/div>\n<p><i>30 июля — 31 июля<\/i><br \/>\nСкор первого трека: <b>0.0537<\/b><\/p>\n<p>Смотрели и думали над всякими сложными случаями в сегментации<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/sega2.jpg\" width=\"1280\" height=\"287\" alt=\"\" \/>\n<\/div>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/sega3.jpg\" width=\"1280\" height=\"277\" alt=\"\" \/>\n<\/div>\n<p>По первому треку доучили остальные бленды эстиматора, сблендили и засабмитили. Так и осталось нашим лучшим результатом.<\/p>\n<p>По сегментации остались на 8ом месте.<\/p>\n<h2>Что хотели попробовать, но не попробовали<\/h2>\n<ul>\n<li>Не использовали никакую синтетику, а скорее всгео надо было бы. Можно и в обоих треках<\/li>\n<li>Надо было учить LSTM на чистых данных (в том числе из теста и из трейна) и сразу на векторах. Наши эвристики в итоге были по каждой оси отдельно<\/li>\n<\/ul>\n",
            "date_published": "2020-08-04T21:38:13+03:00",
            "date_modified": "2020-08-17T15:21:44+03:00",
            "image": "https:\/\/repushko.com\/pictures\/099.png",
            "_date_published_rfc2822": "Tue, 04 Aug 2020 21:38:13 +0300",
            "_rss_guid_is_permalink": "false",
            "_rss_guid": "49",
            "_e2_data": {
                "is_favourite": true,
                "links_required": [],
                "og_images": [
                    "https:\/\/repushko.com\/pictures\/099.png",
                    "https:\/\/repushko.com\/pictures\/lb.jpg",
                    "https:\/\/repushko.com\/pictures\/eye.jpg",
                    "https:\/\/repushko.com\/pictures\/pupil_center.jpg",
                    "https:\/\/repushko.com\/pictures\/countur_orig.jpg",
                    "https:\/\/repushko.com\/pictures\/countur.jpg",
                    "https:\/\/repushko.com\/pictures\/static_gaze.jpg",
                    "https:\/\/repushko.com\/pictures\/saccade.jpg",
                    "https:\/\/repushko.com\/pictures\/vector_visualize.jpg",
                    "https:\/\/repushko.com\/pictures\/submit.jpg",
                    "https:\/\/repushko.com\/pictures\/submit_bot.jpg",
                    "https:\/\/repushko.com\/pictures\/ezgif.com-video-to-gif.gif",
                    "https:\/\/repushko.com\/pictures\/orig.jpg",
                    "https:\/\/repushko.com\/pictures\/flipped.jpg",
                    "https:\/\/repushko.com\/pictures\/shift_scale_rotate.jpg",
                    "https:\/\/repushko.com\/pictures\/mask.jpg",
                    "https:\/\/repushko.com\/pictures\/savgol_2.jpg",
                    "https:\/\/repushko.com\/pictures\/gradient_x.jpg",
                    "https:\/\/repushko.com\/pictures\/unity_eye.jpg",
                    "https:\/\/repushko.com\/pictures\/sega.png",
                    "https:\/\/repushko.com\/pictures\/sega2.jpg",
                    "https:\/\/repushko.com\/pictures\/sega3.jpg"
                ]
            }
        },
        {
            "id": "47",
            "url": "https:\/\/repushko.com\/all\/data-cleaning-stat-gibdd-ru\/",
            "title": "Как работает очистка данных со stat.gibdd.ru",
            "content_html": "<p>Год назад <a href=\"https:\/\/repushko.com\/all\/dtp-stat-helpers\/\">написал скрипты<\/a> для очистки данных статистики ДТП, потому что изначальные данные (именно GPS-координаты) были очень грязными  и их практически нельзя было визуализировать. Сорцы на Гитхабе <a href=\"https:\/\/github.com\/repushko\/dtp_stat_helpers\">имеются<\/a>.<\/p>\n<p>Сейчас скрипты временно неработоспособны, так как Яндексовский геокодер теперь требует ключ для использования API, но скоро я их поправлю.<\/p>\n<p>Я расскажу про красивый и аккуратный способ, как нам точку с неправильными координатами аккуратно подвинуть прямо на улицу, где произошло ДТП.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/graph_explanation.jpg\" width=\"1280\" height=\"960\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Алгоритм очистки данных<\/div>\n<\/div>\n<h2>Описаниме по шагам<\/h2>\n<p>Изначально нам дана синяя точка слева внизу. Это GPS-координаты, которые мы получили из исходных данных. Наша основная зацепка — адрес. Он заполняется вручную и обычно верный.<\/p>\n<p><b>Шаг 1.<\/b> Воспользуемся геокодером. Это такая программа, которая переводит географическое название (город\/село\/улицу + дом) в географические координаты. Я обычно пользуюсь <a href=\"https:\/\/tech.yandex.com\/maps\/geocoder\/\">геокодером Яндекса<\/a>, потому что он точнее для СНГ, но ещё есть <a href=\"https:\/\/nominatim.org\/\">бесплатный от OpenStreetMap<\/a>. Так мы получаем чистую координату дома по адресу (красная точка на рисунке).<\/p>\n<p><b>Шаг 2.<\/b> В OSM хранится граф дорог, при этом они привязаны к географическим координатам (у графа есть точное положение на плоскости). И есть классная особенность: мы можем ввести координаты точки на плоскости и получить кусок графа в радиусе n от этой точки. Общая идея такая:<\/p>\n<ul>\n<li>вводим координаты дома после геокодирования -> получаем круг примерно как на картинке,<\/li>\n<li>выбираем все дороги, попавшие в радиус (можно считать их просто линиями),<\/li>\n<li>строим перпендикуляры из точки до каждой из линий (на рисунке x и y),<\/li>\n<li>выбираем кратчайший (в нашем случае x),<\/li>\n<li>наша красная точка получает новые координаты (уже на ребре графа из OSM) и становится жёлтой точкой,<\/li>\n<li>profit.<\/li>\n<\/ul>\n<p>Так мы кривые координаты ДТП по одному лишь адресу аккуратно перенесли прямо на улицу. Теперь при визуализации всё будет аккуратно и ровно.<\/p>\n",
            "date_published": "2020-06-25T23:15:15+03:00",
            "date_modified": "2020-06-26T09:47:27+03:00",
            "image": "https:\/\/repushko.com\/pictures\/graph_explanation.jpg",
            "_date_published_rfc2822": "Thu, 25 Jun 2020 23:15:15 +0300",
            "_rss_guid_is_permalink": "false",
            "_rss_guid": "47",
            "_e2_data": {
                "is_favourite": false,
                "links_required": [],
                "og_images": [
                    "https:\/\/repushko.com\/pictures\/graph_explanation.jpg"
                ]
            }
        },
        {
            "id": "46",
            "url": "https:\/\/repushko.com\/all\/street-types-tula\/",
            "title": "Типы улиц Тулы",
            "content_html": "<p>Раз уж пошла такая мода (<a href=\"https:\/\/erdavis.com\/2019\/09\/20\/the-beautiful-hidden-logic-of-cities-worldwide\/\">оригинальная идея Эрина Дэвиса<\/a>, <a href=\"https:\/\/t.me\/pathetic_low_freq\/319\">Москва<\/a>, <a href=\"https:\/\/vk.com\/astr.city.data?w=wall-51262629_141\">Астрахань<\/a>), то и я нарисовал карту типов улиц Тулы.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/map.png\" width=\"2560\" height=\"2560\" alt=\"\" \/>\n<\/div>\n<p>Интересно выглядят плотные участки, состоящие только из проездов. Вроде как согласно СНиП (Строительные нормы и правила), к проездам меньше требований по ширине полос, допустимым углам поворота, наибольшему допустимому уклону, ширине пешеходной части.<\/p>\n<p>А ещё в Туле есть особенный тип: «обвод». Он всего один (<a href=\"https:\/\/yandex.ru\/maps\/15\/tula\/search\/%D0%92%D0%BE%D1%81%D1%82%D0%BE%D1%87%D0%BD%D1%8B%D0%B9%20%D0%BE%D0%B1%D0%B2%D0%BE%D0%B4\/?ll=37.662604%2C54.185500&z=14.64\">Восточной обвод<\/a>), но всё таки существует. И целых два проспекта.<\/p>\n",
            "date_published": "2020-06-07T23:54:35+03:00",
            "date_modified": "2020-06-08T17:40:20+03:00",
            "image": "https:\/\/repushko.com\/pictures\/map.png",
            "_date_published_rfc2822": "Sun, 07 Jun 2020 23:54:35 +0300",
            "_rss_guid_is_permalink": "false",
            "_rss_guid": "46",
            "_e2_data": {
                "is_favourite": false,
                "links_required": [],
                "og_images": [
                    "https:\/\/repushko.com\/pictures\/map.png"
                ]
            }
        },
        {
            "id": "44",
            "url": "https:\/\/repushko.com\/all\/dataset-struktury-seti-lightning\/",
            "title": "Датасет структуры сети Lightning",
            "content_html": "<p>Ковыряю в свободное время интересную тему и задачу, которую курирует <a href=\"https:\/\/cs.hse.ru\/en\/lambda\/\">LAMBDA<\/a>.<\/p>\n<h2>Вводная<\/h2>\n<p>Есть сеть <a href=\"https:\/\/lightning.network\/\">Лайтнинг<\/a>, которая является надстройкой над майннетом Биткоина. Придумывалась для более мелких транзакций, которые не позволял делать Биткоин. Например, тебе нужно заплатить за кофе или совершить какую-то маленькую операцию.<\/p>\n<p>Основная терминология:<\/p>\n<ul>\n<li>нода — узел сети. Получатель денег в общем,<\/li>\n<li>канал — ребро сети. Общий кошелёк в майннете Биткоина между двумя нодами.<\/li>\n<\/ul>\n<p>В Лайтнинге интересный механизм поиска пути транзакции. Eсли тебе надо перевести деньги из <i>А<\/i> в <i>С<\/i>, то не обязательно открывать новый общий кошелёк в майннете Биткоина.<\/p>\n<p>Предположим у тебя уже есть канал <i>А<->B<\/i> и есть канал <i>B<->C<\/i>. В таком случае ты можешь сделать перевод <i>A->B->C<\/i>, где <i>B<\/i> за проход транзакции через себя возьмёт какую-то комиссию. А можно перевести и предположим по пути <i>A>D->B->C<\/i>, если такой существует.<\/p>\n<p>Но не всё так просто. Помимо комиссии, на транзакцию накладываются дополнительные условия. У канала есть «ёмкость»: сколько можно переслать денег между двумя нодами без создания нового общего кошелька в майннете. И «ёмкость» <i>А->B<\/i> и <i>B->A<\/i> не одно и то же.<\/p>\n<p>Подробнее и больше можно почитать <a href=\"https:\/\/lightning.network\/\"> в документации<\/a>.<\/p>\n<h2>Цель<\/h2>\n<p>Основная идея ресёча — заменить глупый перебор результатов DFS для проведения транзакции на что-то более умное. Кажется, что это можно сделать, имея статистику «прошедших» транзакций и варианты альтернативных путей. Получиться должно что-то вроде статистического роутинга на основе прошлых транзакций.<br \/>\nДля этого нужно собирать датасет таких транзакций и их альтернатив, но это упирается в некоторые технические сложности и проблемы. Я собственно сейчас пытаюсь их решить, проверяя вообще работоспособность идеи сбора таких данных. Если получится, то будет очень классное и необычное решение.<\/p>\n<h2>Датасет<\/h2>\n<p>До этого этапа хотелось посмотреть (и посмотрели) просто на динамику сети, как она меняется и насколько стабильна. Написал простенький парсер и в итоге получился <a href=\"https:\/\/www.kaggle.com\/grisme\/hourly-snapshots-of-lightning-network\">датасет на 10 Gb<\/a> «слепков» сети: рёбра графа и всякая метаинфа нод (ip-адрес, алиас в сети и гео-координаты).<\/p>\n<p>Парсилось каждый час с 10.12.2019 до 04.03.2020 (84 дня), всего 2022 записи. Каждый результат в отдельном файле со своим временем.<\/p>\n<p>На этом датасете можно построить интересные визуализации динамики графа и прочие клёвые штуки. Почему бы собственно им не поделиться, да?<\/p>\n",
            "date_published": "2020-05-22T02:02:05+03:00",
            "date_modified": "2020-05-22T17:08:05+03:00",
            "_date_published_rfc2822": "Fri, 22 May 2020 02:02:05 +0300",
            "_rss_guid_is_permalink": "false",
            "_rss_guid": "44",
            "_e2_data": {
                "is_favourite": false,
                "links_required": [],
                "og_images": []
            }
        },
        {
            "id": "41",
            "url": "https:\/\/repushko.com\/all\/srednenko-poc\/",
            "title": "«Средненько». Проверка гипотезы",
            "content_html": "<h2>Мотивация<\/h2>\n<p>Я 3-4 года назад услышал про исследование <a href=\"https:\/\/strelka-kb.com\/\">КБ «Стрелка»<\/a>, в котором они скрапили фото из социальных сетей (Инстаграм и ВК) и рисовали хитмапы на картах по ним. Оказывается, это называется <a href=\"https:\/\/strelkamag.com\/ru\/article\/est-takaya-professiya-cifrovoi-antropolog\">цифровой антропологией<\/a>.<\/p>\n<p>Идея кейса, который вдохновил меня, в том, что такое исследование помогло в каком-то там городе РФ выбрать лучшую точку для открытия общественного пространства. Гипотеза такая: если люди где-то делают фото, значит уже проводят там время, а значит там и так всё хорошо с социальной жизнью. В итоге администрации посоветовали открыть новую точку интереса на противоположном конце города от существующей.<\/p>\n<p>Загорелся идеей сделать нечто похожее, но в сферу каких-то постоянных событий идея оставалась идеей без реализации.<\/p>\n<p>Закрывая гештальт (как Инстаграм своё API для доступа к гео-информации о фотографиях в 2016-ом) достиг успеха.<\/p>\n<h2>Реализация<\/h2>\n<p>Т. к. API Инстаграма оказалось закрытым, решил воспользоваться <a href=\"https:\/\/www.flickr.com\/\">Flickr’ом<\/a>.<br \/>\nСуть идеи:<\/p>\n<ul>\n<li>берем 2019ый год,<\/li>\n<li>cкрапим фотографии с Flickr для конкретной локации (т.e. города),<\/li>\n<li>аккуратно накладываем на карту,<\/li>\n<li>видим места, где люди много фотографируют,<\/li>\n<li>делаем какие-то выводы.<\/li>\n<\/ul>\n<p><b>Например<\/b>: люди фотографируют -> там что-то интересное -> логично поселиться во время поездки.<\/p>\n<p><b>Другой например<\/b>: можно увидеть места, которые недостаточно освещены туристически (с точки зрения наличия фотографий) и можно выбрать наоборот район, где живут местные. На примере Берлина эта теория вроде как работает.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/berlin_flickr_project_2019.jpg\" width=\"1280\" height=\"684\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Фотографии в Берлине за 2019ый год<\/div>\n<\/div>\n<p>Найденные подводные камни:<\/p>\n<ul>\n<li>API Flickr’a частично не завелось из python-обертки, которую я нашёл,<\/li>\n<li>фотографий не так много (250к за год), как в Инстаграме. С геопозицией — еще меньше. За 2019ый год только 44к для Берлина,<\/li>\n<li>на карте прямыми линиями из фотографий заметны фотопрогулки, когда один человек шел и фотографировал всё, что видел. Так получается много фотографий одного места, хотя это всего лишь от одного человека. В планах написать кастомную функцию хитмапа, которая бы давала больший вес участкам, где фотографии от разных людей. Так получится сильно честнее.<\/li>\n<\/ul>\n<h2>«Средненько»<\/h2>\n<p>В процессе возникла идея — сопоставить кучу фотографий одной достопримечательности для получения её «усреднённого» вида. Итог получился сильно лучше, чем я ожидал.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/ansgar-scheffold-cyUf9E_mhFc-unsplash.jpg\" width=\"2560\" height=\"1701\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Оригинальные Бранденбургские ворота<\/div>\n<\/div>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/average_brandenburg_gates.jpg\" width=\"1280\" height=\"774\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Усреднённые 55 фотографий Бранденбургских ворот<\/div>\n<\/div>\n<p>Когда-то вероятно продолжу и сделаю для других городов.<\/p>\n",
            "date_published": "2020-04-26T01:05:52+03:00",
            "date_modified": "2020-04-26T01:05:49+03:00",
            "image": "https:\/\/repushko.com\/pictures\/berlin_flickr_project_2019.jpg",
            "_date_published_rfc2822": "Sun, 26 Apr 2020 01:05:52 +0300",
            "_rss_guid_is_permalink": "false",
            "_rss_guid": "41",
            "_e2_data": {
                "is_favourite": true,
                "links_required": [],
                "og_images": [
                    "https:\/\/repushko.com\/pictures\/berlin_flickr_project_2019.jpg",
                    "https:\/\/repushko.com\/pictures\/ansgar-scheffold-cyUf9E_mhFc-unsplash.jpg",
                    "https:\/\/repushko.com\/pictures\/average_brandenburg_gates.jpg"
                ]
            }
        },
        {
            "id": "37",
            "url": "https:\/\/repushko.com\/all\/barkody-seriala-tales-from-the-loop\/",
            "title": "Баркоды сериала «Tales from the Loop»",
            "content_html": "<p>Сделал баркоды, как и с <a href=\"https:\/\/repushko.com\/all\/barkody-seriala-chernobyl\/\">сериалом «Чернобыль»<\/a>. Каждая полоса — средний цвет кадра в этот момент времени.<\/p>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/S1E1.jpg\" width=\"1700\" height=\"400\" alt=\"\" \/>\n<div class=\"e2-text-caption\">«Loop»<\/div>\n<\/div>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/S1E2.jpg\" width=\"1700\" height=\"400\" alt=\"\" \/>\n<div class=\"e2-text-caption\">«Transpose»<\/div>\n<\/div>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/S1E3.jpg\" width=\"1700\" height=\"400\" alt=\"\" \/>\n<div class=\"e2-text-caption\">«Stasis»<\/div>\n<\/div>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/S1E4.jpg\" width=\"1700\" height=\"400\" alt=\"\" \/>\n<div class=\"e2-text-caption\">«Echo Sphere»<\/div>\n<\/div>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/S1E5.jpg\" width=\"1700\" height=\"400\" alt=\"\" \/>\n<div class=\"e2-text-caption\">«Control»<\/div>\n<\/div>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/S1E6.jpg\" width=\"1700\" height=\"400\" alt=\"\" \/>\n<div class=\"e2-text-caption\">«Parallel»<\/div>\n<\/div>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/S1E7.jpg\" width=\"1700\" height=\"400\" alt=\"\" \/>\n<div class=\"e2-text-caption\">«Enemies»<\/div>\n<\/div>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/S1E8.jpg\" width=\"1700\" height=\"400\" alt=\"\" \/>\n<div class=\"e2-text-caption\">«Home»<\/div>\n<\/div>\n",
            "date_published": "2020-04-21T15:24:26+03:00",
            "date_modified": "2020-04-21T18:15:37+03:00",
            "image": "https:\/\/repushko.com\/pictures\/S1E1.jpg",
            "_date_published_rfc2822": "Tue, 21 Apr 2020 15:24:26 +0300",
            "_rss_guid_is_permalink": "false",
            "_rss_guid": "37",
            "_e2_data": {
                "is_favourite": true,
                "links_required": [],
                "og_images": [
                    "https:\/\/repushko.com\/pictures\/S1E1.jpg",
                    "https:\/\/repushko.com\/pictures\/S1E2.jpg",
                    "https:\/\/repushko.com\/pictures\/S1E3.jpg",
                    "https:\/\/repushko.com\/pictures\/S1E4.jpg",
                    "https:\/\/repushko.com\/pictures\/S1E5.jpg",
                    "https:\/\/repushko.com\/pictures\/S1E6.jpg",
                    "https:\/\/repushko.com\/pictures\/S1E7.jpg",
                    "https:\/\/repushko.com\/pictures\/S1E8.jpg"
                ]
            }
        },
        {
            "id": "29",
            "url": "https:\/\/repushko.com\/all\/malenkiy-resech-v-epidemiologii\/",
            "title": "Маленькое исследование в эпидемиологии",
            "content_html": "<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/picture1.jpg\" width=\"1280\" height=\"483\" alt=\"\" \/>\n<\/div>\n<p><a href=\"https:\/\/habr.com\/ru\/company\/ods\/blog\/493200\/\">Написали на Хабре<\/a> вместе с заинтересовавшимися из ODS про модель распространения абстрактного вируса по РФ. Опирались на датасет перевозок за апрель 2019ого, которые дали <a href=\"https:\/\/tutu.ru\">tutu.ru<\/a>. Огромное спасибо Сергею (<a href=\"https:\/\/t.me\/red_spades\">Milfgard<\/a>) за это, без его инициативы ничего бы не было.<\/p>\n<p>Полезное действие — показать, что изоляция и ограничение перемещения действительно помогают снизить темпы распространения.<\/p>\n<p>В статье немножко технических подробностей, но лично мне захотелось теперь лучше разобраться в эпидемиологии и их моделях.<\/p>\n<p>Я тут отвечал за получение полезного и осмысливаемого результата за короткий срок, саму статью и красивые видосы, которые удобнее всего смотреть на скорости 0.25.<\/p>\n<p>На видео симуляция на полгода вперёд. Легенда карты:<\/p>\n<ul>\n<li>размер метки зависит от населения города. Больше населения — больше метка,<\/li>\n<li>цвет метки зависит от числа инфицированных (<span style=\"color:#19994d\">зеленый<\/span> — мало, <span style=\"color:#e12a21\">красный<\/span> — очень много),<\/li>\n<li>если в городе нет инфицированных — он не показывается на карте. Так легко увидеть первые случаи и путь распространения.<\/li>\n<\/ul>\n<div class=\"e2-text-video\">\n<iframe src=\"https:\/\/www.youtube.com\/embed\/nhtFZo2e59k\" frameborder=\"0\" allowfullscreen><\/iframe><div class=\"e2-text-caption\">Полный пассажиропоток, нет никакой изоляции<\/div>\n<\/div>\n<div class=\"e2-text-video\">\n<iframe src=\"https:\/\/www.youtube.com\/embed\/SC7hrwh_nC0\" frameborder=\"0\" allowfullscreen><\/iframe><div class=\"e2-text-caption\">10% от пассажиропотока, есть небольшая социальная изоляция<\/div>\n<\/div>\n",
            "date_published": "2020-03-30T11:31:31+03:00",
            "date_modified": "2020-03-30T03:25:56+03:00",
            "image": "https:\/\/repushko.com\/pictures\/picture1.jpg",
            "_date_published_rfc2822": "Mon, 30 Mar 2020 11:31:31 +0300",
            "_rss_guid_is_permalink": "false",
            "_rss_guid": "29",
            "_e2_data": {
                "is_favourite": true,
                "links_required": [],
                "og_images": [
                    "https:\/\/repushko.com\/pictures\/picture1.jpg"
                ]
            }
        },
        {
            "id": "28",
            "url": "https:\/\/repushko.com\/all\/tesla-i-nn\/",
            "title": "Tesla и нейронные сети",
            "content_html": "<p><a href=\"https:\/\/twitter.com\/elonmusk\/status\/1224182478501482497?s=20\">https:\/\/twitter.com\/elonmusk\/status\/1224182478501482497?s=20<\/a><\/p><p>Илон Маск упомянул, что в Тесле прототипы сеток набрасываются на Python, а реализуются и работают на голом железе или C\/C++. Интересно конечно, у них свой рантайм для них, или какие-то инженеры успешные эксперименты переписывают?<\/p>\n<p>В любом случае мысль, что рантайм NN (обработка запросов и т. д.) должен быть максимально близко к железу очень правильная. Поэтому не люблю упаковывать модели в проде в Flask-контейнеры или какую-то ещё python-обёртку сверху.<\/p>\n<p>Вообще кажется есть тренд на производительный ML (отчасти из-за работы в реальном времени) и на фоне этого TensorRT\/OpenVINO и подобные штуки будут всё популярнее.<\/p>\n<p>Эх, когда-то даже писал шаблон сервиса на Go, чтобы xgboost-модельки гонять.<\/p>\n",
            "date_published": "2020-02-03T20:17:38+03:00",
            "date_modified": "2020-04-01T14:35:24+03:00",
            "_date_published_rfc2822": "Mon, 03 Feb 2020 20:17:38 +0300",
            "_rss_guid_is_permalink": "false",
            "_rss_guid": "28",
            "_e2_data": {
                "is_favourite": false,
                "links_required": [
                    "https:\/\/platform.twitter.com\/widgets.js",
                    "system\/library\/embedded-tweet\/embedded-tweet.js"
                ],
                "og_images": []
            }
        },
        {
            "id": "25",
            "url": "https:\/\/repushko.com\/all\/frames-interpolation-and-ml\/",
            "title": "Интерполяция кадров и ML",
            "content_html": "<p>На выходных потыкал в <a href=\"https:\/\/en.wikipedia.org\/wiki\/Motion_interpolation\">интерполяцию кадров<\/a> с помощью нейронных сетей. Я смотрел на <a href=\"https:\/\/github.com\/sniklaus\/sepconv-slomo\">статью с CVPR 2018<\/a>, но результаты лучше сейчас показывает <a href=\"https:\/\/github.com\/baowenbo\/DAIN\">DAIN с CVPR 2019<\/a>.<\/p>\n<p>В результате получился «Ёжик в тумане» и «Ух ты, говорящая рыба!» в 120 fps, но я не могу никуда их загрузить из-за авторских прав. Хотя бы youtube позволяет показать небольшое демо.<\/p>\n<p>Получаются очень интересные артефакты на кадрах с падением листа дуба.<\/p>\n<div class=\"e2-text-video\">\n<iframe src=\"https:\/\/www.youtube.com\/embed\/S-WotUGnWyw\" frameborder=\"0\" allowfullscreen><\/iframe><\/div>\n",
            "date_published": "2020-02-02T23:14:13+03:00",
            "date_modified": "2020-02-02T23:14:43+03:00",
            "_date_published_rfc2822": "Sun, 02 Feb 2020 23:14:13 +0300",
            "_rss_guid_is_permalink": "false",
            "_rss_guid": "25",
            "_e2_data": {
                "is_favourite": true,
                "links_required": [],
                "og_images": []
            }
        },
        {
            "id": "23",
            "url": "https:\/\/repushko.com\/all\/moscow-lightning\/",
            "title": "Карта всех фонарей Москвы",
            "content_html": "<p>Случайно сделал карту всех фонарей Москвы. Данные стащил с <a href=\"https:\/\/data.mos.ru\/.\">https:\/\/data.mos.ru\/.<\/a><\/p>\n<div class=\"e2-text-picture\">\n<div class=\"fotorama\" data-width=\"1632\" data-ratio=\"1.8093126385809\">\n<img src=\"https:\/\/repushko.com\/pictures\/Screenshot-from-2020-01-29-17-50-18.png\" width=\"1632\" height=\"902\" alt=\"\" \/>\n<img src=\"https:\/\/repushko.com\/pictures\/Screenshot-from-2020-01-29-17-53-47.png\" width=\"1644\" height=\"902\" alt=\"\" \/>\n<\/div>\n<div class=\"e2-text-caption\">Каждая точка — отдельный фонарь<\/div>\n<\/div>\n",
            "date_published": "2020-01-29T19:55:18+03:00",
            "date_modified": "2020-01-29T19:55:16+03:00",
            "image": "https:\/\/repushko.com\/pictures\/Screenshot-from-2020-01-29-17-50-18.png",
            "_date_published_rfc2822": "Wed, 29 Jan 2020 19:55:18 +0300",
            "_rss_guid_is_permalink": "false",
            "_rss_guid": "23",
            "_e2_data": {
                "is_favourite": true,
                "links_required": [
                    "system\/library\/jquery\/jquery.js",
                    "system\/library\/fotorama\/fotorama.css",
                    "system\/library\/fotorama\/fotorama.js"
                ],
                "og_images": [
                    "https:\/\/repushko.com\/pictures\/Screenshot-from-2020-01-29-17-50-18.png",
                    "https:\/\/repushko.com\/pictures\/Screenshot-from-2020-01-29-17-53-47.png"
                ]
            }
        },
        {
            "id": "20",
            "url": "https:\/\/repushko.com\/all\/junction-2019\/",
            "title": "Junction 2019 — русские, русские, русские, VK",
            "content_html": "<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/Screenshot-from-2019-11-17-07-41-05.png\" width=\"732\" height=\"173\" alt=\"\" \/>\n<\/div>\n<p>Был на выходных на Junction-2019 (топовый европейский хакатон в Хельсинки), а это заметка фактами по свежим следам.<\/p>\n<h2>Выжимка<\/h2>\n<p>Русские, русские, автобусы из Питера, иностранцы придумывают, как интегрировать VK с AliExpress 🤯, ещё русские, детская безопасность в интернете, клёвое название нашего проекта, купленные шрифты, Люси в восторге, треки не очень, старость.<\/p>\n<h2>Чуть более развёрнуто<\/h2>\n<p>Похоже Junction окончательно стал главной выездной площадкой для IT-шников в СНГ. Русскоговорящих было по ощущениям больше половины. Приглашения для визы генерил скриптик на сайте, это ли не победа над бюрократией?<\/p>\n<p>Вспомнил, что он же в 2016 был моим первым выездным IT-мероприятием и атмосфера была совсем другой: пиццабургеры, Yousician с укулеле, на которых можно было играть ночью, лазерный луч через всё пространство мероприятия. Тогда это чувствовалось как что-то близкое, организованное такими же как и ты. Сейчас — построенный бизнес, который (видимо успешно) штампует мероприятия для студентов и ищет спонсоров. Ну и призы подросли.<\/p>\n<p>Чувствовалась старость и лень: зачем не спать всю ночь, когда после сна ты сможешь что-то пофиксить за 20 минут? Зачем не спать, когда в понедельник на работу?<\/p>\n<h2>Победители<\/h2>\n<ol start=\"1\">\n<li>Приложение для авторизации детей, которые ещё не умеют читать и писать (а потреблять контент хочется) в соцсетях. Суть в том, что ты придумываешь историю с вымышленными персонажами, и вот эта твоя история и становится паролем.<\/li>\n<li>Симуляция потоков людей на мероприятии. Создали комнатку в игровом движке, наплодили агентов, хакнули A* алгоритм и ПОБЕЖАЛИ ВСЕ НА ВЫХОД ПОЖАРНАЯ ТРЕВОГА УПС, ТЫ СГОРЕЛ И НЕ ДОБЕЖАЛ. Демка выглядела классно.<\/li>\n<li>Оказывается, фины очень много тратят на гэмблинг. Ребята сделали рулетку на телефоне, где проигранные деньги отправляются тебе на банковский счёт и вернутся к тебе только через год.<\/li>\n<\/ol>\n<h2>sad but true<\/h2>\n<p>В итоге мы с Дашей набросали вдвоём маленькое демо приложения для личного контроля финансов, собрав в кучку все лучшие идеи, которые нашлись в других приложениях (типа burnout-char’a для отслеживания твоего ежедневного бюджета). Сервер я уже грохнул, так что есть только скрины. Возможно как-то допилим и сделаем интеграцию со своими банковскими аккаунтами. Оказывается в Европе это сильно проще, чем с российскими банками.<\/p>\n<p>Называется sad but true, потому что в миллениальном настоящем денег у тебя сильно меньше, чем приходит с ЗП на карту: это на квартирку, это на Netflix, а за Spotify кто заплатит, Пушкин? Вот и хочется, чтобы оно там само где-то считалось, списывалось, советовало как сэкономить, а ты повиновался бы бездушным if-else и средним по окнам в временных рядах.<\/p>\n<p>Фронтендик на Svelte оказался удобным. Мне как глупому `if err!= nil ` бэкендеру прям самое то.<\/p>\n<div class=\"e2-text-picture\">\n<div class=\"fotorama\" data-width=\"603\" data-ratio=\"0.64561027837259\">\n<img src=\"https:\/\/repushko.com\/pictures\/Screenshot-from-2019-11-17-07-31-28.png\" width=\"603\" height=\"934\" alt=\"\" \/>\n<img src=\"https:\/\/repushko.com\/pictures\/Screenshot-from-2019-11-17-07-31-41.png\" width=\"869\" height=\"938\" alt=\"\" \/>\n<img src=\"https:\/\/repushko.com\/pictures\/Screenshot-from-2019-11-17-07-31-55.png\" width=\"680\" height=\"923\" alt=\"\" \/>\n<\/div>\n<\/div>\n",
            "date_published": "2019-11-18T16:11:17+03:00",
            "date_modified": "2020-02-03T14:01:50+03:00",
            "image": "https:\/\/repushko.com\/pictures\/Screenshot-from-2019-11-17-07-41-05.png",
            "_date_published_rfc2822": "Mon, 18 Nov 2019 16:11:17 +0300",
            "_rss_guid_is_permalink": "false",
            "_rss_guid": "20",
            "_e2_data": {
                "is_favourite": false,
                "links_required": [
                    "system\/library\/jquery\/jquery.js",
                    "system\/library\/fotorama\/fotorama.css",
                    "system\/library\/fotorama\/fotorama.js"
                ],
                "og_images": [
                    "https:\/\/repushko.com\/pictures\/Screenshot-from-2019-11-17-07-41-05.png",
                    "https:\/\/repushko.com\/pictures\/Screenshot-from-2019-11-17-07-31-28.png",
                    "https:\/\/repushko.com\/pictures\/Screenshot-from-2019-11-17-07-31-41.png",
                    "https:\/\/repushko.com\/pictures\/Screenshot-from-2019-11-17-07-31-55.png"
                ]
            }
        },
        {
            "id": "17",
            "url": "https:\/\/repushko.com\/all\/schastlivy-konec-moyseverozapad-rf\/",
            "title": "Счастливый конец мойсеверозапад.рф",
            "content_html": "<p>Мы в <a href=\"https:\/\/corgilab.ru\">КоргиЛаб<\/a> успешно запустили <a href=\"https:\/\/repushko.com\/all\/moyseverozapad-rf\/\">мойсеверозапад.рф<\/a> 5 месяцев назад и сейчас готовы сообщить о результатах исследований и полученных данных.<\/p>\n<p>Основная цель запуска — помочь магистрантке архитектурного ВУЗа успешно написать и защитить диплом об открытом проектировании в формировании общественных пространств жилого района. Диплом успешно написано и сдан на отлично, время подводить результаты.<\/p>\n<p>Отфильтровав некорректные данные (например больше 5 отметок одного типа с одной анкеты), получили 263 предложения по категориям:<\/p>\n<ul>\n<li>65 «Досуг»,<\/li>\n<li>64 «Спорт»,<\/li>\n<li>44 «События»,<\/li>\n<li>43 «Дети»,<\/li>\n<li>47 собственных идей жителей.<\/li>\n<\/ul>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/Screenshot-2019-07-24-at-02.14.58.png\" width=\"1918\" height=\"1017\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Финальное состояние карты<\/div>\n<\/div>\n<div class=\"e2-text-picture\">\n<img src=\"https:\/\/repushko.com\/pictures\/Screenshot-2019-07-24-at-02.11.53.png\" width=\"661\" height=\"499\" alt=\"\" \/>\n<div class=\"e2-text-caption\">Статистика посещений<\/div>\n<\/div>\n",
            "date_published": "2019-07-24T02:16:34+03:00",
            "date_modified": "2019-07-24T02:16:52+03:00",
            "image": "https:\/\/repushko.com\/pictures\/Screenshot-2019-07-24-at-02.14.58.png",
            "_date_published_rfc2822": "Wed, 24 Jul 2019 02:16:34 +0300",
            "_rss_guid_is_permalink": "false",
            "_rss_guid": "17",
            "_e2_data": {
                "is_favourite": false,
                "links_required": [],
                "og_images": [
                    "https:\/\/repushko.com\/pictures\/Screenshot-2019-07-24-at-02.14.58.png",
                    "https:\/\/repushko.com\/pictures\/Screenshot-2019-07-24-at-02.11.53.png"
                ]
            }
        },
        {
            "id": "12",
            "url": "https:\/\/repushko.com\/all\/santander-2019\/",
            "title": "Santander 2019 на Kaggle: 52 место",
            "content_html": "<p>С коллегами из <a href=\"https:\/\/ods.ai\">ODS<\/a> заняли 52ое место в соревновании на Kaggle среди 8800 команд.<br \/>\nSantander в этот раз молодцы: обошлось почти без ликов.<\/p>\n<p>Данные были странные и несколько тысяч команд застряли на скоре 0.901. В итоге сильно докинула частотность значения признака и хороший тюнинг.<\/p>\n<p>Kaggle = веселье.<\/p>\n",
            "date_published": "2019-04-20T22:47:40+03:00",
            "date_modified": "2019-06-09T01:18:54+03:00",
            "_date_published_rfc2822": "Sat, 20 Apr 2019 22:47:40 +0300",
            "_rss_guid_is_permalink": "false",
            "_rss_guid": "12",
            "_e2_data": {
                "is_favourite": false,
                "links_required": [],
                "og_images": []
            }
        },
        {
            "id": "5",
            "url": "https:\/\/repushko.com\/all\/ml-ss-2019\/",
            "title": "Летние школы по машинному обучению 2019",
            "content_html": "<p>Собрал список летних школ, все проходят в Европе.<\/p>\n<p>Отсортировано по дате начала. None в поле значит, что я не нашел информацию.<\/p>\n<p>В комментарии можно писать о школах, которых нет в списке, или о недочетах.<\/p>\n<div class=\"e2-text-table\">\n<table cellpadding=\"0\" cellspacing=\"0\" border=\"0\">\n<tr>\n<td><b>Название<\/b><\/td>\n<td><b>Место<\/b><\/td>\n<td><b>Даты<\/b><\/td>\n<td><b>Цена<\/b><\/td>\n<td><b>Сроки подачи<\/b><\/td>\n<\/tr>\n<tr>\n<td><a href=\"http:\/\/www.neurodynamic.uottawa.ca\/summer.html\">Summer School of the Centre for Neural Dynamics<\/a><\/td>\n<td>Оттава, Канада<\/td>\n<td>с 26.05 по 07.06<\/td>\n<td>None<\/td>\n<td>конец — 15.02<\/td>\n<\/tr>\n<tr>\n<td><a href=\"https:\/\/nassma.um6p.ma\">NASSMA MLSS<\/a><\/td>\n<td>Бен-Герир, Марокко<\/td>\n<td>с 24.06 по 29.06<\/td>\n<td>None<\/td>\n<td>конец — 15.03<\/td>\n<\/tr>\n<tr>\n<td><a href=\"http:\/\/ciss.deephack.me\">2nd Conversational Intelligence Summer School<\/a><\/td>\n<td>Лоуэл, США<\/td>\n<td>с 24.06 по 29.06<\/td>\n<td>450$ — 900$<\/td>\n<td>конец — 25.03<\/td>\n<\/tr>\n<tr>\n<td><a href=\"http:\/\/2019.dl-lab.eu\">International Summer School on Deep Learning<\/a><\/td>\n<td>Гданьск, Польша<\/td>\n<td>с 1.07 по 5.07<\/td>\n<td>195€ — 245€<\/td>\n<td>конец — 10.03<\/td>\n<\/tr>\n<tr>\n<td><a href=\"https:\/\/sites.google.com\/view\/dlnlp2019\/home\">NLPDL 2019<\/a><\/td>\n<td>Барселона, Испания<\/td>\n<td>с 26.06 по 3.07<\/td>\n<td>None<\/td>\n<td>None<\/td>\n<\/tr>\n<tr>\n<td><a href=\"https:\/\/www.eeml.eu\">Eastern European MLSS<\/a><\/td>\n<td>Бухарест, Румыния<\/td>\n<td>с 1.07 по 6.07<\/td>\n<td>100€ — 300€<\/td>\n<td>конец — 29.03<\/td>\n<\/tr>\n<tr>\n<td><a href=\"https:\/\/indico.cern.ch\/event\/768915\/overview\">The Fifth Machine Learning in High Energy Physics Summer School<\/a><\/td>\n<td>—Гамбург, Германия<\/td>\n<td>c 1.07 по 10.07<\/td>\n<td>300€<\/td>\n<td>конец — 17.03<\/td>\n<\/tr>\n<tr>\n<td><a href=\"https:\/\/rlss.inria.fr\/\">Reinforcement Learning Summer SCOOL<\/a><\/td>\n<td>Лиль, Франция<\/td>\n<td>с 1.07 по 12.07<\/td>\n<td>480€ — 1920€<\/td>\n<td>конец — 15.03<\/td>\n<\/tr>\n<tr>\n<td><a href=\"http:\/\/visum.inesctec.pt\">VISion Understanding and Machine intelligence — VISUM 2019<\/a><\/td>\n<td>Порту, Португалия<\/td>\n<td>с 04.07 по 12.07<\/td>\n<td>100€ — 600€<\/td>\n<td>конец — 22.03<\/td>\n<\/tr>\n<tr>\n<td><a href=\"http:\/\/school-raai.org\">RAAI Summer School<\/a><\/td>\n<td>Москва, Россия<\/td>\n<td>с 4.07 по 7.07<\/td>\n<td>50$<\/td>\n<td>конец — None<\/td>\n<\/tr>\n<tr>\n<td><a href=\"https:\/\/www.fh-ooe.at\/en\/hagenberg-campus\/international\/international-events\/summer-school-2019\/\">The Summer School of Informatics, Communications, and Media<\/a><\/td>\n<td>Хагенберг, Австрия<\/td>\n<td>с 8.07 по 14.07<\/td>\n<td>free — 350€<\/td>\n<td>конец — 30.04<\/td>\n<\/tr>\n<tr>\n<td><a href=\"http:\/\/lxmls.it.pt\/2019\/\">LXMLS<\/a><\/td>\n<td>Лиссабон, Португалия<\/td>\n<td>с 11.07 по 18.07<\/td>\n<td>300€ — 600€<\/td>\n<td>конец — 31.03<\/td>\n<\/tr>\n<tr>\n<td><a href=\"http:\/\/deeplearn2019.irdta.eu\">3rd International Summer School on Deep Learning<\/a><\/td>\n<td>Варшава, Польша<\/td>\n<td>с 22.07 по 26.07<\/td>\n<td>340€ — 520€<\/td>\n<td>конец — 2.03<\/td>\n<\/tr>\n<tr>\n<td><a href=\"https:\/\/dlinnlp.github.io\/index.html\">RANLP’19 Summer School on Deep Learning in Natural Language Processing<\/a><\/td>\n<td>Варна, Болгария<\/td>\n<td>с 29.08 по 30.08<\/td>\n<td>None<\/td>\n<td>None<\/td>\n<\/tr>\n<tr>\n<td><a href=\"http:\/\/deepbayes.ru\/\">Summer school on Deep Learning and Bayesian Methods<\/a><\/td>\n<td>Москва, Россия<\/td>\n<td>с 20.08 по 25.08<\/td>\n<td>1000₽ — 30000₽<\/td>\n<td>конец — 15.04<\/td>\n<\/tr>\n<tr>\n<td><a href=\"https:\/\/mlss-skoltech.github.io\/\">MLSS-Skoltech<\/a><\/td>\n<td>Москва, Россия<\/td>\n<td>с 26.08 по 06.09<\/td>\n<td>None<\/td>\n<td>начало — 4.03, конец — 5.04<\/td>\n<\/tr>\n<\/table>\n<\/div>\n",
            "date_published": "2019-02-22T18:19:07+03:00",
            "date_modified": "2020-04-14T15:15:56+03:00",
            "_date_published_rfc2822": "Fri, 22 Feb 2019 18:19:07 +0300",
            "_rss_guid_is_permalink": "false",
            "_rss_guid": "5",
            "_e2_data": {
                "is_favourite": false,
                "links_required": [],
                "og_images": []
            }
        }
    ],
    "_e2_version": 3565,
    "_e2_ua_string": "E2 (v3565; Aegea)"
}