реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> Шаблоны проектирования
maloii
сообщение Sep 30 2009, 11:20
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 25
Регистрация: 29-02-08
Пользователь №: 35 472



Существуют ли какие ни будь шаблоны проектирования для МК? А конкретно меня интересует шаблон формирования всей программы.
Попытаюсь объяснить проблему. При написании сложной программы как то я уперся что не оптимально разбросал логические элементы программы и получилось так что если посмотреть программу в срезе работы за секунду то 90% программа прохлаждается, а 10% упирается рогами в стену. Естественно я стал как то это оптимизировать и заставлять нагрузку распределять плавно по времени, результат конечно был достигнут, но возник вопрос, а как делать правильно? Сам я по должности JAVA программист и хорошо знаком с разными методами программирования, и одна из важных фишек в моей работе это знание шаблонов программирования. Грубо говоря это описано как надо делать, и как не надо. По сути я понимаю что все программы для МК делятся на конкретные логические блоки и предполагаю что есть правильный способ выполнения этих блоков. На вскидку блоки следующие:
1. Получение данных через прерывания
2. Просто получение данных по АЦП
3. Получение данных по UART/SPI и т.д.
4. Обработка данных
5. Вывод данных

Ну это я написал на вскидку. И вот теперь задача, как эти блоки раскидать в основном цикле так чтобы они плавненько обрабатывались и никому не мешали? Плюс ещё эти блоки делятся на под блоки с различным уровнем вложенности, но задача по сути типична, и я больше чем уверен что в итоге все работающие программы очень похожи. Вот и охота у знать как делать правильно.
Так же шаблоны проектирования стандартизируют код и позволяют другому программисту легко разобраться в нем.
Go to the top of the page
 
+Quote Post
MrYuran
сообщение Sep 30 2009, 11:47
Сообщение #2


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



Самое простое - (в смысле реализации) - использовать готовую RTOS.
Правда, придётся потратить недельку на изучение документации и месяцок-другой на тренировки "на кошках" и усвоение специфики.

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


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
Bronislav
сообщение Sep 30 2009, 11:56
Сообщение #3


Частый гость
**

Группа: Участник
Сообщений: 118
Регистрация: 23-01-06
Пользователь №: 13 477



ИМХО, существуют разные подходы к проектированию программ для МК:
- суперцикл,
- метод конечных автоматов,
- операционная система реального времени.
Go to the top of the page
 
+Quote Post
Dog Pawlowa
сообщение Sep 30 2009, 12:17
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 2 702
Регистрация: 14-07-06
Пользователь №: 18 823



Цитата(maloii @ Sep 30 2009, 14:20) *
.. Вот и охота у знать как делать правильно...

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


--------------------
Уходя, оставьте свет...
Go to the top of the page
 
+Quote Post
Flexz
сообщение Sep 30 2009, 12:20
Сообщение #5


Местный
***

Группа: Свой
Сообщений: 252
Регистрация: 9-10-08
Из: Московская обл.
Пользователь №: 40 797



Из указанного списка в основном цикле обычно делают только обработку данных, а прием/передачу в прерываниях/DMA, если конечно процессор и периферия это могут.
Go to the top of the page
 
+Quote Post
Corvus
сообщение Sep 30 2009, 12:37
Сообщение #6


Знающий
****

Группа: Свой
Сообщений: 771
Регистрация: 24-04-08
Из: Зеленоград
Пользователь №: 37 056



Цитата(Dog Pawlowa @ Sep 30 2009, 16:17) *
Я лично использую автоматы состояний, а их обслуживание засовываю в бэкграунд (прерывания по таймеру) и в обслуживание событий в основном цикле в соответствии с требуемой реакцией.

+1 Для небольших задач - самое то. А для сложных, как уже сказали - RTOS.
Go to the top of the page
 
+Quote Post
maloii
сообщение Sep 30 2009, 12:39
Сообщение #7


Участник
*

Группа: Участник
Сообщений: 25
Регистрация: 29-02-08
Пользователь №: 35 472



Значит все таки есть шаблоны smile.gif. Лана буду гуглить, изучать. За ссылку на описание на русском буду благодарен smile.gif
Go to the top of the page
 
+Quote Post
Dog Pawlowa
сообщение Sep 30 2009, 13:40
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 2 702
Регистрация: 14-07-06
Пользователь №: 18 823



Цитата(maloii @ Sep 30 2009, 15:39) *
Значит все таки есть шаблоны smile.gif.

