# Universitatea Tehnica Cluj-Napoca

## FACULTATEA DE AUTOMATICA SI CALCULATOARE

# Osciloscop Digital

Autori: Alexandru Pana Adrian Soucup grupa 30232 Indrumator: Cristi Mocan

# Cuprins

| 1 | Rezumat                                  | 2  |
|---|------------------------------------------|----|
| 2 | Introducere                              | 3  |
|   | 2.1 Osciloscopul Digital                 | 3  |
|   | 2.2 Tema Proiectului                     | 4  |
|   | 2.3 Continutul si Structura Documentului | 5  |
| 3 | Fundamentare teoretica                   | 6  |
|   | 3.1 Semnalul video VGA                   | 6  |
| 4 | Proiectare si implementare               | 8  |
|   | 4.1 Blocul de esantionare                | 9  |
|   | 4.2 Logica de iesire                     |    |
| 5 | Rezultate experimentale                  | 17 |
| 6 | Concluzii                                | 18 |

### 1 Rezumat

Proiectul de fata isi propune implementarea unui osciloscop digital, folosind o placa de dezvoltare Basys2. Implementarea se va face in limbajul VHDL.

In acest document exploram notiounea de osciloscop digital, plecand de la definitie, analizand modul de functionare dar si modul de folosire. Vom analiza componentele necesare implementarii unui osciloscop digital: logica de esantionare, o memorie de esantioane si o logica de iesire. Fiecare componenta este explicata din punct de vedere al functionarii, dupa care se prezinta modul de implementare al acesteia specific pentru placuta de dezvoltare Basys2. Pentru logica de esantionare vom explora utilizarea unui convertor analog digital si logica ce controleaza modul de esantionare. Pentru logica de iesire vom explora portul VGA, ce este acesta, cum functioneaza, si cum este implementat pe placuta Basys2.

In descrierea implementarii proiectului avem in considerare tehnicalitatile specifice placutei de dezvoltare cum ar fi constrangerile, limitarile dar si avantajele acesteia. Vom urmari schema osciloscopului si modul de functionare al acestuia.

In sectiunea de rezultate experimentale se analizeaza functionearea proiectului atat in mediu simulat dar si in mediu real. Se pune in functiune placuta Basys2 si se descriu rezultatele obtinute. Scopul aceste sectiuni este de a demonstra corectitudinea implementarii si functionarii proiectului.

Documentul se incheie cu concluziile autorilor, in care acestia prezinta experienta lor pe parcursul dezvoltarii proiectului, notiunile si lectiile invatate, dar si ganduri despre ce ar putea fi imbunatatit sau adaugat.

## 2 Introducere

### 2.1 Osciloscopul Digital

Osciloscopul este un aparat electornic de masura ce permite vizualizarea formei unui semnal de voltaj in timp. Osciloscopul este folosit pentru a analiza forma de unda descrisa de un semnal repetitiv. Aceasta vizualizare ofera informatii despre perioada semnalului, amplitudinea acestuia, dar si despre modificari in amplitudine sau perioada. O alta intrebuintare a osciloscoapelor este analiza zgomotelor unui semnal. Fiind aparate de masura ce ofera o reprezentare vizuala detaliata a unui semnal, acestea joaca un rol important in analiza si depanarea circuitelor electrice.



Figura 1: Osciloscop Digital

Un osciloscop digital este format din patru componente: un ecran pentru vizualizarea semnalului impreuna cu 3 panori de configuratie ce controleaza dimensiunea amplitudinii semnalului pe monitor, frecventa de esantionare a semnalului, si modul de declansare a esantionarii. Unele osciloscoape digitale ofera posibilitatea masurarii a doua semnale concurent. Aceasta functionalitate este utila daca se urmareste comparatia a doua semnale. De asemenea se pot analiza si semnale digitale daca semnalul analogic de intrare este de asa natura.

**Ecranul de vizualizare** este, de cele mai multe ori, un mic monitor CRT integrat in osciloscop. Pe acest monitor se afiseaza semnalul analizat, impreuna cu alte informatii suplimentare cum ar fi o grila de referinta, scala la care este reprezentat semnalul, axele X si Y, sau alti indicatori.

