Connect with us

Статьи

Как Сэм Альтман добивается продуктивности

Колонка основателя Y Combinator о том, что он делает каждый день для достижения большей продуктивности.

Анна Гуляева

Опубликовано

/

     
     

Я думаю, что я продуктивнее среднестатистического человека, и люди часто просят у меня советов по продуктивности. Поэтому я решил записать их в одном месте.

Составной рост часто обсуждают в качестве финансовой концепции, но он работает и для карьеры — настоящее волшебство. Даже небольшой рост продуктивности в течение 50 лет может дать очень много. Поэтому всегда стоит подумать над оптимизацией продуктивности. Если вы будете делать что-то на 10% больше и на 1% лучше каждый день, разница будет огромной.

Над чем вы работаете

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

Самые впечатляющие люди из тех, кого я знаю, имеют свои представления о мире, что довольно редко встречается. Если вы соглашаетесь с любым человеком, с которым говорили, это плохо. Конечно, иногда вы будете неправы, но вам нужно выработать уверенность придерживаться своих принципов. Это позволит вам быть смелее, когда вы будете правы по поводу чего-то важного, чего не видят другие люди.

Я всегда оставляю достаточно свободного времени, чтобы думать, над чем я могу работать. Лучшие способы для меня — это чтение книг, встречи с интересными людьми и прогулки на природе.

Я понял, что не могу быть продуктивным по поводу вещей, которые мне безразличны или которые мне не нравятся. Поэтому я пытаюсь не заниматься ими. Вещи, которые вам не нравятся, — это тяжелый груз для вашего морального состояния. Поэтому вот важный урок по поводу делегирования: помните, что все люди наиболее продуктивны, когда делают то, что им нравится, и поэтому постарайтесь понять, кому что нравится и кто в чем хорош, и делегируйте задачи таким образом.

Если вам на протяжении долгого времени не нравится, что вы делаете, задумайтесь о смене работе. Краткосрочное выгорание случается, но если оно не исчезает, возможно, пришло время делать что-то ещё. Мне очень повезло найти работу, которую я был бы готов и так делать бесплатно, что делает продуктивность очень простой задачей.

Важно понять, что вы можете научиться чему угодно, и вы можете быстро стать лучше. Это кажется невероятным чудом первые несколько раз, но постепенно вы научитесь верить, что вы это можете.

Отличная работа обычно требует работы с коллегами. Пытайтесь находиться около умных, продуктивных и счастливых людей, которые не будут принижать ваши амбиции. Мне нравится быть рядом с людьми, которые подталкивают меня и вдохновляют. Избегайте их противоположностей — их влияние на ваше психическое состояние может быть ужасным.

Вы должны выбрать нужную проблему и заняться работой. Простых путей не так много. Если вам нужно сделать что-то важное, вам придется работать усердно и продуманно. Это верно не для каждой сферы (существуют великие математики, которые не особенно много работают), но для многих.

Приоритеты

У моей системы три главные колонны: “Убедись, что все важное сделано”, “Не трать время на глупые вещи” и “Создавай много списков”.

Я очень советую использовать списки. Я создаю списки того, что я хочу достичь каждый год, каждый месяц и каждый день. Списки помогают сфокусироваться и работать с несколькими задачами, потому что мне не приходится держать многое в своей голове. Если я не настроен на какую-то из задач, я всегда могу найти другое занятие.

Я предпочитаю писать списки на бумаге. Это позволяет мне легко добавлять и убирать задания. Я могу посмотреть в список на встрече и не выглядеть невежливым. Я часто переписываю списки, что дает мне возможность продумать все пункты и добавить или удалить что-либо. Я не занимаюсь категоризацией, максимум — ставлю звездочку около действительно важных задач.

Я пытаюсь расставлять вещи таким способом, что бы они создавали импульс. Чем больше я делаю, тем лучше себя чувствую и тем больше я сделаю. Мне нравится начинать день с чего-то, в чем я могу действительно быстро добиться прогресса. Я непреклонен в завершении своих самых важных проектов, и если я хочу, чтобы что-то произошло, и достаточно усердно работаю над этим, это происходит.

Я стараюсь беспощадно говорить “нет” и делать неважные вещи как можно быстрее. Вероятно, это иногда заходит далеко, например, я почти уверен, что близок к грубости при ответе на письма. Я пытаюсь избегать встреч и конференций, так как это время дорогого стоит. Однако важно оставлять в своем расписании место для того, чтобы иметь возможность встретить разные возможности, идеи и новых людей. Хотя 90% случайных встреч оказываются тратой времени, остальные 10% действительно окупают потраченное время. Мне кажется, что встречи лучше всего назначать или на 15-20 минут, или на 2 часа. Стандартная встреча в один час обычно оказывается тратой большого количества времени.

Разное время дня я использую для разных видов работ. Первые несколько часов утра — это мое самое продуктивное время, поэтому я на них ничего не назначаю. Я пытаюсь проводить встречи около обеда. Когда мое внимание начинает исчезать, я делаю перерыв или меняю вид деятельности.

Я не думаю, что многие люди достаточно ценят свое время. Я удивлен количеством людей, которые зарабатывают 100 долларов в час и все равно тратят пару на то, на чем они сэкономят 20 долларов.

Не попадайте в ловушку продуктивности — это средство, а не цель. Многие люди тратят слишком много времени на оптимизацию своих систем и не думают, работают ли они над нужными проблемами.

Главная цель — оптимизировать ваш год, а не ваш день.

Физические факторы

Вероятнее всего, что оптимально для меня, не будет оптимально для вас. Вам нужно будет экспериментировать, чтобы понять, что лучше работает для вашего тела. Это определенно того стоит — это помогает во всех аспектах жизни, и вы будете чувствовать себя лучше и счастливее. Я экспериментировал на протяжении нескольких лет и сейчас я минимум в 1,5 раза продуктивнее, чем мог бы быть.

Сон для меня — это самый важный физический фактор. Сон помогают улучшить специальные трекеры, и я обнаружил, что продолжаю пользоваться только трекерами вроде Emfit QS+Active. Я сплю в прохладной, темной и тихой комнате на отличном матрасе. Я долго отказывался тратить деньги на хороший матрас, но этот значительно улучшило мой сон. Помогает также не есть за несколько часов до сна, а также отказ от алкоголя.

Я использую Chili Pad для охлаждения комнаты, он работает хорошо, но слишком громко. В путешествии я использую маску для глаз и беруши.

Этот пункт может быть противоречивым, но я принимаю маленькую дозу снотворных или очень небольшую дозу каннабиса, когда не могу уснуть. Я обычно плохо сплю, особенно в путешествиях (а я часто путешествую). У этого есть свои минусы, как и у бессонницы. Если у вас хороший сон, я этого не советую.

По утрам я 10-15 минут использую LED-лампу полного спектра, пока читаю письма. Даже если вы не последуете всем остальным моим советам, то лампу обязательно попробуйте. Мне нравится эта, и её можно брать в поездки.

