Микроконтроллеры. Область применения

Многие не знают, как выглядит микроконтроллер, но наверняка все видели небольшие микросхемы, находящиеся на печатной плате. Одна из таких микросхем запросто может оказаться микроконтроллером. Основная его функция – это управление электронными устройствами. Часто микроконтроллер называют «чипом» или «микрочипом», «мозгами» или просто контроллером.

Что такое микроконтроллер?

Микроконтроллер представляет из себя микросхему , внутри которой располагаются процессор, оперативно-запоминающее устройство (ОЗУ), постоянное запоминающее устройство (ПЗУ), генератор тактовой частоты и периферийные устройства , такие как аналоговые и цифровые порты, интерфейсы, компараторы, таймеры и т.п. То есть это настоящий мини компьютер в одном маленьком кристалле, предназначенный для решения относительно простых задач. Центром микрочипа является процессор, выполняющий программу, записанную во внутреннее или внешнее ПЗУ. Посредством выполнения программы и происходит решение задач, для которых предназначено электронное устройство.

История микроконтроллеров

Появились микроконтроллеры в 1971 году, благодаря американцам М. Кочрену и Г. Буну. С тех пор их стали массово использовать в компьютерной технике и промышленной автоматизации. В Советском Союзе также велись разработки подобных устройств. Первый отечественный микроконтроллер был создан в 1979 году.

В настоящее время изготовлением микроконтроллеров занимается множество компаний по всему миру. Выпускаются 8-битные, 16-битные и современные производительные 32-битные микроконтроллеры. Наиболее популярными считаются микроконтроллеры PIC, AVR, MSP430 и ARM.

Разнообразие микроконтроллеров

Внешне одинаковые, все они отличаются друг от друга скоростью работы процессора, его разрядностью и размером внутренней памяти. Существует более 200 модификаций микроконтроллеров. Для каждого устройства необходимы микроконтроллеры с определенными параметрами (желательно максимально подходящими под решаемую устройством задачу при минимальной стоимости). Поэтому помимо производительности, при создании микроконтроллера, учитывается и его итоговая стоимость. Наиболее востребованы рынком массовые типы микроконтроллеров, имеющие простое устройство и наиболее дешевые в производстве. Такие микроконтроллеры предназначены для решения простых задач и используются в детских игрушках, бытовой технике, в системах автоматического открывания дверей и т.д. Но существуют и микроконтроллеры, которые могут выполнять множество различных сложных операций за короткий промежуток времени. Такие микрочипы ставят в современные смартфоны, планшеты и другую сложную технику. Конечно, и цена на такие микросхемы соответствующая.

Как программируют микроконтроллеры?

Для того чтобы быть использованным в электронном устройстве, микроконтроллер должен быть запрограммирован управляющей микропрограммой («прошивкой»), которая будет управлять данным устройством. Прошивки, в большинстве случаев, пишутся на таких языках программирования как Си и ассемблер. Язык Си имеет преимущество перед ассемблером, поскольку предоставляет возможности для более быстрой разработки микропрограммы, обладает универсальностью, лучшей читаемостью алгоритма. Если же задача требует использования высокопроизводительных микроконтроллеров для своего решения, то в большинстве случаев в качестве прошивки используют какую либо операционную систему и специально написанное для нее программное обеспечение.

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

Процесс программирования микроконтроллеров

Процесс программирования микроконтроллеров состоит из нескольких этапов. В первую очередь определяются задачи, которые будет выполнять микроконтроллер. Затем разрабатывается схема электрическая принципиальная – графическая модель, предназначенная для обозначения взаимосвязей элементов. Далее составляется алгоритм работы микроконтроллера в устройстве и пишется микропрограмма (или используется уже имеющаяся). По завершению разработки можно приступить непосредственно к загрузке программы в микроконтроллер («прошивке»). С помощью симуляторов и эмуляторов можно промоделировать работу микрочипа на компьютере и увидеть, как он будет работать в устройстве. Для того чтобы файл-прошивку записать в микроконтроллер, используется специальное устройство – программатор, который вместе с микроконтроллером подключается к персональному компьютеру. Есть два способа прошивки – параллельное программирование и внутрисхемное программирование. Первое более быстрое и используется при массовом производстве. Второй вид программирования часто используется для перепрошивки готового устройства.

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

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