Controlul amplitudinii este factorul ce determina conversia din valoarea semnalului analogic ( in volti ) in spatiul de afisare al ecranului ( in pixeli ). Folosind acest control putem modifica scala la care este afisat semnalul pe axa Y.

Controlul frecventei de esantionare ne permite sa modificam frecventa la care osciloscopul citeste semnalul analog. Cu cat frecventa este mai mare, cu atat reconstruirea semnalului pe ecranul de vizualizare este mai fidela. Unele osciloscoape digitale dispun si de un frecventmetru ce le ofera abilitatea de recunoastere a perioadei unui semnal. Pentru ca perioada calculata sa coincida cu cea reala, adica sa nu apara problema de aliasing, frecventa de esantionare trebuie sa fie suficient de mare.

Modul de declansare a procesului de esantionare determina daca semnalul este esantionat in mod continuu, o singura data sau ca raspuns la un semnal extern. Daca esantionarea se face in mod continuu, imaginea osciloscopului se va schimba constant pentru a reflecta schimbarile semnalului de intrare. Daca esantionarea se face o singura data, monitorul osciloscopului va afisa o imagine statica a semnalului pe o perioada de timp. Daca se alege folosirea unui declansator extern, semnalul va fi esantionat doar la evenimente generate de semnalul declansator.

#### 2.2 Tema Proiectului

Proiectul de fata isi propune implementarea unui osciloscop digital intr-un limbaj de descriere hardware, pentru a fi sintetizat si rulat pe o placa FPGA.

Analizand scopul si modul de functionare a unui osciloscop, se pot observa doua responsabilitati importante ale acestuia:

a. Esantionarea semnalului presupune citirea valorii semnalului analogic la intervale regulate, conversia acestora in valori digitale si salvarea acestor esantioane intr-o memorie interna. Vom implementa aceasta responsabilitate intr-un bloc independent. Acest bloc va avea ca intrari semnalul analog de esantionat, impreuna cu valorile de control pentru frecventa de esantionare si modul de declansare. La iesirile acestui bloc se vor trimite pe rand esantioanele citite.



Figura 2: Blocul de esantionare

a. Afisarea semnalului presupune reprezentarea esantioanelor prezente in memoria interna pe un ecran. Afisarea poate fi implementata independent de modulul de esantionare, comunicand cu acesta printr-o memorie de esantioane. Blocul de afisare va avea ca intrare memoria de esantionari, iar ca iesire un semnal VGA ce poate fi trimis catre orice monitor.



Figura 3: Blocul de afisare

Cele doua blocuri vor fi implementate separat si vor comunica sincron printr-o memorie de esantioane. Aceasta memorie va contine suficiente esantioane ca sa se poata construi forma de unda pe ecran. Detaliile implementari pot fi gasite in sectiunea urmatoare a documentatiei.

#### 2.3 Continutul si Structura Documentului

Acest document este impartit in sase sectiuni, fiecare completand si continuand sectiunea anterioara. Aceste sectiuni sunt:

- Rezumat Aceasta sectiune contine o sinteza scurta a continutului intregului document. Aici sunt prezentate ideile principale din fiecare sectiunie care urmeaza.
- 2. Introducere Introducerea are rolul de a plasa problema proiectului in context, de a prezenta scopul proiectului si pozitia acestuia in domeniul studiat. Se analizeaza utilitatea proiectului luand in considerare constragerile platformei pe care este implementat si timpul de dezvoltare al acestuia.
- 3. Fundamente Teoretice In sectiunea de fundamente teoretice sunt explicate notiunile de baza ale domeniului studiat (analiza semnalelor analogice periodice), implementari similare si o descriere a solutiei propuse. Sunt amintite referintele bibliografice din care s-au documentat autorii.
- 4. Proiectare si Implementare Aceasta sectiune descrie pe larg structura si implementarea proiectului pe baza notiunilor teoretice prezentate anterior. Este prezentata platforma hardware folosita, impreuna cu deciziile pe care autorii le-au luat la implementarea proiectului.
- 5. Rezultate Experimetale Aceasta sectiune are rolul de a demonstra corectitudinea implementarii prin exemplificarea functionalitatii. Sunt analizate rezultatele proiectului prin simulare asistata de calculator dar si prin implementarea si rularea sa pe suportul hardware.
- **6. Concluzii** Sectiunea de concluzii cuprinde propriile concluzii ale autorilor, experienta dobandita in urma implementarii proiectului dar si o analiza asupra procesului de implementare si produsul realizat.