Спорт — это второй важный фактор. Я пробовал несколько разных программ упражнений, и мне лучше всего подошли тренировки с большими весами три раза в неделю и периодические высокоинтенсивные интервальные тренировки.

Третья сфера — это питание. Я редко завтракаю, поэтому каждый день я голодаю около 15 часов, не считая эспрессо после пробуждения. Я знаю, что это противоречит многим советам, и это не подойдет многим людям, но это работает для меня.

Хуже всего я себя чувствую, когда ем много сахара. Я пытаюсь также избегать пищи, которые раздражают мой желудок или повышают изжогу, например, как очень острая еда. У меня не так много силы воли в отношении сладкого, поэтому я просто не приношу такую еду домой.

Я пью большой шот эспрессо сразу после пробуждения и после ланча, это примерно 200 мг кофеина каждый день. Я пробовал и другие конфигурации, но эта работает лучше всего. Я избегаю других стимуляторов, но если я очень устал, то пью ещё кофе.

Я вегетарианец с детства, поэтому принимаю добавки с B12, омега-3, железом и витамином D-3. Я пришел к этому набору после года ежеквартальных анализов крови, и это работает для меня. Мне также приходится пить протеиновые коктейли, которые я ненавижу, и я бы этого не делал, если бы не был вегетарианцем.

Другие вещи

Вот что мне нравится в рабочем месте: естественный свет, тишина, уверенность в том, что меня не будут прерывать без моего желания в течение длительных промежутков времени, и комфорт. У меня отличный стол с парой 4K-мониторов, но я почти все время провожу на диване с ноутбуком.

Я написал свои программы для раздражающих вещей, которые мне приходится делать регулярно. Я также научился печатать очень быстро и выучил горячие клавиши, которые помогли с потоком задач.

Как у многих людей, у меня бывают периоды, когда у меня нет мотивации что-либо делать. Это всегда происходит в самое неподходящее время. Я не знаю, что с этим делать кроме того, как подождать. Я пытаюсь избегать людей и ситуаций, которые приводят меня в плохое настроение, и это хороший совет вне зависимости от того, волнует вас продуктивность или нет.

Я думаю, что лучше немного перестараться. Обычно я заканчиваю все дела, но если у меня немного больше задач, чем обычно, я становлюсь эффективнее, и это хороший способ избегать отвлекающих факторов. Однако слишком большое количество обязанностей действует разрушающе.

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

И последнее: продуктивность в неверном направлении ничего не стоит. Подумайте, над чем вы будете работать.

 

Комментарии
Если вы нашли опечатку - выделите ее и нажмите Ctrl + Enter! Для связи с нами вы можете использовать info@apptractor.ru.
Advertisement
Click to comment

You must be logged in to post a comment Login

Leave a Reply

Программирование

Все инженеры умеют программировать, но не все программисты могут быть инженерами: в чем отличие?

Никто не может стать инженером за два месяца, за шесть месяцев или за год. Почему не все программисты могут называться инженерами и какими навыками обладают настоящие инженеры-разработчики?

Анна Гуляева

Опубликовано

/

Многим людям не нравится термин “инженер по разработке программного обеспечения” из-за относительного сравнения с инженерным делом. Но эта статья посвящена не термину. Если вам не нравится название, вы можете заменить его на “автор ПО”, “мастер ПО” или даже “художник по ПО”.

Под инженером по разработке я подразумеваю человека, который считает создание качественных программ своей профессией. Человек, который применяет науку и статистику в своей профессии и не смотрит на это как на работу, которая просто приносит деньги.

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

Моя любимая аналогия — любой человек может петь для себя в душе, но на вечеринке вы не будете ставить свои записи. Вы полагаетесь на профессионалов.

Хотите еще бльше аналогий? Конечно:

  • Мы изучаем математику и правописание в школе, но это не делает нас математиками и авторами.
  • Многие могут научиться готовить, но, чтобы накормить много людей, мы зовем повара.
  • Вы не будете звать соседа с инструментами, чтобы построить дом с нуля.

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

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

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

Если человек не понимает проблему, он или она не может создать решение для нее.

Склонность к поиску решений

Инженеры не считают свою деятельность просто написанием программ. Они думают о потребностях и решениях проблем. Это важно, потому что не каждая проблем нуждается в новой программе. Некоторые проблемы можно решить уже существующими программами. Некоторые проблемы можно вообще предотвратить, если действовать заранее. Создание хороших программ часто включает предотвращение будущих проблем.

Сложные проблемы требуют создания нескольких программ. Некоторые проблемы требуют параллельной работы программ, а другие — последовательной. Некоторые проблемы можно решить обучением пользователей.

Перед созданием программы инженер задает вопросы:

  • Какие проблемы я пытаюсь решить?
  • Можно ли сделать для их решения что-то, кроме написания кода?
  • Что я могу сделать, чтобы эти проблемы было проще решить при помощи кода?

Качество кода

Отличные программы понятны, и их можно легко расширить, они отлично работают с другими программами, а поддерживать их не так сложно. Качеством кода нельзя жертвовать, а использовать временные решения из-за дедлайна или эмоций — неприемлемо.

Один из самых важных аспектов разработки ПО — создавать с самого начала системы, которые можно будет расширять. Изменение программ неизбежно. Пользователи начнут требовать новых функций и новых способов применения программ.

Каждый программист (не)счастлив по своему

Сама по себе программа не так полезна. Ценность их функций проявляется, когда разные программы коммуницируют друг с другом, обмениваются данными и совместно работают над представлением данных и интерфейсов пользователям. Об этом нужно помнить при создании программ. Какие сообщения они будут принимать? Какие события будут отслеживаться? Какие сообщения они будут отправлять? Как мы будем проводить аутентификацию и авторизацию коммуникаций?

Другой важный аспект отличных программ — это ясность кода, а не количество тестов или число в отчете по тестовому покрытию. Этот код может прочитать кто-то ещё? Смогу ли я понять этот код через несколько недель?

В программировании существует только две по-настоящему сложных вещи: инвалидация кэша и наименование вещей, — Фил Карлтон

Удобство чтения кода важнее, чем вы думаете. К сожалению, для ясности кода нет хороших метрик. Знание хороших методов может помочь, но часто этого недостаточно. Хорошие инженеры просто учатся этому с опытом. Здесь подходит метафора с писательством: знание большого количества слов не поможет вам писать понятные тексты.

“У меня не было времени на короткое письмо, поэтому я написал длинное”, — Марк Твен

В программах случаются ошибки. Возможность без проблем исправить их — это ключевой атрибут хорошей программы. Ошибки должны сопровождаться понятными сообщениями и храниться в одном месте. Когда появляется отчет о новой ошибке, ответственный за исправление человек должен иметь возможность устранить в ней баги. Он или она должны иметь возможность зайти в систему и прочитать информацию об ошибке в любое время. У них должна быть возможность подтвердить ожидания о любой части системы.

