Форум программистов
 

Восстановите пароль или Зарегистрируйтесь на форуме, о проблемах пишите сюда - alarforum@yandex.ru, проверяйте папку спам!

Вернуться   Форум программистов > Программная инженерия > Микроконтроллеры, робототехника, схемотехника, 3D принтеры
Регистрация

Восстановить пароль
Повторная активизация e-mail

Купить рекламу на форуме 85 тыс рублей в месяц

Ответ
 
Опции темы Поиск в этой теме
Старый 21.02.2022, 10:27   #1
ra9ane
 
Регистрация: 19.02.2022
Сообщений: 9
По умолчанию Генератор синусоиды Arduino DDS

Генератор синусоиды, как уменьшить максимальную выходную частоту до 15 Гц ?
помогите пенсионеру, программирование плохо в голову входит, что нужно подправить?
http://interface.khm.de/index.php/la...ave-generator/
Код:
/*
 *http://arduino.ru/forum/obshchii/dds-generator-dlya-upr-h-most?page=1
 * DDS Sine Generator mit ATMEGS 168
 * Timer2 generates the  31250 KHz Clock Interrupt
 *http://interface.khm.de/index.php/lab/interfaces-advanced/arduino-dds-sinewave-generator/
 * KHM 2009 /  Martin Nawrath
 * Kunsthochschule fuer Medien Koeln
 * Academy of Media Arts Cologne
 */

#include "avr/pgmspace.h"
// table of 256 sine values / one sine period / stored in flash memory
PROGMEM const byte sine256[]  = {

  127,130,133,136,139,143,146,149,152,155,158,161,164,167,170,173,176,178,181,184,187,190,192,195,198,200,203,205,208,210,212,215,217,219,221,223,225,227,229,231,233,234,236,238,239,240,

  242,243,244,245,247,248,249,249,250,251,252,252,253,253,253,254,254,254,254,254,254,254,253,253,253,252,252,251,250,249,249,248,247,245,244,243,242,240,239,238,236,234,233,231,229,227,225,223,

  221,219,217,215,212,210,208,205,203,200,198,195,192,190,187,184,181,178,176,173,170,167,164,161,158,155,152,149,146,143,139,136,133,130,127,124,121,118,115,111,108,105,102,99,96,93,90,87,84,81,78,

  76,73,70,67,64,62,59,56,54,51,49,46,44,42,39,37,35,33,31,29,27,25,23,21,20,18,16,15,14,12,11,10,9,7,6,5,5,4,3,2,2,1,1,1,0,0,0,0,0,0,0,1,1,1,2,2,3,4,5,5,6,7,9,10,11,12,14,15,16,18,20,21,23,25,27,29,31,

  33,35,37,39,42,44,46,49,51,54,56,59,62,64,67,70,73,76,78,81,84,87,90,93,96,99,102,105,108,111,115,118,121,124
};

#define cbi(sfr, bit) (_SFR_BYTE(sfr) &= ~_BV(bit))
#define sbi(sfr, bit) (_SFR_BYTE(sfr) |= _BV(bit)) 

byte bb; 
double dfreq;
// const double refclk=31372.549;  // =16MHz / 510
const double refclk=31372.549;      // measured
// variables used inside interrupt service declared as voilatile
volatile byte icnt;              // var inside interrupt
volatile byte icnt1;             // var inside interrupt
volatile byte c4ms;              // counter incremented all 4ms
volatile unsigned long phaccu;   // pahse accumulator
volatile unsigned long tword_m;  // dds tuning word m

void setup()
{
  pinMode(11, OUTPUT);     // pin11= PWM  output / frequency output
 
  Setup_timer2();
  // disable interrupts to avoid timing distortion
  cbi (TIMSK0,TOIE0);              // disable Timer0 !!! delay() is now not available
  sbi (TIMSK2,TOIE2);              // enable Timer2 Interrupt
  dfreq=1000.0;                    // initial output frequency = 1000.o Hz
  tword_m=pow(2,32)*dfreq/refclk;  // calulate DDS new tuning word 
}

void loop()
{
  while(1) {
     if (c4ms > 250) {                 // timer / wait fou a full second
      c4ms=0;
      dfreq=analogRead(0);             // read Poti on analog pin 0 to adjust output frequency from 0..1023 Hz
      cbi (TIMSK2,TOIE2);              // disble Timer2 Interrupt
      tword_m=pow(2,32)*dfreq/refclk;  // calulate DDS new tuning word
      sbi (TIMSK2,TOIE2);              // enable Timer2 Interrupt 
    }
  }
 }
//******************************************************************
// timer2 setup
// set prscaler to 1, PWM mode to phase correct PWM,  16000000/510 = 31372.55 Hz clock

void Setup_timer2() {
// Timer2 Clock Prescaler to : 1
  sbi (TCCR2B, CS20);
  cbi (TCCR2B, CS21);
  cbi (TCCR2B, CS22);
  // Timer2 PWM Mode set to Phase Correct PWM
  cbi (TCCR2A, COM2A0);  // clear Compare Match
  sbi (TCCR2A, COM2A1);
  sbi (TCCR2A, WGM20);  // Mode 1  / Phase Correct PWM
  cbi (TCCR2A, WGM21);
  cbi (TCCR2B, WGM22);
}
//******************************************************************
// Timer2 Interrupt Service at 31372,550 KHz = 32uSec
// this is the timebase REFCLOCK for the DDS generator
// FOUT = (M (REFCLK)) / (2 exp 32)
// runtime : 8 microseconds ( inclusive push and pop)
ISR(TIMER2_OVF_vect) {
  sbi(PORTD,7);          // Test / set PORTD,7 high to observe timing with a oscope
  phaccu=phaccu+tword_m; // soft DDS, phase accu with 32 bits
  icnt=phaccu >> 24;     // use upper 8 bits for phase accu as frequency information
                         // read value fron ROM sine table and send to PWM DAC
  OCR2A=pgm_read_byte_near(sine256 + icnt);    
  if(icnt1++ == 125) {  // increment variable c4ms all 4 milliseconds
    c4ms++;
    icnt1=0;
   }   
   
 cbi(PORTD,7);            // reset PORTD,7
}

Последний раз редактировалось ra9ane; 21.02.2022 в 11:06.
ra9ane вне форума Ответить с цитированием
Старый 21.02.2022, 15:19   #2
Desc
Участник клуба
 
Аватар для Desc
 
Регистрация: 21.11.2007
Сообщений: 1,063
По умолчанию

48-я строка
Код:
dfreq=1000.0;                    // initial output frequency = 1000.o Hz
I am not a wizard, I am just learning.

Последний раз редактировалось Desc; 21.02.2022 в 15:22.
Desc вне форума Ответить с цитированием
Старый 21.02.2022, 15:27   #3
ra9ane
 
Регистрация: 19.02.2022
Сообщений: 9
По умолчанию

Цитата:
Сообщение от Desc Посмотреть сообщение
48-я строка
Код:
dfreq=1000.0;                    // initial output frequency = 1000.o Hz
Я сразу попробовал этот параметр поменять, но ни чего не происходит даже 0 ставил.
ra9ane вне форума Ответить с цитированием
Старый 21.02.2022, 15:36   #4
Desc
Участник клуба
 
Аватар для Desc
 
Регистрация: 21.11.2007
Сообщений: 1,063
По умолчанию

Если совсем ни чего не происходит, проверяйте:
правильность установки тактовой частоты;
таблицу PWM;
корректность всего кода.
I am not a wizard, I am just learning.
Desc вне форума Ответить с цитированием
Старый 21.02.2022, 15:50   #5
ra9ane
 
Регистрация: 19.02.2022
Сообщений: 9
По умолчанию

Цитата:
Сообщение от Desc Посмотреть сообщение
Если совсем ни чего не происходит, проверяйте:
правильность установки тактовой частоты;
таблицу PWM;
корректность всего кода.
схема работает смотрю на осциллографе частота изменяется, но мне нужно ограничить частоту, чтобы можно было плавно регулировать от 0,1 - 15 Гц выше мне не нужно
ra9ane вне форума Ответить с цитированием
Старый 21.02.2022, 19:06   #6
Desc
Участник клуба
 