## 3 Fundamentare teoretica

Osciloscopul este un dispozitiv electronic de testare ce permite observarea unor semnale ce variaza constant sub forma unui grafic bidimensional. Graficul foloseste axa Y pentru a reprezenta valoarea semnalului in functie de timp.

#### 3.1 Semnalul video VGA

Acesta este semnalul de la iesirea osciloscopului. Folosind un semnal VGA, osciloscopul construit in acest proiect poate fi conectat la orice monitor, si nu necesita unul incorporat. Semnalul VGA este usor de generat, iar majoritatea monitoarelor existente acum au conectori compatibili. In plus, construirea unui monitor integrat care sa afiseze semnalul este in afara scopului acestui proiect. Folosind un monitor extern osciloscopul nostru beneficiaza de o felxibiltate ridicata.



Figura 4: Conectorul VGA

Conectorul VGA utilizeaza 5 pini, dintre care 3 pentru culoare (Rosu, Verde si Albastru), impreuna cu 2 de sincronizare care reseteaza pozitia fascicolului de electroni pe verticala, respectiv orizontala. Valoarea tensiunii dintre fiecare pin pentru culoare si valoarea tensiunii pinului GND va determina intensitatea canalului respectiv. Pentru a intelege modul de utilizare al pinilor H-SYNC si V-SYNC trebuie sa intelegem mai intai modul de functionare a fascicolului de electroni in interiorul monitorului.



Figura 5: Timpii de sincronizare VGA

Fascicolul de electroni se misca cu viteza constanta de la stanga monitorului spre dreapta. Se observa totusi ca pozitia de incepeput a acestuia se afla inaintea zonei vizuale. Cand fascicolul de electroni se afla in stanga zonei vizuale, spunem ca se afla la marginea stanga. Definim in mod similar zona marginii drepte. Semnalul  $\mathbf{h}$ -video\_on din Figura 5 are valoarea 1 logic cand fascicolul de electroni se afla in zona vizuala, respectiv 0 logic cand acesta se afla fie la marginea stanga, fie la marginea dreapta. Cand fascicolul a ajuns la capatul marginii drepte, se activeaza semnalul H-SYNC pentru a incepe resetarea acestuia la marginea dreapta. In concluzie, fascicolul de electorni se poate afla in una din starile urmatoare:

- 1. marginea stanga atunci cand se afla in stanga zonei vizuale
- 2. **zona vizuala** cand fascicolul pargurge suprafata monitorului
- 3. marginea dreapta cand fascicolul a depasit suprafata monitorului
- 4. curs de intoarcere cand fascicolul este resetat la inceput

Semnalul H-SYNC trebuie sa fie tinut la valoarea  $\theta$  in perioada a patra, cand fascicolul este in curs de intoarcere. In functie de rezolutia dorita, si frecventa monitorului, fiecare din aceste stari are o perioada fixa de timp. Semnalul V-SYNC are acelasi rol, dar reseteaza fascicolul pe verticala. Deoarece ne vom referi la zonele din afara monitorului atat pe orizontala cat si pe verticala, le vom numi de acum inainte margine de inceput si margine de sfarsit. Ne vom referi la tabelul urmator pentru informatii despre timpi, considerand o rezolutie de 640x480, si o frecventa de 60Hz:

| Stare           | Timp Orizontala | Timp Verticala |
|-----------------|-----------------|----------------|
| margine inceput | 16              | 10             |
| zona vizuala    | 640             | 480            |
| margine sfarsit | 48              | 33             |
| intoarcere      | 96              | 2              |
| total           | 800             | 525            |