Микроконтроллеры в наши дни используются практически во всех сферах деятельности человека – в компьютерах и вычислительной технике, в бытовой и электротехнике, в военной промышленности, транспортных средствах и т. д. У каждого человека дома и на работе есть устройства с микроконтроллерами – телевизоры, мобильные телефоны, стиральные машинки, автомобили. Это можно перечислять бесконечно. Уже невозможно представить мир без умных электронных устройств. Использование микроконтроллеров позволяет сделать устройство более компактным и снизить энергопотребление, а грамотно написанная микропрограмма повысит его конкурентоспособность. Поэтому важно обращаться для создания электронных устройств с использованием микроконтроллеров в , где высококвалифицированные специалисты выполнят и помогут выпустить вашу идею на рынок в кратчайшие сроки.

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

Итак, микроконтроллер это небольшая микросхема, на кристалле которой собран настоящий микрокомпьютер! Это означает, что внутри одной микросхемы смонтировали процессор, память (ПЗУ и ОЗУ), периферийные устройства, заставили их работать и взаимодействовать между собой и внешним миром с помощью специальной микропрограммы, которая храниться внутри микроконтроллера.

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

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

Так выглядят современные микроконтроллеры.

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

Мы сказали, что микроконтроллер это своего рода микрокомпьютер (старое название однокристальные микроЭВМ). Представим его в виде черного ящика. Внутри этого ящика расположены основные структурные элементы микроконтроллера.

Арифметико-логическое устройство (АЛУ) – предназначено для выполнения арифметических и логических операций, на самом деле в совокупности с регистрами общего назначения АЛУ выполняет функции процессора.

Оперативно – запоминающее устройство (ОЗУ) – предназначено для временного хранения данных при работе микроконтроллера.

Память программ - выполнена в виде перепрограммируемого постоянного запоминающего устройства и предназначена для записи микропрограммы управления микроконтроллером, так называемая прошивка.

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

Микроконтроллер в своем составе может иметь и другие вспомогательные элементы.

Аналоговый компаратор – предназначен для сравнения двух аналоговых сигналов на его входах

Таймеры в микроконтроллерах применяются для осуществления различных задержек и установки различных интервалов времени в работе микроконтроллера.

Аналогово-цифровой преобразователь (АЦП) необходим для ввода аналогового сигнала в микроконтроллер и его функция перевести аналоговый сигнал в цифровой.

Цифро-аналоговый преобразователь (ЦАП) выполняет обратную функция, то есть сигнал из цифрового вида преобразует в аналоговый вид.

Работа микроконтроллера синхронизируется тактовыми импульсами с генератора и управляется устройством управления микроконтроллера.

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

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

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

Видео посвящено видеокурсу о программировании микроконтроллеров фирмы Atmel , пройдя который вы не только познакомитесь с замечательным миром микроконтроллеров, но и научитесь программировать микроконтроллеры, а следовательно самостоятельно создавать электронные устройства на микроконтроллерах.

Видеокурс "Программирование микроконтроллеров для начинающих" более 70 часов качественного видео.

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

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

Несмотря на сложность конструкции современного микроконтроллера, рассказать, как он работает можно всего одним предложением: "В память микроконтроллера просто пишется код программы, МК считывает команды из этой программы, а затем просто выполняет их", - вот и весь принцип работы.


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

Некоторые МК могут иметь огромное число базовых команд, другие куда меньшее. Это условное разделение, для которых думатели используют два термина: CISC и RISC. CISC - это много разных видов команд, RISC - это только самые нужные.

Большинство МК предпачитают молиться богу RISC. Объясняется это тем, что при применении сокращенного набора команд МК изготовить гораздо проще и наного дешевле, кроме того их легче переваривают разработчики аппаратуры, особенно чайники. Между CISC и RISC имеется множество отличий, но принципиально важно понять чайнику только то, что CISC - много команд, RISC -мало. Глубже разберемся, чуть позже, когды вы не будете такими зелеными.

Давайте представим идеальный случай, У нас есть МК и в его память уже записан программный код. Или, как обычно говорят "ушастые перцы", Микроконтроллер "прошит" (при этом программный код кличат "прошивкой").

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

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

Устройство типичного МК

Любой МК, как и любая микропроцессорная система базируется на трёх китах:

Процессор (АЛУ + устройство управления)
Память (RAM, ROM,FLASH)
Порты ввода-вывода.

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


