Генератор с длительностью импульсов 20us с частотой 80Khz
-
linkov1959
- Держит паяльник хвостом
- Сообщения: 923
- Зарегистрирован: Пн сен 10, 2018 19:16:28
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
КРАМ, Я делал делитель опорной частоты на счетчиках, ГУН на 531ГГ1 и подавал выходы на фазовый детектор, который управлял ГУН. Мог выставить любую частоты до 50Мгц с точностью 1 Гц. Это не NCO?
- Реклама
- КРАМ
- Друг Кота
- Сообщения: 25305
- Зарегистрирован: Чт янв 10, 2008 22:01:02
- Откуда: Московская область, Фрязино
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
Нет, это не NCO. Принцип работы NCO я чуть ранее уже упомянул. То, о чем говорите вы, называется ФАПЧ (PLL) и ничего общего с прямым цифровым синтезом (DDS) не имеет. А вот NCO как раз и является ядром любого DDS.
DDS, в отличии от PLL, может управлять частотой с точностью до мгновенной фазы. А разрешение по частоте зависит только от разрядности аккумулятора фазы. Элементарно получить шаг в 0,001 Гц.
DDS, в отличии от PLL, может управлять частотой с точностью до мгновенной фазы. А разрешение по частоте зависит только от разрядности аккумулятора фазы. Элементарно получить шаг в 0,001 Гц.
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
КРАМ а какое количество точек минимально достаточно для таблицы в 1024? Пробовал до 1/8 таблицы. Сглаживал фильтром второго порядка.
-
linkov1959
- Держит паяльник хвостом
- Сообщения: 923
- Зарегистрирован: Пн сен 10, 2018 19:16:28
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
КРАМ, теперь понятно, почему я и разобрал свой ФАПЧ, а оставил китайский DDS FY3200S. Век живи, век учись.
С пиками я не дружу, а на stm32 нет NCO?
С пиками я не дружу, а на 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-битниках тема с набором специально заточенной периферии и относительно слабым ядром для ее конфигурирования вполне актуальна для бюджетных решений.
Вообще то от количества точек зависит частотное расстояние до кратных спектров. При 2 отсчетах на период спектры смыкаются. Отсюда делайте вывод о необходимой чистоте спектра и требуемого подавления на этих самых кратных спектрах.
Добавлено after 5 minutes 25 seconds:
[uquote="linkov1959",url="/forum/viewtopic.php?p=3980433#p3980433"]а на stm32 нет NCO?[/uquote]
Нет. В мощных контроллерах обычно нет специфической периферии. Если уже вы поставили МК за 7 баксов, то добавить еще 4 за приличный DDS уже нет проблем. А вот в 8-битниках тема с набором специально заточенной периферии и относительно слабым ядром для ее конфигурирования вполне актуальна для бюджетных решений.
- Реклама
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
Как бы я не старался, как бы я не мучился, но с Атмеги dds - только показометр получается.
Будем отталкиваться от 80кГц.
У числа 80000 всего 40 делителей на которые это число делится нацело.
Вот ониК примеру 3200Гц, 80000/3200 = 25 ровно. Джиттер отсутствует.
Тогда как 3340Гц, 80000/3340 = 23,95209581 - вот тут будет джиттер.
То же самое если тактовую 16МГц делить на эти числа.
То есть что бы мне получить идеальные 3340Гц, я должен тактировать МК от 15998600Гц.
КРАМ, если вам не трудно,чтобы раcставить все точки над i и подвести окончательный итог,
в протеусе есть модель PIC10F322 с пометкой NC0, частота 3340Гц импульс 10us, hex файл плиз.
Будем отталкиваться от 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Тогда как 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 дает очень пристойный звук. У меня так работает аларм на металломагнитодетекторах в серийных изделиях.
Там код простейший. В прерываниях по таймеру инкрементируется/декрементируется регистр частоты модуля. Так и гоняется тон от минимального до максимального порога.
Там код простейший. В прерываниях по таймеру инкрементируется/декрементируется регистр частоты модуля. Так и гоняется тон от минимального до максимального порога.
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
Я имел ввиду импульс 10us. Как?
У этого PIC с NCO набор какой-то скудный, ЦАПа на выходе NCO нет - синус не получить,
один меандр, ШИМ то хоть может это NCO что бы из таблицы синус брать?
Хотя я документацию по диагонали смотрел.
Вы этот ПИК предложили, хоть бы пример какой выложили.
У этого PIC с NCO набор какой-то скудный, ЦАПа на выходе NCO нет - синус не получить,
один меандр, ШИМ то хоть может это NCO что бы из таблицы синус брать?
Хотя я документацию по диагонали смотрел.
Вы этот ПИК предложили, хоть бы пример какой выложили.
- КРАМ
- Друг Кота
- Сообщения: 25305
- Зарегистрирован: Чт янв 10, 2008 22:01:02
- Откуда: Московская область, Фрязино
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
[uquote="Dimon456",url="/forum/viewtopic.php?p=3980853#p3980853"]Хотя я документацию по диагонали смотрел.[/uquote]
Оно и видно...
Импульсы на выходе NCO можно получить с помощью Ripple-таймера этого модуля. Длительность устанавливается в регистре NCO1CLK битами N1PWS. При накачке 16 МГц длительность можно выбрать максимум 8 мкс, а при накачке 8 МГц - получается либо 8, либо 16 мкс. Если использовать внешнюю накачку, то при выборе частоты 12,8 МГц и N1PWS=111 (128 тиков) выйдет как раз 10 мкс.
Синус формируется элементарно. Берется таблица синуса, а частота на выходе NCO синтезируется кратно выше по длине таблицы.
Например, при таблице в 64 отсчета нужно генерировать частоту в 64 раза выше. В прерывании от NCO очередное значение таблицы загружается в PWM. Вот и вся хитрость.
Примеры кода я писать не буду принципиально. Это слишком простая в смысле кода задача. Достаточно принципов функционирования. Их я и объясняю. Довольно подробно.
Если у вас будут проблемы с кодом, задавайте конкретные вопросы по коду, а не просите готовенькое.
ЗЫ. В догон. На таком бюджетном МК писать на Си слишком расточительно. АСМ там простой и позволяет вытянуть максимум по скорости в такого рода задачах. А от скорости зависит и чистота спектра синтезируемого сигнала.
Оно и видно...
Импульсы на выходе 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
КРАМ, гладко было на бумаге, да забыли про овраги. Для синусных таблиц оперативки маловато.
Добавлено after 11 minutes 2 seconds:
Re: Генератор с длительностью импульсов 20us с частотой 80Khz
Dimon456, там нужен ГУН и частотомер в обратную связь. На пиках отличные частотомеры получаются.
Добавлено after 11 minutes 2 seconds:
Re: Генератор с длительностью импульсов 20us с частотой 80Khz
Dimon456, там нужен ГУН и частотомер в обратную связь. На пиках отличные частотомеры получаются.
- КРАМ
- Друг Кота
- Сообщения: 25305
- Зарегистрирован: Чт янв 10, 2008 22:01:02
- Откуда: Московская область, Фрязино
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
Господин Линьков, как же вам в голову пришла идея держать таблицу КОСТАНТ в ОЗУ?

