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

Что Не Так С Алгоритмом?


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

Только начал изучать асемблер как такая проблема. Сделал по алгоритму прошивку а она толково не работает. Когда на порт D подаешь - то на порту B должен быть тоже минус. и светодиод должен постояно гореть а он мерцает. что не так с алгоритмом.

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

Очень люблю спасибку.

Спасибка ни кого еще не убила.

Професия: Електро-механик.

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

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

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

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

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

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

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

Зачем же так сложно? Может сделать проще?

main:
in temp,pind
out portb,temp
rjmp main

В таком случае порт В будет соответствовать порту D.

Вот только что заметил проблему нужно чтоб на весь порт B выводилось состояние того что есть на одной ноге порта D.

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

Очень люблю спасибку.

Спасибка ни кого еще не убила.

Професия: Електро-механик.

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

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

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

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

Ну дак ставьте проверку нужного бита по порту D, и в зависимости от результата записывайте в B либо 0x00, либо 0xFF. Команды для проверки бита имеются. Можно и через маску...

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

Или так

main:
clr temp
SBIC pind,cont_pin
ldi temp,0xFF
out portb,temp
rjmp main

Проверял не работает

Очень люблю спасибку.

Спасибка ни кого еще не убила.

Професия: Електро-механик.

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

Cont_pin нужно заменить на числовое значение проверяемого пина. В твоем случае на 0. Могу поправить tcoder-a немного... ldi temp,0x255 лучше заменить на ser temp. Смысл тот же, но читается лучше.

tcoder

Дуплетом. :)

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

ldi temp,0x255 лучше заменить на ser temp.

Ага, почитал что это за инструкция. Это уж вам, авр-щикам наверно привычнее использовать) Я то не практикую AVR. Хотя подозревал что ser быстрее должен выполняться, но как оказалось загрузка константы за то же время происходит однако.... видимо нескоро я от IBM отвыкну :)

Дуплетом

Долго думал про что, пока на время добавления постов про Cont_pin не глянул :) Действительно)

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

Тот же цикл, только в команде константа уже зашита.

Т.е. в бинарном виде нельзя отличить LDI от SER и от CLR как я понял? *Глянуть чтоле)

*глянул. Действительно КОПы SER и LDI идентичны, а вот CLR отличается и 10 бит на регистр вместо 8, как у LDI и SER.

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

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

Очень люблю спасибку.

Спасибка ни кого еще не убила.

Професия: Електро-механик.

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

Бред. Частота выполнения алгоритма - это частота выполнения команд грубо говоря, с какой скоростью перебираются команды никак не должно влиять на состояние порта. Это просто недопустимо и нелогично.

Если что-то замерцало, когда не должно было - значит в алгоритме есть ошибка. Обсуждаемые здесь короткие алгоритмы должны ровно работать. Если всё равно мерцает - значит проблема не в алгоритме.

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

Вот:

main:

sbi PORTB,0

in temp, PIND

sbrc temp, 0

rjmp main

cbi PORTB, 0

rjmp main

сократил код до минимума. но задержка в тысячние осталась. думаю так и оставить и изучать дальше асемблер

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

Очень люблю спасибку.

Спасибка ни кого еще не убила.

Професия: Електро-механик.

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

Ваш последний Ваш вариант #16 будет мерцать.

Для этого даже смотреть алгоритм особо не надо. У вас первой же строкой по метке main идёт установка бита. Далее мы видим, что все rjmp идут на эту метку. Вывод - чтобы в алгоритме не случилось - при возврате на main всё равно единица установится.

Задержкой реакции здесь как раз будет время выполнения команд между чтением порта Д и записью в порт Б включительно + rjmp. Рассчитать время реакции можно точно, зная частоту, на которой работает МК и тайминги команд (они приведены в датащите).

Касательно битовых операций прямо на порте - я лично избегаю этих команд в быстрых циклах, т.к. опасаюсь эффекта "мусора", связанного с ёмкостным поведением порта при использовании битовых операций (они же Считал-Изменил-Записал, а порт то не успевает стабилизироваться к следующему вызову битовой операции). Далеко не уверен, что на всех микроконтроллерах этот эффект есть, но всё равно избегаю (суеверие чтоле... надеюсь нелишнее)

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

hardbar

Вы недопонимаете приведенный нами алгоритм. Дело в том, что в наших с tcoder-ом алгоритмах изменение состояния порта более статично по отношению к главному циклу main. Т.е. если в предыдущем цикле порт имел состояние 0, и в следующем цикле он должен быть 0, то значение порта не изменяется. В вашем случае, вы постоянно взводите "курок" (как перед выстрелом), а потом применяете требуемое значение. Отсюда и импульсы. Они появляются только когда требуется вывести 0, а при 1 их нет? Угадал?