Аватар для Desc
 
Регистрация: 21.11.2007
Сообщений: 1,063
По умолчанию

Ну так переменная dfreq это и есть граничная частота.
Ставте значение dfreq = 15.0;
И константу подправьте на:
const double refclk=31372.54902;

P. S.
По вашей же ссылке на проект есть ссылка на DDS калькулятор:
Link: dds_calc
I am not a wizard, I am just learning.
Desc вне форума Ответить с цитированием
Старый 21.02.2022, 20:05   #7
ra9ane
 
Регистрация: 19.02.2022
Сообщений: 9
По умолчанию

[QUOTE=Desc;1844914]Ну так переменная dfreq это и есть граничная частота.
Ставте значение dfreq = 15.0;
И константу подправьте на:
const double refclk=31372.54902;

Ваши цифры мне не подошли, нужно видимо разбираться в этом калькуляторе.
Буду "морщить репу" и методом научного тыка подбирать цифры.
dfreq=15.0; // initial output frequency = 1000.o Hz
а ниже dfreq
dfreq=analogRead(0);

tword_m=pow(2,32)*dfreq/refclk; // calulate DDS new tuning word

Последний раз редактировалось ra9ane; 21.02.2022 в 20:45.
ra9ane вне форума Ответить с цитированием
Старый 22.02.2022, 21:08   #8
ra9ane
 
Регистрация: 19.02.2022
Сообщений: 9
По умолчанию

[QUOTE=Desc;1844914]Ну так переменная dfreq это и есть граничная частота.
Ставте значение dfreq = 15.0;
И константу подправьте на:
const double refclk=31372.54902;

Как я понял прочитав форум http://arduino.ru/forum/obshchii/dds...-h-most?page=1
что не возможно понизить частоту генератора
OCR2A влияет только на скважность, частота не меняется.
ra9ane вне форума Ответить с цитированием
Старый 22.02.2022, 21:15   #9
Desc
Участник клуба
 
Аватар для Desc
 
Регистрация: 21.11.2007
Сообщений: 1,063
По умолчанию

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

P. S.
Таблица тактов влияет на точность, чем больше тактов тем выше точность на выходе. Граничный предел -- граничная частота ядра.
Но и не следует забывать что каждое действие кода это так-же такты.
I am not a wizard, I am just learning.

Последний раз редактировалось Desc; 22.02.2022 в 21:27. Причина: Добавил P. S.
Desc вне форума Ответить с цитированием
Старый 22.02.2022, 21:24   #10
ra9ane
 
Регистрация: 19.02.2022
Сообщений: 9
По умолчанию dds_calc

Цитата:
Сообщение от Desc Посмотреть сообщение
Ну так переменная dfreq это и есть граничная частота.
Ставте значение dfreq = 15.0;
И константу подправьте на:
const double refclk=31372.54902;

P. S.
По вашей же ссылке на проект есть ссылка на DDS калькулятор:
Link: dds_calc
dfreq =в калькуляторе находится в ячейке В7
рассчитывается параметр
Tuning Word M=B7*СТЕПЕНЬ(2;B12)/B13
Куда его применить в программе не понимаю
Вложения
Тип файла: xls dds_calc.xls (8.0 Кб, 1 просмотров)
ra9ane вне форума Ответить с цитированием
Ответ


Купить рекламу на форуме 85 тыс рублей в месяц

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Photoshop dds maks1331 Моделирование, изометрия, photoshop, 3d редакторы 5 03.02.2017 00:33
График синусоиды Sour1 Помощь студентам 2 16.12.2015 23:28
Текст по контуру синусоиды Abbath1349 Win Api 0 29.12.2010 19:20
Эмулятор диспетчера процессов. Бегущие синусоиды. JarBem Помощь студентам 1 13.12.2010 10:16
Алгоритм подсчета числа вершин синусоиды? Mixasik Помощь студентам 8 07.06.2009 18:39