Да уж не знаю.
Вот только что "из-под пера" простейший автомат управления насосом повышения давления.
Будет вставлен в обработку события 100 мс.

Код
enum { BOOSTER_PASSIVE=0, BOOSTER_WAIT_HIGH_PRESSURE, BOOSTER_WAIT_LOW_PRESSURE};
uchar booster_state;
void  BoosterPumpService100ms(void)
{   switch (booster_state)
    { case BOOSTER_PASSIVE:  
        break;
      case BOOSTER_WAIT_HIGH_PRESSURE:
        if (Sensor(HighOutputPressure))  booster_state=BOOSTER_WAIT_LOW_PRESSURE;
        break;
      case BOOSTER_WAIT_LOW_PRESSURE:
        if (Sensor(LowOutputPressure))  booster_state=BOOSTER_WAIT_HIGH_PRESSURE;
        break;
   }
   if (GetFlag(booster_filled) && Sensor(NivBelowLow)) return;
   if (Sensor(NivBelowEmpty)) return;  
   if (booster_state==BOOSTER_WAIT_HIGH_PRESSURE) OnPin(BoosterPump);
   else OffPin(BoosterPump);
}
void StartBooster(void) { booster_state=BOOSTER_WAIT_HIGH_PRESSURE; }
void StopBooster(void)  { booster_state=BOOSTER_PASSIVE;            }


--------------------
Уходя, оставьте свет...
Go to the top of the page
 
+Quote Post
manul78
сообщение Sep 30 2009, 16:03
Сообщение #9


Местный
***

Группа: Участник
Сообщений: 403
Регистрация: 14-05-07
Из: Россия, г.Пенза
Пользователь №: 27 719



Цитата(Corvus @ Sep 30 2009, 16:37) *
А для сложных, как уже сказали - RTOS.


Если Вас не затруднит, Вы не могли-бы дать короткий обзор существующих RTOS для МК серии AVR.
Если можно ссылки.
Еще интересуют размеры занимаемые во FLASH и требуемые ресурсы.

Заранее благодарен.


--------------------
" Многие вещи нам непонятны не потому, что наши понятия слабы; но потому, что сии вещи не входят в круг наших понятий." (с) К.Прутков.
Go to the top of the page
 
+Quote Post
Corvus
сообщение Sep 30 2009, 17:52
Сообщение #10


Знающий
****

Группа: Свой
Сообщений: 771
Регистрация: 24-04-08
Из: Зеленоград
Пользователь №: 37 056



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

Сообщение отредактировал Corvus - Sep 30 2009, 17:54
Go to the top of the page
 
+Quote Post
Flexz
сообщение Sep 30 2009, 18:07
Сообщение #11


Местный
***

Группа: Свой
Сообщений: 252
Регистрация: 9-10-08
Из: Московская обл.
Пользователь №: 40 797



А не тяжеловат FreeRTOS для Avr? Есть AvrX, маленькая и легкая, специально под AVR-ы написанная, правда к сожалению в реальных проектах попользовать не довелось.
Go to the top of the page
 
+Quote Post
SasaVitebsk
сообщение Sep 30 2009, 22:38
Сообщение #12


Гуру
******

Группа: Свой
Сообщений: 2 712
Регистрация: 28-11-05
Из: Беларусь, Витебск, Строителей 18-4-220
Пользователь №: 11 521



На МК очень широко используются прерывания. В одной программе может существовать их довольно много (до 10 штук). Некоторые задачи могут объединятся в одном прерывании.

Например АЦП/таймер/управление двигателем. Естественно прерывание при этом должно выполнятся максимально быстро. Если этого нет, то в прерывании взводятся флаги, а в голове по конкретному флагу исполняется кусок.

Голова может быть построена как кооперативная ОС. Особенно если задачи слабо связаны. Если сильно связаны, то как автомат. То есть либо:

if(flag1)
{
flag1=FALSE;
...
}
if(flag2)
{
flag2=FALSE;
...
}

Либо:

if(state==1)
{
state++;
...
}
if(state==2)
{
state++;
...
}

И в том и в другом случае, время нахождения в одном состоянии должно быть ограничено. Обычно, у меня, к примеру, голова программы очень мало загружена.
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 6th July 2025 - 02:12
Рейтинг@Mail.ru


Страница сгенерированна за 0.01468 секунд с 7
ELECTRONIX ©2004-2016