Вам бы поработать с VMLAB 3.15, там есть осциллограф и при пошаговой отладке все видно (откуда что берется). Упс... Attiny2313 там нет.

Те строчки, которые все портят:

main:
sbi PORTB,0	 ;подняли порт в 1, а если было и должно быть 0
in temp, PIND ;пока "раскорячимся"
sbrc temp, 0 ;и поймем, что...
rjmp main
cbi PORTB, 0 ;дествительно, должен быть 0, как и ранее...
rjmp main

...пройдет время, а на выходных линиях порта в это время будет висеть импульс лог.1, созданный вами с начала цикла main. Берите алгоритм tcoder-а, он рабочий.

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

Свою ошибку я понял . Но не понял как сделать так чтобы не сводить "курок". при нажатии светит при отпускании тухнет. как после отпускания клавиши убрать 0 с порта?

Очень люблю спасибку.

Спасибка ни кого еще не убила.

Професия: Електро-механик.

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

Применить алгоритм tcoder-а (самый оптимальный).

С поправкой к реальным условиям:

main:
clr temp
SBIC pind,0
ser temp
out portb,temp
rjmp main

В данном варианте, изменение состояния порта производится ОДИН РАЗ ЗА ОДИН ПРОХОД цикла main, потому что все манипуляции производятся в регистром общего назначения, а не с регистром ввода/вывода. Поэтому "служебные" передергивания алгоритма не отражаются на линиях порта В.

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

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

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

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

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

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

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

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

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

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

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

    • Ну вот, пока готовил эскиз, на все вопросы ответили :-) Действительно, в 3D моделях DipTrace нет (или не нашёл) модели корпуса ТО220 с распайкой с нижней стороны и креплением к радиатору - по этому и получился такой 3D-портрет платы. Задуманная конструкция выглядит примерно так:  По факту, для наладки, сейчас подключаю транзисторы, закрепленные на радиаторе, проводами.
    • Чтобы потом не допиливать паровоз до истребителя. Заводские варианты схемотехники куда более предсказуемы. Из "вольностей" в первую очередь как-то решать проблему коммутации, подходящий переключатель для режимов искать история долгая и грустная. Что-то там с реле. На диапазоны 6п4н вроде же ?  пг2 хрен найдёшь, п2г тугое неудобство(  Рассыпушный ацп делать, боже упаси. Ну разве что был грешен, побаловался когда-то пнч-ацп. С 1108пп1 и 155 серией
    • Но зачем повторять 1в1? Там дана просто топология   Но не совсем же с нуля. Маловероятно, что вы найдете расширение диапазона 7135 до 200мВ по тому же методу, что это реализовано в В7-38, тем не менее, это вполне реализуемо. А вот до 20мВ я спустить диапазон не смог Что-то предусилитель интегратора отказывается вести себя хорошо   Для сравнения, та же точка (вход интегратора) при 200мв пределе, усиление х10   Ну и 2В Госпаде боже лтц2400, на этой штуке можно и 6 разрядник собрать, лютый АЦП, какие 4.5 разряда Цена на него сейчас конечно негуманная кстати.
    • Что то не нашёл примеров такой реализации замены. С нуля целесообразность подобного действа под вопросом. Тут мои полномочия всё) Как бы почему смотрю на hm8011-3, возможность реализации +/- норм настольного мультиметра без всякой там жести в виде кодинга и микро-мелких современных элементов. Для калибровки валяется где-то в1-12 и прецизионных резисторов если моих не хватит, есть где заказать.  На данный момент разве что качественного файла нет, пытался там всякими улучшайками чего сделать, увы. Пойду через впн лазить по уголочкам всяким, вдруг всплывёт чего. ------------- 8012, 80c32 + 27c512. Чертежи плат есть, осталось hex раздобыть 
    • Вот на этом фото? Я думал  тут радиатор будет под ними, и они к нему "пузом" будут прикручиваться, а дырочки - для отвёртки. У @asng60 транзисторы в наружную сторону "мордой" смотрят. "Пузом" на плату ложатся. Плата так разведена. Вот и непонятно, как их "пузом" к радиатору прикручивать.
    • Что касаемо модели Парафина, я бы порекомендовал товарищу Джексону проверить ток покоя выходного каскада, это первым делом, и вторым делом- проверить модель ОУ. Ибо в ОМ нет никаких оу а в парафине- есть. 
×
×
  • Создать...