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

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


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

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

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

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

5 часов назад, Юрий_Нд сказал:

Интернетом не пользовался, книжки умные по этому вопросe не читал

Это напрасно.

4 часа назад, Юрий_Нд сказал:

Я просто хочу сказать, что всё это числа. И смотреть на это всё нужно, как на числа.

Цифровая электроника в любом случае сводится к числам. Только числа эти не в статике существуют - с ними производятся различные операции. И операции эти имеют определённые формы записи, различные в разных языках программирования. Поэтому и int x - это тоже всего лишь число, а вовсе не кило картошки и не пушистый котёнок. Только толку от такого заявления без соответствующих уточнений - ноль. Тоже, что характерно, число.

 

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

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

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

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

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

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

5 часов назад, IMXO сказал:

я ничего не упустил?

Да ты упустил вообще всё...
На данный момент у меня реализовано:

Глобальные переменные:
int z=0;                           //Общий таймер секунд.
int zsum=0;                   //Текущий таймер секунд.
int noel=0;                     //Номер элемента.
float volt[4];                  //Вольты.
float ampr[4];               //Амперы.
float chas[4];                //Время, часы.
float amch[4];               //Ампер-часы.
float vach[4];     
  
Функции:       
0.   100% int readADC(unsigned int ch) функция первичного опроса АЦП (10 бит, 6 каналов от мультиплексора);
1.   100% void siem(void)              процедура съёма показаний АЦП (формирование массива);
2.   20 % void rasschet(void)        процедура расчёта и обработки первичных показаний АЦП (только болванка, без математики);
3.1. 90 % void start (void)             процедура предварительных настроек (кнопки, светодиоды,таймер, прерывания);
3.2. 80 % void presets()                 процедура предварительных настроек (АЦП, дисплей 5110);
      3.1. + 3.2. = 3.                           объединить функции
4.   60 % void pokaz(void)             процедура вывода на экран дисплея, после функции 2;
5.   80 % ISR (TIMER1_COMPA_vect)      процедура прерываний по совпадению таймера Т1 (каждые 5 секунд, в последствии каждые 5 минут функция 1 АЦП, 2 расчёт);
5.   90 % int main(void)                  Главная функция (кнопка старт, кнопка следующий элемент (их будет 3), вывод показаний на дисплей каждые 5 секунд, мигалка).

 

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

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

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

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

17 часов назад, dasZebra сказал:

Вам вам стоит бы прежде всего  себя, вообще неависимо от рода Вашей деятельности. 

Что?

Слушайте, после фразы "но чтобы кодить - нет" с вами всё понятно.
Очередной теоретик-фантазер.
Дальнейшую дискуссию считаю вредной, ибо тратит мое время

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

8 часов назад, Юрий_Нд сказал:

А ещё, согласно этой логике, можно записать:
PORTD |= (1<<6);
можно:
PORTD |= (4<<4);
а можно и 
PORTD |= 64;

... и все это будут "однохренственные " операции.

Как-бы да, но -  зачем?
Вы понимаете смысл выражения (1<<x) применительно к работе с портами?
Это означает обращение к конкретному биту.
x
говорит нам в каком разряде будет эта единичка. Во всех остальных разрядах - нули.

Вот простенький пример - бегущий огонь.

while(1)
{
	for(uint8_t c=0; c<8; c++)
	{
		PORTD = (1<<c);
		//тут можно задержку поставить
	}
}

К вам, Юрий, есть претензии, но вы хотя-бы стараетесь разобраться.
Один минус - не хотите (по неведомой мне причине) идти правильным путем, а исследуете всё методом тыка.

И нет, я вам не предлагал помощь с кодом. Благотворительностью не занимаюсь.

5 часов назад, IMXO сказал:

еще хуже когда фигвам выглядит так:

А что там не так?
Вроде a тут 32 битная переменная? И единичку можно сдвинуть на 18 разрядов.

Или я, пардон, что-то не так понял?

1 час назад, Юрий_Нд сказал:

Глобальные переменные:

float volt[4];                  //Вольты.
float ampr[4];               //Амперы.
float chas[4];                //Время, часы.
float amch[4];               //Ампер-часы.
float vach[4];     