Физическая структура микроконтроллеров разных серий может достаточно сильно отличаться, но общая база у них будет похожа и она будет состоять из следующих блоков: ОЗУ, ПЗУ, АЛУ, таймеры, порты ввода/вывода, регистры, счетчики.

ПЗУ Постоянное запоминающее устройство или постоянная память. Всё, что записано в ПЗУ, остаётся в нем и после отключения питания.
ОЗУ Оперативно запоминающее устройство - рабочая память МК. В неё сохраняются все промежуточные результаты выполнения програмного кода или данные от внешних датчиков.
АЛУ Мозг МК. Именно он вычитает, складывает, умножает, а иногда и делит, сравнивает единички и нолики в процессе выполнения программы..
Порты I/O Порты ввода и вывода: Устройства через которые МК ведет диалог с внешним миром с внешним миром. Наш МК должен общаться с внешним миром. Благодаря портам мы можем посылать в микроконтроллер сигналы от датчиков, клавиатуры и т.п. А МК после обработки таких сигналов отправит через эти устройства свой ответ, с помощью которого можно регулировать яркость свечения лампы или скорость вращения двигателя.
Таймеры Он отсчитывает интервалы, выдает сигнал о срабатывании и т.д.
Счетчики Необходимы, когда нужно что-то подсчитать.
Каждый регистр представляет собой миниатюрную ячейку памяти. И обычно в МК их всего несколько десятков.

Как ты уже знаешь из курса основы цифровой электроники, вся информация в цифровом мире представляется в виде двоичных чисел, которые записываются с помощью всего двух цифр: "нуля" и "единицы" в двоичной системе счисления. Число три в привычной для нас десятичной системе в двоичной будет "11", т.е. 3 10 = 11 2 . Нижние индексы подсказывают о системе счисления. Одна цифра в двоичном числе называется разрядом. У разрядов имеется старшинство. Самый правый разряд называют младшим, а самый левый соответственно старшим. Старшинство разряда увеличивается справа налево:


При работе микроконтроллера в нем "бегают такие же двоичные числа". Они перемещаются от процессора к памяти и обратно, а также к устройствам ввода-вывода (УВВ). Бегают циферки по проводам (в МК они спрятаны внутри микросхемы). Каждый такой проводник в какой-то заданный программой момент времени может передавать только один разряд со значением "0" или "1". Поэтому, для передачи 8-ми разрядного числа от процессора к памяти и обратно понадобится минимум 8 таких проводников.

Несколько таких объединенных проводов, называют шиной. Шины бывают нескольких видов:

Шина адреса
Шина данных
Шина управления

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

Разрядность шины адреса влияет на количество адресов, которые можно по ней пропустить. Допустим, в 4-разрядной системе это 2 4 = 16 адресов, в 64-разрядной, числов адресов будет уже 2 64 =18446744073709551616, т.е чем выше разрядность адресной шины тем к больше объем памяти и больше УВВ можно использовать, с которыми может работать МК. Это очень важный момент.

Разрядность шины данных влияет на то, сколько данных процессор способен считать за один раз. Чем больше разрядность, тем больше данных можно считать за один раз. Разрядность шины данных целиком задается конструкцией конкретного МК. Но при этом она всегда будет кратна восьми. Объясняется это тем, что практически во всех устройствах памяти минимальной единицей информации является байт, т.е. обычное двоичное число из восьми разрядов.

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

Кстати в отличии от привычной системы счисления, 1 байт = 8 бит, 1 килобайт = 1024 байтам, 1 мегабайт = 1024 килобайтам и т.д. Почему именно 1024? Спросите вы. Да потому, что размер памяти кратен степени двойки: т.е 2 3 = 8, 2 10 =1024.

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

Для того, чтобы подсказать МК какую из этих команд требуется выполнить и нужна шина управления. По ней к памяти или портам ввода-вывода следуют сигналы:

Если МК необходимо обратиться к памяти он задает на управляющей шине сигнал MREQ, при этом одновременно с ним задается сигнал RD/WR. Если МК будет писать в память, то задается сигнал WR, если чтение, соответственно RD. Тоже случится, когда МК обращается к УВВ.

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

Таким образом, если подать питающее напряжение на МК, то он выставляет сигнал на управляющей шине MREQ, RD, а на адресной шине - адрес, по которому в ячейке памяти должна быть первая команда его алгоритма (программного кода, обычно это нулевой адрес памяти). Затем МК её выполняет и в зависимости от управляющих команд на шинах управления, адреса и данных будут появляться соответствующие программе данные и сигналы.

