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

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


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

Реклама: ООО ТД Промэлектроника, ИНН: 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 пользователей онлайн

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

  • Сообщения

    • Согласен, очень криво объяснил. Это работа трёх вольтовой линии, просто на диод шотки сдвоенный, на один анод приходит сигнал напрямую с трансформатора, а на второй через дроссель. Вольт/деление 5 вольт в клетке, тайминг по моему 10 МС. Третья фотография это сигнал на катодах уровень земли ровно по центру экрана. Но все линии по итогу в порядке 3.3 в, 5, в, 12 в и -12 в. Нагрузить все линии не могу сразу ,так как тут же выгорают транзисторы (имеется нагрузка 250 ватт по 10 ампер на каждую линию за исключением-12в), поэтому нагружаю 3.3 вольтовую линию на 10 ампер,  подключаю переменный резистор 50 ватт на 15 ом на 5 вольтовую линию и постепенно довожу до той той картины с перекосом (это гдето  50 ватт общее). По поводу микросхемы, вверху имеется скрин где между импульсами проскакивает мини импульс, если так можно сказать, он проскакивает и на одной  и на второй ноге (7,8). Микросхема не tl 494, а lw4933/abx942.1/c9421646. Далее они приходят на базы транзисторов 945g  коллекторы этих транзисторов соединены с  выводами трансформатора. Просто схема типовая, легче мне кажется просто привести фото самого блока, для тех кто разбирается будет гораздо информативне.  Диод шотки по 12 вольтовой линии был подгоревший, заменил на донора. Приводить скрины не буду что бы не захламлять тему. В итоге, пока все так же, при достижении определенной нагрузки суммарно где-то 50 ватт, появляется этот "выброс и перекос". По этому имеются мысли на два варианта, это микросхема , этот мини импульс между периодами, на низкой нагрузке особо не влияет, но при достижении определенной приводит с самовозбуждению входной цепи и непроизвольному открытию транзистора нижнего плеча. Либо дело в "горячей части", плавающий дефект в обвязке силовых ключей.  Спасибо за ответ.
    • @Gomerchik а вы контролировали как меняется уровень сигнала на А1 ардуины?
    • Спасибо за совет. Автором данного проекта я не являюсь, мне нужно было воссоздать уличный датчик для метеостанции взамен пропавшего(( Из разного найденного в интернете этот проект работает с моей станцией Орегон (спасибо автору). В понедельник попробую последовать Вашему совету. Но все равно куча непоняток  как блин это работает)) Если дело в неправильной отправки команды, то как на это влияет подключение датчика температуры? Если совсем не подключать таймер, то передача идет один раз (как и прописано в программе), станция принимает и отображает, но минут через сколько-то естественно станция уже ни чего не показывает, но с таймером питание полностью не пропадает с ардуинки, но передача сигнала каким-то образом работает по таймеру.  В моем понимании данная команда подается один раз потому, что таймер должен отключать питание МК после передачи сигнала и каждые 43 сек снова подавать питание (так того требует станция).  Ардуино передает показания температуры отключается полностью и 43 секунды мк не работает.  Сейчас у меня питание пока сделано на подпитке от солнечной батареи, но пару пасмурных дней и аккумулятор съедается до отключения(
    • thickman Так и сделаю. Вытащу из бу БП.  Буду знать, как отличить. Благодарю. Заменил транзисторы на IRFB20N50K. Картина стала, совсем другой.  Похоже трудность не в драйвере, на момент подвозбуда, переходные процессы, в нем, завершены. Увеличил затворные резисторы до 50ом, стало немного лучше.  Не понятно, почему верхний ключ греется несколько сильнее. Возможно, стоит посмотреть ток в коллекторе.  Снабберные емкости временно удалил, изменений не произошло.  Замена ТГР на другой, на кольце MSTN-16A-TH, так же, результата не принесла.   irfb20n50k.pdf
    • А что нить из ассортимента активных щупов производства СССР..))
    • Типа такого: https://aliexpress.ru/item/2044864227.html?sku_id=58855020183
  • Похожий контент

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