Генератор с длительностью импульсов 20us с частотой 80Khz

Обсуждаем контроллеры компании Atmel.
linkov1959
Держит паяльник хвостом
Сообщения: 923
Зарегистрирован: Пн сен 10, 2018 19:16:28

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение linkov1959 »

КРАМ, Я делал делитель опорной частоты на счетчиках, ГУН на 531ГГ1 и подавал выходы на фазовый детектор, который управлял ГУН. Мог выставить любую частоты до 50Мгц с точностью 1 Гц. Это не NCO?
Реклама
Аватара пользователя
КРАМ
Друг Кота
Сообщения: 25305
Зарегистрирован: Чт янв 10, 2008 22:01:02
Откуда: Московская область, Фрязино

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение КРАМ »

Нет, это не NCO. Принцип работы NCO я чуть ранее уже упомянул. То, о чем говорите вы, называется ФАПЧ (PLL) и ничего общего с прямым цифровым синтезом (DDS) не имеет. А вот NCO как раз и является ядром любого DDS.
DDS, в отличии от PLL, может управлять частотой с точностью до мгновенной фазы. А разрешение по частоте зависит только от разрядности аккумулятора фазы. Элементарно получить шаг в 0,001 Гц.
Реклама
Sergi
Мучитель микросхем
Сообщения: 412
Зарегистрирован: Ср янв 04, 2012 11:57:40
Откуда: Алчевск

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение Sergi »

КРАМ а какое количество точек минимально достаточно для таблицы в 1024? Пробовал до 1/8 таблицы. Сглаживал фильтром второго порядка.
linkov1959
Держит паяльник хвостом
Сообщения: 923
Зарегистрирован: Пн сен 10, 2018 19:16:28

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение linkov1959 »

КРАМ, теперь понятно, почему я и разобрал свой ФАПЧ, а оставил китайский DDS FY3200S. Век живи, век учись.
С пиками я не дружу, а на stm32 нет NCO?
Реклама
Эиком - электронные компоненты и радиодетали
Аватара пользователя
КРАМ
Друг Кота
Сообщения: 25305
Зарегистрирован: Чт янв 10, 2008 22:01:02
Откуда: Московская область, Фрязино

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение КРАМ »

[uquote="Sergi",url="/forum/viewtopic.php?p=3980432#p3980432"]Пробовал до 1/8 таблицы. Сглаживал фильтром второго порядка.[/uquote]
Вообще то от количества точек зависит частотное расстояние до кратных спектров. При 2 отсчетах на период спектры смыкаются. Отсюда делайте вывод о необходимой чистоте спектра и требуемого подавления на этих самых кратных спектрах.

Добавлено after 5 minutes 25 seconds:
[uquote="linkov1959",url="/forum/viewtopic.php?p=3980433#p3980433"]а на stm32 нет NCO?[/uquote]
Нет. В мощных контроллерах обычно нет специфической периферии. Если уже вы поставили МК за 7 баксов, то добавить еще 4 за приличный DDS уже нет проблем. А вот в 8-битниках тема с набором специально заточенной периферии и относительно слабым ядром для ее конфигурирования вполне актуальна для бюджетных решений.
Реклама
Dimon456
Мудрый кот
Сообщения: 1849
Зарегистрирован: Вс дек 25, 2016 08:34:54

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение Dimon456 »

Как бы я не старался, как бы я не мучился, но с Атмеги dds - только показометр получается.

Будем отталкиваться от 80кГц.
У числа 80000 всего 40 делителей на которые это число делится нацело.
Вот они
Спойлер1, 2, 4, 5, 8, 10, 16, 20, 25, 32, 40, 50, 64, 80,  100,  125,  128,  160,  200,  250,  320,  400,  500,  625,  640,  800, 1 000, 1 250, 1 600, 2 000, 2 500, 3 200, 4 000, 5 000, 8 000, 10 000, 16 000, 20 000, 40 000, 80 000
К примеру 3200Гц, 80000/3200 = 25 ровно. Джиттер отсутствует.
Тогда как 3340Гц, 80000/3340 = 23,95209581 - вот тут будет джиттер.