МК AVR приобрели огромную популярность в радиолюбительской среде, привлекая электронщиков такими показателями, как цена, энергоэффективность и быстродействие. Кроме того огромным плюсом являются удобные режимы программирования, свободная доступностью программных средств поддержки и широкий выбор МК. Эта серия компании Atmel применяется в автомобильной и бытовой электронике, сетевых картах и материнских платах компьютеров и ноутбуков, в смартфонах и планшетах.

Одной из первых фирм выпустившей в большой мир микроконтроллеры на ядре ARM Cortex-M3 является компания «STMicroelectronics». Начиналось всё не так и давно в 2007 году с появления двух семейств – «Performance Line» (STM32F103) и «Access Line» (STM32F101). На текущий момент МК STM32 представлены десятью основными линейками для различных задач. Основные их достоинства это «pin-to-pin» и полная программная совместимость по всем возможным линейкам. И это всё уместилось на ядре ARM Cortex-M3. Рассмотрим основные инструменты, для того что бы можно было начать работу с МК STM32.

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

Многообразие применений

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

Что это такое?

Микроконтроллер - это компьютер. Все компьютеры, независимо от того, являются ли они персональными или большими мэйнфреймами, обладают некоторыми общими чертами. У них есть который выполняет программы, загружая команды из какого-либо хранилища данных. На ПК, например, это жесткий диск. Компьютер также оборудован оперативным запоминающим устройством (ОЗУ). Для коммуникации с внешним миром должны предусматриваться специальные средства. На ПК клавиатура и мышь являются устройствами ввода информации, а монитор и принтер используются для ее вывода. Жесткий диск объединяет в себе обе эти функциональные возможности, поскольку работает как с входными, так и выходными данными.

ЦПУ

Тип используемого в микроконтроллере процессора зависит от конкретного приложения. Доступны варианты от простых 4-, 8- или 16-разрядных до более сложных 32- или 64-битных. Что касается памяти, то могут использоваться ОЗУ, флэш-память, EPROM или EEPROM. Как правило, микроконтроллеры рассчитаны на использование без дополнительных вычислительных компонентов, поскольку они спроектированы с достаточным объемом встроенной памяти, а также имеют контакты для общих операций ввода-вывода, чтобы напрямую взаимодействовать с датчиками и другими компонентами.

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

Программирование

Процессоры микроконтроллеров могут базироваться на расширенном (CISC) или сокращенном наборе команд (RISC). CISC обычно включает около 80 инструкций (RISC - около 30), а также большее число режимов адресации - 12-24 по сравнению с 3-5 у RISC. Хотя расширенный набор команд проще реализовать и он эффективнее использует память, его производительность ниже из-за большего количества тактовых циклов, необходимых для их выполнения. RISC-процессоры уделяют больше внимания программному обеспечению и более производительны.

Первоначально языком микроконтроллеров был ассемблер. Сегодня популярным вариантом является язык C.

При наличии соответствующего кабеля, программного обеспечения и ПК запрограммировать микроконтроллер своими руками несложно. Необходимо подключить контроллер кабелем к компьютера, запустить приложение и загрузить набор команд.

Определяющие характеристики

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

  • Микроконтроллеры являются элементами какого-либо другого устройства (часто бытовой техники) для управления его функциями или работой. Еще их называют встроенными контроллерами.
  • Устройство предназначено для выполнения одной задачи и запуска одной конкретной программы, хранящейся в ПЗУ, которая обычно не изменяется.

  • Микроконтроллеры - это маломощные чипы. Их мощность при питании от батареи составляет около 50 мВт. Настольный компьютер почти всегда подключен к розетке и потребляет 50 Вт и больше.
  • Микроконтроллер отличается наличием специального блока ввода и часто (но не всегда) небольшого светодиода или ЖК-дисплея для вывода. Принимает входные данные от устройства, которым он управляет, посылая сигналы различным его компонентам. Например, микроконтроллер телевизора получает сигналы с ПДУ и отображает вывод на экране телевизора. Он управляет селектором каналов, динамиками и некоторыми настройками изображения, такими как контраст и яркость. Контроллер автомобильного двигателя принимает входные сигналы от датчиков кислорода и детонации, регулирует создание топливной смеси и синхронизирует работу свечей зажигания. В микроволновой печи он принимает ввод с клавиатуры, отображает вывод на ЖК-дисплее и управляет реле включения и отключения СВЧ-генератора.
  • Микроконтроллеры - это зачастую небольшие и недорогие устройства. Компоненты выбираются таким образом, чтобы минимизировать размеры и максимально удешевить производство.
  • Часто, но не всегда, работа микроконтроллера осуществляется в неблагоприятных условиях. Например, устройство управления двигателем автомобиля должно работать в экстремальных температурах, при которых обычный компьютер вообще не может функционировать. На севере микроконтроллер автомобиля должен функционировать при температуре -34 °C, а на юге - при 49 °C. В моторном отсеке температура может достигать 65-80 °C. С другой стороны, микроконтроллер, встроенный в проигрыватель Blu-ray, вообще не должен быть особо прочным.

