Частотомер своими руками
Этот проект посвящен созданию простого частотомера, способного измерять частоту до 100МГц с точностью 0.002%. За основу я взял ATtiny414, задействовав при этом его таймер/счетчик TCD0 и систему событий.
Недавно я задумал собрать частотомер с возможностью измерения до 100МГц, что позволило бы использовать его для проверки частоты процессора и кристаллов. В сети есть немало схем для сборки подобных девайсов на базе микроконтроллера, ведь в этом и состоит одно из назначений встроенных в МК таймеров/счетчиков. Однако большинство таких устройств не достигают уровня 100МГц, так как измерение внешней частоты ограничено половиной собственной тактовой частоты микроконтроллера.
Первая попытка
Я решил использовать внешние RTC (часы реального времени), тактируемые кристаллом 32.768кГц, для генерации прерываний с частотой 1Гц. Затем второй таймер/счетчик, тактируемый измеряемой частотой, будет отсчитывать количество циклов в этом односекундном интервале, в результате сообщая частоту в Гц.
Для первого прототипа я использовал таймер/счетчик TCB0 , тактируемый через входной вывод, с захватом, который активировался от RTC подачей сигнала 1Гц. Как и предполагалось, измерить я смог только половину тактовой частоты, или 10МГц, поэтому потребовался четырехкаскадный делитель для деления входной частоты 100Мгц на 16, чтобы вписать ее в подходящий диапазон. В качестве делителя я попробовал задействовать CCL. Кстати, о подобной его реализации у меня даже есть отдельная статья Frequency Divider Using CCL.
Использование таймера/счетчика TCD0
Об использовании TCD0 я задумался просто между делом. Это 12-битное устройство, но, в отличие от большинства своих аналогов, работает оно асинхронно, то есть независимо от тактов процессора.
В первую очередь TCD0 предназначен для генерации сигналов, например при управлении электродвигателем, и я даже не знаком со многими из его возможностей. Однако мне показалось, что с его помощью вполне можно реализовать захват значения счетчика, работающего под управлением часов реального времени.
Опытным путем я выяснил, что TCD0 можно тактировать на частоте более 100МГц, что позволило бы собрать очень простой частотомер с нужным мне диапазоном действия без делителя.
Использование системы событий
Я мог использовать RTC для генерации прерывания каждую секунду, а затем захватывать значение счетчика из TCD0 через программу обработки прерываний. Тем не менее последние процессоры AVR предоставляют систему событий (Event System), позволяющую реализовать это более эффективно.
Можно сгенерировать внутренний сигнал с RTC и с помощью него непосредственно активировать захват. Преимущество здесь в том, что вызов службы прерываний не требует лишней обработки, в результате чего ответ возвращается практически мгновенно.
Выбор микроконтроллера
Компания Microchip предлагает три новых серии микроконтроллеров AVR:
- ATtiny 0-, 1- и 2-;
- ATmega 0;
- AVR DA- и DB-.
Первую версию схемы я протестировал с AVR128DA28, но для конечной все же выбрал ATtiny414, потому что он выполнен в более компактном корпусе, а дополнительные входы/выходы мне не требовались.
В итоге получилось так, что при использовании AVR128DA28 события работали, а после перехода на ATtiny414 перестали. Оказалось, что проблема в отличии терминологии для более ранних процессоров. Здесь я хочу поблагодарить пользователя AVR Freaks под ником kabasan за то, что помог разобраться. Если вы хотите побольше узнать о применении системы событий, то советую начать с серии AVR DA- или DB-, для которых используется более логичная терминология.
Примечание. Не стоит путать ATtiny 1 серии, ATtiny414, вышедшие в 2020, с более старыми ATtiny441, появившимися в 2014 в качестве расширенной версии еще более старого ATtiny44.
Измерение частоты кристалла
Я решил, что будет нелишним задействовать кварцевый резонатор, который позволит использовать частотомер для измерения частоты колебаний кристалла. В одном из вариантов схем подобного резонатора применяется небуферизованный КМОП-инвертор LVC1GU04 и ряд других компонентов 1 :
Здесь я задумался о возможности создания инвертора на базе ATtiny414 с применением системы событий таким образом:
- Определить PA2 в качестве событийного выхода, EVOUT0 . Это был единственный вариант, так как другой выход, EVOUT1 , находится на том же выводе, что и TOSC2 , используемый кварцевым резонатором RTC.
- Определить PA1 в качестве асинхронного генератора событий на канале 0. Подойдет любой вывод на PORTA .
- Настроить PA1 на инвертирование входа.
На моем прототипе эта схема отлично работала без каких-либо дополнительных компонентов с диапазоном частоты кристаллов от 2 до 25МГц. Однако для того, чтобы заставить кварц резонировать, может потребоваться дополнительное место на макетной плате. Так что, если вы проектируете для этой схемы печатную плату, то советую оставить место под пассивные компоненты на случай, если они понадобятся.
Схема
Вот схема частотомера 100МГц, компоновка которой соответствует схеме макетной платы:
Схема частотомера 100МГц на базе ATtiny414
В качестве дисплея используется модуль OLED 128x32 I2C с драйвером SSD1306. Для прототипа я взял дисплей Adafruit 2 , хотя вполне подойдет и любой аналог с AliExpress 3 . Резистор 33кОм и конденсатор 0.1мкФ обеспечивают корректный сброс дисплея при первой подаче питания, хотя они могут и не понадобиться.
В качестве резонатора служит кристалл 32.768кГц с точностью 20ppm и емкостной нагрузкой 12.5пФ 4 . Для вычисления значений конденсатора я использовал формулу С = 2(СL – CS), где СL представляет емкостную нагрузку 12.5пФ, а CS паразитную емкость, которая на макетной плате достигает, вероятно, 5пФ, давая С = 15пФ. На печатной же плате ее значение, возможно, составит 2.5пФ.
В роли процессора выступил ATtiny414 в 14-контактном корпусе SOIC 5 , который я установил на коммутационную плату – подходящий вариант есть у Adafruit 6 . Проект можно также реализовать на базе ATtiny814 или ATtiny1614 с бОльшим объемом памяти, но не на ATtiny404, поскольку в нем нет поддержки внешнего кристалла RTC.
Использование частотомера
Измерение частоты
Для измерения частоты сигнала нужно подключить устройство между In и GND. При питании 3.3В частотомер работал в диапазоне до 105МГц, а при повышении напряжения до 5В верхний порог сместился к 110МГц.
Измерение частоты кристалла
Для измерения частоты колебаний кристалла подключаемся между выводами Xtal и In:
Измерение частоты колебаний кристалла 16МГц
Программная часть
Код для ATtiny414
При написании кода для ATtiny414 и его обвязки мне пригодилась документация AVR1000b: Getting Started with Writing C-Code for AVR MCUs. Кроме того, при выборе символов для конкретных настроек регистра, будет нелишним почитать iotn414.h , который находится у вас на ПК в megaTinyCore.
OLED дисплей
В интерфейсн дисплея я задействовал те же функции, что и во многих прежних проектах, например Tiny Function Generator, где использовался такой же OLED дисплей I2C. Текст отрисовывается при помощи набора символом размером 6х8 пикселей, но при удвоенном масштабе для получения символов 12х16 пикселей используется функция сглаживания, описанная мной в Smooth Big Text.
Обратите внимание, что на ATtiny414 в megaTinyCore размер буфера I2C с целью экономии ОЗУ составляет всего 16 байт, поэтому мне пришлось изменить функции ClearDisplay и PlotChar() на отправку данных меньшими порциями.
Функцию Plotlnt() я подкорректировал на отображение запятых между каждой тройкой цифр, чтобы облегчить их чтение.
Часы реального времени
Настраивать RTC на использование внешнего кристалла сложнее, чем может показаться, поскольку контроллер часов защищен от случайного вмешательства со стороны протокола изменения конфигурации (CCP). По этой причине перед каждым внесением корректировок необходимо это действие активировать. Хорошо, что в приложении есть примечание, объясняющее, как это делать, и код я писал на примере из этого примечания 7 .
Таймер/счетчик TCD0
TCD0 настроен вести отсчет от 0 до 0xFFF и захватывать значение счетчика в регистр CAPTUREB при получении события B . Он генерирует прерывания при событии захвата, а также при переполнении счетчика, и тактируется от внешнего сигнала, поступающего через вывод EXTCLK/PA3 :
Служба прерываний при переполнении инкрементирует счетчик MSByte для старшей части значения частоты:
Служба прерывания при захвате считывает регистр захвата и совмещает его значение с MSbyte , формируя значение Counter .
Она также зажигает светодиод, сигнализируя о выполнении захвата. Если вам это не нужно, можете светодиод исключить.
События
Для того, чтобы задействовать события, нужно настроить переполнение RTC на генерацию события в канале 1, а TCD0 на использование этого события для выполнения захвата:
Канал событий 0 служит для создания инвертора между PA1 и PA2 , который, как говорилось выше, будет выступать в качестве кварцевого резонатора.
Основной цикл
Основной цикл ожидает установки глобальной переменной Ready , что укажет на выполнение захвата. Затем он копирует значение Counter в temp . При этом прерывания отключены, чтобы исключить возможное изменение этого значения службой прерываний в процессе его отображения:
При отсутствии входного сигнала TCD0 не тактируется, и значение Counter не обновляется. Для проверки подобной ситуации присутствует односекундный таймаут, который сбрасывает Counter на ноль, если Ready не была установлена. Нулевое значение отображается функцией PlotInt() в виде трех прочерков.
Точность
Для проверки этого проекта мне нужно было найти способ генерировать точные сигналы с частотой до 100МГц, но такого генератора у меня нет. Точность моего предыдущего проекта, Programmable Signal Generator, составляет всего 1.1%, чего для данного случая будет явно недостаточно, к тому же его верхний предел всего 68МГц.
В связи с этим я купил коммутационную плату генератора тактовых импульсов Si5351A от Adafruit 8 , которую можно через I2C запрограммировать на генерацию сигналов от 8кГц до 160МГц (еще есть вариант аналогичной платы на Banggood 9 ). Управление ей я реализовал через прекрасную библиотеку Si5351 Джейсона Миллдрама 10 , работающую на Arduino Uno.
Точность частотомера в первую очередь зависит от точности кристалла, используемого для генерации дискретизированного сигнала 1Гц. Я использовал цилиндрический кристалл с заявленной точностью 20ppm. Звучит неплохо, пока не вычислишь, что при входном сигнале 100МГц это эквивалентно ±2000Гц. На практике же его точность в целом оказалась раз в 5-10 выше заявленной.
Компиляция
Для компиляции используйте megaTinyCore Спенса Конде c GitHub. В меню Board под вкладкой megaTinyCore выберите опцию ATtiny1614/1604/814/804/441/404/241/204 . Проверьте, чтобы следующие опции были установлены так (на остальные внимания не обращайте):
Затем с помощью программатора UPDI загрузите программу на ATtiny414. Теперь megaTinyCore поддерживает две возможности:
- Создание программатора UPDI из Arduino Uno или другой платы на базе ATmega328P (инструкция на странице Make UPDI Programmer) и установку опции Programmer на jtag2updi .
- Использование платы USB-Serial, такой как SparkFun FTDI Basic 11 , подключение TX к выводу UPDI через резистор 4.7кОм, подключение RX напрямую к выводу UPDI и установку опции Programmer на Serial port and 4.7k (pyupdi style) .
Если же возникнет такая ошибка:
Это значит, что вы не установили опцию millis()/micros() как TCA0 , о чем говорилось выше.
Вот вся программа для частотомера до 100МГц: 100MHz Frequency Meter Program.
Дополнительные возможности
Интерфейс
Эта схема подразумевает, что сигнал представляет собой меандр с амплитудой равной логическому уровню. В частотомере для рабочего применения лучше всего реализовать управление счетчиком через аналоговый интерфейс с защитой входа. Как вариант, можно взять модуль, основанный на высокоскоростном компараторе TLV3501.
Измерение периода
Используемая в этом частотомере техника подсчета импульсов наиболее точна на высоких частотах. Данный подход можно совместить с измерением интервалов для низких частот, о чем я писал в статье Frequency Probe.
Если уж браться за создание цифрового частотомера, то делать сразу универсальный измерительный прибор, способный мерять частоты не до пары десятков мегагерц (что свойственно большинству таких схем), а до 1000 МГц. При всём этом, схема не сложнее стандартной, с использованием pic16f84. Отличие лишь в установке входного делителя, на специализированной микросхеме SAB6456. Этот электронный счетчик будет полезен для измерения частоты различного беспроводных оборудования, особенно передатчиков, приемников и генераторов сигналов в диапазонах УКВ.
Технические характеристики частотомера
Особенности и преимущества схемы. Быстрая работа — короткий период измерения. Высокая чувствительность входного сигнала в диапазонах СВЧ. Переключаемое промежуточное смещение частоты для использования его совместно с приемником — в качестве цифровой шкалы.
Принципиальная схема самодельного частотомера на PIC
Список деталей частотомера
R1 — 39 k
R2 — 1 k
R3-R6 — 2,2 k
R7-R14 — 220
C1-C5, C6 — 100-n mini
C2, C3, C4 — 1 n
C7 — 100 ед.
C8, C9 — 22 p
IC1 — 7805
IC2 — SAB6456 (U813BS)
IC3 — PIC16F84A
T1 — BC546B
T2-T5 — BC556B
D1, D2 — BAT41 (BAR19)
D3 — HD-M514RD (красный)
X1 — 4.000 МГц кварц
Вся необходимая информация по прошивке микроконтроллера, а также полное описание микросхемы SAB6456, находятся в архиве. Данная схема многократно испытана и рекомендована к самостоятельному повторению.
Самый простой частотомер своими руками может с легкостью получиться из дешевого китайского приемника. Цены подобных китайских девайсов колеблются в пределах пары долларов, а времени для переделки понадобится с полчаса.
Частотомер из китайского приемника
Для экспериментов был выбран старый и хорошо потрепанный жизнью кассетный плеер Atlanfa. Он имеет на борту желанный ЖК дисплей частотомера.
(Для переделки подходит не каждый китайский приемник или плеер у которых есть ЖК дисплей и частотомер, если кроме кнопок SCAN и RESET нет больше никаких элементов управления FM приемником, то скорей всего данный аппарат подойдет для переделки)
Первым делом разбираем приемник и добираемся к проводам от ЖК панели.
Прозваниваем провод и находим + и – (провода питания). У нас это: розовый и серый – плюс, а белый — минус.
Дальше необходимо найти провод, через который поступает сигнал на частотомер от гетеродина приемника. Его легко можно вычислить, для этого включаем приемник и поочередно касаемся каждого провода, если частота поплывет – скорей всего это нужный провод. Отпаиваем провод от платы и включаем приемник. Частота на табло будет 00.0 МГц или 00.1 МГц, приемник при этом должен работать как ни в чем небывало.
Дальнейшим этапом станет снятие платы частотомера, которую можно после тестов установить уже в самодельный корпус.
Устанавливаем перемычку между розовым и серым проводом.
Подключаем питание к частотомеру (сигнальный провод подключать к антенне передатчика лучше через конденсатор емкостью 1-3 пФ). Тесты будем проводить с помощью FM передатчика на варикапе.
Как видим все работает четко и слаженно, показания частотомера четко совпадают с частотой, на которой ловится передатчик. Как небольшая полезность останутся: переключатель для отображения времени и кнопки настройки часов.
Частотомер из приемника станет очень полезным прибором для новичков при настройке самодельных простых передатчиков, жучков или приемников. Большинство китайских приемников, которые можно переделать под частотомер своими руками, построены на микросхеме частотомера SC3610. Подключение и распиновку микросхемы смотрим на схеме.
И наглядный тест работы самодельного частотомера. Вносим щуп мультиметра в катушку передатчика, естественно, что его частота меняется, что и отображается на частотомере.
Этот частотомер не требует цифрового индикатора и, из-за отсутствии динамической индикации, намного меньше аналогов шумит в эфир. Прибор может понравиться ретролюбителям.
Содержание / Contents
Поиск в Интернете схемы стрелочного частотомера на микроконтроллере результатов не дал. Пришлось самому придумывать.
↑ Схема частотомера и её работа
Переключателем выставляется нужный диапазон. При этом, если требуется, включается внутренний делитель частоты с заданным коэффициентом деления. Далее сигнал поступает на ждущий мультивибратор с высчитанной фиксированной длительностью положительного импульса и на стрелочный индикатор.
Когда меняется в работе длительность периода входной и выходной частоты, то внутри этой выходной длительности периода будет фиксированная длительность положительного импульса. Их начала совпадают, то есть меняется скважность.
Ниже 20 Гц стрелка начинает вибрировать, поэтому нужен конденсатор С5. С ним вибрация проявляется ниже 10 Гц.
↑ Настройка частотомера
Подбором резистора R2 установите напряжение на коллекторе транзистора VT1 около 2 Вольт для наибольшей чувствительности по входу.
↑ Конструкция и детали
Не обращайте внимания на "лишние" детали – потенциометр и тумблер. Они не включены в итоговую схему
↑ Результаты
Работа проверена от 1 Гц до 30 мГц. Частоту выше нечем проверить, но по моим прикидкам прибор должен верно работать до 40 — 50 мГц.
Точность моего частотомера около 1-2% при максимуме показаний. Т.е. погрешность показаний составляет 1-2 делениям на шкале из 100 делений.
↑ Файлы
Файл прошивки PIC16F628A:
Добавлен исходник на Ассемблере! 🎁Statya-na-Datagor.7z 2.91 Kb ⇣ 66
Читайте также: