Время на прочтение
4 мин
Количество просмотров 57K
Сталкиваясь с реалиями машиностроительной промышленности, большинство разработчиков программного обеспечения не справляются – уж очень узкоспециализированы продукты, с которыми приходится работать. Это вам не создание программ для интернет-пользователей, компьютеров и даже не мобильные приложения, а потому новички чувствуют себя, как Томас из фильма «Бегущий в лабиринте». Посмотрите, примерно, 50 секунд трейлера – и вы поймете, какой шок испытывают те, кто имеет дело с разработкой ПО для автомобилей впервые.
Все, что у вас есть — это множество терминов и инструментов, о которых вы понятия не имеете. Когда во время собеседования в одной автомобильной компании я поинтересовался, какую IDE они используют, интервьюеру мой вопрос, мягко говоря, не понравился. Я привык к Visual Studio, и наивно надеялся, что здесь для разработки встроенного программного обеспечения понадобится что-то аналогичное. Я даже не представлял, что меня ожидало! Просто море мелких и серьезных (по сложности) инструментов, которым нужна была очередная жертва.
Причем, когда речь идет о разработке программного обеспечения для автомобилей, инструменты отнюдь не единственная проблема. Практически невозможно найти литературу для новичков или просто обучающие материалы, касающиеся библиотек или архитектуры соответствующих программ. Термин «учебное пособие» и вовсе звучит неуместно, ведь сфера автомобилестроения – весьма закрытое сообщество. Да и сообществом ее вряд ли назовешь, ведь при такой конкуренции никто не должен догадаться, как вы создаете ту или иную программу. Чтобы узнать хоть что-то об отдельных инструментах и механизмах этого сегмента программирования, вы можете записаться на запредельно дорогие курсы, но ваша компания должна быть готова выложить немалую сумму и потребуется не меньше нескольких недель, чтобы получить опыт, который вам нужен уже сейчас. Очень жаль, что разобраться в специфике программирования для автомобилестроения так сложно, а потому я решил посвятить свою статью именно этой теме.
Поскольку мне неоднократно приходилось переключаться с создания приложений для интернет-пользователей/компьютеров на разработку встроенных программ и обратно, мне не понаслышке известно о проблемах, с которыми сталкиваются новички, имеющие дело, в основном, с первым блоком продуктов. Аналогичные сложности возникают и у программистов, которые никогда не сталкивались со спецификой автомобильной промышленности.
В этой и следующей статье мне хотелось бы поговорить о принципах работы встроенных программ для автомобилей, а также заглянуть в недра экзотической архитектуры встроенных приложений.
Какие темы мы рассмотрим?
- Как встроенное программное обеспечение повышает производительность автомобиля?
- Как встроенные приложения позволяют управлять автомобилем?
- Какие существуют типичные ограничения CPU?
- Как благодаря встроенным программам осуществляется процесс непрерывной обработки данных с датчиков?
- Как это программное обеспечение структурировано и как отдельные приложения взаимодействуют между собой для управления автомобилем?
Я отвечу на эти вопросы, рассмотрев конкретный пример, а заодно сделаю обзор по разработке архитектуры встроенного программного обеспечения. В качестве примера мы возьмем полностью электронную систему рулевого управления. Это не настоящая модель, но по строению она, в принципе, похожа на то, что вы, скорее всего, видели в своем автомобиле. Мы поговорим подробнее об архитектуре, а затем перейдем к упрощенной схеме, раскрывающей суть функционала системы.
Вы можете посмотреть видео, посвященное разработке электронной системы рулевого управления. Кстати, я тоже работал в этой команде.
Данная модель частично управляется программно. Частично означает, что специализированное ПО лишь помогает водителю, но полный контроль над системой имеет именно он.
Предположим, нам нужно создать полностью электронную систему рулевого управления, в которой руль напрямую не связан с колесами. Вместо этого датчик измеряет угол поворота руля и отправляет полученные данные нашей программе. В автомобильной терминологии это сервопривод. Вы не поверите, но благодаря Nissan на рынке уже появилась модель с сервоприводом.
Работу ПО обеспечивает крошечный процессор или, если говорить точнее, микроконтроллер, по сети подключенный к датчику.
Когда водитель поворачивает руль, благодаря датчику, который постоянно передает информацию о текущем угле поворота, ПО получает соответствующий сигнал. Например, если водитель поворачивает руль на 90 ° вправо, в течение секунды сигнал датчика обрабатывается по следующему принципу:
Помимо этого, ПО также управляет работой электрического двигателя, который перемещает зубчатую рейку слева направо и в обратном направлении, а, значит, изменяется угол поворота передних колес автомобиля. Соответственно, ПО может направить машину влево или вправо. Связь между микроконтроллером, запускающим ПО, и электродвигателем обеспечивается благодаря электронному блоку управления (ECU), в состав которого входит собственно микроконтроллер и усилитель мощности, регулирующий систему питания двигателя. Таким образом, наша программа варьирует подачу тока в двигателе и положение зубчатой рейки изменяется в нужном направлении.
Электронный блок управления (ECU)
При условии, что встроенное программное обеспечение работает корректно, при повороте руля почти мгновенно изменяется положение зубчатой рейки.
Руль — синий, рулевая рейка — розовый (прим.)
Становится понятно, что даже обработка информации здесь не подчиняется ни логике событийно-ориентированного программирования, как в случае с привычными приложениями графического интерфейса пользователя, ни законам пакетных фалов. Вместо этого требуется непрерывная, своевременная обработка входящих данных. Если программе понадобится слишком много времени, чтобы проанализировать показатели датчиков, рулевая рейка и передние колеса автомобиля будут двигаться с задержкой, и водитель это заметит. Скорее всего, в экстремальной ситуации это приведет к потере контроля над автомобилем, например, при повороте руля в целях объезда препятствия машина не сразу среагирует на маневр. Подобная специфика повышает требования к временным показателям программ для автомобилей, особенно, если учесть ограниченную производительность процессора стандартных электронных блоков управления.
В продолжение серии мы рассмотрим архитектуру программного обеспечения, позволяющую устранить обозначенные проблемы, и, надеюсь, с помощью этих материалов начинающие разработчики встроенных приложений для автомобилей гораздо быстрее освоят базовые принципы, действующие в данной сфере.
Часть 2/2
Собственно из-за отсутствия времени решил пока написать про написание прошивки в сжатом виде. Позже когда со временим будет попроще напишу развернутый материал. А на первых парах сегодняшнего материала хватит для понимания что такое написания прошивки.
Все описанное в данной статье делается на ваш страх и риск. Ответственности за поврежденные вами ДВС и понесенные вами убытки не несу.
Начнем с того что прежде чем писать прошивку нам надо иметь:
1) Средства для проведения диагностики автомобиля. Кабеля Consult и диагностического ПО вполне достаточно.
2) ECU с возможностью их перепрошивки.
3) ПО для изменения прошивки ECU. (Я буду использовать Nistune, для моих нужд его триал версии вполне достаточно.)
4) Программатор чипов.
5) Двигатель в идеальном или близком к идеалу состояние.
Остановимся подробнее на состояние двигателя. Т.к. неисправный двигатель может «развалиться» или в лучшем случае свести к минимуму наши труды.
Что требуется от двигателя перед началом тюнинга:
1) Отсутствие кодов ошибок.
2) Свежий воздушный фильтр и исправный MAF.
3) Исправный и правильно настроенный TPS(ДПДЗ)
4) Бензонасос и топливный фильтр — новые или в идеальном состояние. Исправные и чистые форсунки.
5) Правильно выставленное зажигание по стробоскопу. Как правило для Nissan Это 15 градусов (реже 20).
6) Новые или в хорошем состояние свечи зажигания. Для турбомоторов Nisssan я бы рекомендовал свечи производства NGK с зазором 0,6мм
Так же не стоит при тюнинге расчитывать на чудо. К примеру если мы имеем полный сток SR20DET, то по MAF-у мы упираемся в потолок равный 290 лс, а по форсункам в 280. И превышение максимально возможных параметров для форсунок опасно для двигателя смертью.
И написание каждой прошивки свыше 280 лс рассчитывается индивидуально под приобретенные спеки снимающие потолок в 280 л.с.
Так даже для потолка стока в 280 л.с. я бы рекомендовал поставить бензонасос 255 л/ч.
Далее как выглядит написание прошивки в nistune. Собственно писать я её буду под сток двигатель с бустконтроллером, прямоток и нулевиком.
При запуске Nistune с начала выбираем модель под которую будет писаться прошивка. Это очень важный момент т.к. разные ECU имеют разные адресные карты и с «не родным» адресным файлом, ваша машина в лучшем случае просто не заведется.
Далее там появиться меня и ищем в нем свою платформу и двигатель. После выбора так же надо будет выбрать прошивку нашего двигателя.
После того как у нас откроется прошика мы сможем её редактировать. Прошивку тоже желательно выбирать согласно модели своего ECU.
Первым делом я направися во вкладку Limits. Она отвечает за отсечки по TPS, оборотам, скорости.
Изменение параметров не вызывает трудности. После клика мыши открывается не большое меню с бегунком которым и производится регулирование.
Soft Rev limit 1 — отвечает у нас за отсечку по оборотам когда дроссель полностью не открыт.
Hard Rev limit 1 — отвечает у нас за отсечку по оборотам когда дроссель полностью открыт. Не рекомендую эту отсечку трогать со стоковыми валами т.к. сток валы примерно при 7500 тысячах начинают активно деградировать.
Safety Rev limit — отвечает за отсечку оборотов при полностью закрытом дросселе.
Safety TP limit — отвечает за отсечку по допустимому открытию дросселя.
Speed limit 1 — отвечает за отсечку по скорости при полностью открытом дросселе.
Speed limit 2 — отвечает за отсечку по скорости когда дроссель полностью не открыт.
Я трогал только отсечку по скорости, поставил оба параметра в 250 км/ч.
Так же если есть необходимость можно изменить карту MAF и К константу при замене форсунок.
Запчасти на фото: 4501450, 0344748, 4711304
В нистюн это все автоматизированно. Если будете работать с другой программой константу К придется считать в ручную. Формула расчета замены форсунок не сложна (производительность старых форсунок / производительность новых форсунок) * константа старых форсунок = константа новых форсунок.
Т.к. у нас прямоток и нулевик, то нам нужно убрать в ECU ограничения что бы наши улучшения не свелись к нулю (да, да прямоток и нулевик без перепрошивки не дают некого прироста мощности, одни звуковые изменения)
Находим вкладку Limit tables
Запчасти на фото: 4871403, 4821482
Min TPulse width — этот параметр отвечает за длительность впрыска топлива что бы двигатель не заглох когда вы после активного педалирования бросаете газ. Его можно не трогать.
Min TPulse width — этот параметр отвечает за максимальное время впрыска топлива. Это и есть один из ограничителей наших спеков типа нулевика и прямотока. Т.к. двигатель даже получая больше воздуха, в цилиндры не нальет топлива больше чем положено и сделает нулевик, и прямоток бесполезными. Тут можно начиная примерно с 2800 оборотов ставить 175. Не советую без тонкой настройки ставить максимальное значение в 255 т.к. вам скорее всего будет заливать свечи и взорвется выхлоп.
Load cut — отсечка по топливу/бусту. Вторая палка мешающая нашим спекам увеличить мощность нашего мотора. Из-за этого параметра при поступление воздуха больше чем указано мозгу он отсекает подачу топлива. Тут можно выставить везде 255 если вы собираетесь дуть в двигатель больше 1кг. Я ограничился так же 175 от 2800 оборотов.
В моем случае я на этом закончил. И сохранил прошивку сразу для записи её на чипы.
Запчасти на фото: 4208470, 030870, 4821482
Но сохраняем в формате odd/even для 256 чипов. Если у вас ECU использует 512 чипы то нужно сохранять одним файлом.
После прихода некоторых спеков напишу про более подробное написание прошивки с расширением топливных карт и прочими интересными вещами.
Первое автомобильное программное обеспечение появилось в автомобилях еще в 60-х годах. Благодаря этому отрасль серьезно изменилась – сегодня электроника, и особенно программное обеспечение, являются основными источниками инноваций. Автомобильное программное обеспечение повышает надежность с помощью систем активной и пассивной безопасности, таких как антиблокировочная тормозная система и электронная система курсовой устойчивости (ESC). Кроме того, происходит постепенная интеграция бытовой электроники в автомобили.
Содержание
- Разработка автомобильного программного обеспечения
- Требования к программному обеспечению в автомобиле
- Структура программного обеспечения в автомобилях
- Важные стандарты для автомобильного программного обеспечения
- Органы и комитеты
- AUTOSAR
- Стандарты диагностики
- Процесс разработки программного обеспечения
- Модели для описания процессов
- Принцип V-модели
- Модели для оценки процессов
- ISO 9000 и TS 16949
- CMMI
- Automotive SPICE
- Контроль качества при разработке программного обеспечения
- ISO 61508 и TS 26262
- Процессы разработки программного обеспечения для автомобилей
- Разработка программного обеспечения на базе моделей
- Функциональные сети и сети ЭБУ
- Моделирование и имитация программных функций
- Моделирование
- Создание прототипа быстрого управления программными функциями
- Процедура обхода
- Приложения обхода
- Приложение с полной поддержкой
- Виртуальное создание прототипов
- Проектирование и реализация программных функций
- Интеграция и тестирование программного обеспечения и ЭБУ
- Требования
- Циклические испытательные системы
- Калибровка программных функций
- Процедура
- Автономная калибровка
- Калибровка в реальном времени
- Перспективы
Разработка автомобильного программного обеспечения
Любая разработка программного обеспечения имеет целью создание новой или улучшение существующей функции. Такие функции создают дополнительные плюсы и удобства для водителя, других пассажиров, механиков СТО, перевозчиков, обеспечивают соответствие требованиям законодательства, упрощают обслуживание или повышают эффективность проектирования и изготовления. Техническая реализация может быть механической, гидравлической, электрической или электронной. Часто комбинируют сразу несколько этих технологий, а ключевую роль в реализации многих автомобильных новшеств все чаще играет электроника. Благодаря использованию электрики, электроники и программного обеспечения — логического ядра систем — экономически эффективно реализуются «интеллектуальные» функции привода, шасси и остальной части автомобиля.
Управление и контроль практически всех функций в автомобилях всех классов сегодня осуществляет электроника. Технологический прогресс и развитие электроники позволяют реализовать многие новые, более мощные функции за счет использования программного обеспечения.
Требования к программному обеспечению в автомобиле
Требования к программному обеспечению в автомобиле сильно разнятся. Многие системы для управления двигателем и обеспечения безопасности движения должны гарантировать реакцию операций управления, чтобы не возникло отставание от физического процесса. Поэтому при управлении очень быстрыми физическими процессами, такими как управление двигателем или динамикой движения, вычисления должны выполняться очень быстро. Кроме того, очень высоки требования к надежности во многих областях. Это особенно относится к функциям обеспечения безопасности. Автомобильное программное обеспечение и электроника контролируются сложными системами диагностики.
Автомобильное программное обеспечение используется во многих вариантах автомобиля и даже модельных рядах. Поэтому оно должно легко адаптироваться к соответствующим системам. Для этого оно содержит параметры калибровки и программные карты. Их количество в автомобиле может достигать нескольких десятков тысяч. Эти регулируемые переменные имеют множество взаимных зависимостей. К тому же постоянно увеличивается степень связи отдельных систем между собой. Все чаще одна функция распределяется между несколькими системами или ЭБУ.
Программное обеспечение в автомобиле большей частью разрабатывается под конкретные области применения и интегрируется в единую систему. Его еще называют встроенным программным обеспечением, «зашитым» в постоянное запоминающее устройство. Многие функции часто разрабатываются и дорабатываются в течение длительного времени во многих уголках мира. Поскольку запасные части должны оставаться в наличии даже после завершения производства конкретного автомобиля, электроника в автомобиле должна иметь относительно длительный срок службы — до 30 лет.
Из соображений экономии в ЭБУ зачастую содержатся микроконтроллеры с ограниченной вычислительной мощностью и ограниченным объемом памяти. Во многих случаях для этого требуются меры по оптимизации разработки программного обеспечения для сокращения количества необходимых аппаратных средств.
Характерные особенности программного обеспечения зависят от области применения. В то время как программное обеспечение для привода и трансмиссии имеет широкие рамки, в программном обеспечении для ходовой части акцент делается на характеристиках, проявляемых в реальном времени. В системах обеспечения безопасности комфорта акцент делается на эффективность, т.е. расход ресурсов, а в мультимедийных приложениях за короткое время требуется обрабатывать большие объемы данных.
Проблемы, возникающие в связи с этими требованиями, должны решаться в тесном сотрудничестве автопроизводителей и поставщиков.
Структура программного обеспечения в автомобилях
Программное обеспечение в автомобиле состоит из множества компонентов. Как и в случае с персональным компьютером, различают «воспринимаемые функции» программного обеспечения, прикладное программного обеспечения и платформенное программное обеспечение, частично зависящее от аппаратной части (рис. «Основные компоненты статичной программной архитектуры для микроконтроллеров и стандартизованных программных компонентов» ). Взаимодействие между всеми функциями определяется в архитектуре. Здесь могут быть различные отображения. Статичное отображение иерархически описывает функциональные группы, сигналы и распределение ресурсов. С другой стороны, функциональное отображение описывает прохождение сигнала через различные функции. Динамическое отображение, т.е. зависимое от времени, анализирует отклик при выполнении различных задач. Уже на раннем этапе введены стандарты для обеспечения взаимодействия между отдельными компонентами и их дальнейшего развития. Наиболее важные стандарты описаны ниже.
Важные стандарты для автомобильного программного обеспечения
Органы и комитеты
Ассоциация стандартизации автоматизированных и измерительных систем (ASAM) занимается стандартизацией в автомобильной промышленности применительно к моделям данных, интерфейсам и синтаксису. ASAM разработала различные стандарты для подключения ЭБУ к компьютеру или терминалу ввода данных. Стандарт ASAM-MCD1 (MCD — измерение, калибровка и диагностика) поддерживает различные протоколы передачи данных. При использовании спецификаций ASAM-MCD2 можно обращаться к двоичным данным в ЭБУ и одновременно отображать соответствующие данные в виде физических значений и обрабатывать их. Стандарт ASAM-MCD3 также позволяет автоматизировать такие процессы, например, для автоматической калибровки данных. Есть и другие стандарты ASAM, регламентирующие, к примеру, обмен функциональными описаниями и данными.
Консорциум FlexRay разработал спецификацию для полевой шины FlexRay для регулирования по разомкнутому и замкнутому (с обратной связью) циклу в автомобилях. Благодаря высокой скорости передачи данных с запрограммированным арбитражем шины и отказоустойчивой конструкции она особенно подходит для использования в системах активной безопасности и в системе привода.
Международная электротехническая комиссия (IEC) устанавливает стандарты в области электротехники и электроники. IEC предлагает три системы анализа, с помощью которых можно проверить соответствие международным стандартам. IEC работает в тесном взаимодействии с международной организацией по стандартизации (ISO), международным телекоммуникационным союзом (ITU) и многочисленными органами стандартизации (в том числе Институтом инженеров-электриков и электронщиков, IEEE).
Ассоциация разработчиков программного обеспечения для автомобилей (MISRA) — организация в автопромышленности, устанавливающая правила для разработки и внедрения надежного программного обеспечения в автомобильных системах. Самым известным является стандарт программирования MISRA-C, разработанный компанией MISRA. Он предписывает правила надежного программирования на языке С. Цель этого стандарта — избежать ошибок периода исполнения из-за ненадежных конструкций языка С и возникновения слабых мест в структуре из-за непонимания между программистами, и защитить правильность выражений. Многие правила могут автоматически проверяться и учитываться при генерировании кодов.
Сообщество автомобильных инженеров (SAE) — международная научно-техническая организация, работающая в области технологий для обеспечения мобильности. Помимо прочего, оно устанавливает стандарты для автомобильной промышленности и способствует обмену знаниями.
Стандартизационный орган «Открытые системы и их интерфейсы для автомобильной электроники» (OSEK) появился из проекта немецкой автомобильной промышленности. Позже появилась инициатива «Vehicle Distributed Executive» (VDX) французской автомобильной промышленности. Стандартизация базовых компонентов программного обеспечения осуществляется под эгидой OSEK/VDX в следующих областях:
- Связь (обмен данными внутри и между ЭБУ);
- Операционная система (выполнение в реальном времени программ ЭБУ и базовых услуг для других модулей OSEK/VDX);
- Управление сетью (конфигурация и контроль).
Архитектура программных платформ для японской автомобильной промышленности (JasPar) — инициатива для сокращения расходов и технологий разработки в автомобильной электронике. Она поощряет японские компании совместно разрабатывать технологии, не имеющие отношения к конкуренции, такие как сетевые решения, сервисные функции и базовое программное обеспечение. JasPar работает в тесном сотрудничестве с AUTOSAR и FlexRay.
AUTOSAR
AUTOSAR — это ассоциация автопроизводителей, изготовителей ЭБУ и средств для разработки, базового программного обеспечения для ЭБУ и микроконтроллеров. Цель AUTOSAR — упрощение обмена программного обеспечения на разных ЭБУ. Для этого была разработана стандартизированная программная архитектура со стандартизированными форматами описания и конфигурации для встроенного автомобильного программного обеспечения. AUTOSAR определяет методы описания программного обеспечения в автомобилях, обеспечивающие возможность повторного использования, обмена, масштабирования и интеграции компонентов программного обеспечения.
Главным для AUTOSAR является логическое распределение между базовым программным обеспечением (BSW) для конкретных ЭБУ и прикладным программным обеспечением, независимым от ЭБУ (ASW) и их соединение по виртуальной системе шин (VFB) (рис. «Архитектура AUTOSAR» ). Эта виртуальная шина также соединяет компоненты программного обеспечения, реализованные в разных ЭБУ. Таким образом, их можно смещать между разными ЭБУ без необходимости вносить изменения в сами компоненты программного обеспечения. Это может быть полезно при оптимизации вычислительной мощности, требований к памяти и коммуникационной нагрузки.
Функциональные программные компоненты (SWC) строго разграничиваются между собой и с базовым программным обеспечением. Они, как правило, содержат конкретные алгоритмы управления, выполняемые во время прогона программы. Они сообщаются через интерфейс AUTOSAR с другими функциями и интерфейсами ЭБУ. Эти интерфейсы (API) определяются в описаниях SWC XML.
Среда прогона программы (RTE) обеспечивает связь между функциональными компонентами программного обеспечения и соответствующим базовым программным обеспечением на ЭБУ. RTE адаптируется к конкретному ЭБУ и области применения. Она может в большой степени создаваться автоматически из требований к интерфейсу.
Базовое программное обеспечение содержит программные части для конкретных ЭБУ — интерфейсы связи, диагностику и управление памятью. Базовое программное обеспечение также содержит слой сервисов. Это программное обеспечение сочетает в себе программные компоненты для общих сервисных функций (SRV), связи (СОМ) и операционной системы, частично зависящей от используемого ЭБУ (OS). Последняя базируется на операционной система OSEK/VDX. В этой области ресурсы ЭБУ группируются и управляются таким образом, чтобы получить оптимальную сетевую поддержку, управление памятью, диагностику и пр. Используемые аппаратные средства заключаются в два слоя со взаимной зависимостью. Абстракция микропроцессора (MCAL) с прямым доступом к интерфейсным модулям ЭБУ продолжается в еще одном слое (абстракция ЭБУ). Драйверы сложных устройств (CCD) обеспечивают прямой доступ к ресурсам микроконтроллера для приложений с особыми требованиями к функциональности и выбору времени. Они также являются неотъемлемой частью базового программного обеспечения, т.е. прикладное программное обеспечение можно разрабатывать независимо от аппаратной части, даже когда требуются услуги драйверов сложных устройств.
Помимо архитектуры ЭБУ, AUTOSAR частично стандартизирует также методы разработки. Это прежде всего относится к структуре и зависимостям различных рабочих продуктов (например, файлов). Они нужны для создания выполнимых программ для соответствующих ЭБУ из разных описаний программных компонентов.
Стандарты диагностики
Системы диагностики для проектирования и производства, ремонта и обслуживания автомобилей показали себя как очень затратные и негибкие. Они привязывают изготовителей к поставщикам и предотвращают простой обмен данными в случае взаимодействия между компаниями. Поэтому был разработан ряд диагностических стандартов.
Рабочая группа Automotive Electronics (ASAM-AE) разработала три спецификации для программных средств диагностики автомобилей, публикуемых в виде международных стандартов в группе стандартов ISO 22900:
- Интерфейс между средой прогона и устройствами связи (MCD-1Dи PDU-API, ISO 22900);
- Стандарт ODX для обмена данными диагностики, например, для передачи данных на тестер СТО (MCC-2D, ISO 22901);
- Интерфейс объектно-ориентированного программирования (MCD-3D, ISO 22900) для диагностических приложений, таких как, например, диагностика с подсказками.
Стандарт MCD-1C учитывает существующие стандартные инструменты, например, устройства для программирования ЭБУ.
В настоящее время в рамках проекта стандарта ISO разрабатываются требования к формату обмена, «Коммуникационный формат последовательной проверки на отсутствие разрывов» (ОТХ), для создания, использования и обмена диагностическими программами.
Процесс разработки программного обеспечения для автомобиля
Краеугольным камнем разработки программного обеспечения является изображение логической системной архитектуры в конкретной системе со всеми программами и данными. Здесь рассматривается вся система автомобиля, управляемая процессором. Особая важность придается четкому разделению составления технического задания, проектирования и реализации. Техническое задание с определением функций программного обеспечения составляется на физическом уровне, а проектирование и реализация программ и данных привязываются к конкретному микроконтроллеру.
Для удовлетворения приведенных выше требований в разработке программного обеспечения для автомобилей неотъемлемой частью разработки, в дополнение к технологии и инструментам, являются определяемые последовательности (процессы).
Модели для описания процессов
Для описания процессов при разработке программного обеспечения используется множество более или менее сложных моделей. Они обеспечивают прозрачность процессов, их сравнение, выявляют проблемные области и служат для проверки соответствия определенным стандартам. Однако они изначально не задумывались для непосредственного повышения качества самого программного обеспечения, эффективности или устранения систематических сбоев в процессах. Поэтому модели для описания процессов являются подходящими лишь частично. Ниже приводится описание на примере распространенной V-модели.
Принцип V-модели
Описанное здесь V-образное отображение процесса разработки используется во многих вариациях и степенях детализации. V-модель Федерации проектирования и реализации в сфере информационных технологий правительства Германии здесь описана не будет.
V-модель распределяет этапы процесса, связанные непосредственно с разработкой, по лучам воображаемой буквы V, где по оси х отображается ход разработки, а по оси у — степень детализации соответствующего этапа (рис. «Расширенная V-модель» ). Этап процесса можно описать необходимыми вводными переменными, процедурой, методами, ролями, инструментами, критериями качества и выходными переменными. Этапы процесса, определяемые на левом луче латинской V, проверяются на ее правом луче. Эти этапы могут также проходиться несколько раз или быть поделены на части.
В расширенной V-модели можно рассмотреть сопутствующие процессы — например, запрос, изменение, управление проектом и качеством.
Модели для оценки процессов
Модели для оценки процессов, в дополнение к чистому описанию задач и процессов, предоставляют информацию о зрелости и качестве процессов. Таким образом, можно сравнивать, оценивать и утверждать этапы работы. Они также позволяют определить узкие места процессов, влияющие, к примеру, на качество продукта или затраты. Однако информация о качестве процессов не дает полной картины качества самих продуктов. Здесь описываются три самые важные модели оценки процессов.
ISO 9000 и TS 16949
Ориентированный на процессы стандарт EN ISO 9000 регламентирует требования к системе управления качеством. Акцент здесь делается на взаимодействия и интерфейсы. Изначально акцент делался на производство и интерфейсы заказчика.
Техническая спецификация ISO/TS16949 была разработана североамериканской и европейской автомобильной промышленностью устанавливает требования к системам управления качеством. Цель этого стандарта — эффективное повышение качества системы и процессов для повышения степени удовлетворенности клиентов, выявления сбоев и рисков в производственном процессе и каналах сбыта, устранения их причин и проверки эффективности коррекционных и профилактических мер. Сутью спецификации является не выявление, а скорее предотвращение сбоев. Соответствие ISO 9000 и TS 16949 можно проверить путем сертификации.
CMMI
CMMI — это модель для оценки и систематической оптимизации организаций- разработчиков и их процессов, изначально разработанная Институтом разработки программного обеспечения (SEI). Она описывает набор требований к процессам и их зависимости (рис. «Обзор процесс CMMI. ML-уровень зрелости» ). CMMI обеспечивает рамки, реализация которых требует ориентированной на бизнес интерпретации и организации содержания. Она описывает то, что необходимо сделать. Организация должна соответствующим образом описать, «как» это необходимо сделать. Содержание модели CMMI базируется на передовых методах организации работы, т.е. «лучших методах». CMMI обеспечивает процедуру для оптимизации процессов на долгосрочную перспективу от пути развития организации до обучения организации.
CMMI имеет много общего в плане содержания с ISO 9000/TS 16949. В этом контексте CMMI имеет большую степень детализации, в то время как ISO 9000/TS 16949 охватывает более широкий спектр областей применения.
CMMI различает пять уровней зрелости (ML) подразделения организации (рис. «Уровни зрелости CMMI» ). Рассматриваются различные области процесса, в зависимости от уровня зрелости. Уровень зрелости считается достигнутым, когда все соответствующие области процесса отлажены и проверены системой оценки. Для выхода на более высокий уровень зрелости нужно еще раз проверить области процесса нижнего уровня.
CMMI используется в качестве оптимизационной-оценочной модели для организаций-разработчиков и обеспечивает хорошую поддержку при оптимизации процессов во всех подразделениях организации и оценке поставщиков.
Automotive SPICE
Аббревиатура SPICE расшифровывается как «совершенствование процессов в разработке программного обеспечения и определение возможностей». Automotive SPICE — это «автомобильный» вариант международного стандарта ISO/IEC 15504 (Процессы при разработке программного обеспечения). Это модель для оценки, с учетом специфики проекта, процессов, имеющих место при разработке программного обеспечения. Она, как и CMMI, концентрируется на требованиях к систематической разработке. Поэтому содержание моделей Automotive SPICE и CMMI очень похоже. Automotive SPICE больше концентрируется на требованиях к уровню и дает меньше возможностей для ориентированной на бизнес интерпретации требований. Automotive SPICE фокусируется (в настоящее время) только на программном обеспечении и только на отдельных проектах. Напротив, области применения CMMI шире и охватывают любые работы и услуги в сфере разработки и руководство ими. Automotive SPICE используется автопроизводителями в качестве модели для оценки проектов и поставщиков в области разработки программного обеспечения.
Оценка процессов выполняется с помощью двухразмерной модели. Понятие «размер процесса» служит для определения и выбора анализируемых процессов, а «размер уровня зрелости» — для определения и оценки их соответствующей возможности. Размер уровня зрелости состоит из шести ступеней уровня зрелости — «не завершено», «выполнено», «проконтролировано», «установлено», «предсказуемо» и «оптимизация».
Контроль качества при разработке программного обеспечения
Как и в случае с любым техническим продуктом, при разработке автомобильного программного обеспечения также используется множество инструментов для контроля качества. В отличие от механики и электрики, контроль качества играет менее значительную роль в создании программного обеспечения, поскольку оно относительно легко воспроизводится. Важными моментами здесь являются общая функциональность системы, стандарты качества, овладение сложностью и применение. Поскольку программное обеспечение в автомобиле также охватывает системы, имеющие отношение к безопасности — например, систему управления динамикой и системы повышения безопасности при движении (DAS), контроль качества играет важную роль. Кроме того, очень важное значение имеет экономическое представление качества программного обеспечения, особенно в сложных системах.
ISO 61508 и TS 26262
В настоящее время автомобильная промышленность разрабатывает стандарт ISO 26262 (Транспортные средства — функциональная безопасность) для проектирования имеющих отношение к безопасности электрических и электронных систем в автомобилях на базе стандарта IEC 61508 (Функциональная безопасность электрических / электронных / программируемых электронных систем, имеющих отношение к безопасности). Он включает в себя требования и к продукту, и к процессу разработки, и охватывает концепцию, проектирование, разработку, реализацию, запуск, обслуживание, модификацию, выключение и демонтаж как самой системы, имеющей отношение к безопасности, так и систем, уменьшающих риск. Стандарт обозначает эти этапы в целом как «полный жизненный цикл безопасности». Продукты делятся на уровни интеграции безопасности SIL1 — SIL 4 (ISO 61508) и автомобильные SIL, ASIL А — ASIL D (ISO 26262). SIL 1 и ASIL А, являются самым низким, a SIL 4 и ASIL D самым высоким уровнем интеграции безопасности.
Процессы разработки программного обеспечения для автомобилей
Междисциплинарная кооперация в разработке (например, между разработкой привода и электроники), распределенная разработка (например, между поставщиком и автопроизводителем или разработка в разных местах) и длительные жизненные циклы элементов программного обеспечения требуют общего понимания задач в целом. Например, при проектировании автомобильных функций управления с обратной связью и без нее, также должен обеспечиваться общий обзор всех требований к надежности и безопасности, а также аспектов реализации программного обеспечения. Для этого во многих областях используется разработка программного обеспечения на базе моделей (рис. «Этапы разработки программных функций на основе моделей» ).
Разработка программного обеспечения на базе моделей
Различают две области разработки программного обеспечения на базе моделей. Логическая системная архитектура содержит и описывает виртуальную область моделей, в то время как техническая системная архитектура содержит реальные ЭБУ и автомобили. Логическая системная архитектура отображается серым цветом, а техническая системная архитектура — белым. Эта процедура описывается функциями управления с обратной связью и без обратной связи, но подходит также и для общей реализации функций — например, для контроля и диагностики.
Функциональная модель на базе графики рассматривает все компоненты системы и может использоваться в качестве основы для общего понимания. При разработке программного обеспечения использование методов разработки на базе моделей, с блок-схемами или машинами конечного состояния, все чаще заменяет текстовые спецификации программного обеспечения. Этот метод моделирования программных функций имеет и другие преимущества. Если модель спецификации описывается формально, т.е. однозначно, без вариантов интерпретации, как математическая функция, то спецификация может быть выполнена на компьютере в режиме имитации и быстро и реалистично протестирована в самом автомобиле посредством создания прототипа быстрого управления. Кроме того, намного проще могут быть вскрыты несоответствия.
Для реализации заданных функциональных моделей в качестве программных компонентов для ЭБУ можно использовать методы автоматизированного генерирования кода. Поэтому функциональные модели должны содержать дополнительную информацию о разработке программного обеспечения. Сюда могут относиться меры по оптимизации, зависящие от характеристик продукта, необходимых электронной системе. Автоматизированное генерирование кода также гарантирует последовательность качественных характеристик кода.
На следующем этапе виртуальные модели среды, при необходимости дополняемые реальными компонентами, такими как форсунки, имитируют среду ЭБУ, тем самым позволяя проводить циклические лабораторные испытания формата «In-the-Loop». По сравнению с испытаниями на стенде и на дороге они повышают гибкость и глубину испытаний, упрощая их воспроизводимость. Калибровка функций программного обеспечения в электронной системе должна учитывать настройки, относящиеся к конкретному автомобилю — например, параметры, записанные в виде характеристических значений, кривых и карт этих функций. Во многих случаях это сопоставление происходит лишь на более поздней стадии разработки; зачастую прямо в автомобиле во время работы систем. Однако усиливается тенденция к более ранней (предварительной) передаче данных; т.е. уже на ранних этапах разработки как можно более реалистичные калибровочные данные определяются с помощью моделей или эмпирических значений. Из-за множества калибровочных переменных и взаимной зависимости для калибровки требуются подходящие процедуры и инструменты, потому что в конечном итоге качество калибровки, т.е. точная адаптация программного обеспечения к автомобилю, определяет степень использования потенциала программного обеспечения.
Функциональные сети и сети ЭБУ
Эта процедура может также применяться к разработке функциональных сетей и сетей ЭБУ. Однако в этих случаях появляются дополнительные аспекты, например:
- Комбинации смоделированных, виртуальных компонентов и функций, уже реализованных в коде ЭБУ;
- Комбинации смоделированных, виртуальных и реализованных механических компонентов и устройств.
Это полезно для различения функций на абстрактном уровне и технической реализации на более конкретном уровне. Концепция раздельного абстрактно-конкретного подхода применима ко всем компонентам автомобиля, к водителю и окружающей среде.
Моделирование и имитация программных функций
Моделирование систем управления автомобиля
Для моделирования систем управления с обратной связью и без обратной связи следует по возможности использовать блок-схемы. В этих схемах для отображения отклика компонентов используются блоки, а для отображения потока сигналов между блоками — стрелки (рис. «Моделирование с блок-схемами и имитацией» ). Поскольку большинство систем многовариантны, то все сигналы обычно представлены в виде векторов. Они классифицируются на:
- Измерительные переменные или переменные обратной связи у;
- Выходные переменные с управлением без обратной связи или с обратной связью u*
- Контрольные или заданные переменные w;
- Значения, задаваемые водителем w*;
- Переменные с управлением без обратной связи или с обратной связью у*:
- Регулируемые переменные u
- Значения возмущений z
Блоки классифицируются на:
- Блоки с управлением без обратной связи или с обратной связью;
- Модели исполнительных механизмов;
- системная модель;
- Модели генераторов заданных значений и датчиков;
- Модель водителя и окружающей среды.
Водитель может повлиять на функции контроллера без обратной связи или с обратной связью путем определения заданных значений. Все компоненты для ввода значений, задаваемых водителем (например, выключатели или педали), известны как генераторы заданных значений. В отличие от них, датчики регистрируют сигналы с завода. Модель этого типа может быть выполнена в имитационной системе (например, на персональном компьютере), что позволяет более детально проанализировать ее.
Создание прототипа быстрого управления программными функциями
Создание прототипа быстрого управления в этом контексте включает в себя все методы для ранней реализации спецификаций для функций управления без обратной связи или с обратной связью в реальном автомобиле. Для этого в испытании должны быть реализованы смоделированные функции управления без обратной связи или с обратной связью. В качестве платформы для реализации программных частей функций управления без обратной связи или с обратной связью можно использовать экспериментальные системы (рис. «Создание прототипа быстрого управления программных функций в реальном автомобиле» ).
Экспериментальные системы соединяются с генераторами заданных значений, датчиками и исполнительными органами, а также другими автомобильными ЭБУ, относящимися к общей системе. Интерфейсы с реальным автомобилем означают, что программные функции, реализованные в экспериментальной системе — и в ЭБУ — учитывают потребности в реальном времени.
В качестве ЭБУ в экспериментальных системах обычно используются компьютерные системы реального времени со значительно большей вычислительной способностью. Для решения этой задачи в качестве процессорного ядра все чаще используются персональные компьютеры. Это позволяет автоматически преобразовать модель программной функции из спецификации в реализуемую модель посредством создания прототипа быстрого управления, регламентируемого стандартизированными правилами. Затем заданное поведение можно моделировать с максимально возможной точностью.
Экспериментальные системы с модульной структурой можно конфигурировать под конкретную область применения — например, под необходимые интерфейсы для сигналов ввода-вывода. Вся система рассчитана на использование в автомобиле и управление от компьютера, например, персонального. Это позволяет тестировать спецификации программных функций на ранней стадии прямо в автомобиле. Затем спецификации могут, при необходимости, быть изменены.
При использовании экспериментальных систем различают приложения обхода и приложения с полной поддержкой.
Процедура обхода
Приложения обхода в основном используются тогда, когда разрабатывается лишь несколько программных функций и имеется ЭБУ с хорошо зарекомендовавшей себя базовой функциональностью — например, из предыдущего проекта.
Приложения обхода также подойдут, если функции датчика и исполнительного механизма ЭБУ очень сложны, а их поддержка требует значительных усилий со стороны экспериментальной системы (например, в случае с ЭБУ двигателя).
Приложения с полной поддержкой больше подходят, если ЭБУ этого типа нет, если требуется протестировать дополнительные генераторы заданных значений, датчики и исполнительные механизмы и если функциональность ЭБУ достаточно сложная.
Можно также скомбинировать обход отдельных частей программного обеспечения с полной поддержкой всего программного обеспечения в целом, что повышает гибкость.
Приложения обхода
Приложения обхода подходят для раннего тестирования дополнительной или модифицированной программной функции автомобильного ЭБУ. Новая или модифицированная программная функция определяется моделью и работает в экспериментальной системе. Для этого требуется ЭБУ, способный выполнять базовые функции программного обеспечения, поддерживать все необходимые генераторы заданных значений, датчики и исполнительные органы и обеспечивать интерфейс обхода для экспериментальной системы. Новая или модифицированная программная функция разрабатывается с помощью создания прототипа быстрого управления. В этом случае она выполняется в экспериментальной системе (рис. «Разработка прототипа с системой обхода» ).
Этот подход также приемлем для дальнейшего развития существующих функций ЭБУ. В этом случае существующие функции в ЭБУ продолжают использоваться, но модифицируются до такой степени, чтобы вводные значения отправлялись через интерфейс обхода, и использовались выходные значения из новой функции обхода. Необходимые программные изменения в ЭБУ называются ловушками обхода. Для синхронизации функциональных вычислений между ЭБУ и экспериментальной системой обычно используется процедура, когда ЭБУ инициирует вычисления функции обхода в экспериментальной системе через интерфейс управляющей логики. ЭБУ контролирует правдоподобие выходных значений функции обхода.
На функцию обхода можно также повлиять через автомобильную шину (например, CAN). Возможен даже доступ к центральному процессору ЭБУ через интерфейсы микроконтроллера посредством эмулятора.
Приложение с полной поддержкой
Если в автомобиле должна тестироваться совершенно новая функция, а ЭБУ с интерфейсом обхода нет, то испытания можно провести с помощью приложения «с полной поддержкой». В этом случае экспериментальная система должна поддерживать все генераторы заданных значений, датчики и интерфейсы исполнительных органов для данной функции.
Поведение функции в реальном времени также должно быть определено и гарантировано экспериментальной системой (рис. «Разработка прототипов с полной поддержкой» ). Вообще, это делается операционной системой реального времени на компьютере с полной поддержкой.
Виртуальное создание прототипов
В случае со сложными системами лучше тестировать функции как можно раньше. Одну из возможностей дает виртуальное создание прототипов. Здесь прототип тестируется в виртуальной модели среды. Операционная система более нового ЭБУ (например, RTA) работает в экспериментальной системе. Это позволяет считать временную характеристику более нового программного обеспечения хорошей.
Проектирование и реализация программных функций
На основании спецификации данных на стадии проектирования необходимо учесть функциональное поведение программной функции и ее поведение в реальном времени, все технические детали сети ЭБУ, реализованный микроконтроллер и архитектуру программного обеспечения. Тогда окончательная реализация программных функций может быть определена и осуществлена на базе программных компонентов (рис. «Реализация функции управления с обратной связью и без обратной связи с помощью сети ЭБУ» ).
В дополнение к решениям по структуре и поведению программной функции, здесь учитываются временные и дискретные функции микроконтроллеров, реализация включает в себя решения по поведению в реальном времени, распределению и интеграции микроконтроллеров и ЭБУ и требованиям к надежности и безопасности электронных систем. Необходимо также учитывать все требования к электронным системам и автомобилям с точки зрения производства и обслуживания (например, концепции контроля и диагностики, параметризация программных функций, или обновления программного обеспечения для ЭБУ).
Создание кода и сопутствующих данных (данные для документации, управление вариантами или предварительная передача данных калибровки) часто выполняются автоматически в соответствии с установленными стандартами.
Интеграция и тестирование программного обеспечения и ЭБУ
Требования к программному обеспечению автомобиля
Прототипы автомобилей зачастую имеются в ограниченном количестве. Это означает, что у поставщика компонентов часто отсутствует полная или обновленная среда для интеграции и тестирования поставляемых компонентов. Ограничения среды тестирования могут иногда ограничивать возможные его этапы. По этой причине модели сред часто служат основой для испытательных систем и стендов на этапе интеграции и тестирования.
Интеграция компонентов — это точка синхронизации для разработок всех отдельных компонентов. Интеграционное, системное и приемочное тестирование не могут быть выполнены до тех пор, пока не будут доступны все компоненты. Для ЭБУ это означает, что программные функции могут тестироваться только при наличии всех компонентов в системе автомобиля (ЭБУ, генераторов заданных значений, датчиков, исполнительных механизмов и системы). Использование циклических систем тестирования формата In-the-Loop в лаборатории позволяет заранее проверять ЭБУ в виртуальной среде тестирования при отсутствии фактических периферийных компонентов (рис. «Интеграция и тестирование ЭБУ с помощью циклической испытательной системы» ).
Это позволяет проводить и автоматизировать испытания в воспроизводимых лабораторных условиях с высоким уровнем гибкости. В отличие от испытаний на стенде или в реальном автомобиле можно протестировать полный, неограниченный спектр рабочих состояний (например, ЭБУ двигателя можно протестировать при любой нагрузке и любых оборотах). Износ автомобиля и ситуации сбоев имитируются легко и позволяют протестировать функции контроля, диагностики и обеспечения безопасности. Допуски компонентов (например, в генераторах заданных значений, датчиках и исполнительных органах) можно имитировать таким образом, чтобы можно было проверять надежность функций управления с обратной связью и без обратной связи.
Значительным плюсом также является большая глубина тестирования, которой можно достичь путем автоматизации. Это позволяет, к примеру, протестировать максимально возможное количество типов сбоев и их комбинаций при точно воспроизводимых условиях и документировать их в журнале сбоев.
Эта процедура также применима к испытаниям имеющихся генераторов, заданных значений, датчиков и исполнительных органов. Интерфейсы испытательной системы необходимо соответствующим образом изменить. В эту процедуру можно также встроить любые промежуточные этапы.
На рис. «Интеграция и тестирование ЭБУ с помощью циклической испытательной системы» ЭБУ изображены в виде «черного ящика». Поведение функций ЭБУ можно оценить только на основе входных и выходных сигналов w, у и u*. Этого изображения в виде «черного ящика» достаточно для простых программных функций. Однако для тестирования более сложных функций требуется интеграция процедуры измерения для внутренних промежуточных переменных ЭБУ. Эта технология измерения также называется инструментальным методом. Тестирование диагностических функций также требует доступа к запоминающему устройству неисправностей через диагностический интерфейс ЭБУ, а для этого требуется интеграция измерительно-диагностической системы (рис. «Интеграция и тестирование ЭБУ в реальном автомобиле» ).
Циклические испытательные системы
При циклических испытаниях встроенная электронная система подключается через интерфейсы к реальной (датчики, исполнительные органы) или виртуальной (математические модели) среде. Реакция системы анализируется и вводится обратно в систему. В зависимости от типа испытательных образцов различают следующие испытательные системы:
- В случае циклических испытаний модели (Model-in-the-Loop, MiL) тестируется функциональная модель программного обеспечения. Модель запускается на инструментальном компьютере систем автоматизированного проектирования.
- В случае циклических испытаний ПО (Software-in-the-Loop, SiL) тестируется программный код. Он запускается на инструментальном компьютере систем автоматизированного проектирования.
- В случае циклических испытаний функции (Function-in-the-Loop, FiL) тестируется программный код. Однако в отличие от SiL, он прогоняется на конечном устройстве. Связь между программным обеспечением и моделью среды выполняется посредством ловушек и эмулятора.
- В случае циклических испытаний аппаратной части (Hardware-in-the-Loop, HiL), весь ЭБУ проверяется посредством интерфейсов ввода-вывода. Также используются сочетания FiL и HiL. В качестве имитационных компьютеров все больше используются персональные компьютеры.
Циклические испытательные системы могут использоваться для проверки и дальнейшей разработки программного обеспечения и аппаратной части.
Калибровка программных функций
Процедура
Любая электронно-управляемая автомобильная система может лишь тогда развит свою способность, когда она оптимально адаптирована к соответствующему типу автомобиля. Чтобы программные функции можно было использовать в как можно большем количестве вариантов автомобилей, они содержат регулируемые параметры. Адаптация этих параметров к соответствующему варианту автомобиля и к каждому режиму работы (например, холодный режим работы, экстремальная жара или высота) называется калибровкой. Для достижения нужного уровня функциональности в автомобиле в целом необходимо использовать множество характеристических значений, кривых и программных карт — калибровочных данных.
Большинство изменений в автомобиле требует изменений в калибровке. Пример, кислородный датчик (λ-зонд в системе запуска измеряет остаточный кислород в выхлопе. На основе его сигналов можно определить фактически впрыскиваемое количество топлива. Таким образом, можно непрерывно и точно адаптировать параметры активации в ЭБУ двигателя. Необходимо адаптировать изменения в выпускной системе, приводящие изменению противодавления отработавших газов в точке, где установлен λ-зонд (например, измененный выпускной коллектор, сажевый фильтр). Если этого не сделать, то результатом будет увеличение расхода и вредных выбросов.
Управление вариантами в разработке, производстве и обслуживании можно: упростить путем разграничения программного статуса и статуса данных. Программный статус содержит, например, всю информации: о переменных, их предельных значениях и взаимосвязях, а статус данных содержит тактически примененные переменные.
Калибровка выполняется в лаборатории на стендах для двигателя и автомобиля во время испытаний автомобиля и в реальных условиях на испытательных маршрутах. В дополнение к измерительно-диагностической системе часто требуется калибровочная система для калибровки внутренних параметров ЭБУ, например, характеристических кривых и голограммных карт). По завершении калибровки производится комплексная проверка данных. Затем эти значения записываются в стираемую программируемую постоянную память (EPROM) или флэш-память последовательных ЭБУ.
Во время калибровки значения параметров должны быть регулируемыми. Поэтому система калибровки состоит из одного или более ЭБУ с подходящим интерфейсом измерительно-диагностической системы (рис. «Принцип работы измерительно-калибровочных инструментов» ). В дополнение к использованию в автомобилях, измерительно-диагностические и калибровочные системы можно также использовать в циклических испытательных системах и на испытательных стендах.
Изменения значений параметров, например, значений характеристической кривой, поддерживаются в калибровочной системе редакторами. Они также могут работать на уровне реализации (т.е. с примененными значениями) или на уровне физической спецификации. Соответственно, измерительная система преобразует записанные значения в физическое представление или представление реализаций. На рис. «Принцип работы измерительно-калибровочных инструментов» показан пример физического уровня и уровня реализации для характеристической кривой и записанного сигнала измерения.
При работе с системами калибровки обычно можно выбрать либо автономную калибровку, либо калибровку в реальном времени.
Автономная калибровка
При автономной калибровке выполнение функций управления с обратной связью и без обратной связи и функций контроля, т.е. «программы привода», прерываются для корректировки значений параметров. Поэтому при автономной калибровке возникает много ограничений. В частности, при использовании на испытательных стендах и во время тестирования в автомобиле она всегда влечет за собой прерывание испытаний на стенде или на дороге.
Калибровка в реальном времени
При калибровке в реальном времени значения параметров можно регулировать во время выполнения программных функций микроконтроллерами. Поэтому можно регулировать значения параметров при выполнении функций управления с обратной связью и без обратной связи и функций контроля, и стало быть, во время обычного использования на испытательном стенде или в автомобиле.
Калибровка в реальном времени предъявляет высокие требования к стабильности функций управления с обратной связью и без обратной связи и функций контроля, поскольку ездовой цикл должен оставаться стабильным во время всех процедур регулировки при возникновении исключений, например, если распределение точек интерполяции в характеристических кривых не сможет монотонно расти в течение коротких периодов времени. Калибровка в реальном времени подходит для долгосрочной модификации менее динамичных параметров (например, подстройки функций управления двигателем на моторном испытательном стенде).
Для применения более динамичных функций или функций, имеющих критичное значение для обеспечения безопасности (например, настройки программных функций системы ABS для маневров торможения во время тест-драйва), настройки не выполняются во время фактических маневров торможения. В этом случае калибровка в реальном времени все равно может сэкономить время посредством предотвращения любых прерываний выполнения программы и, соответственно, снижения интервала между двумя тест-драйвами.
Перспективы развития автомобильных функций и технологий
Новые автомобильные функции и технологии будут продолжать увеличивать объем программного обеспечения в автомобилях-даже в бюджетном сегменте. При этом во многих автомобилях количество ЭБУ остается неизменным. В результате объем функций некоторых ЭБУ продолжает расти. В целом системные разграничения между различными ЭБУ исчезают — например, в управлении гибридным приводом. Таким образом, электроника в автомобилях становится все более сложной. Поэтому ключевым элементом будущих разработок автомобильного программного обеспечения и сред разработки станет экономическая составляющая.
Другой тенденцией является все большая виртуализация разработок, когда отдельные части более поздних этапов разработки, таких как тестирование и калибровка, интегрируются в более простые фазы разработки, чтобы, к примеру, уже функциональные модели можно было циклически тестировать и снабжать данными на предварительной основе. Таким образом, сбои выявляются раньше, и непосредственно перед запуском серийного производства устраняются слабые места.
РЕКОМЕНДУЮ ЕЩЁ ПОЧИТАТЬ:
Сталкиваясь с реалиями машиностроительной промышленности, большинство разработчиков программного обеспечения не справляются – уж очень узкоспециализированы продукты, с которыми приходится работать. Это вам не создание программ для интернет-пользователей, компьютеров и даже не мобильные приложения, а потому новички чувствуют себя, как Томас из фильма «Бегущий в лабиринте». Посмотрите, примерно, 50 секунд трейлера – и вы поймете, какой шок испытывают те, кто имеет дело с разработкой ПО для автомобилей впервые.
Все, что у вас есть — это множество терминов и инструментов, о которых вы понятия не имеете. Когда во время собеседования в одной автомобильной компании я поинтересовался, какую IDE они используют, интервьюеру мой вопрос, мягко говоря, не понравился. Я привык к Visual Studio, и наивно надеялся, что здесь для разработки встроенного программного обеспечения понадобится что-то аналогичное. Я даже не представлял, что меня ожидало! Просто море мелких и серьезных (по сложности) инструментов, которым нужна была очередная жертва.
Причем, когда речь идет о разработке программного обеспечения для автомобилей, инструменты отнюдь не единственная проблема. Практически невозможно найти литературу для новичков или просто обучающие материалы, касающиеся библиотек или архитектуры соответствующих программ. Термин «учебное пособие» и вовсе звучит неуместно, ведь сфера автомобилестроения – весьма закрытое сообщество. Да и сообществом ее вряд ли назовешь, ведь при такой конкуренции никто не должен догадаться, как вы создаете ту или иную программу. Чтобы узнать хоть что-то об отдельных инструментах и механизмах этого сегмента программирования, вы можете записаться на запредельно дорогие курсы, но ваша компания должна быть готова выложить немалую сумму и потребуется не меньше нескольких недель, чтобы получить опыт, который вам нужен уже сейчас. Очень жаль, что разобраться в специфике программирования для автомобилестроения так сложно, а потому я решил посвятить свою статью именно этой теме.
Поскольку мне неоднократно приходилось переключаться с создания приложений для интернет-пользователей/компьютеров на разработку встроенных программ и обратно, мне не понаслышке известно о проблемах, с которыми сталкиваются новички, имеющие дело, в основном, с первым блоком продуктов. Аналогичные сложности возникают и у программистов, которые никогда не сталкивались со спецификой автомобильной промышленности.
В этой и следующей статье мне хотелось бы поговорить о принципах работы встроенных программ для автомобилей, а также заглянуть в недра экзотической архитектуры встроенных приложений.
Какие темы мы рассмотрим?
- Как встроенное программное обеспечение повышает производительность автомобиля?
- Как встроенные приложения позволяют управлять автомобилем?
- Какие существуют типичные ограничения CPU?
- Как благодаря встроенным программам осуществляется процесс непрерывной обработки данных с датчиков?
- Как это программное обеспечение структурировано и как отдельные приложения взаимодействуют между собой для управления автомобилем?
Я отвечу на эти вопросы, рассмотрев конкретный пример, а заодно сделаю обзор по разработке архитектуры встроенного программного обеспечения. В качестве примера мы возьмем полностью электронную систему рулевого управления. Это не настоящая модель, но по строению она, в принципе, похожа на то, что вы, скорее всего, видели в своем автомобиле. Мы поговорим подробнее об архитектуре, а затем перейдем к упрощенной схеме, раскрывающей суть функционала системы.
Вы можете посмотреть видео, посвященное разработке электронной системы рулевого управления. Кстати, я тоже работал в этой команде.
Данная модель частично управляется программно. Частично означает, что специализированное ПО лишь помогает водителю, но полный контроль над системой имеет именно он.
Предположим, нам нужно создать полностью электронную систему рулевого управления, в которой руль напрямую не связан с колесами. Вместо этого датчик измеряет угол поворота руля и отправляет полученные данные нашей программе. В автомобильной терминологии это сервопривод. Вы не поверите, но благодаря Nissan на рынке уже появилась модель с сервоприводом.
Работу ПО обеспечивает крошечный процессор или, если говорить точнее, микроконтроллер, по сети подключенный к датчику.
Когда водитель поворачивает руль, благодаря датчику, который постоянно передает информацию о текущем угле поворота, ПО получает соответствующий сигнал. Например, если водитель поворачивает руль на 90 ° вправо, в течение секунды сигнал датчика обрабатывается по следующему принципу:
Помимо этого, ПО также управляет работой электрического двигателя, который перемещает зубчатую рейку слева направо и в обратном направлении, а, значит, изменяется угол поворота передних колес автомобиля. Соответственно, ПО может направить машину влево или вправо. Связь между микроконтроллером, запускающим ПО, и электродвигателем обеспечивается благодаря электронному блоку управления (ECU), в состав которого входит собственно микроконтроллер и усилитель мощности, регулирующий систему питания двигателя. Таким образом, наша программа варьирует подачу тока в двигателе и положение зубчатой рейки изменяется в нужном направлении.
Электронный блок управления (ECU)
При условии, что встроенное программное обеспечение работает корректно, при повороте руля почти мгновенно изменяется положение зубчатой рейки.
Руль — синий, рулевая рейка — розовый (прим.)
Становится понятно, что даже обработка информации здесь не подчиняется ни логике событийно-ориентированного программирования, как в случае с привычными приложениями графического интерфейса пользователя, ни законам пакетных фалов. Вместо этого требуется непрерывная, своевременная обработка входящих данных. Если программе понадобится слишком много времени, чтобы проанализировать показатели датчиков, рулевая рейка и передние колеса автомобиля будут двигаться с задержкой, и водитель это заметит. Скорее всего, в экстремальной ситуации это приведет к потере контроля над автомобилем, например, при повороте руля в целях объезда препятствия машина не сразу среагирует на маневр. Подобная специфика повышает требования к временным показателям программ для автомобилей, особенно, если учесть ограниченную производительность процессора стандартных электронных блоков управления.
В продолжение серии мы рассмотрим архитектуру программного обеспечения, позволяющую устранить обозначенные проблемы, и, надеюсь, с помощью этих материалов начинающие разработчики встроенных приложений для автомобилей гораздо быстрее освоят базовые принципы, действующие в данной сфере.
Автор: ragequit
Источник
Программный код в автомобиле +17
Программирование микроконтроллеров, Автомобильные гаджеты, Транспорт, Блог компании НПП ИТЭЛМА
Рекомендация: подборка платных и бесплатных курсов Python — https://katalog-kursov.ru/
Требуется множество микропроцессоров, обрабатывающих 100 миллионов строк кода, чтобы обеспечивать работу машины премиум-класса (2009 год). И это в скором времени станет еще сложнее.
Система авионики в F-22 Raptor, реактивном истребителе военно-воздушных сил США, состоит примерно из 1,7 миллиона строк программного кода. F-35 Joint Strike Fighter, появившийся в 2010 году, требует около 5,7 миллионов строк кода для работы бортовых систем. А новому Boeing 787 Dreamliner требуется около 6,5 миллионов строк программного кода для работы систем бортового электронного оборудования.
Впечатляет, не правда ли? Но если вы недавно купили автомобиль премиум-класса, он, вероятно, содержит около 100 миллионов строк программного кода. Так говорит Манфред Брой, профессор информатики в Техническом университете Мюнхена, ведущий эксперт по программному обеспечению в автомобилях. Все это ПО запускается на 70-100 микропроцессорных электронных блоках управления (ECU), распределенных по всему кузову вашего автомобиля.
Альфред Катценбах, директор по управлению информационными технологиями в Daimler, сказал, что для радионавигационной системы в нынешнем Mercedes-Benz S-класса требуется более 20 миллионов строк кода. В автомобиле содержится почти столько же ECU, сколько в новом Airbus A380 (без учета развлекательной системы на борту). Программное обеспечение в автомобилях будет расти не только в количестве. Сложность ПО с каждым разом увеличивается все сильнее. В конце прошлого года исследовательская фирма Frost & Sullivan подсчитала, что для машин в ближайшем будущем потребуется от 200 до 300 миллионов строк программного кода.
Даже в бюджетных автомобилях теперь есть от 30 до 50 ECU, встроенных в кузов, двери, приборную панель, крышу, багажник, сиденья. Их можно найти практически где угодно. Все зависит от фантазии проектировщиков автомобиля. Это значит, что большинство новых автомобилей обрабатывают десятки миллионов строк программного кода, контролируя все, начиная от ваших тормозов и заканчивая громкостью радио.
«Автомобили больше не представляют собой только лишь батарею, распределитель или генератор переменного тока и карбюратор; они чрезвычайно современны по своей сложности», — говорит Thomas Little, профессор электротехники в Бостонском университете штата Массачусетс. Томас занимается разработкой интеллектуальных транспортных систем. «Преследуя цели экономии энергии, сокращения [выбросов] и повышения безопасности помимо прочего мы пришли к внедрению электроники».
Я недавно испытал эту сложность на себе. В прошлом году я купил новый автомобиль и был поражен, когда открыл руководство пользователя. В нем было 500 страниц. Еще 200 страниц объясняли работу GPS и радиосистем. Одной из новых рекламируемых функций было увеличение отдела для перчаток, но размеры, вероятно, были указаны где-то внутри бесконечного руководства.
Моя новая машина идет в комплекте с передними и боковыми подушками безопасности. Дюжины датчиков обеспечивают электронный контроллер подушки безопасности данными. Эти датчики должны работать годами при любых температурах — и в суровый мороз в Миннесоте и под жарким летним солнцем в Аризоне.
Большую часть времени система подушек безопасности просто отслеживает состояние автомобиля. Но иногда подушки безопасности срабатывают, скажем, из-за столкновения нескольких транспортных средств. В таком случае у программного обеспечения в ECU, управляющего их раскрытием, есть от 15 до 40 миллисекунд, чтобы определить, «какие подушки безопасности активируются и в каком порядке», — говорит Брой.
В ближайшем будущем, по словам Броя, системы управления подушками безопасности будут использовать не только информацию о вероятности столкновения. Например, у BMW многие модели 2009 года оснащены системой BMW Assist. Эта система рассчитывает «риск серьезной травмы» на основе информации, полученной от контроллера подушки безопасности автомобиля и других его ECU. Аварийно-технические службы получают информацию не только о месте происшествия, но и о вероятности получения серьезной травмы пассажирами.
Количество программного обеспечения в автомобилях в наше время поражает.
Первый серийный ECU автомобильного микрокомпьютера представлял собой однофункциональный контроллер. Его использовали для электронного зажигания в 1977 году в General Motors в автомобиле Oldsmobile Toronado. В 1978 году GM предложили поставить свой Cadillac Trip Computer на Cadillac Seville. Компьютер представлял собой модифицированный микропроцессорный чип Motorola 6802. Он отображал информацию о скорости, топливе, поездке и двигателе. Однако микросхема выполняла другую функцию: GM использовали ее для проверки того, насколько хорошо микропроцессор может управлять несколькими функциями, такими как впрыск топлива, электронная синхронизация зажигания и круиз-контроль.
К 1981 году GM использовали микропроцессорное управление двигателем в производстве легковых автомобилей. Они обрабатывали около 50 000 строк кода. Другие автомобильные компании быстро последовали их примеру.
Jonas Bereisa, инженер GM, написал в 1983 году в статье IEEE Transactions по промышленной электронике, что «разработка программного обеспечения станет наиболее важным фактором в разработке новых продуктов». Он был чертовски прав. По оценкам Broy, более 80 процентов автомобильных инноваций происходят благодаря компьютерным системам. ПО стало основным источником стоимости в автомобилях, в том числе прейскурантной. Соотношение стоимости электроники и стоимости транспортных средств в процентах возросло с 5 процентов в конце 1970-х годов до 15 процентов в 2005 году (без учета затрат на окончательную сборку).
У гибридов количество ПО, необходимого только для одного управления двигателем, почти вдвое больше, чем у стандартного автомобиля. Соотношение стоимости электроники и стоимости транспортных средств у них приближается к 45 процентам. В течение 10 лет, по прогнозам некоторых экспертов, процентная доля стоимости электроники от стоимости транспортного средства вырастет до 50 процентов у обычных транспортных средств и до 80 процентов у гибридов.
Для современных автомобилей премиум-класса «стоимость программного обеспечения и электроники может достигать 35–40 процентов от стоимости автомобиля», — заявляет Брой. На разработку программного обеспечения приходится около 13–15 процентов от этой стоимости. Он говорит, что если каждая строчка разработанного программного обеспечения стоит 10$ — что очень мало — у автомобиля премиум-класса, одно только его программное обеспечение представляет собой инвестицию на сумму около миллиарда долларов.
John Voelcker, редактор IEEE Spectrum, написал в апреле 2007 года о гибридном автомобиле GMC Yukon и его двухрежимной автоматической коробке передач. Voelcker сказал, что «из всех рабочих часов затраченных на создание двухрежимной коробке передач… около 70 процентов… ушли на разработку управляющего программного обеспечения».
Voelcker отметил, что логика управляющего программного обеспечения анализирует сотни входных данных каждые 10 миллисекунд, включая нагрузку на автомобиль, работу двигателя, параметры аккумулятора и температуру в высоковольтных электрических компонентах.
Из-за сложности кода возникают проблемы с надежностью. IBM утверждает, что примерно 50 процентов гарантийных расходов на автомобили в настоящее время связаны с электроникой и их встроенным программным обеспечением. По данным на 2005 год автопроизводителям в Соединенных Штатах это обошлось примерно в 350 долларов за один автомобиль, а европейским автопроизводителям в 250 долларов.
В 2005 году Toyota отозвала 160 000 своих гибридов Prius 2004 года выпуска и некоторые модели начала 2005 года из-за программной проблемы — автомобили глохли или внезапно останавливались. Время, необходимое для ремонта программного обеспечения, оценивалось примерно в 90 минут на одно транспортное средство — около 240 000 рабочих часов. Это обошлось им дорого.
Только в прошлом году было несколько отзывов автомобилей, связанных с проблемами программного обеспечения. Например, в мае 2008 года Chrysler отозвал 24 535 своих Jeep Commanders 2006 года из-за проблемы в программном обеспечении автоматической трансмиссии. Затем в июне Volkswagen отозвал около 4000 своих Passats и Passat Wagons 2008 года и около 2500 Tiguans из-за проблемы в программном обеспечении модуля управления двигателем. Эта проблема может привести к неожиданному увеличению оборотов двигателя в минуту при включении кондиционирования воздуха. В ноябре GM отозвала 12 662 из своих автомобилей Cadillac CTS 2009 года из-за проблемы с программным обеспечением в системе обнаружения пассажиров, которая могла отключить подушку безопасности пассажира, сидящего спереди, когда она должна быть включена, или включить ее, когда она должна быть отключена. Тем не менее, стоит отдать должное разработчикам автомобильного ПО, так как отзывов автомобилей из-за программного обеспечения не так много.
Более широкое использование программного обеспечения не только повлияло на стоимость гарантии на автомобиль, но и усложнило ремонт автомобилей. Страховым компаниям легче объявить полную гибель автомобиля, поврежденного в результате несчастного случая, чем отремонтировать его.
Несложно понять почему. «В автомобиле премиум-класса от 2000 до 3000 уникальных функций, связанных с программным обеспечением», — говорит Брой. Затем они объединяются в 250–300 функций, используемых водителем и пассажирами для управления системами автомобиля.
У большинства коммерческих самолетов есть межсетевые экраны между критически важными бортовыми системами и бортовыми развлекательными системами. У машин, в отличии от самолетов, происходит более сложная передача информации между электронными системами, используемыми для управления автомобилем, и системами, предназначенными для развлечения водителя и пассажиров. В бизнес-школе Wharton была опубликована статья под заголовком «Проблемы с автомобилем: стоит ли отозвать автомобильную промышленность США?». Несколько лет назад некоторые водители Mercedes обнаружили, что водительское кресло сдвигалось, если они нажимали определенную кнопку; проблема заключалась в том, что кнопка должна была управлять навигационной системой.
По словам бывшего автомобильного инженера, с которым я беседовал, примерно треть всего программного обеспечения в автомобилях посвящена одной лишь диагностике. Но даже несмотря на всю эту диагностическую информацию, автомеханики часто не могут определить точную причину проблемы.
Broy сказал мне, что более 50 процентов ECU, которые механики заменяют в автомобилях, технически не содержат ошибок: у них нет проблем ни с аппаратным, ни с программным обеспечением. Механики заменяют ECU просто потому, что не могут починить машину иначе.
«Работники СТО и любители повозиться с машиной в гараже действительно находятся в тех реалиях, когда ремонт автомобиля слишком сложен и требует больших затрат[для них]», — говорит Брой. Удаленная диагностика и ремонт могут сделать механику ненужной для многих задач.
По словам Броя, в не столь отдаленном будущем, когда у вас возникнут проблемы с компьютерной системой в автомобиле, вы отправитесь в гараж, где ваш автомобиль будет подключен к сети. Cторонние OEM-специалисты смогут скачать данные, сделать анализ, а затем загрузить исправление программного обеспечения.
По словам Voelcker, он не удивится, если увидит, что бортовые системы, такие как BMW Assist, Ford Sync и GM OnStar, начнут регулярно передавать параметры рабочих данных обратно в централизованные системы, которыми управляют производители автомобилей. А производители в свою очередь будут анализировать данные для деталей, выходящих за пределы спецификации или для ПО, нуждающегося в обновлении. Водителя автоматически проинформируют о том, что автомобиль необходимо отвезти в ремонт.
Помимо контроля за состоянием своих внутренних деталей, автомобили начинают анализировать мир вокруг них. «Мы вступаем в эпоху, когда помимо того, что мы знаем, что происходит внутри автомобиля, мы используем такие вещи, как радары для обнаружения присутствия внешних объектов, лазеры для измерения расстояния у круиз-контроля, а также видео и ультразвук для обнаружения объектов позади тебя, — говорит Little. «Тенденция будет заключаться в том, чтобы извлекать информацию, которая относится к вашему автомобилю и к другим транспортным средствам. Затем эта информация будет использоваться для повышения безопасности. Например, автомобили перед вами сообщат вашему автомобилю, есть ли на шоссе лед или произошла ли авария.
Little говорит: «Мы отказываемся от маленьких частей контроля в обмен на безопасность. В какой момент вы и я будем готовы сказать: «Хорошо. Я не собираюсь вести машину, пусть она везет меня.
Об авторе
Robert N. Charette редактор IEEE Spectrum, самопровозглашенный «эколог риска», который исследует влияние меняющейся концепции риска на технологии и развитие общества. Charette также пишет IEEE Spectrum Online’s The Risk Factor.
Едем дальше
Манфред Брой и его коллеги написали исчерпывающую статью для февральского выпуска «Proceedings of the IEEE» под названием «Engineering Automotive Software» в феврале 2007 года. Она, вероятно, является одним из лучших обзоров на то, как разрабатывают и используют ПО для автомобилей.
Хорошую раннюю историческую точку зрения на использование ПО в автомобилях ищите в статье Jonas Bereisa, опубликованную в мае 1983 года в журнале IEEE Transactions по промышленной электронике под названием «Applications of Microprocessors in Automotive Electronics.». В ней представлена ??интересная хронология многих приложений микрокомпьютеров, которые использовались в автомобилях с 1977 по 1982 год.
о журнале IEEE Spectrum
(По материалам Википедии)
IEEE Spectrum — ежемесячный журнал, издаваемый Институтом инженеров электротехники и электроники (англ. Institute of Electrical and Electronics Engineers — IEEE). Официальное описание журнала:
«Журнал «IEEE Spectrum», флагманская публикация IEEE, исследует развитие, применение и последствия внедрения новых технологий. Он предвосхищает тенденции в области машиностроения, науки и техники, а также служит форумом для понимания, обсуждения и руководства в этих областях.»
Журнал «IEEE Spectrum» читает более 385 000 инженеров по всему миру, что делает его одним из ведущих научных и инженерных журналов в мире. Тематика журнала охватывает широкий круг технических проблем и достижений компьютерной техники, средств связи и электроники. Как и в стандартных журналах, статьи «IEEE Spectrum» пытаются сделать доступными для неспециалистов, хотя предполагается их инженерное образование. Материалы журнала пользуются авторитетом и часто цитируются другими изданиями.