Author Topic: Accumulatore di fase per DDS su FPGA  (Read 3478 times)

nanostallmann

  • Newbie
  • *
  • Posts: 2
    • View Profile
Accumulatore di fase per DDS su FPGA
« on: January 26, 2013, 11:42:41 PM »
Ciao a tutti,
ho una domanda a riguardo di un accuulatore di fase per un DDS che sto implementando sulla ATLYS (Spartan6).
L'accumulatore che ho progettato lavora con una phase_word in ingresso d 18bit e pone in uscita un indirizzo a 10bit per un banco di ROM.
Quando mando in ingresso una phase_word che interviene solo sulla parte intera o solo su quella frazionaria (per esempio parole come 000000001000000000 or 000100000000000000 or 000000000010000000) l'accumulatore genera in uscita valori con incremento costante e pari a il valore imposto dalla parola (per l'esempio riportato su  2 ogni periodi di clock , 64 ogni periodi di clock  or 1 ogni 2 periodi di clock per l'esempio appena citato).
Quando mando in ingresso una phase_word che interviene sia sulla parte intera che su quella frazionaria (per esempio 000000000110000000) l'accumulatore pone in uscita una sequenza con un incremento variabile (per l'esempio appena citato una volta con un incremento pari a uno e una volta con un incremento pari a due).
Matematicamente io penso sia corretto ma la questione è:
Quando cambio la fase con un incremento variabile l'onda in uscita non risulterà distorta da spurie generate proprio da questo comportamento???

Per chiarezza allego degli screen-shoots ( diversi dagl'esempi riportati su):

Io penso che una soluzione potrebbe essere interpolare i valori di uscita.... la vostra opinione???
Grazie

nanostallmann

  • Newbie
  • *
  • Posts: 2
    • View Profile
Re:Accumulatore di fase per DDS su FPGA
« Reply #1 on: January 27, 2013, 12:46:54 AM »
Ho cablato l'accumulatore con la rom contenente i campioni dell'onda da riprodurre e contrariamente a quello che mi aspettavo, dopo aver rielaborato i risultati ottenuti, ho notato che, a parte il (sempre presente) rumore di quantizzazione non sembra esserci presenza di spurie.
Allego uno screen-shot.
A presto

 

Sitemap 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71