Перейти к содержанию

Вопросы от начинающих по МК


Рекомендуемые сообщения

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

  • Ответов
  • Создана
  • Последний ответ

Топ авторов темы

нет, не нужно...

Точности с внутрнним генератором не добиться...только внешний кварц, да и то нужна будет адаптация/поправка времени

самый простой выход...как бы так объяснить...по факту прерывания идут по переполнению...

смотри здесь

// Timer1 Overflow Interrupt: On

// Input Capture Interrupt: Off

// Compare A Match Interrupt: Off

// Compare B Match Interrupt: Off

тоесть счетчик считает так = 1000000/63536=15,73910853689247. Тоесть хвост после запятой и есть ошибка по времени ,73910853689247.

тоесть опережение будет составлять 0,73910853689247/15=0,049273902459498 тоесть 4,92%

включение Compare A работает по сравнению напряжения на ножке...

поставь счетчик не 0*FFFF а 0*FF, тогда 1000000/256=3906,25, тоесть после каждого 3906 будет прирост в 0,25 и на 4й раз считай до 3905...тогда будет точно

Надеюсь, что идея понятна...

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

Изменено пользователем Oleg_Shonin
Ссылка на комментарий
Поделиться на другие сайты

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

ща запущу код вижион гляну, атмега32, правильно?

смотри

допущена неточности с 0*FF и 0*00FF

post-169290-0-94011900-1372164915.png

Изменено пользователем Oleg_Shonin
Ссылка на комментарий
Поделиться на другие сайты

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

А пока кто нибуть ответте на мой вопрос в пункте про фьюзы, плиз.

Ссылка на комментарий
Поделиться на другие сайты

Когда прошивал, фузы не трогал. Не дошел я до фьюзи

Тогда непонятно, на что надеялся?

тоесть счетчик считает так = 1000000/63536=15,73910853689247. Тоесть хвост после запятой и есть ошибка

Не стоит связываться с такой ошибкой. Когда есть нужный режим работы таймера когда он считает до значения занесенного в регистр компаратора и сбрасывается. т.е. можно занести в компаратор число 10000(или 99999?) переключить его в нужный режим работы и счетчик будет считать до срабатывания компаратора и автоматически сбрасываться! т.е. получаем делитель ровно на 10 тысяч. без плясок, без дробных частей...

Учение - изучение правил. Опыт - изучение исключений.

Ссылка на комментарий
Поделиться на другие сайты

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

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

Ссылка на комментарий
Поделиться на другие сайты

Восьмибитным получится поделить на 200*2^N как-то так, используя предделитель.

set_io TCCR0A, 0b00000010 ; режим таймера - 02, Clear-On-Compare
set_io TCCR0B, 0b10000001	 ; Регистр сравнения OCRA указывает максимальное значение счетчика
set_io OCR0A, 200 ; Период прерываний таймера
set_io TIMSK0, 0b00000100 ; разрешаем прерывание от таймера(по сранению на OCRA).

Это без предделителя, счетчик будет считать до 200 и сбрасываться т.е. 0..100..199 и следующий такт - сброс, т.е. отмерит ровно 200 интервалов.

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

Изменено пользователем Alexeyslav

Учение - изучение правил. Опыт - изучение исключений.

Ссылка на комментарий
Поделиться на другие сайты

Там еще два таймера есть с ШИМом, даже каждый с двумя... 4 ШИМа, и один таймер под секунды.

Учение - изучение правил. Опыт - изучение исключений.

Ссылка на комментарий
Поделиться на другие сайты

Добрый день всем. Есть необходимость подключить биполярный двигатель к ULN2008 или ULN2003A. В протеусе собрал в таком виде - работает. Какую роль играют резисторы, я не понимаю как все происходит. 32_1262701743.jpg

smcuu1.jpg

Прошу обьяснить)) Спасибо)

Ссылка на комментарий
Поделиться на другие сайты

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

Учение - изучение правил. Опыт - изучение исключений.

Ссылка на комментарий
Поделиться на другие сайты

для двигателя резисторы не нужны, а вот ногу 9 надо бы на +питания посадить, можно через стабилитрон (поищиет в поисковике - всё нарисовано)

то, что показано на вашей схеме, это банальные инверторы по схеме ОК - открытый коллектор

Изменено пользователем Гость
Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

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

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Сообщения

    • У меня до саба ещё дело не дошло, только сейчас думаю купить амп на полкиловатта, но так можно, при условии, что на входе будет моно, и будет срез частот
    • Про флаг Т: если он не используется в основной программе, а у меня он постоянно в деле. для меня меня отложенная обработка прерывания обычное дело, нужно лишь правильно расставить приоритеты частей программы. И обычное дело: выставляешь частоту задающего генератора побольше, делишь его до получения частоты 1000 Гц каким либо таймером, загоняешь в прерывание с флагом. затем закольцовываешь основную программу с проверкой флага прерывания от таймера 1000Гц. загоняешь программу в Sleep. Получаешь кольцо обработки с образцовым интервалом в 1 мс. После любого прерывания проверяешь флаг от таймера, если он, то сбрасываешь флаг и начинаешь перебирать подпрограммы обработки индикаторов, клавиатуры, и тд. и тп, подпрограммы обработки флагов и др. После окончания обработки всех подпрограмм возвращаешься к Sleep. И так по кольцу. Если происходит прерывание не от таймера, программа выходит из Sleep, проверяется флаг от таймера, если не он (а это не он) обратно к Sleep. В большенстве программ использую этот алгоритм.  
    • @korsaj Сегодня попробовал сделать как ты посоветовал. Получился следующий код. #define F_CPU 7372800UL #define BAUND 9600L #define UBRRL_value (F_CPU/(BAUND*16))-1 #include <avr/io.h> #include <util/delay.h> #include <avr/interrupt.h> #include <stdlib.h> void init_pin(void); #define C_PC0 (~PINC&(1<<PC0)) #define C_PC1 (~PINC&(1<<PC1)) #define LED_1_ON() PORTD|=(1<<PD2) #define LED_1_OFF() PORTD&=~(1<<PD2) #define LED_2_ON() PORTD|=(1<<PD3) #define LED_2_OFF() PORTD&=~(1<<PD3) #define FLAG_END_RX (1<<3) #define FLAG_ERR_RX (1<<4) #define BUF_SIZE 20 char rx_buf[BUF_SIZE]; char buf_index = 0; volatile start=1, flags; char b; ISR(USART_RXC_vect) { b=UDR; if(!(flags & FLAG_END_RX)) { rx_buf[buf_index]=UDR; if(rx_buf[buf_index] == 0x0D) { flags |= FLAG_END_RX; return; } buf_index++; if(buf_index >= BUF_SIZE) { buf_index = 0; flags |= FLAG_ERR_RX; } } } void init_UART() { UBRRL = UBRRL_value; UBRRH = UBRRL_value>>8; UCSRB|=(1<<TXEN); UCSRB|=(1<<RXEN); UCSRC|=((1<<URSEL)|(1<<UCSZ0)|(1<<UCSZ1)); UCSRB|=(1<<RXCIE); sei(); flags = 0; } void send_UART(char value) { while(!(UCSRA&(1<<UDRE))); UDR=value; } int main(void) { init_pin(); init_UART(); while(1) { if (start==1) { _delay_ms(500); send_UART('O'); send_UART('K'); send_UART('!'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); start=0; } if (b == '0') { LED_1_ON(); LED_2_OFF(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('0'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '1') { LED_1_OFF(); LED_2_ON(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('1'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '2') { LED_1_ON(); LED_2_ON(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('2'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '3') { LED_1_OFF(); LED_2_OFF(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('3'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (C_PC0) { send_UART('P'); send_UART('C'); send_UART('0'); send_UART(0x0D); send_UART(0x0A); _delay_ms(250); } if (C_PC1) { send_UART('P'); send_UART('C'); send_UART('1'); send_UART(0x0D); send_UART(0x0A); _delay_ms(250); } } } void init_pin(void) { DDRC = 0b00000000; PORTC = 0b11111111; DDRD |= ((1<<2)|(1<<3)); PORTD &=~ ((1<<2)|(1<<3)); } Ну как сказать всё работает, но вот меня очень интересует приём команд на саму ATMEGA16. Он так и работает только с цифрами. Более ничего корректно принять не получается даже используя таблицу ascii. А мне нужно будет принимать команды и посложней чем просто буквенно - цифровые. Потому как возвращаясь к командам самого плеера там в этих командах хранятся различные данные. Вот примерно так это всё выглядит. AT+QM \ r \ n Запрос режима работы [0: Bluetooth], [1: MP3] AT+M1 \ r \ n Номер текущего файла AT+M2 \ r \ n Общее количество звуковых файлов AT+MD \ r \ n Источник музыки USB или SD Card AT+MT \ r \ n Общее время воспроизведения текущего файла AT+MK \ r \ n Время воспроизведения текущего файла AT+MP \ r \ n Текущее состояние плеера [0]Стоп, [1]Воспроизведение, [2]Пауза К примеру при отправке команды AT+M1 \ r \ n в ответ мы получим M1 + 000002 \ r \ n при этом здесь может быть любое число в hex формате. Мне же нужно каким то образом принять эти данные и обработать их соответствующим образом. Но при этом и нужно учитывать так же что плеер может сам отправить эти данные по началу воспроизведения трека. Вот в этом сейчас и стоит основная задача. Чего я и пытаюсь получить в итоге.
    • Ну тогда дорога к сименсу в гости - они вам какой-нибудь Desigo CC или даже Siematic предложат, тыщ за 10 долларов. Ну и ещё тыщ 5 надо будет отдать за контроллеры и их конфигурирование.   А если попроще - то можно к отечественным MasterSCADA обратиться, либо к WiredBoard - у них не совсем SCADA система, но нормальные контроллеры, довольно просто настраиваются и можно графическую оболочку рисовать.
    • тогда вы имеете то, что имеете, и никак от этого не избавиться. Хоть святой водой окропите. "Или трусы или крестик" (с) Нагрузки у вас немаленькие. Вы же с нуля переделываете, снова некуда ? Понятие LowESR очень неконкретное. Сколько вешать в граммах ? пустая трата времени
    • Да все это туфта, выеденного яйца не стоит. В общем чушь собачья. На мониторе тему уже сплавили в мусорку, а здесь треп еще будет на 10 страницах. Все камеры, их у него было три, исправные. Записывают отлично. А дальше вся проблема в этом. Особо интересно - монтажник видео.
  • Похожий контент

×
×
  • Создать...