Правильный разработчик

Среда и тестирование

Когда инженеры пишут программы, они должны убедиться, что эти программы будут работать в разных средах, на разных устройствах, в разных часовых поясах. Программы должны работать на экранах разного размера и ориентации. Они должны справляться с ограниченностью памяти или вычислительной мощности.

Программное обеспечение для браузера должно работать во всех популярных браузерах. Программы для компьютеров должны работать для пользователей Mac и Windows. Приложения для работы с данными должны работать, когда подключение слишком медленное или его совсем нет.

Чтобы написать программу, инженеры должны продумать любой возможный сценарий и спланировать тестирование всех этих сценариев. Это начинается со “счастливого пути”, когда ничего неожиданного не происходит, но затем инженеры должны прописать каждую проблему, которая может случиться, и написать для них тесты. Некоторые инженеры начинают с написания тест-кейсов, которые симулируют эти сценарии. Затем они пишут код, который проходит все эти тесты.

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

Стоимость и эффективность

Во многих случаях инженеры могут решить проблемы быстро. Если вы думаете, что найм опытных программистов повысит расходы, подумайте еще раз. Чем больше у программиста опыта, тем быстрее он или она сможет создать надежное решение, которое можно будет поддерживать без особых трудностей. Это означает сокращение расходов в долгосрочной перспективе.

Как найти лучших разработчиков для работы над проектом

Вам также нужно принять во внимание стоимость запуска программы. Каждая программа будет использовать компьютерные ресурсы, которые не бесплатны. Инженеры будут писать эффективные программы, которые не будут тратить компьютерные ресурсы впустую. Например, это кэширование часто используемых данных, но это только одно из тысяч решений, которые могут сделать программу быстрее и эффективнее.

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

Удобство использования

Хорошие программы создаются с учетом пользовательского опыта. Взаимодействие человека и компьютера — это большая тема с многочисленными исследованиями и выводами. Чем чаще будут учитываться эти выводы, тем лучше будут программы.

Вот несколько примеров:

  • При создании форм для ввода данных хорошая программа будет игнорировать прописные или строчные буквы? которые используются для ввода email-адреса. Она также уберет ненужные пробелы. Не нужно мучать пользователя из-за включенного Caps Lock, адрес почты уникален. Если программа принимает новые адреса, она должна сообщать пользователю о проблемах с вводом, например, об отсутствии знака @ или опечатке в gmail.ocm.
  • При перенаправлении пользователя хорошая программа запомнит первоначальное местоположение и перенаправит пользователя туда после завершения задачи. Хорошая программа также запомнит уже введенные данные и взаимодействия, которые нужны будут в следующих шагах. Например, вы ищете авиабилеты на Expedia в качестве гостя. Затем вы решили создать аккаунт. Вся ваша история поиска будет сохранена в новый аккаунт, и вы сможете получить к ней доступ с разных устройств.
  • Хорошая программа создается с учетом пользовательских сценариев. Поставьте себя на место пользователя. Однажды я забронировал билет United и забыл ввести свой номер постоянного пассажира. После получения подтверждения я отправился на сайт United, чтобы добавить номер, и эта задача заняла у меня десять минут. К этой функции не было очевидных путей, поэтому мне пришлось проверить все ссылки, которые могли бы вести к ней. Я уже был на странице с этой функцией, но я не увидел её в первый раз, потому что она была спрятана в большой форме. Мне пришлось найти информацию о пассажире, пролистать около 20 строк в этой форме, ввести номер пассажира и номер телефона, чтобы отправить эту форму. Это пример программы, которая создавалась без учета точки зрения пользователя.

Читабельность и безопасность

Это наиболее важные моменты, которые отличают профессионалов от любителей. Они знают, что ответственны за создание надежных и безопасных решений.

Программа должна быть устойчивой к плохим входным данным, состояниям и взаимодействиям. Этого очень сложно достичь, и поэтому мы слышим о том, что люди погибают из-за ошибок в ПО.

Пользователи будут вводить неверные данные в программу. Некоторые будут делать это специально, чтобы взломать её. Ответственного за недавний скандал с Equifax обвинили в том, что этот человек не сделал свою работу, то есть не создал устойчивую к зловредным входным данным программу.

Безопасность касается не только зловредных данных, но и обычных. Если пользователь забывает пароль, то сколько раз он или она сможет его ввести? Заблокируете ли вы после этого аккаунт? Что если кто-то этого и добивается? Позволите ли вы вводить пароль через незащищенное соединение? Что если попытка логина состоялась из необычного места? Что если логин кажется сгенерированным автоматически?

Что вы сделаете, чтобы защитить пользователей от межсайтового скриптинга и подделки запросов, атаки посредника и простого социального фишинга? Есть ли у вас стратегия на случай DDoS-атаки? Эти вопросы — это только несколько из проблем, к которым вы должны готовиться.

Безопасные программы не хранят чувствительную информацию в форме простого текста, а в виде зашифрованных данных, которые сложно взломать. Это запасная стратегия на случай взлома. В программах будут случаться ошибки, и если вы об этом не знаете или вы не подготовлены, то вас нельзя считать профессионалом.

Дефекты программ невидимы. Наша способность предсказывать и предотвращать известные дефекты ограничена. Поэтому инженеры понимать ценность хороших инструментов, которые могут помочь им писать корректные и безопасные программы.

Инструменты

Несомненно, нам нужны хорошие инструменты. Они многое меняют и часто недооцениваются. Представьте, если бы нам все ещё нужны были FTP для ффайлов! Представьте проблемы с производительностью и устранением багов без Chrome DevTools! Представьте, как неэффективно бы было писать на JavaScript без ESLint и Prettier!

Любой инструмент, который сокращает цикл обратной связи, должен быть ценным дополнением. Аргумент Брета Виктора об изобретении мгновенной визуальной репрезентации того, что мы создаем, открыл мне глаза. Принятие и улучшение инструментов — это единственный способ попасть в это светлое будущее.

Когда я нахожу отличный инструмент, я жалею лишь о том, что не нашел его раньше. Хорошие инструменты помогут вам стать хорошим программистом. Ищите их, используйте их, цените их и улучшайте их.

Выбор языка имеет значение. Типобезопасность имеет значение. Лучшее, что случилось с JavaScript — это TypeScript и Flow. Статический анализ кода важнее, чем вы думаете. Если вы этого не делаете, то ставите себя под удар неизвестных будущих проблем. Не программируйте без системы статической проверки типов. Если в вашем языке этого нет, поменяйте язык или используйте компилятор. Сегодняшние компиляторы могут работать, просто читая комментарии в коде, и это будущее проверки типов для языков, которые не поддерживают её.

Эволюция разработки

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

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