Timpii sunt calculati in impulsuri de clock, iar frecventa clock-ului pentru un monitor de frecventa 60Hz este 25.175MHz.

Valorile semnalelor *Red*, *Green* si *Blue* se schimba la fiecare impuls de clock cand fascicolul de electroni se afla in zona vizuala, pentru fiecare pixel in parte. Cand fascicolul se afla intr-una din marginile exterioare zonei vizuale sau se afla in starea de intoarcere, aceste semnale sunt setate la nivelul *GND*.

## 4 Proiectare si implementare

Osciloscopul va fi format din 3 parti: Logica de intrare, Memoria esantioanelor si logica de iesire.



Figura 6: Schema Block

Propunem o implementare in limbaj de descriere hardware a unui osciloscop digital ce poate fi sintetizat pe o placa **FPGA Basys 2 (Spartan 3E)**. Pentru esantionarea semnalului de intrare vom folosi un convertor analog digital. Vom realiza un protocol de comunicare intre convertor si placuta FPGA astfel incat sa fie usor de schimbat cu alt convertor de exemplu. Frecventa de esantionare a semnalului o vom controla de la switch-uri sau butoane.

Dispunem de o placuta **CEREBOT II**, placuta care are integrat un **convertor AD/10 biti** pe care il putem folosi. Pentru afisarea datelor vom folosi un monitor cu intrare **VGA**. Placuta Basys 2 dispune de o iesire VGA integrata. Controlul osciloscopului se va face cu ajutorul butoanelor si switch-urilor placutei Basys 2.

Ideea de baza a dispozitivului e sa esantioneze un semnal la un interval de timp modificabil si sa salveze pentru fiecare perioada de timp o valoare care reprezinta amplitudinea semnalului de intrare. Dimensiunea intervalului de timp monitorizat este prestabilit sau se poate controla de la switch-uri/butoane. De fiecare data cand intervalul este baleiat vom trimite datele spre controller-ul VGA spre a fi afisate.

Pentru afisarea graficului putem utiliza interpolare spline liniara intre valorile succesive ale amplitudinii semnalului. Cel mai probabil vom avea nevoie de o matrice bidimensionala de pixeli (framebuffer) in care vom desena forma de unda a semnalului de intrare.

#### 4.1 Blocul de esantionare

Blocul de esantionare este o componenta logica care citeste valorile tensiunii semnalului de intrare la un anumit interval de timp si salveaza in memoria video aceste valori.



Figura 7: Schema blocului de esantionare cu convertor AD real

Acesta este compus din trei subcomponente majore. Componenta ADC, componenta COMM si componenta SAMPLER. Fiecare din aceste componente este un automat de stare.

Componenta COMM este responsabila cu transmiterea de informatii dintre convertorul analog digital si componenta de esantionare. Protocolul de comunicare este simplu de inteles si robust. Transmisia bitilor se face in mod serial in pachete de cate 8. In modul IDLE liniile START\_BIT si REQ\_BIT sunt tinute pe zero logic. Cand se doreste transmiterea unui pachet de 8 biti, COMM va trimite un impuls de o lungime fixa (in cazul nostru de 50MHz div 64) pe linia START\_BIT. Dupa o anumita perioada COMM va incepe sa trimita impulsuri pe linia REQ\_BIT de aceiasi lungime cu impulsul de pe START\_BIT. Placuta CEREBOT va detecta aceste impulsuri ca intreruperi externe. Dupa ce s-a trimis un impuls pe REQ\_BIT, COMM va intra intr-o stare de asteptare pana cand linia BIT\_VALID va deveni 1 logic. Este obligatoriu ca aceasta linie sa fie tinuta pe 1 logic pana cand se va transmite un alt impuls pe REQ\_BIT. COMM va citi bitul de pe linia BIT intr-un registru de deplasare, iar mai apoi va trimite din nou o cerere REQ\_BIT pana cand registrul de deplasare este plin.



Figura 8: Formele de unda pentru COMM