Требования к ЦПУ

Процессоры, используемые в микроконтроллерах, могут сильно различаться. Например, в сотовых телефонах применялся 8-разрядный микропроцессор Z-80, разработанный в 1970-х годах и первоначально использовавшийся в домашних компьютерах. GPS-навигатор Garmin оборудовался маломощной версией Intel 80386, которую также первоначально устанавливали в настольных ПК.

Большая часть бытовой техники, такой как микроволновые печи, нетребовательна к процессорам, но их цена является важным фактором. В этих случаях производители обращаются к специализированным микроконтроллерам, разработанным из недорогих, небольших и маломощных ЦПУ. Motorola 6811 и Intel 8051 являются хорошими примерами таких чипов. Также выпускается серия популярных компании Microchip. По сегодняшним меркам эти процессоры невероятно минималистичны, но они чрезвычайно дешевы и часто могут полностью удовлетворить потребности конструктора.

Экономичность

Типичный микроконтроллер - это чип с 1000 байтов ПЗУ, 20-ю байтами ОЗУ и 8-ю контактами ввода-вывода. При выпуске большими партиями их стоимость невысока. Конечно, запустить Microsoft Word на таком чипе невозможно - для этого потребуется не менее 30 МБ ОЗУ и процессор, выполняющий миллионы операций в секунду. Но для управления микроволновой печью этого и не нужно. Микроконтроллер выполняет одну конкретную задачу, а низкая стоимость и энергопотребление являются его главными преимуществами.

Как работает?

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

  • При отключенном питании устройство никак себя не проявляет.
  • Подключение микроконтроллера к источнику энергии запускает блок логики системы управления, который отключает все другие схемы, кроме кварцевого кристалла.
  • Когда напряжение достигает своего максимума, частота генератора стабилизируется. Регистры заполняются битами, отражающими состояние всех схем микроконтроллера. Все контакты конфигурируются как входы. Электроника начинает работать согласно ритмической последовательности тактовых импульсов.
  • Счетчик команд обнуляется. Инструкция по этому адресу отправляется в декодер команд, который ее распознает, после чего она немедленно выполняется.
  • Значение счетчика команд увеличивается на 1, и весь процесс повторяется со скоростью миллион операций в секунду.

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

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

Начиналась вся эта эра микроконтроллеров, которые мы сегодня используем во всех видах техники, с микро-ЭВМ или Электро-Вычислительных-Машин. Они, по сути, и были первыми контроллерами, что традиционно означает – управляющее устройство, но строились на платформе одного кристалла.

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

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

Назначение и область применения микроконтроллера

Но давайте разберёмся, чем smd микроконтроллеры 14 pin отличаются от 12 пиновых и как применять микроконтроллеры для чайников.

Для начала стоит обозначить, что область применения МК – гигантская, каждый современный автомобиль, холодильник и любой электрический прибор, если не учитывать различные адаптеры и модули, содержат в себе тот самый однокристальный (чаще поликристальный) чип. Ведь без него было бы невозможно, в принципе, контролировать приборы и каким-либо образом ими манипулировать.

А назначение устройства выплывает напрямую из терминологии, описанной выше, ведь любой МК, по своей сути, – маленький процессор, обрабатывающий команды, способный принимать и передавать данные, а в исключительных случаях, даже сохранять их в постоянной памяти.

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

Без этого ни одно приложение бы не запустилось. Но это лишь конкретная область применения, на деле, с помощью Ардуино и похожих систем, можно контролировать любые переменные, включая свет по хлопку или раздвигание штор при изменении освещения на улице. Вот и выходит, что назначение МК – это контроль любых переменных и изменение системы под их состояние, возможно, с последующим выводом промежуточных данных, для проверки работоспособности.