А зачем тут вообще float?
Вы в курсе, что это весьма неточный формат представления числа?
Если вам нужны десятичные дроби - используйте фиксированную точку.
Например, вам нужны сотые доли вольта. Берете переменную такого типа в который влезет максимальное напряжение умноженное на 100.
Т.е., у вас максимальное напряжение 20 вольт, а разрешение вам интересно 0,01 вольт. тогда вам нужно взять uint16_t, так как в него влезает число 2000.
Эта фиксированная точка потом просто вами учитывается в расчетах и всё.

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

22 минуты назад, IMXO сказал:

внимательно посмотри значение а 

Ок. 32-х битная переменная a, по адресу 0x20 имеет значение 1 (0x00000001).
По коду мы видим a = (1<<18); , т.е. переменной a присваивают значение 0x00040000.

если красненький треугольник означает текущий шаг в симуляции, то непонятно, почему эта переменная содержит число 1, хотя должно содержать то же, что и b.
Видимо, это особенности компилятора и он не использовал неявное приведение типов?

Я в таких случаях делаю так: a = ((uint32_t)1)<<18; 
Такое написание отнимает пару секунд времени, зато не приходится потом искать такого рода ошибки.

Подскажите пожалуйста, у вашего компилятора включена совместимость с C99? Возможно из-за этого неявное приведение типов не работает?

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

12 минут назад, LiVit сказал:

у вашего компилятора включена совместимость с C99?

в ХС8 вообще нет этой опции , он включен по дефолту,
но суть в том что здесь нет неявного приведения типа
константа 1 вполне укладывается uint16_t , стандарт не нарушается

мало того если не включить оптимизацию на скорость кода
при явном указании размерности операнд b эта сцуко
вместо установки 18бита  ,  записывает в переменную b=1
и потом честно делает сдвиг на бит влево в цикле 18 раз :D

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

23 минуты назад, LiVit сказал:

Как-бы да, но -  зачем?

Только с одной целью. Я хотел чтобы Вы увидели, что я в этой теме действительно разобрался, а не плаваю...

39 минут назад, LiVit сказал:

Вы понимаете смысл выражения (1<<x) применительно к работе с портами?

Обидеть хотите?
Ну что ж, как Вам будет угодно.
Я полностью Вашим услугам/желаниям.
Единственная просьба, от дискуссий не уходите.

43 минуты назад, LiVit сказал:

К вам, Юрий, есть претензии, но вы хотя-бы стараетесь разобраться.

... то есть, я уже НЕ агрессивный невежда. Спасибо и на этом.

47 минут назад, LiVit сказал:

Благотворительностью не занимаюсь.

С детства не люблю подачек. Ваших благотворительных консультаций здесь, более чем достаточно. И за это Вам Большое спасибо.
В отличии от многих здесь присутствующих, каждое Ваше сообщение несёт полезную информацию, а не разного рода ухмылки, которые похожи на банальный флуд. Но это совершенно не моё дело. Пусть продолжают, если им некуда девать времени...

54 минуты назад, LiVit сказал:

Один минус - не хотите (по неведомой мне причине) идти правильным путем, а исследуете всё методом тыка.

... Я думал, что это очевидно, но если Вы не понимаете, постараюсь пояснить. Как Вы думаете какова цена знаниям полученным собственным умом и знаниям прочитанным в книжке?
Нужно продолжать? 
Далее. В начале этого сообщения я Вам более чем красноречиво показал, что в этой теме я прекрасно разобрался. Чем мне поможет с Бьерн Страуструп, если не ошибаюсь 2007 года издания, который сейчас где-то пылится у меня на полке? В коричневом твёрдом переплёте, книга большого формата. Приходилось держать в руках подобный экземпляр?

1 час назад, LiVit сказал:

Берете переменную такого типа в который влезет максимальное напряжение умноженное на 100.

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

1 час назад, LiVit сказал:

весьма неточный формат представления числа?

Здесь Вы затронули очень Важную для меня тему. Вы готовы её обсудить со мной, как диалог инженера с программистом? Здесь я конечно же имею в виду Ваше личное время.

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

42 минуты назад, IMXO сказал:

мало того если не включить оптимизацию на скорость кода
при явном указании размерности операнд b эта сцуко
вместо установки 18бита  ,  записывает в переменную b=1
и потом честно делает сдвиг на бит влево в цикле 18 раз :D

Как страшно жыть.....:blink:

Мне легче - я для ARM-ов пишу, в KEIL

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

13 минут назад, LiVit сказал:

ARM-ов пишу, в KEIL

