Результатом моей трёхгодовой работы в качестве PO/Functional Architector в медицинском домене является следующий значимый и уникальный опыт. В ходе работы над техническими решениями мировых компаний, их заказчиков и потребностей рынка я пришел к следующему важному заключению: основной ошибкой в разработке ПО является ошибка безграмотного проектирование систем. Это то о чем говорит Алан Купер в своей книге “Психбольница в руках пациентов”, а мой опыт является ярким подтверждением, что проблема существует и поныне.

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

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

  2. “Маленькая задача”: общий бизнес-процесс компания заключается в разработке healthcare портала, который направлен на исцеление пациентов, в том числе улучшения показателей курса лечения: (приема препаратов), мониторинг процесса приема препаратов наблюдение симптомов на протяжении времени.

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

Какой будет результат? Будет еда, но 100% не будет пиццы, максимум частичное попадание (что-то из ингредиентов все таки будет приобретено чисто интуитивно). Будет потрачено время, ваше, как заказчика, жены, как исполнителя (разработчика), неоправданное ожидание и, конечно же, энная сумма денег на “еду” (в разработке - это проектирование функциональных возможностей системы).

Также произошло с моим 1 опытом по решению “большой” задачи, когда вместо mapping оценки конкретных требований бизнеса и функциональных возможностей системы, новая система 3-ей стороны стала просто встраиваться через “ну как-нибудь”, “ну что-то будет”.

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

  1. была подорвана разработка основной, ключевой системы,

  2. срывы контрактов с заказчиками,

  3. уровень квалификации команды (команда стала просто распадаться) Итогом стало:

  4. Команда проектирования системы осталась хорошей, все сделала правильно (себя, конечно же, только хвалим),

  5. Встраиваемая система 3-ей стороны оказалась плохой,

  6. Потрачен бюджет с 0.0000 и просроченный дедлайн в 1 год разработки,

  7. Утрачена возможность в запланированные сроки прохождение медицинских исследований продукта.

  8. Появились разговоры про поиски очередной и “плохой” системы. Вопрос: А как же всё-таки сделать надо было сделать?

В многочисленных и постоянно повторяющихся “ошибках проектирования систем” моих коллег я выработал для себя следующий подход решения возникающих ошибок.

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

  2. Затем я выявляю "периметр пазла", те создаю рамку всей общей задачи, по-другому - это рассматриваю границы "пазла" (границы самого проекта или конкретной задачи)

  3. Затем смотрю что "нарисовано в самом пазле", те какие кусочки у нас есть и каких не хватает (какие шаги нужно сделать по направлению к завершению общей задачи/проекта)

  4. Сажусь за проектирование “конкретных пазлов”, те предпринимаю те шаги, которые приведут команду к успеху и помогут реализовать задачу/выполнить проект.

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


К чему это ведет:

  1. “удобный” - сформирует ложное представление о процессе лечения и его результатах.

  2. “эффективный” - работа с объективными метриками, правильное и целевое расходование средств, те “исцеление”.

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

Комментарии (4)


  1. Maxmyd
    13.07.2022 23:23
    +2

    Э-э-э... Да, так о чём это вы?


  1. XaBoK
    14.07.2022 00:15

    То есть обычно проектируется система через пазл? Ну наверное не самый лучший вариант, если учесть, что по вашим словам у вас 3 года опыта из которых больше года ушло на провалившийся проект интеграции, результатом которого стал поиск новой системы и видимо еще раз год+ интеграции. Там ещё где-то зафакапили и "маленький" проект. Может поэтому вы используете древний и пафосный Architector вместо обычного Architect... Себя же надо только хвалить...


  1. tolyan_ekb
    14.07.2022 09:41

    У меня пазл не сложился. Ожидал увидеть описание работы над ошибками с указанием "как было - как надо".


  1. AlexBream
    14.07.2022 10:11
    +2

    В статье "Functional Architector" (эт ничо, что в английском английском "архитектор" все же "Architect"?!) прямым текстом признается в собственном неполном служебном соответствии, что, очевидно, произрастает из того, что до "архитектора"-то выслужился, но, что печально, не научился понимать достаточно очевидные вещи:

    • "менеджмент" не занимается "проектированием системы", ни "грамотно", ни "безграмотно"

    • Проектирование системы (или их интеграций) - как раз Ваша, милсдарь, зона ответственности и тут мы наблюдаем два ваших личных провала как специалиста

    • Претензии к крайне невнятному изложению мыслей "...общий бизнес-процесс компания заключается в разработке healthcare портала, который направлен на исцеление пациентов..." и уровню непонимания обсуждаемых сущностей - то мои частные претензии, но: "Не может человек, не знающий родного языка, быть инженером - у него мозги не так устроены"