Проблемы эволюционируют, и разработка должна развиваться аналогично. Будущее этой профессии — позволить обычным пользователям использовать свои компьютеры без необходимости учиться пять лет. Дайте пользователям возможность решать простые проблемы простыми инструментами. Инженеры должны создавать хорошие инструменты, решать большие проблемы и пытаться предотвращать неизвестные.

 

Комментарии
Продолжить чтение

Разработка

Что нужно и чего не нужно делать во время Code Review

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

Анна Гуляева

Опубликовано

/

Code Review могут быть спорными. Недавно я впервые выступала на конференции с темой токсичного поведения в культуре просмотра кода. Я готовилась получить большое количество критики, но в итоге тему приняли добротой и поддержкой.

Меня попросили поделиться слайдами, но мне кажется, что сами по себе они не очень полезны, так как им не хватает контекста. Так как они распространились по интернету без этой нужной информации, я решила написать статью, чтобы более полно донести свое выступление.

Я перечислила несколько распространенных шаблонов поведения, которые случаются во время Code Review, а также несколько рекомендаций о том, как команды разработчиков могут создать более благоприятную атмосферу, если не будут делать токсичность нормой. Все описанное происходило со мной или я была этому свидетельницей. Я и сама вела так себя в прошлом.

1. Представление мнения в качестве факта

Не делайте заявлений, пока не сможете процитировать документацию, формальные требования или примеры кода, чтобы подтвердить их. Людям нужно знать, почему их просят внести изменение, и личные предпочтения — это недостаточно хороший аргумент.

Вместо того, чтобы говорить “В этом компоненте не должно быть состояний” предоставьте контекст этих рекомендаций:

“Так как в этом компоненте нет методов или состояний жизненного цикла, его можно сделать функциональным компонентом без состояний. Это улучшит производительность и читабельность. *Вот* документация.”

Это поведение распространено, когда разработчики обсуждают предпочтения в стиле и синтаксисе. Это важные обсуждения, но они не должны происходить во время просмотра кода, так как стиль и синтаксис не относятся к проблеме, которую разработчик изначально планировал решить.

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

Это особенно важно, когда у вас более высокая должность или авторитет в команде. Если вы будете так себя вести, у разработчиков не останется другого выбора, и им придется подстраиваться под ваши требования.

2. Лавина комментариев

Когда человек совершает ошибку, вероятно, он или она сделали ту же ошибку в других местах. Я заметила, что часто те, кто просматривает код, указывают на каждый случай ошибки вместо того, чтобы оставить один детальный комментарий со ссылками на полезные ресурсы.

Объединение комментариев позволит вам донести свое сообщение и не ошеломить человека. Бесполезно и угнетает:

Более полезно:

Я могу понять, что это может быть полезно, так как комментарий исчезает, когда разработчик исправляет ошибку. Но если эта ошибка повторяется, значит, разработчик не знает об определенном правиле, и ему или ей нужно указать на корректные ресурсы.

3. Просить инженеров решить проблемы, которые возникли не из-за них

Не просите разработчиков решать проблемы, которые не относятся к их изменениям или к проблеме, которую они пытаются решить. Даже если разработчик работает с беспорядочной частью кода, не просите его или её исправлять код просто потому, что они работают с ним в данный момент.

Я не говорю, что разработчики не должны чувствовать ответственность за код, который начали писать не они. Я говорю, что более правильным решением будет создать отдельный тикет и решение для беспорядочного кода. Так вы не добавите кому-то работы, и плохой код будет исправлен.

Правила, которые я выработал по результатам тысяч code review

4. Задавать осуждающие вопросы

Не задавайте вопросов вроде: “Почему ты просто не сделаешь это здесь?”. Такие вопросы предполагают, что это очевидное решение. Это также заставляет разработчиков оправдываться.

Эти осуждающие вопросы часто являются замаскированными просьбами. Вместо этого напишите рекомендацию (с цитированием документации) и не используйте грубые слова.

“Ты можешь сделать это, и это будет полезно поэтому.”

5. Сарказм

Сарказм — это неправильное поведение, когда вы даете обратную связь. Саркастические комментарии ничего не объясняют. Вместо этого детально опишите проблему и напишите рекомендации, но оставьте шутки в стороне.

Бесполезно: “Ты вообще тестировал(а) этот код?”

Полезно: “Происходит сбой при вводе отрицательного числа. Можешь, пожалуйста, разобраться с проблемой?”

Вот ещё один пример комментария, который несмешной и бесполезный:

Я не говорю, что мы подлые. Мы просто беспощадные. Ты заметишь, что я оставил комментарий “Бип!” на импорте каждого файла, к которому ты притронулся. Я имел в виду, что твои импорты нарушают нашу стандартную процедуру, но это было слишком долго писать в каждом файле.

Комментарий “Бип!” бесполезен. Это просто педантичный юмор, который не помогает человеку, который писал код.

6. Использование эмодзи, чтобы указать на проблемы

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

Вряд ли вас действительно будет тошнить от ошибок в коде. Вы можете использовать радостные эмодзи, чтобы показать, что код выглядит хорошо, но не используйте их, чтобы указать на проблему.

7. Ответ не на все комментарии

Люди, которые писали код, могут тоже вести себя некорректно. Если вы отправляете код без ответа на все комментарии, люди могут задуматься, зачем они вообще тратили время на помощь вам, а вы покажете, что некоторые мнения важнее других.

Если комментарий относится не к вашей работе или вы не будете действовать в соответствии с обратной связью, просто кратко объясните причины. Не занимайтесь гостингом.

8. Игнорирование токсичного поведения производительных людей

Токсичное поведение не нужно игнорировать только потому, что разработчик отлично работает. Хотя он или она может делать фантастическую работу, важно помнить, что их поведение делает работу других людей сложнее.

О работе с людьми, ведущими себя токсично:

Всем остальным работать с этим человеком будет сложно и неинтересно. Они будут избегать взаимодействия с ними, даже если это негативно повлияет на их способность выполнять задания. Коммуникация в вашей организации нарушится. Если все станет плохо, ваша команда начнет искать возможности в другом месте. Пока вы будете сталкиваться с утечкой людей и неудачными проектами, эти разработчики продолжат работать так, как будто все в порядке. — Джозеф Гефрох.

Бездействие может оказать серьезное влияние на команду, так как разработчики будут чувствовать себя демотивированными. Они начнут бояться процессов фидбэка, которые должны были помогать им расти. Лично я нервничаю каждый раз, когда получаю письмо о том, что бывший коллега (который оставлял токсичную и бесполезную обратную связь), прокомментировал мой запрос. Хотя такое поведение влияет на всех по-разному, мы все можем согласиться, что никто не получает от этого пользы.

Примечание: хочу отметить, что случайное проявление одной из описанных вещей не делает человека токсичным. А вот повторяющиеся оскорбления и язвительная обратная связь говорят о многом.

Как писать чистый и красивый код