COMM este un automat de stare. In continuare este prezentata o schema cu tranzitiile intre stari. Starile auxiliare BEGIN\* exista deoarece in ele se va intializa un numarator care va avea rolul de a genera impulsuri de o lungime mai mare decat durata tactului de pe placuta FPGA. Avem nevoie de impulsuri mai lungi deoarece placuta CEREBOT2 nu poate detecta intreruperi care sunt mai scurte decat durata clock-ului propriu (8 MHz).



Figura 9: Diagrama cu tranzitii de stare

Componenta SAMPLER are rolul de declansa conversia analog digitala cu ajutorul bitului REQ\_SAMPLE si a salva valoarea din magistrala SAMPLE cand bitul SAMPLE\_VALID devine 1 intr-o locatie din memoria interna. Memoria video are dimensiunea de  $512 \times 8$  si in ea se vor regasi toate esantioanele capturate.

Frecventa de esantionare este controlata cu variabila FREQ. Aceasta este conectata la SWITCH-urile placutei FPGA si reprezinta numarul de CLK-uri de durata 20ns pe care unitatea sa le astepte intre doua esantioane consecutive.  $\nu = \frac{1}{ConversionTime + 20ns*FREQ}$ 

In interiorul componentei se foloseste un registru in care se afla valoarea curenta a adresei de scriere a memoriei. Dupa fiecare esantion capturat valoarea din registru se incrementeaza cu 1, astfel urmatorul sample va fi salvat in continuare in memorie. Exista doua moduri de functionare a osciloscopului: Timp Real si Captura. In modul Timp Real memoria este baleiata si actualizata in mod continuu, in timp ce in modul Captura memoria este actualizata doar atunci cand se detecteaza o schimbare pe portul FREQ.

### Exemplu de functionare



| Name                     | V  | 2,379,100 ns | 2,379,150 ns    | 2,379,200 ns | 2,379,250 ns | 2,379,300 ns | 2,379,350 ns | 2,379,400 ns | 2,379,450 ns |
|--------------------------|----|--------------|-----------------|--------------|--------------|--------------|--------------|--------------|--------------|
| Ū <sub>e</sub> dk        | 1  |              |                 |              |              |              |              |              |              |
| urrentstate currentstate | sl | waituntilthe | endofconversion |              | X            |              |              | sleep        |              |
| ▶ 🖷 sample[7:0]          | 22 | 24           | )               |              |              |              |              | 224          |              |
| la regsample             | 0  |              |                 |              |              |              |              |              |              |
| la samplevalid           | 0  |              |                 |              |              |              |              |              |              |
|                          | П  |              |                 |              |              |              |              |              |              |
|                          | П  |              |                 |              |              |              |              |              |              |
|                          | П  |              |                 |              |              |              |              |              |              |
|                          | П  |              |                 |              |              |              |              |              |              |
|                          |    |              |                 |              |              |              |              |              |              |