там тоже  для (uint32_t) в CMSIS указан явный тип

Скрытый текст

 


/* SCB Interrupt Control State Register Definitions */
#define SCB_ICSR_NMIPENDSET_Pos            31                                             /*!< SCB ICSR: NMIPENDSET Position */
#define SCB_ICSR_NMIPENDSET_Msk            (1ul << SCB_ICSR_NMIPENDSET_Pos)               /*!< SCB ICSR: NMIPENDSET Mask */

 

 

 

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

30 минут назад, Юрий_Нд сказал:

... то есть, я уже НЕ агрессивный невежда. Спасибо и на этом.

... Я думал, что это очевидно, но если Вы не понимаете, постараюсь пояснить. Как Вы думаете какова цена знаниям полученным собственным умом и знаниям прочитанным в книжке?

Чем мне поможет с Бьерн Страуструп, если не ошибаюсь 2007 года издания, который сейчас где-то пылится у меня на полке? 

Здесь Вы затронули очень Важную для меня тему. Вы готовы её обсудить со мной, как диалог инженера с программистом? Здесь я конечно же имею в виду Ваше личное время.

1 - уточню - пассивно-агрессивный )))). А невежда от того, что не используете соответствующую литературу.

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

3 - ничем. Труп страуса про плюсы писал, если я не ошибаюсь. А Керниган и Ричи  - про Си. Был тут один гражданин на форуме. Он без затей попросил консультаций по Си, но за денежку. Я ему помогал, потом он пропал с горизонта. Недавно опять списывались. Так он понял, для чего ему Керниган и Ричи. Книжка бесплатная, там разжевано всё что нужно знать по Си. Если что-то нужно про двоичное счисление - тоже можно найти. Это просто.

4 - пишите, чем могу - помогу. Если время будет. А можно поступить проще - послушать умных людей на ютубе. Ссылка раз, ссылка два - это вообще по Си. А конкретно по float нужно у Хирьянова поискать. Возможно это было в цикле лекций по питону.

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

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

2 часа назад, LiVit сказал:

float?
Вы в курсе, что это весьма неточный формат представления числа?

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

... можно количество значащих цифр.

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

1 hour ago, Юрий_Нд said:

Только...  не нужно никаких выкладок из книжек.

"451 градус по Фаренгейту» - вы пришли к нам оттуда? За что вы так не доверяете книгам? Вы их ненавидите?

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

6 часов назад, Юрий_Нд сказал:

float chas[4];                //Время, часы.

это с каких пор время (целый тип данных) превратился в плавающую точку?

3 часа назад, Юрий_Нд сказал:

Насколько неточный?
Можете сказать самую большую относительную погрешность?

мантисса в флоте имеет 24 бита.

целые числа не более (2^24 - 1) ошибку не имеют.

а числа от 2^24 и выше сохраняются с погрешностью.

и самая большая погрешность - у самого большого числа типа флот.

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

Мудрость приходит вместе с импотенцией...

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

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

Уважаемый Старичок,
Я Вам очень благодарен за такую подробную выкладку. 
Насколько я вижу, относительная погрешность измеряется меньше чем даже в тысячных долях в процента.
Поэтому, для инженерных расчётов можно считать, что погрешности вообще нет.
Ещё раз Вам Большое спасибо за помощь,
С уважением ___________ Юрий.
п.с. ... да, и по-моему Вы немножко недоглядели. В наименовании моей переменной последняя буква S, как доллар, а не R, как Вы подумали.

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

я не совсем слепой. я видел, что название - час, в латинской транскрипции.

Мудрость приходит вместе с импотенцией...

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

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

о , конечно подскажите
и если не затруднит подскажите

15 часов назад, LiVit сказал:

А зачем тут вообще float?

очень хочется послушать мнение анжинера

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

13 hours ago, Юрий_Нд said:

не нужно никаких выкладок из книжек.

27 minutes ago, Юрий_Нд said:

Можете подсказать, почему chas должен быть целым?

Это действительно троллинг. Или все настолько безнадежно.

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

Подскажите пожалуйста, почему в Microchip Studio, слева, переменные нулевые,
а справа, в Proteus, содержат "правильные", ненулевые значения?