То же самое если тактовую 16МГц делить на эти числа.

То есть что бы мне получить идеальные 3340Гц, я должен тактировать МК от 15998600Гц.

КРАМ, если вам не трудно,чтобы раcставить все точки над i и подвести окончательный итог,
в протеусе есть модель PIC10F322 с пометкой NC0, частота 3340Гц импульс 10us, hex файл плиз.
Реклама
Аватара пользователя
КРАМ
Друг Кота
Сообщения: 25305
Зарегистрирован: Чт янв 10, 2008 22:01:02
Откуда: Московская область, Фрязино

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение КРАМ »

Вы ничего не поняли. Джиттер в ДДС есть почти всегда. И если соотношение частот накачки и выхода выбрано большим, то этот джиттер лежит на уровнях ниже -60 дБ к основной гармонике. Генерация меандра с линейной ЧМ и центральной частотой примерно 4 кГц на NCO в 10F322 дает очень пристойный звук. У меня так работает аларм на металломагнитодетекторах в серийных изделиях.
Там код простейший. В прерываниях по таймеру инкрементируется/декрементируется регистр частоты модуля. Так и гоняется тон от минимального до максимального порога.
Dimon456
Мудрый кот
Сообщения: 1849
Зарегистрирован: Вс дек 25, 2016 08:34:54

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение Dimon456 »

Я имел ввиду импульс 10us. Как?
У этого PIC с NCO набор какой-то скудный, ЦАПа на выходе NCO нет - синус не получить,
один меандр, ШИМ то хоть может это NCO что бы из таблицы синус брать?
Хотя я документацию по диагонали смотрел.

Вы этот ПИК предложили, хоть бы пример какой выложили.
Аватара пользователя
КРАМ
Друг Кота
Сообщения: 25305
Зарегистрирован: Чт янв 10, 2008 22:01:02
Откуда: Московская область, Фрязино

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение КРАМ »

[uquote="Dimon456",url="/forum/viewtopic.php?p=3980853#p3980853"]Хотя я документацию по диагонали смотрел.[/uquote]
Оно и видно... :tea:
Импульсы на выходе NCO можно получить с помощью Ripple-таймера этого модуля. Длительность устанавливается в регистре NCO1CLK битами N1PWS. При накачке 16 МГц длительность можно выбрать максимум 8 мкс, а при накачке 8 МГц - получается либо 8, либо 16 мкс. Если использовать внешнюю накачку, то при выборе частоты 12,8 МГц и N1PWS=111 (128 тиков) выйдет как раз 10 мкс.
Синус формируется элементарно. Берется таблица синуса, а частота на выходе NCO синтезируется кратно выше по длине таблицы.
Например, при таблице в 64 отсчета нужно генерировать частоту в 64 раза выше. В прерывании от NCO очередное значение таблицы загружается в PWM. Вот и вся хитрость.
Примеры кода я писать не буду принципиально. Это слишком простая в смысле кода задача. Достаточно принципов функционирования. Их я и объясняю. Довольно подробно.
Если у вас будут проблемы с кодом, задавайте конкретные вопросы по коду, а не просите готовенькое.
ЗЫ. В догон. На таком бюджетном МК писать на Си слишком расточительно. АСМ там простой и позволяет вытянуть максимум по скорости в такого рода задачах. А от скорости зависит и чистота спектра синтезируемого сигнала.
linkov1959
Держит паяльник хвостом
Сообщения: 923
Зарегистрирован: Пн сен 10, 2018 19:16:28

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение linkov1959 »

КРАМ, гладко было на бумаге, да забыли про овраги. Для синусных таблиц оперативки маловато.

Добавлено after 11 minutes 2 seconds:
Re: Генератор с длительностью импульсов 20us с частотой 80Khz
Dimon456, там нужен ГУН и частотомер в обратную связь. На пиках отличные частотомеры получаются.
Аватара пользователя
КРАМ
Друг Кота
Сообщения: 25305
Зарегистрирован: Чт янв 10, 2008 22:01:02
Откуда: Московская область, Фрязино

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение КРАМ »

