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

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


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

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

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

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

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

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

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

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

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

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

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

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

Только что, Дмитрий Мамедиев сказал:

Почему нельзя например так int (0>=x >5);

То, что вы написали, вообще не имеет смысла: x меньше или равно нулю, и при этом x больше пяти - такого не может быть в принципе.

А вообще на счет цепочечных сравнений скажу так: вы должны учитывать, что операторы одинакового приоритета исполняются слева направо. Т.е. сначала сравнится 0 >= x, а потом то, что получится, сравнится с пятеркой. Поскольку результатом логического оператора всегда будет только 0 или 1, то второе сравнение всегда даст ложный результат, т.к. и 0 и 1 меньше пяти.

Используйте традиционную проверку на вхождение в диапазон: if((x >= 0) && (x < 5)).

Если забанить всех, кто набрался смелости думать независимо, здорово будет на форуме - как на кладбище: тишина, птички поют...

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

Еще вопрос. Подключаю лсд 1602. По стандартной схеме, когда используются пины 4567, все ок. Но мне нужно подключить 0123 пины мк, так вот на лсд тоже нужно использовать 0123?

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

1 час назад, Дмитрий Мамедиев сказал:

Мне нужна переменная в определенных пределах. Почему нельзя например так int (0>=x >5);

ну я тебе и написал,  только придел ты задал [1:4] ,я конкретно под него и написал

 

6 минут назад, Дмитрий Мамедиев сказал:

Еще вопрос.

а теперь то же самое только по русски

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

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

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

8 минут назад, Дмитрий Мамедиев сказал:

...Если я подключаю мк через 0123 то на лсд тоже нужно использовать пины 0123?

А какая связь между нумерациями портов LCD и МК?

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

Только что, Дмитрий Мамедиев сказал:

Если я подключаю мк через 0123 то на лсд тоже нужно использовать пины 0123?

Вопрос странный. Вы же подключаете к микросхеме сигналы на её ножки в соответствии с их назначением, а не так, как вам удобно. С чего вдруг на ЖКИ (ЛСД - этот наркотик, а ЖКИ - это по-русски LCD - жидкокристаллический дисплей) вы будете подключать сигналы не в соответствии с назначением контактов ЖКИ, а как вам удобнее?

В микроконтроллере переназначить пины можно программно - это всегда можно, а произвольно назначать выводы ЖКИ - это перегиб.

Если забанить всех, кто набрался смелости думать независимо, здорово будет на форуме - как на кладбище: тишина, птички поют...

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

Только что, Дмитрий Мамедиев сказал:

Можно подключить на мк к пинам 0123 а на лсд 4567?

Конечно можно. Я ж вам намекал: если у микросхемы нужный пин имеет номер 7, это ведь не означает, что только с 7-го пина МК можно подавать сигнал на него. Из МК вы можете сформировать нужные сигналы практически на произвольных его ножках.

Если забанить всех, кто набрался смелости думать независимо, здорово будет на форуме - как на кладбище: тишина, птички поют...

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

42 минуты назад, Дмитрий Мамедиев сказал:

Я не понял

любое число при логическом умножении на 3 (0b00000011) даст числа [0:3]

на 7 (0b00000111) даст числа [0:7] , на 15 (0b00000011) даст числа [0:15]

у тебя диапазон  [1:4] на единицу больше диапазона [0:3]

z--;  // вычли единицу, получили диапазон [0:3]
z&=3; // обрезали
z++; // прибавили единицу , вернули диапазона [1:4]

50 минут назад, Дмитрий Мамедиев сказал:

В сети примеры

выводы МК могут быть любыми , выводы ЖКИ при 4битном подключении только <4:7>

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

void lcd_com(unsigned char com)
{
	PORTC &= ~(1 << RS); // RS = 0 (запись команд)
	PORTC |= (1 << EN); // EN = 1 (начало записи команды в LCD)
	PORTD &= 0xF0; //обнуляем 0:4 пины порта Д
	PORTD |= (com >> 4); // старший нибл
	_delay_us(100);
	PORTC &= ~(1 << EN); // EN = 0 (конец записи команды в LCD)
	_delay_us(100);
	PORTC |= (1 << EN); // EN = 1 (начало записи команды в LCD)
	PORTD &= 0xF0; //обнуляем 0:4 пины порта Д
	PORTD |= (com & 0x0F); // младший нибл
	_delay_us(100);
	PORTC &= ~(1 << EN); // EN = 0 (конец записи команды в LCD)
	_delay_us(100);
}

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

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

Только что, Дмитрий Мамедиев сказал:

не получается все равно

Схему в студию.

Если забанить всех, кто набрался смелости думать независимо, здорово будет на форуме - как на кладбище: тишина, птички поют...

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

#define F_CPU 1000000UL
#include <avr/io.h>
#include <avr/interrupt.h>
#include <util/delay.h>
#include <stdio.h>
#include <stdlib.h>
#include <avr/io.h>