Полезные вещи в обзоре кода

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

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

Никогда не требуйте от людей внести изменения и не задавайте осуждающих вопросов, потому что это не открывает диалог между вами. Резкие вопросы заставляют их оправдываться. Вместо этого спросите, что человек думает о предложенном решении:

“Можно поместить эти трансляции в файл констант, как думаешь? Их слишком много, имеет смысл создать для них отдельный файл.”

или предоставьте рекомендацию:

“У тебя в этом файле много запросов на трансляцию функции X. Имеет смысл создать отдельный файл под константы функции X.”

2. Не указывайте, а работайте вместе

Когда вы занимаетесь парным программированием, вы должны задавать вопросы, обсуждать и давать ссылки на ресурсы.

“Когда вы хотите работать с другим человеком, вы должны быть полностью вовлечены, а не просто появляться периодически”, — указания для пользователей Recurse Center.

3. Отвечайте на каждый комментарий

Если вы не планируете применять советы человека, оставьте заметку об этом. Не игнорируйте тех, кто уделил время на помощь вам.

Например:

“ — Что ты думаешь о создании хелпера для этого вызова API?

— Эта строка не входит в мой набор изменений. Я пока отправлю этот код, но я создам отдельную issue на GitHub для вызова API и отправлю это в бэклог группы.”

4. Иногда обсуждение нужно перенести в оффлайн

После десятков противоречивых комментариев и предложенных решений должно быть понятно, что онлайн-коммуникация стала непродуктивной для решения проблемы. Устройте встречу, чтобы обсудить вопрос вживую, так вы сможете прийти к решению быстрее.

5. Используйте возможности, чтобы научить чему-то, и не хвастайтесь

Перед тем, как участвовать в просмотре кода, спросите себя — ваш комментарий помогает другому разработчику учиться или вы просто любите придираться?

Подумайте, почему вы принимаете в этом участие. Помните, что цель просмотров кода — помочь другим разработчикам расти.

6. Не выказывайте удивление

Не нужно удивляться, если у кого-то нет тех же знаний, что есть у вас. Если люди могут понять нехватку опыта в какой-то теме и попросить о помощи —  это отлично. Не заставляйте их переживать из-за того, что они “уже должны были знать” эту информацию.

Григорий Петров: Код проекта: что хотел сказать разработчик

7. Автоматизируйте все возможное

Просмотр проблем, которые могут уловить линтеры, перехватчики в git или автоматизированные тесты, бесполезен. Люди не всегда видят эти проблемы, и поэтому существуют эти инструменты автоматизации.

Существуют инструменты, которые запускают тесты после проверки кода, и они показывают предупреждения, когда набор изменений нарушает какие-либо тесты. Эти функции есть у TeamCity и Jenkins CI. Используйте перехватчики в git. Они запускают тесты и линтеры, когда кто-то пытается отправить код, и перехватывают этот запрос, если в нем содержится код с ошибками.

8. Отказывайтесь от нормализации токсичного поведения

Не нужно поддерживать токсичные комментарии из-за их статуса кво. Ищите коллег, которые вас поддержат в этом. Если вы заметите, что кто-то оставляет бесполезные комментарии, дайте им знать об этом (если вы можете сделать это на вашей должности и в вашей компании) и будьте прямолинейны.

Григорий Петров: Как и зачем читать чужой код

9. Менеджеры, нанимайте внимательно, слушайте свою команду и применяйте меры

Менеджеры могут создать позитивную и дружелюбную культуру в своей команде.

  • Не нанимайте в команду токсичных разработчиков. Смотрите не только на технические навыки, оценивайте способности кандидатов к коллаборации и коммуникации. Критически анализируйте их работу и смотрите на их реакцию. Убедитесь, что каждый человек привносит что-то положительное в культуру компании.
  • Если у вас в команде есть токсичные разработчики, спросите у всех в отчетах о том, как им работается наедине с другими сотрудниками. Отчеты покажут, если у вас действительно есть токсичный разработчик.
  • Поговорите с этим человеком. Покажите ему примеры и правильную обратную связь.
  • Не изолируйте токсичного разработчика. Нужно побудить этого человека на здоровую коммуникацию с командой. Изоляция не поможет человеку исправиться.
  • Повторяйте, что ожидаете от команды коллаборации в дружелюбной обстановке.

10. Установите стандарт с самого начала существования команды

Если ваша команда небольшая, она может принять идеи и начать воплощать их сразу. Даже если вам это пока не нужно, помните, что вы хотите, чтобы ваша команда оставалась отличной с появлением новых сотрудников.

11. Поймите, что вы можете быть частью проблемы

Чтобы сделать обстановку лучше, важно быть честными с собой и подумать о том, не вели ли вы себя таким образом. Когда я была джуниор-разработчиком, у меня было несколько случаев, когда я видела баг в чьем-то коде и радовалась, потому что так я могла стать частью просмотра. Я теперь понимаю, что использовала эту возможность, чтобы похвастаться, а не помочь. Я пытаюсь помнить об этом и я думаю, что у каждого должен быть такой момент саморефлексии.

Одна последняя вещь…

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

Я знаю, что обратная связь важна, и я не объявляю ей войну. Я не прошу команды жертвовать качеством своего кода. Здоровая культура Code Review и высокое качество кода не исключают друг друга. Я надеюсь, что люди предпримут шаги, чтобы предоставлять конструктивную обратную связь и создать более благоприятную среду, где разработчики смогут учиться, расти и совершать ошибки.

Краткое содержание:

Комментарии
Продолжить чтение

Разработка

Обнаружение объектов с помощью Глубокого Обучения на Raspberry Pi

CEO проекта NanoNets рассказал об использовании нейронных сетей на небольших устройствах вроде Raspberry Pi.

Анна Гуляева

Опубликовано

/

В мире существует множество устройств с ограниченной памятью и небыстрыми процессорами, такие как, например, мобильные телефоны и Raspberry Pi, которые не могут запускать сложные модели глубокого обучения. Эта статья показывает, как вы тем не менее можете распознавать объекты при помощи Raspberry Pi.

Если вам не терпится, вы можете пролистать пост до ссылок на GitHub.

Почему Raspberry Pi?

Raspberry Pi покорил сердца людей: в мире продано около 15 миллионов устройств, на которых создаются отличные проекты. Учитывая популярность Raspberry Pi и глубокого обучения, мы решили создать систему распознавания любого объекта при помощи Pi.

Что такое обнаружение объектов?

За 20 миллионов лет эволюции человеческое зрение сильно развилось. 30% нейронов мозга человека работают над обработкой визуальной информации, для осязания этот показатель составляет 8%, а для слуха — 3%.

По сравнению с машинами, у людей есть два больших преимущества: стереоскопическое зрение и бесконечное количество данных для обучения (за пять лет жизни ребенок обрабатывает примерно 2,7 миллиарда изображений со скоростью 30fps).

Чтобы имитировать производительность людей, учёные разбили задачу визуального восприятия на четыре категории:

  1. Классификация — присваивание ярлыка целому изображению.
  2. Локализация — определение рамки вокруг объекта и его описание.
  3. Обнаружение объектов — создание нескольких рамок на изображении.
  4. Сегментация изображения — создание точных сегментов, содержащих объекты, на изображении.

Обнаружение объектов применяется в нескольких случаях. Хотя сегментация изображения дает более точный результат, её проблемой является сложность создания данных для обучения. Человек в 12 раз дольше сегментирует изображение по сравнению с созданием рамок. Более того, после обнаружения объекта есть возможность сегментировать его из рамки.

Использование обнаружения объектов

Обнаружение объектов — это важная функция, которая используется во многих индустриях. Несколько примеров показаны ниже:

Как использовать обнаружение объектов для решения моих проблем?

Обнаружение объектов можно использовать для ответа на многие вопросы. Вот несколько категорий:

  1. Присутствует ли объект на моем изображении? Пример: нет ли в моем доме грабителя?
  2. Где находится объект на изображении? Пример: когда автомобиль перемещается, важно знать, где находятся разные объекты.
  3. Сколько объектов на изображении? Пример: сколько коробок стоит на полке в складе?
  4. Какие типы объектов есть на изображении? Пример: какое животное находится в конкретной части зоопарка?
  5. Каков размер объекта? При помощи статичной камеры просто определить размер объекта. Пример: какого размера манго?
  6. Как разные объекты взаимодействуют друг с другом? Как группировка на футбольном поле влияет на результат?
  7. Где находится объект во времени? Пример: отслеживание движущегося объекта вроде поезда и вычисление скорости.

Обнаружение объектов менее чем за 20 строк кода

Существуют разные модели и архитектуры для обнаружения объектов. Каждая отличается по скорости, размеру и точности. Мы выбрали один из самых популярных алгоритмов — YOLO, и показали, как он работает в 20 строк кода (если игнорировать комментарии).

Примечание: это псевдокод. который не должен быть рабочим примером. В нем есть черный ящик, часть со сверточной нейронной сетью, которая довольно стандартна и показана на изображении ниже. Вы можете прочитать полную статью здесь: https://pjreddie.com/media/files/papers/yolo_1.pdf.

Архитектура сверточной нейронной сети, которая используется в YOLO

Как создать модель глубокого обучения для обнаружения объектов?

Процесс глубокого обучения состоит из шести шагов, которые разбиты на три части:

  1. Сбор данных для обучения
  2. Обучение модели
  3. Прогнозы на новых изображениях

Фаза 1 — сбор данных для обучения

Шаг 1. Соберите изображения (минимум 100 на один объект)

Для этой задачи вам нужно будет сто изображений для одного объекта. Попытайтесь собрать данные, максимально близкие к тем, для которых вы потом будете делать прогнозы.

Шаг 2. Аннотации (нарисуйте рамки на изображениях вручную)

Нарисуйте рамки на изображениях. Вы можете использовать инструмент вроде labelImg. Вам понадобятся люди, которые будут работать над аннотациями. Это занятие может занять много времени.

Фаза 2 — обучение модели на графическом процессоре

Шаг 3 — поиск уже обученной модели для обучения на основе переноса

Вы можете прочитать об этом больше здесь. Вам нужна будет обученная модель, чтобы сократить необходимое для обучения количество данных. Без этого шага вам понадобится минимум 100 тысяч изображений для обучения модели. Вы можете найти обученные модели в этом репозитории.

Шаг 4 — обучение на графическом процессоре (облачные сервисы вроде AWS/GCP или вашем собственном процессоре)

Для упрощения процесса обучения мы создали docker image, которое сделает обучение проще.

Чтобы начать обучение модели, вы можете запустить:

sudo nvidia-docker run -p 8000:8000 -v `pwd`:data docker.nanonets.com/pi_training -m train -a ssd_mobilenet_v1_coco -e ssd_mobilenet_v1_coco_0 -p '{"batch_size":8,"learning_rate":0.003}'

По этой ссылке вы можете узнать больше о деталях процесса.

В docker image содержится скрипт run.sh, который можно вызвать при помощи следующих параметров.

run.sh [-m mode] [-a architecture] [-h help] [-e experiment_id] [-c checkpoint] [-p hyperparameters]
-h          display this help and exit
-m          mode: should be either `train` or `export`
-p          key value pairs of hyperparameters as json string
-e          experiment id. Used as path inside data folder to run current experiment
-c          applicable when mode is export, used to specify checkpoint to use for export

Больше деталей можно найти здесь.

Чтобы обучить модель, вам нужно подобрать правильные гиперпараметры.

Подбор гиперпараметров

Искусство глубокого обучения требует поиска лучших параметров для повышения точности модели. Этот процесс — это немного магии и немного теории. Вот отличный ресурс, который поможет вам найти правильные параметры.

Квантование модели (чтобы она умещалась на маленьких устройствах)

На маленьких устройствах вроде телефонов или Raspberry Pi очень мало памяти и вычислительной мощности.

Обучение нейронной сети происходит при помощи внесения крохотных изменений в веса, и этим изменениям для работы нужна точность плавающей запятой (хотя в некоторых исследованиях здесь пытаются применить и квантованные репрезентации).

Использование обученной модели и получение вывода очень отличаются. Одно из магических свойств сетей глубокого обучения — они хорошо справляются с высоким уровнем шума в данных.

Зачем производить квантование?

Модели на основе нейронных сетей могут занимать много места на диске. Почти все пространство занимают веса нейронных связей, так как в одной модели много миллионов таких весов.

Узлы и веса нейронной сети обычно хранятся как 32-битные числа с плавающей запятой. Цель квантования — сжать размер файлов при помощи хранения минимума и максимум каждого слоя, а затем привести каждое плавающее значение к восьмибитному целому числу. Размер файлов сокращается на 75%.

Код для квантования:

curl -L "https://storage.googleapis.com/download.tensorflow.org/models/inception_v3_2016_08_28_frozen.pb.tar.gz" |
  tar -C tensorflow/examples/label_image/data -xz
bazel build tensorflow/tools/graph_transforms:transform_graph
bazel-bin/tensorflow/tools/graph_transforms/transform_graph \
--in_graph=tensorflow/examples/label_image/data/inception_v3_2016_08_28_frozen.pb \
  --out_graph=/tmp/quantized_graph.pb \
  --inputs=input \
  --outputs=InceptionV3/Predictions/Reshape_1 \
  --transforms='add_default_attributes strip_unused_nodes(type=float, shape="1,299,299,3")
    remove_nodes(op=Identity, op=CheckNumerics) fold_constants(ignore_errors=true)
    fold_batch_norms fold_old_batch_norms quantize_weights quantize_nodes
    strip_unused_nodes sort_by_execution_order