Господин Линьков, как же вам в голову пришла идея держать таблицу КОСТАНТ в ОЗУ? :dont_know:
:)))
Sergi
Мучитель микросхем
Сообщения: 412
Зарегистрирован: Ср янв 04, 2012 11:57:40
Откуда: Алчевск

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение Sergi »

Я держал в ОЗУ, формировал из пзу с учётом амплитуды (0-100%)и формы (пять встроенных). Форму можно было подгружать по uart, пока не пригодилось ))).
Аватара пользователя
Zhuk72
Сверлит текстолит когтями
Сообщения: 1231
Зарегистрирован: Ср янв 29, 2014 08:41:31
Откуда: Баку
Контактная информация:

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение Zhuk72 »

[uquote="Dimon456",url="/forum/viewtopic.php?p=3980853#p3980853"]Вы этот ПИК предложили, хоть бы пример какой выложили.[/uquote]
Вот тут oleg110592 выкладывал пример. Даже два.

Добавлено after 20 minutes 21 second:
Re: Генератор с длительностью импульсов 20us с частотой 80Khz
Кстати, схожая штука имеется и у 51-х МК от Силабса. Она есть и в старых типа C8051Fxxx, и в новых EFM8.
Эта независимая от ядра "штука" называется PCA - Programmable Counter Array, имеющая несколько каналов входа/выхода.
Одна из возможных его функций - Frequency Output Mode. Разница с ПИКовой на мой взгляд в основном в разрядности - всего 8 бит. Формула частоты смены состояния выходного пина та же (с учетом битности).
Для примера вот RM на первую базовую серию EFM8BB1, раздел 15 на весь модуль и страница 151 конкретно на этот функционал.

P.S. Платка с EFM8BB10F8G в "кузове" QSOP-24, минимальным обвесом и программатором-отладчиком стоит всего $6.25, и у меня она имеется :hunger:
Каждый имеет право на свое личное ошибочное мнение.

У меня было тяжелое детство - я до 14 лет смотрел черно-белый телевизор.
linkov1959
Держит паяльник хвостом
Сообщения: 923
Зарегистрирован: Пн сен 10, 2018 19:16:28

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение linkov1959 »

[uquote="КРАМ",url="/forum/viewtopic.php?p=3981045#p3981045"]Господин Линьков, как же вам в голову пришла идея держать таблицу КОСТАНТ в ОЗУ? :dont_know:
:)))[/uquote]
Теперь понятно, почему у меня был самый быстрый синус на самом медленном проце.:)
Аватара пользователя
КРАМ
Друг Кота
Сообщения: 25305
Зарегистрирован: Чт янв 10, 2008 22:01:02
Откуда: Московская область, Фрязино

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение КРАМ »

[uquote="linkov1959",url="/forum/viewtopic.php?p=3981128#p3981128"]Теперь понятно[/uquote]
Не надо фантазировать. Чтение флеша в подавляющем количестве архитектур незначительно дольше, а часто и равно по времени чтению ОЗУ. Если говорить о синтезе синусоиды, то таблица во флеше вообще никак не повлияет на скорость. Ибо период отсчетов НА ПОРЯДКИ больше ничтожных пары...тройки лишних машинных циклов
Dimon456
Мудрый кот
Сообщения: 1849
Зарегистрирован: Вс дек 25, 2016 08:34:54

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение Dimon456 »

Zhuk72, и КРАМ, я вас правильно понял, что бы проверить мне и собственными глазами убедиться в отсутствии фазового дрожания я должен скачать компилятор под PIC10F?
Хорошо, какой самый минимальный компилятор который соберет эти три несчастные строчки?
Аватара пользователя
КРАМ
Друг Кота
Сообщения: 25305
Зарегистрирован: Чт янв 10, 2008 22:01:02
Откуда: Московская область, Фрязино

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение КРАМ »