Re: Генератор с длительностью импульсов 20us с частотой 80Kh
Я держал в ОЗУ, формировал из пзу с учётом амплитуды (0-100%)и формы (пять встроенных). Форму можно было подгружать по uart, пока не пригодилось ))).
- Zhuk72
- Сверлит текстолит когтями
- Сообщения: 1231
- Зарегистрирован: Ср янв 29, 2014 08:41:31
- Откуда: Баку
- Контактная информация:
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
[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, и у меня она имеется
Вот тут 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, и у меня она имеется
Каждый имеет право на свое личное ошибочное мнение.
У меня было тяжелое детство - я до 14 лет смотрел черно-белый телевизор.
У меня было тяжелое детство - я до 14 лет смотрел черно-белый телевизор.
-
linkov1959
- Держит паяльник хвостом
- Сообщения: 923
- Зарегистрирован: Пн сен 10, 2018 19:16:28
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
[uquote="КРАМ",url="/forum/viewtopic.php?p=3981045#p3981045"]Господин Линьков, как же вам в голову пришла идея держать таблицу КОСТАНТ в ОЗУ?
[/uquote]
Теперь понятно, почему у меня был самый быстрый синус на самом медленном проце.
Теперь понятно, почему у меня был самый быстрый синус на самом медленном проце.
- КРАМ
- Друг Кота
- Сообщения: 25305
- Зарегистрирован: Чт янв 10, 2008 22:01:02
- Откуда: Московская область, Фрязино
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
[uquote="linkov1959",url="/forum/viewtopic.php?p=3981128#p3981128"]Теперь понятно[/uquote]
Не надо фантазировать. Чтение флеша в подавляющем количестве архитектур незначительно дольше, а часто и равно по времени чтению ОЗУ. Если говорить о синтезе синусоиды, то таблица во флеше вообще никак не повлияет на скорость. Ибо период отсчетов НА ПОРЯДКИ больше ничтожных пары...тройки лишних машинных циклов
Не надо фантазировать. Чтение флеша в подавляющем количестве архитектур незначительно дольше, а часто и равно по времени чтению ОЗУ. Если говорить о синтезе синусоиды, то таблица во флеше вообще никак не повлияет на скорость. Ибо период отсчетов НА ПОРЯДКИ больше ничтожных пары...тройки лишних машинных циклов
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
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, который входит в среду.
А в этом есть какая то проблема? Скачать нужно среду разработки, причем можно даже компактный MPLAB 8.92.
Нащщет компилятора я сомневаюсь, однако... Проще написать на MPASM, который входит в среду.
- oleg110592
- Друг Кота
- Сообщения: 3832
- Зарегистрирован: Сб сен 10, 2011 17:46:25
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
[uquote="Dimon456",url="/forum/viewtopic.php?p=3981337#p3981337"]Хорошо, какой самый минимальный компилятор который соберет эти три несчастные строчки?[/uquote]
можно онлайн попробовать
https://mplabxpress.microchip.com/mplabcloud/ide

можно онлайн попробовать
https://mplabxpress.microchip.com/mplabcloud/ide
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
Привет всем
попробывал этот код:
Это прсто, компактно, гениально!!!
Растущй фронт и спадающий фронт ровный во всем диапозоне!
1-80KHz.
Dimon456 - Тебе респект! так держать.
попробывал этот код:
Код: Выделить всё
#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)
{
}
}
Растущй фронт и спадающий фронт ровный во всем диапозоне!
Dimon456 - Тебе респект! так держать.
- Zhuk72
- Сверлит текстолит когтями
- Сообщения: 1231
- Зарегистрирован: Ср янв 29, 2014 08:41:31
- Откуда: Баку
- Контактная информация:
Re: Генератор с длительностью импульсов 20us с частотой 80Kh
[uquote="Dimon456",url="/forum/viewtopic.php?p=3981337#p3981337"]Zhuk72, и КРАМ, я вас правильно понял, что бы проверить мне и собственными глазами убедиться в отсутствии фазового дрожания я должен скачать компилятор под PIC10F?[/uquote]
Могу на днях, если не к спеху, то в выходные дни, на живом изделии запустить и выложить диаграмму с логического анализатора. Правда у меня не 10-й ПИК, а 16F18446. У него NCO 20-битный. Надеюсь на небольших частотах мой китайский Салеае покажет честную картинку.
Могу на днях, если не к спеху, то в выходные дни, на живом изделии запустить и выложить диаграмму с логического анализатора. Правда у меня не 10-й ПИК, а 16F18446. У него NCO 20-битный. Надеюсь на небольших частотах мой китайский Салеае покажет честную картинку.
Каждый имеет право на свое личное ошибочное мнение.
У меня было тяжелое детство - я до 14 лет смотрел черно-белый телевизор.
У меня было тяжелое детство - я до 14 лет смотрел черно-белый телевизор.