| Name                                                                         | ٧  |      | 2,290 us | 2,300 us | 2,310 us     | 2,320 us  | 2,330 us | 2,340 us | 2,350 us | 2,360 us | 2,370 us        |
|------------------------------------------------------------------------------|----|------|----------|----------|--------------|-----------|----------|----------|----------|----------|-----------------|
| Ve clk                                                                       | 1  | 3333 |          |          |              |           |          |          |          |          |                 |
| le currentstate                                                              | sl |      | s        | еер      | / waituntift | neendofco |          | sleep    |          | (wai     | untiltheendofco |
| ▶ ■ sample[7:0]                                                              | 22 |      |          | 48       | XX           | k000000   |          | 195      |          |          | XXXXXXXX        |
| 🏣 regsample                                                                  | 0  |      |          |          |              |           |          |          |          | 1        |                 |
| Vector currentstate  ➤ Med sample[7:0]  Vector regsample  Vector samplevalid | 0  |      |          |          |              |           |          |          |          |          |                 |
| _                                                                            | П  |      |          |          |              |           |          |          |          |          |                 |
|                                                                              | ı  | ı    |          |          |              |           |          |          |          |          |                 |
|                                                                              | ш  |      |          |          |              |           |          |          |          |          |                 |



Figura 10: Diagrama de stare a automatului SAMPLER

Starea ChangeDetected reprezinta starea de initializare a registrului de baleiaj cu adresa 0. Se intra in aceasta stare din Idle cand se detecteaza o schimbare a datelor de pe magistrala FREQ. In starea StartConversion bitul REQ\_SAMPLE devine 1 logic, astfel se semnaleaza o cerere de conversie spre modulul de comunicare (COMM). Se asteapta in starea WaitUntilTheEndO-fConversion pana cand bitul SAMPLE\_VALID devine 1 logic iar apoi se intra in starea Sleep in care se incrementeaza un registru la fiecare tact pana la valoarea semnalului FREQ. Cand se atinge aceasta valoare se intra in starea EndSleep de unde se poate continua baleierea adreselor sau inghetarea automatului in starea Idle. Modul de functionare "Timp Real" presupune tranzitia in starea StartConversion iar modul "Captura" tranzitia in starea Idle.

Protocolul de comunicare este implementat pe placuta CEREBOT2 folosind intreruperile externe. Cand se detecteaza o tranzitie de tip front crescator al bitului START\_BIT se va genera o intrerupere in care se cere o conversie AD. Valoarea unui registru (de stare) va fi setata pe Waiting. Cand conversia AD este terminata se va genera o alta intrerupere unde se salveaza valoarea convertita intr-un registru. Dupa fiecare intrerupere REQ\_BIT se va trimite spre iesire valoarea convertita, se va face 1 logic BIT\_VALID iar apoi registrul se deplasa cu un bit. Daca conversia nu este gata cand vine prima cerere REQ\_BIT vom astepta pana cand va fi gata intr-o stare de Wait (while(1)). BIT\_VALID va deveni 0 de fiecare data cand se executa bucla principala a programului.

Pentru testarea in simulator noi am folosit un bloc care genereaza esantioane pseudo- aleatoare cu bistabile si porti xor. Aceasta componenta respecta interfata de comunicare COMM si este o masina de stare.



Figura 11: Schema blocului de esantionare cu generator de valori aleatoare pentru testarea in simulator

#### 4.2 Logica de iesire

Aceasta sectiune a documentului este dedicata implementarii blocului de afisare din Figura 3.

Dupa cum s-a vazut la capitolul de fundamente teoretice, un controller VGA trebuie sa furnizeze cinci semnale: trei pentru culoarea curenta, si 2 pentru sincronizarea fascicolului de electroni. Din fericire, placuta Basys2 pune la dispozitie 10 semnale pe care le converteste la un port VGA dupa cum urmeaza:

Observam ca Basys2 ne pune la dispozitie trei semnale digitale pentru canalul culorii *Rosu*, trei pentru *Verde* si doar 2 pentru *Albastru*. Impreuna formeaza un bus de 8 biti. Culoarea albastra primeste o rezolutie mai mica deoarece ochiul uman este mai sensibil la verde si rosu. Basys2 converteste aceste valori digitale la un semnal analogic pentru fiecare canal. Semnalele pentru sincronizarea orizontala si verticala sunt legate fara logica suplimentara.

Deoarece clock-ul placutei Basys2 este de 50Mhz, putem aproxima o frecventa de 25.157Mhz impartind la doi frecventa placutei. O frecventa de 25Mhz este suficienta pentru ca majoritatea monitoarelor sa se recunoasca rezolutia.



Figura 12: Basys2 VGA Port

Din pacate, oscilatorul placutei Basys2 nu este suficient de stabil pentru a sincroniza monitoarele moderne. Se recomanda folosirea unui oscilator separat, conectat la slotul dedicat al placutei. Autorii proiectului nu au avut acces la un oscilator stabil. Imaginea rezultata folosind oscilatorul nativ sufera de artefacte verticale. Cu toate acestea, forma de unda este vizibila si poate fi recunoscuta de catre utilizator.

Componenta de control a logicii de iesire are ca semnal de intrare impulsul de clock, iar ca semnale de iesire pozitia pe X si Y a fascicolului de electroni pe suprafata monitorului, impreuna cu un semnal de control care indica daca fascicolul se afla pe suprafata vizibila sau nu.

Folosind doua comparatoare, se determina daca pozitia fascicolului pe verticala ( axa Y ) se afla intre valorile esantioanelor de la adresele X, respectiv X-1. Aceasta metoda presupune ca dimensiunea memoriei de esantioanelor este egala cu rezolutia verticala a monitorului in pixeli, iar valorile esantioanelor sunt scalate in prealabil pentru a fi mapate direct in spatiul monitorului.

Pentru a face comparatia intre pozitia curenta si valoarea a doua esantioane intr-un singur impuls de clock ( respectiv doua, luand in considerare faptul ca fascicolul de electroni petrece doua semnale de clock deasupra unui pixel, frecventa clock-ului intern al controllerului VGA fiind jumatate din frecventa clock-ului placutei ), se memoreaza valoarea esantionului de pe pozitia anterioara intr-un bistabil D. Daca pozitia curenta a fascicolului se afla intre valorile esantioanelor, culoarea trimisa la portul VGA este cea alba, adica "11111111". In caz contrar, sau daca fascicolul se afla in afara zonei vizibile, culoarea trimisa este cea neagra, respectiv "000000000". Acest lucru se face folosind un multiplexor legat la o logica combinationala ce foloseste valorile de iesire ale comparatoarelor, si semnalul ce indica daca fascicolul se afla in zona vizuala sau nu.



Figura 13: Comparator

Comparatoarele sunt circuite combinationale ce primesc ca semnale de intrare doua valori de comparat, si prezinta la iesire doua semnale digitale numite EQ si LESS, active pe '1' logic, ce au ca semnificatie:

| EQ | LESS | Interpretare                     |
|----|------|----------------------------------|
| 1  | *    | Semnalele sunt egale             |
| 0  | 0    | Semnalul A este mai mic decat B  |
| 0  | 1    | Semnalul A este mai mare decat B |



5 Rezultate experimentale

## 6 Concluzii

In primul rand acest proiect este mai mult didactic si nu poate inlocui solutii care sunt mai eficiente din punct de vedere calitate/pret. Contributia noastra a fost determinarea componentelor unui osciloscop digital si implementarea acestuia pe o placuta FPGA in limbajul VHDL. Automatele de stare au fost folosite excesiv pentru controlul componentelor, astfel demonstrandu-se puterea lor in a rezolva probleme de timp real.

Design-ul ofera un anumit grad de flexibilitate, osciloscopul avand posibilitatea de a fi conectat la orice monitor VGA si la orice sistem de achizitie atat timp cat se respecta protocolul de comunicare (COMM).

Pentru entuziasti, sistemul poate fi folosit pentru verificarea unor semnale analogice cu conditia ca acestea sa aiba tensiunea suportata de ADC-ul placutei CEREBOT 2. Sistemul poate fi extins adaugand module care sa afiseze date statistice sau auxiliare pe monitorul VGA, cum ar fi o legenda de timp, sau frecventa si amplitudinea undei detectate.

## Bibliografie

- [1] Leslie Lamport, \( \mathbb{P}T\_EX: \) A Document Preparation System. Addison Wesley, Massachusetts, 2nd Edition, 1994.
- [2] Analog and Digital Oscilloscope http://en.wikipedia.org/wiki/Oscilloscope
- [3] Practical questions and answers about oscilloscope use http://forum.allaboutcircuits.com/showthread.php?t=2645
- [4] Basys 2 Reference Manual http://www.digilentinc.com/Data/Products/BASYS2/Basys2\_rm.pdf
- [5] VGA controller and specification http://www.eng.utah.edu/~cs3710/labs/VGA.pdf
- [6] Hardware Design with VHDL: VGA Example http://www.ece.unm.edu/~jimp/vhdl\_fpgas/slides/VGA.pdf
- [7] VGA Timings http://hamsterworks.co.nz/mediawiki/index.php/VGA\_timings
- [8] Cerebot II Reference Manual http://www.digilentinc.com/Data/Products/CEREBOT-II/Cerebot\_ II\_rm\_RevB.pdf