[uquote="Dimon456",url="/forum/viewtopic.php?p=3981337#p3981337"]Zhuk72, и КРАМ, я вас правильно понял, что бы проверить мне и собственными глазами убедиться[/uquote]
А в этом есть какая то проблема? Скачать нужно среду разработки, причем можно даже компактный MPLAB 8.92.
Нащщет компилятора я сомневаюсь, однако... Проще написать на MPASM, который входит в среду.
Аватара пользователя
oleg110592
Друг Кота
Сообщения: 3832
Зарегистрирован: Сб сен 10, 2011 17:46:25

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение oleg110592 »

[uquote="Dimon456",url="/forum/viewtopic.php?p=3981337#p3981337"]Хорошо, какой самый минимальный компилятор который соберет эти три несчастные строчки?[/uquote]
можно онлайн попробовать
https://mplabxpress.microchip.com/mplabcloud/ide
Изображение
Аватара пользователя
Chip_step
Родился
Сообщения: 19
Зарегистрирован: Сб янв 30, 2021 16:34:46

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение Chip_step »

Привет всем :))
попробывал этот код:

Код: Выделить всё

#include <tiny44.h>

#define n_counter1 32768 //  65536 / (160000 / 80000) = 32768
char period[] = { 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1 };

// Timer 0 output compare A interrupt service routine
      interrupt [TIM0_COMPA] void timer0_compa_isr(void)
  {
      static unsigned  int gen_counter = 0;

      gen_counter = gen_counter + n_counter;
      if (period[(gen_counter>>11)] == 1){ PORTA |= (1<<(PORTA0));  }else{  PORTA &= (~(1<<(PORTA0))); }

  }

void main(void)
{
// Crystal Oscillator division factor: 1
#pragma optsize-
CLKPR=(1<<CLKPCE);
CLKPR=(0<<CLKPCE) | (0<<CLKPS3) | (0<<CLKPS2) | (0<<CLKPS1) | (0<<CLKPS0);
#ifdef _OPTIMIZE_SIZE_
#pragma optsize+
#endif

// Input/Output Ports initialization
// Port A initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=Out
// State7=T State6=T State5=T State4=T State3=T State2=T State1=T State0=0
PORTA=0x00;
DDRA=0xFF;




// Timer/Counter 0 initialization
// Clock source: System Clock
// Clock value: 16000,000 kHz
// Mode: CTC top=OCR0A
// OC0A output: Disconnected
// OC0B output: Disconnected
// Timer Period: 6,25 us
TCCR0A=(0<<COM0A1) | (0<<COM0A0) | (0<<COM0B1) | (0<<COM0B0) | (1<<WGM01) | (0<<WGM00);
TCCR0B=(0<<WGM02) | (0<<CS02) | (0<<CS01) | (1<<CS00);
TCNT0=0x00;
OCR0A=0x63;
OCR0B=0x00;


// Timer/Counter 0 Interrupt(s) initialization
TIMSK0=(0<<OCIE0B) | (1<<OCIE0A) | (0<<TOIE0);

#asm("sei")

while (1)
      {



      }
}

Это прсто, компактно, гениально!!!
Растущй фронт и спадающий фронт ровный во всем диапозоне! :)) 1-80KHz.

Dimon456 - Тебе респект! так держать. :beer:
Аватара пользователя
Zhuk72
Сверлит текстолит когтями
Сообщения: 1231
Зарегистрирован: Ср янв 29, 2014 08:41:31
Откуда: Баку
Контактная информация:

Re: Генератор с длительностью импульсов 20us с частотой 80Kh

Сообщение Zhuk72 »

[uquote="Dimon456",url="/forum/viewtopic.php?p=3981337#p3981337"]Zhuk72, и КРАМ, я вас правильно понял, что бы проверить мне и собственными глазами убедиться в отсутствии фазового дрожания я должен скачать компилятор под PIC10F?[/uquote]
Могу на днях, если не к спеху, то в выходные дни, на живом изделии запустить и выложить диаграмму с логического анализатора. Правда у меня не 10-й ПИК, а 16F18446. У него NCO 20-битный. Надеюсь на небольших частотах мой китайский Салеае покажет честную картинку.
Каждый имеет право на свое личное ошибочное мнение.

У меня было тяжелое детство - я до 14 лет смотрел черно-белый телевизор.
Ответить

Вернуться в «AVR»