#define RS PINC0
#define EN PINC1
// Функция передачи команды
void lcd_com(unsigned char com)
{
	PORTC &= ~(1 << RS); // RS = 0 (запись команд)
	PORTC |= (1 << EN); // EN = 1 (начало записи команды в LCD)
	PORTD &= 0xF0; //обнуляем 0:4 пины порта Д
	PORTD |= (com >> 4); // старший нибл
	_delay_us(100);
	PORTC &= ~(1 << EN); // EN = 0 (конец записи команды в LCD)
	_delay_us(100);
	PORTC |= (1 << EN); // EN = 1 (начало записи команды в LCD)
	PORTD &= 0xF0; //обнуляем 0:4 пины порта Д
	PORTD |= (com & 0x0F); // младший нибл
	_delay_us(100);
	PORTC &= ~(1 << EN); // EN = 0 (конец записи команды в LCD)
	_delay_us(100);
}
// Функция передачи данных
void lcd_data(unsigned char data)
{
	PORTC |= (1 << RS);PORTC|=(1 << EN); // RS = 1 (запись данных), EN - 1 (начало записи команды в LCD)
	PORTD &= 0xF0; PORTD |= (data >> 4); // старший нибл
	_delay_us(100);
	PORTC &= ~(1 << EN); // EN = 0 (конец записи команды в LCD)
	_delay_us(100);
	PORTC |= (1 << EN); // EN = 1 (начало записи команды в LCD)
	PORTD &= 0xF0; PORTD |= (data & 0x0F); // младший нибл
	_delay_us(100);
	PORTC &= ~(1 << EN); // EN = 0 (конец записи команды в LCD)
	_delay_us(100);
}
//функция передачи строки
void lcd_string (const char str1[])
{
	wchar_t n;
	for(n=0;str1[n]!='\0';n++)
	lcd_data(str1[n]);
}
//функция вывода чисел
void lcd_chisla(unsigned int chislo)
{//делим число и выводим посимвольно в buffer, buffer[2] значение запятой
	unsigned char buffer[5]={'0','0',',','0',0};
	buffer[0]=(chislo/100)+'0';
	buffer[1]=((chislo%100)/10)+'0';
	buffer[3]=(chislo%10)+'0';
	for (unsigned char i=0;i<5;i++)
	{
		lcd_data(buffer[i]);
	}
}
//функция позиционирования курсора
void lcd_poz(unsigned char x)
{
	char adress;
	adress=x|0b10000000;//set DDRAM adress дш стр24
	lcd_com(adress);
}
//функция инициализации дисплея
void lcd_ini(void)
{
	_delay_ms(15);
	// Конфигурирование четырехразрядного режима
	PORTC |= (1 << PIND1);
	PORTC &= ~(1 << PIND0);
	// Активизация четырехразрядного режима
	PORTC |= (1 << EN);
	PORTC &= ~(1 << EN);
	lcd_com(0x20); //0b00100000 - 4 разрядная шина, 1 строки
	_delay_ms(40);
	lcd_com(0x08); // 0b00001000 полное выключение дисплея
	_delay_ms(40);
	lcd_com(0x01); // 0b00000001 очистка дисплея
	lcd_com(0x06);  //0b00000110 - курсор движется вправо, сдвига нет
	_delay_ms(40);
	lcd_com(0x0C);  //0b00001100 - дисплей включен, курсор выключен, мерцание выключено
	_delay_ms(40);
}
//функция очистки дисплея
void lcd_clear (void)
{
	lcd_com(0b00000001);
}

void port_ini (void)
{
	DDRD|=0xFF;
	DDRB|=0xFF;
	DDRC|=0xFF;
	PORTD|=0;
	PORTB|=0;
	PORTC|=0;
}
int main(void)
{
	port_ini();
	lcd_ini();
	while (1)
	{	
		lcd_poz(0);
		lcd_string("i love maria");
	}
}

вот вся портянка

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

_delay_ms(20); //Ждем 15 мс (стр 45)
	sendhalfbyte(0b00000011);
	_delay_ms(4);
	sendhalfbyte(0b00000011);
	_delay_us(100);
	sendhalfbyte(0b00000011);
	_delay_ms(1);
	sendhalfbyte(0b00000011);
	_delay_ms(1);
	sendhalfbyte(0b00000010);
	_delay_ms(1);
		
	sendbyte(0b00101000,0); //0-0-1-DL-N-F-0-0,(4бит-режим DL=0) и (2 линии N=1, N=0 1 линия), (F=0 размер символов 5*8 точек F=1 размер 5*10)
	_delay_ms(1);
	sendbyte(0b00001100,0); //0-0-0-0-1-D-C-B,(включаем изображение на дисплее (D=1 вкл D=0 выкл),курсор выкл=0 вкл=1 (C-подчеркивание, B-квадрат)
	_delay_ms(1);
	sendbyte(0b00000110,0); //0-0-0-0-0-1-I/D-S,(I/D=0 счетчик адреса уменьшается =1 увелич.(S=0 сдвиг экрана не будет,S=1 сдвиг производится согласно I/D
	_delay_ms(1);
	clearlcd();//стереть дисплэй

Я полагаю у вас не верная инициализация дисплея. Нужна вот такая последовательность.. sendhalfbyte(0b00000011); функция отсылает 1-е 4 бита.(0-3)

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

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

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

Гость
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 страницах. Все камеры, их у него было три, исправные. Записывают отлично. А дальше вся проблема в этом. Особо интересно - монтажник видео.
  • Похожий контент

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