1 - Обменник - 49.png

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

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

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

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

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

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

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

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

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

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

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

  • Сообщения

    • @Богдан Назаренко , 4558 и 5532 на слух не отличить. Да и параметры у них практически одиннаковые. Мне показалось TL072 звучит хуже.
    • @maxim1881  Какой курс  студент ?  Прочитать схему  то умеешь ? И где - то к этой схеме есть описание  ...  Так вот по описанию и можно сделать то что  требуется ...  Я лично  два года учился , пока пришло просветение чтения схем  И так подтолкну  один блок тебе :  DD1.5 , DD1.6 , R9 C5 - генератор ... И так  далее ... Кароче  шукай  описание  в журналах на данную схему и все получится     Датчик пересечения ИК-луча Другая сфера применения аналоговых усилителей на основе микросхемы 4069 - инфракрасный датчик или фотоприемник инфракрасного сигнала. На рисунке 7 показана схема успешно эксплуатируемого уже несколько лет датчика, реагирующего на пересечение либо отражение инфракрасного луча. Интересно то, что в схеме нет широко используемых в таких случаях готовых интегральных фотоприемников. Сигнал принимается обычным ИК-фотодиодом, а усиление производится усилительными каскадами, выполненными на основе инверторов микросхемы 4069. Наличие шести инверторов в одном корпусе микросхемы 4069 позволяет весь датчик, как его приемную, так и передающую части выполнить на одной микросхеме 4069. И так, схема показана на рис. 7. Как обычно, ИК-датчик работающий на отражение или пересечение луча состоит из передатчика ИК-луча и его приемника. Передатчик ИК-луча состоит из ИК-светодиода HL1 (здесь светодиод, такой как в пультах ДУ аппаратуры), токового ключа на транзисторах VТ1 и VТ2 и генератора импульсов частотой около 8-10 kHz. Импульсы с выхода мультивибратора на элементах D1.5 и D1.6 поступают через токовый ключ на VT1 и VT2 на ИК-светодиод HL1. Резистор R11 ограничивает ток через светодиод. HL1 излучает ИК вспышки, следующие с частотой 8-10 kHz. Если существует видимость между HL1 и FH1, излученные вспышки воздействуют на фотодиод FH1 ив нем возникают импульсы тока. Благодаря резистору R1 они преобразуются в импульсы напряжения. Переменное напряжение через конденсатор С1 поступает на первый усилитель на элементе D1.1. Его в усилительный режим переводит резистор R2. Далее, через С2 усиленное переменное напряжение поступает на усилитель на D1.2. В цепи ООС D1.2 есть резистор R3, который смещает его вход в сторону напряжения логической единицы. В результате его выход смещен в сторону логического нуля. Поэтому, в отсутствие входного сигнала напряжение на С3 соответствует логическому нулю. Но при наличии входного сигнала за счет работы детектора на VD1 напряжение на С3 увеличивается до логической единицы. Выходные импульсы формирует триггер Шмитта на элементах D1.3 и D1.4. Фотодиод РН302 можно заменить любым ИК-фотодиодом. Налаживание датчика сводится к подбору сопротивления R3, чтобы при отсутствии сигнала на выходе D1.4 был ноль, а при наличии сигнала - единица. Везде вместо микросхемы 4069 можно попробовать микросхему К561ЛН2. Тюльгин Ю.М. РК-2016-03.
    • Ух... добавили вы мне оптимизма... Никогда б не подумал что  на такой мелочёвки жулики так заморочились.. Ну как сказать... В своё время я зарабатывал на ремонте 3УСЦТ и старше (само собой и смежной технике). Потом несколько лет ремонт связной спецтехники (основная задача - настройка-обслуживание, а ремонты - то по необходимости). Но последние лет 20 паяльник используется редко и то в основном для пайки проводов-разъёмов и разной мелочёвки.
    • 4558 неплохая микросхема, особо не отличается от 5532, и наушники потянет, если у вас нет завышенных требований.
    • Они да более мение хороши а вот флажки смотря где использовать,в блоки питания или НЧ части его можно использовать роботать будет хорошо но ВЧ не очень он уж тогда хороший получается обычно по сравнению с КМ конденсаторами,и кстати ещё один вопрос возник вот есть такие коричневые конденсаторы керамические современные с кодами они ещё,которые ещё бывают паралельно моторику в детских игрушках ставят и очень много где ещё,и он же получаеться как флажок примерно по характеристикам?потомучто что то и что то ставят много где,интересно было бы и про них узнать информацию,ещё я их ни когда не использовал,что они из себя такое эдакое представляют 
  • Похожий контент

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