Примечание: в наш docker image уже встроено квантование.

Фаза 3 — предсказание на новых изображениях

Шаг 5 — захват нового изображения посредством камеры

Вам нужна будет работающая камера Raspberry Pi. Затем захватите новое изображение.

Для инструкции по установке посмотрите эту ссылку.

Шаг  6 — прогноз на основе нового изображения

Скачайте модель

Как только вы закончите обучать модель, вы можете скачать её на Pi. Чтобы экспортировать модель, запустите:

sudo nvidia-docker run -v `pwd`:data docker.nanonets.com/pi_training -m export -a ssd_mobilenet_v1_coco -e ssd_mobilenet_v1_coco_0 -c /data/0/model.ckpt-8998

Затем загрузите модель на Raspberry Pi.

Установка TensorFlow на Raspberry Pi

В зависимости от устройства вам, возможно, нужно будет изменить установку.

sudo apt-get install libblas-dev liblapack-dev python-dev libatlas-base-dev gfortran python-setuptools libjpeg-dev
sudo pip install Pillow
sudo pip install http://ci.tensorflow.org/view/Nightly/job/nightly-pi-zero/lastSuccessfulBuild/artifact/output-artifacts/tensorflow-1.4.0-cp27-none-any.whl
git clone https://github.com/tensorflow/models.git
sudo apt-get install -y protobuf-compiler
cd models/research/
protoc object_detection/protos/*.proto --python_out=.
export PYTHONPATH=$PYTHONPATH:/home/pi/models/research:/home/pi/models/research/slim

Запустите модель для прогноза

python ObjectDetectionPredict.py --model data/0/quantized_graph.pb --labels data/label_map.pbtxt --images /data/image1.jpg /data/image2.jpg

Измерение производительности Raspberry Pi

У Raspberry Pi есть ограничения по памяти и вычислительной мощности (совместимая с GPU Raspberry Pi версия TensorFlow пока недоступна). Таким образом, важно измерить, сколько времени у модели займет создание прогноза на новом изображении.

Рабочий процесс с NanoNets

Наша цель в NanoNets — сделать работу с глубоким обучением очень простой. Обнаружение объектов — это важная область для нас, и мы создали процесс, который решает много проблем с внедрением моделей глубокого обучения.

Как NanoNets делает процесс проще:

  1. Не требуется аннотация

Мы убрали потребность в аннотации изображений, у нас есть аннотаторы, которые сделают это за вас.

  1. Автоматизация лучшей модели и выбор гиперпараметров

Мы автоматически обучаем лучшую модель для вас, запуская ряд моделей с разными параметрами, чтобы выбрать лучшую для ваших данных.

  1. Отсутствие необходимости в дорогом оборудовании

NanoNets находится в облаке и работает. не используя ваше оборудование.

  1. Совместимость с мобильными устройствами вроде Raspberry Pi

Так как устройства вроде Raspberry Pi и смартфоны не созданы для сложных вычислительных задач, вы можете передать рабочий процесс в облако, которое делает все вычисления за вас.

Вот небольшой отрывок для создания прогноза на основе изображения при помощи NanoNets API

Создание своей NanoNet


Вы можете создать свою модель при помощи:

  1. Используя GUI и автоаннотацию модели
  2. Используя наш API

Шаг 1: клонируйте репозиторий

git clone https://github.com/NanoNets/object-detection-sample-python.git
cd object-detection-sample-python
sudo pip install requests

Шаг 2: получите бесплатный ключ API

Получите бесплатный ключ API здесь.

Шаг 3: установите ключ API как Environment Variable

export NANONETS_API_KEY=YOUR_API_KEY_GOES_HERE

Шаг 4: создайте новую модель

python ./code/create-model.py

Примечание: здесь генерируется MODEL_ID, который вам нужен будет для следующего шага.

Шаг 5: установите Model ID как Environment Variable

export NANONETS_MODEL_ID=YOUR_MODEL_ID

Шаг 6: загрузите данные для обучения

Соберите изображения объекта, который вы хотите обнаруживать. Вы можете оставлять аннотации при помощи нашего веб-UI (https://app.nanonets.com/ObjectAnnotation/?appId=YOUR_MODEL_ID) или использовать инструменты с открытым исходным кодом вроде labelImg. Как только в вашем наборе данных будет готовы папки, аннотации и изображения, начните загружать набор данных.

python ./code/upload-training.py

Шаг 7 — обучение модели

Как только изображения загружены, начните обучать модель.

python ./code/train-model.py

Шаг 8 — получите состояние модели

Обучение модели занимает два часа. Вы получите письмо, как только обучение закончится. В процессе вы можете проверять состояние модели.

watch -n 100 python ./code/model-state.py

Шаг 9 — сделайте прогноз

Как только модель будет обучена, вы сможете делать прогнозы.

python ./code/prediction.py PATH_TO_YOUR_IMAGE.jpg

Код на GitHub

Обучение модели

Код TensorFlow для обучения и квантования модели

Код NanoNets для обучения модели

Прогнозы на Raspberry Pi

Код TensorFlow для прогнозов на Raspberry Pi

Код NanoNets для прогнозов на Raspberry Pi

Наборы данных с аннотациями

Автомобили на индийских дорогах

Набор данных Coco

Комментарии
Продолжить чтение

A/B тестирование

A/B-тестирование в Firebase: часть 2

Продолжаем изучать Remote Config и A/B-тестирование в Firebase и учимся делать ваших пользователей самыми счастливыми!

AppTractor

Опубликовано

/

Автор:

Расширенный пользовательский таргетинг

Давайте изменим механизмы, чтобы понять, что еще мы можем сделать с Firebase Remote Config вне A/B-теста.

В предыдущем уроке вы избежали международного кризиса, установив shouldWeIncludePluto в true для ваших пользователей в Скандинавии. Оказывается, однако, что такой настройки на основе страны недостаточны. Выбор того, планета ли Плутон, является глубоко личным, и многие люди со всего мира хорошо относятся к планетному статусу Плутона. Как мы можем настроить Planet Tour для всех?

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

Свойства пользователя в Google Analytics

Свойство пользователя в Google Analytics для Firebase – это просто свойство, связанное с конкретным пользователем.

Некоторые примеры пользовательских свойств – премиум-пользователи в вашем приложении, пользовательские цели в вашем приложении по фитнесу или любые другие связанные с пользователем данные, которые вы можете захотеть отфильтровать.

В вашем случае вы будете использовать свойство likeSmallRocks, чтобы понять то, как пользователь относится к небольшим, холодным скалам на окраинах нашей солнечной системы. Затем вы будете использовать это свойство в сочетании с Remote Config, чтобы предоставить пользователям новый опыт на основе этого значения.

Хотя существуют разные способы определить, является ли пользователь поклонником маленьких отдаленных скальных пород, проще всего просто спросить их.

В верхней части PlanetsCollectionViewController.swift добавьте эту строку:

import Firebase

Затем добавьте следующее определение reuseIdentifier:

private let takenSurveyKey = "takenSurvey"

Наконец, добавьте следующее внутри расширения с помощью MARK: – Internal, прямо над функцией addFancyBackground ().

@objc func runUserSurvey() {
  let alertController = UIAlertController(title: "User survey",
    message: "How do you feel about small, remote, cold rocks in space?",
    preferredStyle: .actionSheet)

  let fanOfPluto = UIAlertAction(title: "They're planets, too!", style: .default) { _ in
      Analytics.setUserProperty("true", forName: "likesSmallRocks")
  }

  let notAFan = UIAlertAction(title: "Not worth my time", style: .default) { _ in
      Analytics.setUserProperty("false", forName: "likesSmallRocks")
  }

  alertController.addAction(fanOfPluto)
  alertController.addAction(notAFan)
  navigationController?.present(alertController, animated: true)

  UserDefaults.standard.set(true, forKey: takenSurveyKey)
}

Нужно отметить две вещи в опросе, который вы добавили – во-первых, после того, как вы получите ответ от пользователя, вы записываете его в новое свойство пользователя likesSmallRocks. Во-вторых, вы делаете заметку в UserDefaults этого пользователя, который уже принял участие в опросе, чтобы его не спрашивать каждый раз при посещении приложения.

Теперь, когда вы определили свое свойство пользователя в коде, вам необходимо выполнить второй шаг, который позволяет консоли Firebase знать, что это свойство существует, чтобы оно могло начать создавать отчеты на его основе. Лучше всего добавлять user property в консоль Firebase одновременно с добавлением ее в код. Откройте консоль Firebase и выберите «Google Analytics», затем «User Properties» .

Теперь будьте осторожны в следующем шаге – консоль Firebase не позволяет редактировать или удалять свойства пользователя после их создания! Выберите NEW USER PROPERTY и создайте новую запись, которая называется likeSmallRocks. Я рекомендую копировать и вставлять имя, чтобы убедиться, что оно точно соответствует. Дайте ему любое описание, которое вы хотели бы. Затем нажмите CREATE.

Вернитесь в PlanetsCollectionViewController.swift и в конце viewDidAppear(_:) и добавьте эти строки, чтобы убедиться, что вы запрашиваете это только один раз при установке приложения:

if !UserDefaults.standard.bool(forKey: takenSurveyKey) {
  runUserSurvey()
}

Если вы хотите немного упростить тестирование, добавьте этот код viewWillAppear(_:) выше customizeNavigationBar(), который добавит кнопку на панель навигации, чтобы запустить опрос в любое время, минуя проверку того, что вы уже видели это:

let retakeSurveyButton = UIBarButtonItem(barButtonSystemItem: .compose,
                                         target: self,
                                         action: #selector(runUserSurvey))
parent?.navigationItem.rightBarButtonItem = retakeSurveyButton

Создайте и запустите приложение. Теперь вас спросят, как вы относитесь к маленьким скалам в космосе. Не стесняйтесь и честно ответьте.

Настройка вашего приложения

Теперь вы можете начать настройку Remote Config на основе этого значения. Откройте консоль Firebase и выберите Remote Config. Если вы закончили предыдущий туториал, вы увидите свою запись для shouldWeIncludePluto. И если вы этого не сделали, создайте ее заново.

Если вам нужно создать, сначала нажмите «ADD YOUR FIRST PARAMETER». Затем введите значение параметра shouldWeIncludePluto для Parameter key и сохраните значение по умолчанию пустым (Default value). Затем нажмите ADD PARAMETER.

Нажмите значок карандаша рядом с надписью shouldWeIncludePluto, чтобы изменить его, затем выберите Add value for condition > Define new condition. Назовите новое условие «Small rock fans» и укажите это условие, если User property > likesSmallRocks | exactly matches | true.

Примечание. Не выбирайте оператор сравнения == в этом диалоговом окне – это используется только для чисел.

Нажмите CREATE CONDITION, затем установите для этого значения значение true и значение по умолчанию – false .

Примечание. Если вы не выполнили предыдущий туториал, то здесь не будет состояния «Pluto fans». Ничего страшного!

Нажмите UPDATE, затем PUBLISH CHANGES.

Теперь создайте и запустите приложение снова.

Если вы указали, что являетесь фанатом маленьких отдаленных планет, то теперь вы должны увидеть Плутон среди списка планет. Если вы этого не сделали, вы не увидите Плутон… если ваше устройство не думает, что оно находится в скандинавской стране, и в этом случае Плутон все еще там (при условии, что вы прошли предыдущий туториал и установили это условие).

Если вы хотите посмотреть, как выглядит ваше приложение для людей, которые ответили на опрос по другом, нажмите кнопку вверху, чтобы перепройти опрос, а затем закройте и запустите приложение заново.

Как насчет внесения некоторых более тонких изменений в призыв к действию для ваших поклонников Плутона? В вашем приложении есть переменная planetImageScaleFactor,  которая определяет, насколько близко размер изображений планеты соответствует фактическому размеру соответствующей планеты.

При значении 1.0 они соответствуют масштабу, поэтому планеты, подобные Плутону, едва ли с пиксель велиичной. При значении 0.0, все планеты имеют одинаковый размер. Прямо сейчас эта переменная имеет значение по умолчанию 0.33, которое дает вам представление об относительных размерах планет, в то же время делая их легкими для обнаружения.

Нужно немного уменьшить это значение для поклонников небольших планет, чтобы более мелкие планеты, такие как Плутон и Меркурий, стали больше.

Вернитесь в Remote Config в консоли Firebase и создайте новую запись для planetImageScaleFactor. Дайте ему значение 0,2 для пользователей в состоянии «Small rock fans» и значение по умолчанию 0,45. Нажмите UPDATE, затем PUBLISH CHANGES.

Снова запустите Planet Tour. В зависимости от того, как вы относитесь к маленьким скалам, планеты, такие как Марс или Плутон, должны выглядеть пропорционально больше или меньше.

Хотя это может показаться забавным и несущественным изменением, такие типы настроек могут быть весьма полезными. Когда вы узнаете больше о своих пользователях и разных частях своего приложения, которые они предпочитают, вы можете начать предоставлять пользователям по-настоящему индивидуальный опыт, сделав так, чтобы элементы, которые им нравятся, были всегда впереди и в центре.

И вы можете выполнить некоторые A/B-тесты с этими параметрами, чтобы узнать, что делает пользователей вашего приложения самыми счастливыми!

Комментарии
Продолжить чтение

Реклама

Наша рассылка

Каждому подписавшемуся - "1 час на UI аудит": бесплатный ускоренный курс для разработчиков!

Нажимая на кнопку "Подписаться" вы даете согласие на обработку персональных данных.

Вакансии

Популярное

X
X

Спасибо!

Теперь редакторы в курсе.