Но давайте разберёмся, почему любая разработка ПО для микроконтроллеров с помощью специальных сред в итоге компилирует (превращает) код в двоичный, и зачем это нужно?

Принцип работы

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

  1. Он принимает определённые переменные или другие данные, которые прежде должны быть преобразованы в двоичный сигнал. Это необходимо, поскольку на низшем уровне система способна воспринимать лишь 2 состояния – есть сигнал или нет сигнала. Такой принцип называют аналоговым. Существует аналогичный алгоритм, когда сигнал присутствует постоянно, но меняется по частоте – цифровой. У них множество различий, как в областях применения, так и в особенностях работы сигнала, но суть одна – процессор способен воспринимать лишь значения 0 и 1, или true и false, и не важно, какими путями микропроцессоры и микроконтроллеры будут их считывать.
  2. Во внутренней памяти устройства хранится набор специальных инструкций, который позволяет, путем базовых математических преобразований, выполнять какие-то действия с полученными данными. Именно эти базовые операнды и берутся на вооружение компилируемых языков программирования, когда необходимо написать библиотеку готовых функций. Остальные нюансы языков программирования – это уже синтаксис и теория алгоритмов. Но в результате, всё сводится к базовым операндам, которые превращаются в двоичный код и обрабатываются внутренней системой процессора.
  3. Всё, что было получено и сохранено после обработки, выдается на выход. На самом деле, данный пункт выполняется всегда, единственная разница, что выходом может быть и преобразование состояния объекта какой-то системы. Простейшим примером станет замыкание электрической цепи, в случае, если на специальный датчик подать ток, вследствие чего загорится лампочка. Здесь всё зависит от типа устройства, так, 8051 микроконтроллер может выполнять несколько видов выводов, имея 14 пинов, а какой-то другой – всего один, ведь у него 1 пин на выход. Количество выходов влияет на многопоточные свойства девайса, иными словами, возможность выводить информацию сразу на несколько устройств или совершать несколько действий одновременно.

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

Это напрямую влияет на скорость работы устройств, и именно из-за этой характеристики 2-ух ядерные девайсы мощнее, чем 1-ядерные, но имеющие большую герцовку (способность выполнять большее количество преобразований за единицу времени).

Но почему микроконтроллер овен не способен выполнять некоторые действия, характерные для 8051, и какая классификация вообще существует в данной сфере?

Виды микроконтроллеров

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

  1. Количеству аналоговых и цифровых пинов.
  2. Общему количеству пинов.
  3. Количеству ядер, которые присутствуют в МК.
  4. Скорости выполнения операций или герцовке.
  5. Объему оперативной и постоянной внутренней памяти.
  6. Размерам.

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

Особенности микроконтроллеров Ардуино

Но всё же у большинства, при упоминании МК, в памяти всплывает название «Ардуино», и это не удивительно. Ведь у данной разновидности поликристальных чипов есть характерные особенности, выгодно выделяющие ее на фоне конкурентов:

  1. Низкий порог входа . Так как программная среда уже написана и протестирована за вас, никаких «велосипедов» придумывать не нужно.
  2. Оптимизация под конкретные задачи . У создателей есть целая линейка разнообразных чипов, которые сильно различаются по характеристикам, благодаря чему будет проще подобрать подходящий.
  3. Готовая платформа и множество решений различных проблем или задач в открытом доступе.

Подключение и управление

Подключаются чипы через специальные разъемы, называемые пинами. Те, в свою очередь, распределяются на:

  1. Отвечающие за питание . Стандартное сочетание из нуля, фазы и заземления. Последнее чаще всего игнорируют.
  2. Отвечающие за ввод данных .
  3. Отвечающие за вывод данных . Их можно разделить на аналоговые и цифровые, о главном различии уже упоминалось выше, и каждый из выходов имеет свои достоинства и недостатки.

С помощью всех этих «ножек» и происходит управление системой, а их необходимое количество напрямую зависит от поставленной задачи.

Микроконтроллеры для начинающих

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

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

Пример применения микроконтроллера Ардуино

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

  1. Системы смарт-хауса . Это различные умные переключатели, занавески, вентиляторы и разнообразные сигнализации. Они позволяют сделать ваше взаимодействие с жильем более интерактивным.