Scrigroup - Documente si articole

     

HomeDocumenteUploadResurseAlte limbi doc
AeronauticaComunicatiiElectronica electricitateMerceologieTehnica mecanica


Masurarea inductantei bobinelor L-metru -

Electronica electricitate



+ Font mai mare | - Font mai mic



Universitatea "Lucian Blaga" din Sibiu

Colegiu Universitar



Proiect de diploma

Universitatea "Lucian Blaga" din Sibiu

Colegiu Universitar

Masurarea inductantei bobinelor:

L-metru

Coordonator:

Introducere

Acest aparat masoara inductanta bobinelor in gamele: 100nH - 5 μH si 5 μH - 500mH fara a masura insa factorul de calitate. Masurarea inductantei este posibila pentru bobine care au factorul de calitate mare respective rezistenta serie mai mica maxim 2 ohmi.

Masurarea se face utilizand 2 oscilatoare:

de joasa frecventa construit cu LM339, in gama 100nH < L < 5 μH;

de inalta frecventa construit cu tranzitorul FET, BF256, in gama 100nH < L <5 μH.

Afisarea valorii inductantei se face pe un afisaj LCD 2 x 16 caractere.

Simultan cu afisarea valorii inductantei se indica si valoarea frecventei oscilatorului. Functionarea aparatului este gestionata de microcontrolerul PIC 16F84 care calculeaza valoarea inductantei dupa formula L= si comanda LCD.

Schimbarea gamei de masura se face cu ajutorul butonului "selectie gama ". Masurarea cu acest aparat se face cu o eroare in medie de 10%.

Cuprins

Introducere

Cap.1 Partea teoretica

1.1 Introducere in microcontrolere pag. 5

1.2 Bobina:parametrii, caracteristici pag.24

1.3 Afisarea LCD.Principii de functionare pag.35

1.4 Metode de programare a Pic-ului pag.39

Cap.2 Partea tehnica

2.1 Scheme bloc pag.44

2.2 Blocul(oscilator cu bobina:LM,FET) pag.45

2.3 Divizorul de frecventa pag.51

2.4 Multiplexorul pag.54

2.5 PIC16F84 pag.56

2.6 LCD(Initializare LCD) pag.59

2.7 Schema logica a programului pag.63

2.8 Sursa de alimentare pag.68

ANEXE : A.1. Schema electronica pag.70

A.2. Cablaje pag.71

A.3. Lista componenete pag.72

A.4. Listarea programului si limbajului de asamblare pag.73

BIBLIOGRAFIE

Mihu P.Ioan - Dispozitive si circuite electronice,vol I.-Editura Alma Mater 2002

Ciugudean Marian - Proiectarea unor circuite electrice,Editura Facla 1983

Badea M,Ristea.I - Tranzistoare cu efect de camp-Editura Tehnica 1982

Edmund Nicolau - Masurari electrice,Editura Tehnica 1989

Vintan Lucian - Exploatarea paralelismului in microprocesoarele avansate,Alma Mater 2001

www.microchip.com

www.electronica.ro

www.elektronikladen.de

Cap. 1 Partea teoretica

1.1 Introducere in microcontrolere

Istoria microcontrolelor

Este anul 1969, si o echipa de ingineri japonezi de la compania BUSICOM sosesc in Statele Unite cu cerer ea ca unele circuite integrate pentru calculatoare sa fie facute folosind proiectele lor. Propunerea a fost facuta catre INTEL, iar Marcian Hoff a fost desemnat responsabil cu acest proiect. Pentru ca el era cel ce avea experienta in lucrul cu un calculator ( PC) PDP8, i-a venit sa sugereze o solutie diferita fundamental in locul constructiei propuse. Aceasta solutie presupunea ca functionarea circuitului integrat este determinata de un program memorat in el. Aceasta a insemnat ca configuratia ar fi fost mult mai simpla, dar aceasta ar fi cerut  mult mai multa memorie decat ar fi cerut proiectul propus de inginerii japonezi. Dupa un timp, cu toate ca inginerii au cautat sa caute o solutie mai simpla, ideea lui Marcian a castigat, si aluat nastere primul microcontroler. In transformarea unei idei intr-un produs finit, Frederico Faggin a fost de un ajutor major pentru INTEL. El s-a transferat la INTEL, si doar in 9 luni a reusit sa scoata un produs din prima sa conceptie. INTEL a obtinut drepturile de a vinde acest bloc integral in 1971. In primul rand ei au cumparat licenta de la compania BUSICOM care nu au avut idee ce comoara avusesera. In timpul acelui an a aparut pe piata un microprocesor numit 4004. Acela a fost primul microprocesor de 4 biti cu viteza 6000 operatii pe secunda. Nu mult dupa aceea, compania americana CTC a cerut de la INTEL si de la Texas Instruments sa faca un microprocesor pe 8 biti pentru folosinta in terminale. Cu toate ca CTC a renuntat la aceasta idee pana la sfarsit, INTEL si Texas Instruments au continuat sa lucreze la microprocesor si in aprilie 1972 a aparut pe piata primul microprocesor de 8 biti sub numele de 8008. Putea sa adreseze 64Kb de memorie si avea 45 de instructiuni si viteza de 300.000 de operatii pe secunda. Acel microprocesor a fost predecesorul tuturor microprocesoarelor de astazi. INEL au continuat dezvoltarile lor pana in aprilie 1974 si au lansat pe piata microprocesorul de 8 biti sub numele de 8080 ce putea adresa 64Kb de memorie si avea 75 de instructiuni, iar pretul incepuse de la 360$.

Intr-o alta companie americana Motorola, si-au dat seama repede ce se intampla, asa ca au lansat pe piata un microprocesor de 8 biti 6800. Costructor sef era Chuck Peddle si pe langa microprocesorul propriu-zis, Motorola a fost prima companie care sa faca alte periferice ca 6820 si 6850. La acel timp multe companii au recunoscut marea importanta a microprocesoarelor  si au inceput propriile lor dezvoltari. Chuck Peddle paraseste Motorola pentru a se muta la MOS Technology si continua sa lucreze intensiv la dezvoltarea microprocesoarelor.

La expozitia WESCON din Statele Unite din 1975 a avut loc un eveniment critic in istoria microprocesoarelor. MOS Technology a anuntat ca produce microprocesoarele 6501 si 6502 la 25$ bucata pe care cumparatorii le puteau cumpara imediat. Aceasta a fost atat de senzational incat au crezut ca este un fel de inselaciune, gandind ca competitorii vindeau 8080 si 6800 la 179$. Ca un raspuns la competitorii lor atat INTEL cat si Motorola au scazut preturile lor in prima zi a expozitiei pana la 69.95$ pe microprocesor. Motorola intenteaza repede proces contra lui MOS Technology si contra lui Chuck Peddle pentru copierea protejatului 6800. MOS Technology inceteaza de a mai produce 6501 dar continua sa produca 6502. 6502 este un microcontroler pe 8 biti cu 56 de instructiuni si o capabilitate de adresare directa de 64Kb de memorie. Datorita costului scazut, 6502 devine foarte popular, asa ca este instalat in computere   ca :KIM-1, Apple I, Apple II, Atari, Comodore, Acorn, Oric, Galeb, Orao, Ultra si multe altele. Curand apar cativa producatori de 6502 (Rockwell, Sznertek, GTE, NCR, Ricoh si Comodore preiau MOS Technology) ce era in momentul prosperitatii sale vandut la o rata de 15 milioane de microprocesoare pe an!

Altii totusi nu au cedat. Federico Faggin paraseste INTEL, si isi porneste propria sa companie Zilog Inc.

In 1976 Zilog anunta Z80. In timpul crearii acestui microprocesor, Faggin face o decizie cruciala. Stiind ca un mare numar de programe fusesera dezvoltate pentru 8080, Faggin isi da seama ca multi vor ramane fideli acelui microprocesor din cauza marii cheltuieli care ar rezula in urma refacerii tuturor programelor. Astfel el decide ca un nou microprocesor trebuie sa fie compatibil cu 8080, sau ca trebuie sa fie capabil sa execute toate programele care deja fusese scrise pentru 8080. Inafara acestor caracteristici, multe altele noi au fost adaugate, asa ca Z80 a fost un microprocesor foarte puternic la vremea lui. Se putea adresa direct la 64Kb de memorie, avea 176 instructiuni, o singura sursa,mult mai mare viteza de lucru etc. Z80 a fost un succes mare si toata lumea a facut conversia de 8080 la Z80. Se poate spune ca Z80 a fost fara nici o indoiala comercial, cel mai de succes microcontroler de 8 biti a acelui timp. Inafara de Zilog, alti noi producatori apar de asemenea ca :Mostek, NEC, SHARP si SGS. Z80 a fost inima a multor computere ca :Spectrum, Partner, TRS703, Z-3 si Galaxi aici acasa.

In 1976, INTEL iese pe piata cu o versiune imbunatatita de microprocesor pe 8 biti numit 8085. Totusi, Z80 era cu mult mai bun incat INTEL a apierdut batalia. Chiar daca inca cateva microprocesoare au aparut pe piata (6809,2650,SC/MP etc.), totul fusese de fapt deja hotarat. Nu mai erau de facut imbunatatiri importante ca sa-i faca pe producatori sa se converteasca spre ceva nou, asa ca 6502 si Z80 impreuna cu 6800 au ramas ca cei mai reprezentativi ai microprocesoarelor de 8 biti a acelui timp.

Deosebirea dintre microprocesoare si microcontrolere

Microcontrolerul difera de un microprocesor in multe feluri. In primul rand si cel mai important este functionalitatea sa. Pentru a fi folosit, unui microprocesor trebuie sa i se adauge alte componente ca memorie, sau componente pentru primirea si trimiterea de date. Pe scurt, aceasta inseamna ca microprocesorul este inima computerului. Pe de alta parte, microcontrolerul este proiectat sa fie toate acestea intr-unul singur. Nu sunt necesare alte componente externe pentru aplicarea sa pentru ca toate perifericele necesare sunt deja incluse in el.

Astfel, economisim timpul si spatiul necesare pentru construirea de aparate.  Un microcontroler este un 'calculator pe un chip'. Cuvantul 'micro' sugereaza marimea redusa a dispozitivului iar 'controler' ne spune ca dispozitivul poate fi folosit pentru a controla obicte, procese sau evenimente.
         

Microcontrolerele pot fi gasite in componenta oricarui tip de aparat. Orice aparat care masoara, stocheaza, comanda, calculeaza sau afiseaza informatii este o potentiala gazda pentru un microcontroler.De exemplu orice automobil fabricat astazi este echipat cu cel putin un microcontroler care comanda motorul masinii si adesea chiar cu mai multe pentru comanda sistemelor aditionale din automobil. In calculatoare de birou (PC) se pot gasi microcontrolere in tastatura, modemuri, imprimante si alte periferice. In echipamentele de testare fac posibila adaugarea unor facilitati ca de exemplu memorarea rezultatelor masurarii, afisarea mesajelor si formelor de unda. Produsele de larg consum care includ microcontrolere sunt camerele video, video recorderele, compact-disk (CD) playere si altele. Un microcontroler este similar unui microprocesor. Ambele contin o unitate centrala de prelucrare sau UCP (cenral processing unit). CPU executa instructiuni care indeplinesc operatiile de baza logice, matematice si de curgere a informatiei.

Pentru a construi un calculator complet, microprocesorul necesita memorie pentru pastrarea datelor si programelor, interfete de intrare-iesire (I/O) pentru conectarea dispozitivelor externe cum ar fi tastatura sau monitorul. Spre diferenta de microprocesor, microcontrolerul este un calculator pe un chip deorece el contine si memorie si interfete de intrare-iesire pe langa CPU. Deoarece memoria si interfetele care incap pe un chip sunt limitate, microcontrolerele tind sa fie utilizate in sisteme mai mici care necesita doar un microcontroler si cateva elemente aditionale

Blocurile de baza a microcontrolerului

Unitatea de memorie

Memoria este o parte a microcontrolerului a carei functie este de a inmagazina date.

Cel mai usor mod de a explica este de a-l descrie ca un dulap mare cu multe sertare. Daca presupunem ca am marcat sertarele intr-un asemenea fel incat sa nu fie confundate, oricare din continuturile lor vor fi atunci usor accesibile. Este suficient sa se stie desemnarea sertarului si astfel continuturile lui ne vor fi cunoscute in mod sigur.

Fig.1.1.1

Componentele de memorie sunt exact asa. Pentru o anumita intrare obtinem continuturile unei anumite locatii de memorie adresate si aceasta este totul. Doua noi concepte ne sunt aduse :adresarea si locatia de memorie. Memoria consta din toate locatiile de memorie, si adresarea nu este altceva decat selectarea uneia din ele. Aceasta inseamna ca noi trebuie sa selectam locatia de memorie la un capat, si la celalalt capat trebuie sa asteptam continuturile acelei locatii. In afara de citirea dintr-o locatie de memorie, memoria trebuie de asemenea sa permita scrierea in ea. Aceasta se face asigurarea unei linii aditionale numita linie de control. Vom desemna aceasta linie ca R/W (citeste /scrie). Linia de control este folosita in urmatorul fel : daca r/w=1, se face citirea, si daca opusul este adevarat atunci se face scrierea in locatia de memorie. Memoria este primul element, dar avem nevoie si de altele pentru ca microcontrolerul nostru sa functioneze.

Unitatea centrala de procesare

Sa adaugam alte 3 locatii de memorie pentru un bloc specific ce va avea o capabilitate incorporata de inmultire, impartire, extragere si sa-i mutam continuturile dintr-o locatie de memorie in alta. Partea pe care tocmai am adaugat-o este numita 'unitatea de procesare centrala' (CPU). Locatiile ei de memorie sunt numite registri.

Fig.1.1.2

Registrii sunt deci locatii de memorie a caror rol este de a ajuta prin executarea a variate operatii matematice sau a altor operatii cu date oriunde se vor fi gasit datele. Sa privim la situtia curenta. Avem doua entitati independente (memoria si CPU)  ce sunt interconectate, sI astfel orice schimb de informatii este ascuns, ca si functionalitatea sa. Daca, de exemplu, dorim sa adaugam continuturile a doua locatii de memorie si   intoarcem rezultatul inapoi in memorie, vom avea nevoie de o conexiune intre menmorie si CPU. Mai simplu formulat, trebuie sa avem o anumita 'cale' prin care datele circula de la un bloc la altul.

Bus-ul de date

Calea este numita 'bus'-magistrala. Fizic, el reprezinta un grup de 8, 16, sau mai multe fire. Sunt doua tipuri de bus-uri : bus de adresa si bus de date. Primul consta din atatea linii cat este cantitatea de memorie ce dorim sa o adresam, iar celalalt este atat de lat cat sunt datele, in cazul nostru 8 biti sau linia de conectare. Primul serveste la transmiterea adreselor de la CPU la memorie, iar cel de al doilea la conectarea tuturor blocurilor din interiorul microcontrolerului.

Fig.1.1.3

In ceea ce priveste functionalitatea, situatia s-a imbunatatit, dar o noua problema a aparut de asemenea: avem o unitate ce este capabila sa lucreze singura, dar ce nu are nici un contact cu lumea de afara, sau cu noi ! Pentru a inlatura aceasta deficienta, sa adaugam un bloc ce contine cateva locatii de memorie a caror singur capat este conectat la busul de date, iar celalat are conexiune cu liniile de iesire la microcontroler ce pot fi vazute cu ochiul liber ca pini la componenta electronica.

Unitatea de intrare-iesire

Aceste locatii ce tocmai le-am adaugat sunt numite 'porti'.Sunt diferite tipuri de porti :intrare, iesire sau porti pe doua-cai. Cand se lucreaza cu porti, mai intai de toate este necesar sa se aleaga cu ce pot urmeaza sa se lucreze, si apoi sa se trimita date la, sau sa se ia date de la port.

Fig.1.1.4

Cand se lucreaza cu el portul se comporta ca o locatie de memorie. Ceva este pur si simplu scris in sau citit din el, si este posibil de a remarca usor aceasta la pinii microcontrolerului.

Porturi de comunicatie

Cu aceasta am adaugat la unitatea deja existenta posibilitatea comunicarii cu lumea de afara. Totusi, acest mod de comunicare are neajunsurile lui. Unul din neajunsurile de baza este numarul de linii ce trebuie sa fie folosite pentru a transfera datele. Ce s-ar intampla daca acestea ar trebui transferate la distanta de cativa kilometri? Numarul de linii si numarul de kilometri nu promite costuri eficiente pentru proiect. Nu ne ramane decat sa reducem numarul de linii     intr-un asa fel incat sa nu afectam functionalitatea. Sa presupunem ca lucram doar cu 3 linii, si ca o linie este folosita pentru trimiterea de date, alta pentru receptie si a treia este folosita ca o linie de referinta  atat pentru partea de intrare cat si pentru partea de iesire. Pentru ca aceasta sa functioneze, trebuie sa stabilim regulile de schimb ale datelor. Aceste reguli sunt numite protocol. Protocolul este de aceea definit in avans ca sa nu fie nici o neitelegere intre partile ce comunica una cu alta. De exemplu, daca un om vorbeste in franceza, si altul vorbeste in engleza, este putin probabil ca ei se vor intelege repede si eficient unul cu altul. Sa presupunem ca avem urmatorul protocol. Unitatea logica '1' este setata pe linia de transmisie pana ce incepe transferul. Odata ce incepe transferul, coboram linia de transmisie la '0' logic pentru o perioada de timp (pe care o vom desemna ca T), asa ca partea receptoare va sti ca sunt date de primit, asa ca va activa mecanismul ei de receptie. Sa ne intoarcem acum la partea de transmisie si sa incepem sa punem zero-uri si unu-uri pe linia de transmisie in ordinea de la un bit a celei mai de jos valori la un bit a celei mai de sus valori. Sa lasam ca fiecare bit sa ramana pe linie pentru o perioada de timp egala cu T, si la sfarst, sau dupa al 8-lea bit, sa aducem unitatea logica  '1' inapoi pe linie ce va marca  sfarsitul transmisiei unei date. Protocolul ce tocmai l-am descris este numit in literatura profesionala NRZ (Non-Return to Zero).

Fig.1.1.5

Pentru ca aven linii separate de receptie si de transmitere, este posibil sa receptionam si sa transmitem date (informatii) in acelasi timp. Blocul ce permite acest mod de comunicare este numit blocul de comunicare seriala. Spre deosebire de transmisia paralela, datele sunt mutate aici bit cu bit, sau intr-o serie de biti, de unde vine si numele de comunicatie seriala. Dupa receptia de date trebuie sa le citim din locatia de transmisie si sa le inmagazinam in memorie in mod opus transmiterii unde procesul este invers. Datele circula din memorie prin bus catre locatia de trimitere, si de acolo catre unitatea de receptie conform protocolului.

Unitatea de timer

Acum ca avem comunicatia seriala , putem receptiona , trimite si procesa date.

Fig.1.1.6

Watchdog-ul

Inca un lucru ce necesita atentia noastra este functionarea fara defecte a microcontrolerului in timpul functionarii. Sa presupunem ca urmare  a unei anumite interferente (ce adesea se intampla in industrie) microcontrolerul nostru se opreste din executarea programului, sau si mai rau, incepe sa functioneze incorect.

Fig.1.1.7

Bineanteles, cand aceasta se intampla cu un computer, il resetam pur si simplu si va continua sa lucreze. Totusi, nu exista buton de resetare pe care sa apasam in cazul microcontrolerului care sa rezolve astfel problema noastra. Pentru a depasi acest obstacol, avem nevoie de a introduce inca un bloc numit watchdog-cainele de paza. Acest bloc este de fapt un alt contor liber unde programul nostru are nevoie sa scrie un zero ori de cate ori se executa corect. In caz ca programul se 'intepeneste', nu se va mai scrie zero, iar contorul se va reseta singur pana la obtinerea valorii sale maxime. Aceasta va duce la rularea programului din nou, si corect de aceasta data pe toata durata. Acesta este un element important al fiecarui program ce trebuie sa fie fiabil fara supravegherea omului.

Convertorul Analog-Digital

Pentru ca semnalele de la periferice sunt substantial diferite de cele pe care le poate intelege (zero si unu), ele trebuie convertite intr-un mod care sa fie inteles de microcontroler. Aceasta sarcina este indeplinita de un bloc pentru conversia analog-digitala sau de un convertor AD. Acest bloc este responsabil pentru convertirea unei informatii despre o anumita valoare analoga intr-un numar binar si pentru a o urmari pe tot parcursul la un bloc CPU asa ca blocul CPU sa o poata procesa.

Fig.1.1.8

Astfel microcontrolerul este acum terminat, si tot ce mai ramane de facut este de a-l pune intr-o componenta electronica unde va accesa blocurile interioare prin pinii acestei componente. Imaginea de mai jos arata cum arata un microcontroler in interior.

Fig.1.1.9.Cofiguratia fizica a interiorului unui microcontroler

Liniile subtiri ce merg din interior catre partile microcontrlerului reprezinta fire conectand blocurile interioare cu pinii capsulei microcontrolerului. Schema urmatoare reprezinta sectiunea centrala a microcontrolerului.

Fig.1.1.10

Pentru o aplicatie reala, un microcontroler singur nu este de ajuns. Inafara de microcontroler, avem nevoie de un program pe care sa-l execute, si alte cateva elemente ce constituie o interfata logica catre elementele de stabilizare (ce se va discuta in capitolele urmatoare).

Programul

Scrierea programului este un domeniu special de lucru al microcontolerului si este denumit 'programare'. Sa incercam sa scriem un mic program ce il vom crea singuri si pe care oricine va fi in stare sa-l inteleaga.

START
REGISTER1=MEMORY LOCATION_A
REGISTER2=MEMORY LOCATION_B
PORTA=REGISTER1 + REGISTER2

END

Programul adauga continuturile a doua locatii de memorie, si vede totalul lor la portul A. Prima linie a programului este pentru mutarea continuturilor locatiei de memorie 'A' intr-unul din registri unitatii centrale de procesare. Pentru ca avem nevoie si de celelalte date de asemenea, le vom muta de asemenea in celalalt registru al unitatii centrale de procesare. Urmatoarea instructiune instruieste unitatea centrala de procesare sa adauge continuturile celor doi registri sa sa trimita un rezultat obtinut la portul A, incat suma acestei adaugari sa fie vizibila pentru toata lumea de afara. Pentru o problema mai complexa, programul care sa lucreaze la rezolvarea ei va fi mai mare.

Programarea poate fi facuta in catava limbaje ca Assembler, C si Basic care sunt cele mai folosite limbaje. Assembler apartine limbajelor de nivel scazut ce sunt programate lent, dar folosesc cel mai mic spatiu in memorie si da cele mai bune rezultate cand viteza de executie a programului se are in vedere. Pentru ca este cel mai folosit limbaj in programarea microcontrolerelor va fi discutat intr-un capitol ulterior. Programele in limbajul C sunt mai usor de scris, mai usor de inteles, dar sunt mai lente in executare decat programele in Assembler. Basic este cel mai utor de invatat, si instructiunile sale sunt cele mai aproape de modul de gandire a omului, dar ca si limbajul de programare C este de asemenea mai lent decat Assembler-ul. In orice caz, inainte de a va hotari in privinta unuia din aceste limbaje trebuie sa studiati cu atentie cerintele privind viteza de executie, marimea memoriei si timpul disponibil pentru asamblarea sa.

Dupa ce este scris programul, trebuie sa instalam microcontrolerul intr-un aparat si sa-l lasam sa lucreze. Pentru a face aceasta  trebuie sa adaugam cateva componente externe necesare pentru functionarea sa. Mai intai trebuie sa dam viata microcontrolerului prin conectarea sa la o sursa (tensiune necesara pentru operarea tuturor instrumentelor electronice) si un oscilator a carui rol este similar inimii din corpul uman. Bazat pe ceasul sau microcontrolerul executa instructiunile programului. Indata ce este alimentat microcontrolerul va executa un scurt control asupra sa, se va uita la inceputul programului si va incepe sa-l execute. Cum va lucra aparatul depinde de multi parametri, cel mai important fiind priceperea dezvoltatorului de hardware, si de expertiza programatorului in obtinerea maximului din aparat cu programul sau.

Microcontrolerul PIC16F84

PIC16F84 apartine unei clase de microcontrolere de 8 biti cu arhitectura RISC. Structura lui generala este aratata in schita urmatoare reprezentand blocurile de baza.

Memoria program (FLASH)-pentru inmagazinarea unui program scris. Pentru ca memoria ce este facuta in tehnologia FLASH poate fi programata si stearsa mai mult decat odata, aceasta face microcontrolerul potrivit pentru dezvoltarea de componenta.

EEPROM-memorie de date ce trebuie sa fie salvate cand nu mai este alimentare. Este in mod uzual folosita pentru inmagazinarea de date importante ce nu trebuie pierdute daca sursa de alimentare se intrerupe dintr-o data. De exemplu, o astfel de data este o temperatura prestabilita in regulatoarele de temperatura.  Daca in timpul intreruperii alimentarii aceasta data se pierde, va trebui sa facem ajustarea inca o data la revenirea alimentarii. Asfel componenta noastra pierde in privinta auto-mentinerii.

RAM-memorie de date folosita de un program in timpul executarii sale. In RAM sunt inmagazinate toate rezultatele intermediare sau datele temporare ce nu sunt cruciale la intreruperea sursei de alimentare.

PORTUL A si PORTUL B sunt conexiuni fizice intre microcontroler sin lumea de afara. Portul A are 5 pini, iar portul B are 8 pini.

TIMER-ul LIBER este un registru de 8 biti in interiorul microcontrolerului ce lucreaza independent de program. La fiecare al patrulea impuls de ceas al oscilatorului isi incrementeaza valoarea lui pana ce atinge maximul (255), si apoi incepe sa numere tot din nou de la zero. Dupa cum stim timpul exact dintre fiecare doua incrementari ale continutului timer-ului, poate fi folosit pentru masurarea timpului ce este foarte util la unele componente.

Unitatea cerntrala de prelucrare are rolul unui element de conectivitate intre celelalte blocuri ale microcontrolerului. Coordoneaza lucrul altor blocuri si executa programul utilizatorului.

Fig.1.1.11

CISC, RISC

S-a spus deja ca PIC1684 are o arhitectura RISC. Acest termen este adeseori gasit  in literatura despre computere, si are nevoie sa fie explicat aici mai in detaliu. Arhitectura Harvard este un concept mai nou decat von-Neumann`s.   S-a nascut din nevoia de marire a vitezei microcontrolerului. In arhitectura Harvard, bus-ul de date bus-ul de adrese sunt separate. Astfel un mare debit de date este posibil prin unitatea de procesare centrala, si bineinteles, o viteza mai mare de lucru. Separand  un program de memoria de date face posibil ca mai departe instructiunile sa nu trebuiasca sa fie cuvinte de 8 biti. PIC16F84 foloseste 14 biti pentru instructiuni ceea ce permite ca toate instructiunile sa fie instructiuni de un cuvant. Este de asemenea tipic pentru arhitectura Harvard sa aiba mai putine instructiuni decat von-Newmann si sa aiba instructiuni executate uzual intr-un ciclu.

Microcontrolerele cu arhitectura Harvard sunt de asemenea numite 'microcontrolere RISC'. RISC inseamna Reduced Instruction Set Computer. Microcontrolerele cu arhitectura von-Newmann sunt numite 'microcontrolere CISC'. Titlul CISC inseamna Complex Instruction Set Computer.

Pentru ca PIC16F84 este un microcontroler RISC, aceasta inseamna ca are un set redus de instructiuni, mai precis 35 de instructiuni (de ex. microcontrolerele INTEL si Motorola au peste 100 de instructiuni). Toate aceste instructiuni sunt executate intr-un ciclu cu exceptia instructiunilor jump si branch. Conform cu ceea ce spune constructorul, PIC16F84 ajunge la rezultate de 2:1 in compresia cod si 4:1 in viteza in comparatie cu alte microcontrolere de 8 biti din clasa sa.

Aplicatii :

PIC16F84 se potriveste perfect in multe folosinte, de la industriile auto si aplicatiile de control casnice la instrumentele industriale, senzori la distanta, manere electrice de usi si dispozitivele de securitate. Este de asemenea ideal pentru cardurile smart ca si pentru aparatele alimentate de baterie din cauza consumului lui mic.

Pic16F84, un microcontroller de 8 biti cu un set restrins de vre-o 34 de instructiuni, cu arhitectura de tip RISC (una, maxim  doua instructiuni pe tact ) impreuna cu un programator si un compilator ( si un simulator ) devine o jucarie extrem de interesanta pentru un electronist obisnuit cu proiectarea CMOS sau TTL. Memoria EEPROM face mai usoara aplicarea microcontrolerelor la aparate unde se cere inmagazinarea permanenta a diferitor parametri (coduri pentru transmitatoare, viteza motorului, frecventele receptorului, etc.). Costul scazut , consumul scazut, manuirea usoara si flexibilitatea fac PIC16F84 aplicabil chiar si in domenii unde microcontrolerele nu au fost prevazute inainte (exemple:functii de timer, inlocuirea interfetei in sistemele mari, aplicatiile coprocesor, etc.) Programabilitatea sistemului acestui cip (impreuna cu folosirea a doar doi pini in transferul de date) face posibila flexibilitatea produsului, dupa ce asamblarea si testarea au fost terminate. Aceasta capabilitate poate fi folosita pentru a crea productie pe linie de asamblare, de a inmagazina date de calibrare disponibile doar dupa testarea finala, sau poate fi folosit pentru a imbunatati programele la produse finite.

Ciclul de clock / instructiune : clock-ul este un semnal periodic dreptunghiular generat de un oscilator cu frecventa stabila. Clock-ul de la oscilator intra intr-un microcontroler prin pinul OSC1 unde circuitul intern al unui microcontroler divide clock-ul in 4 clock-uri egale Q1,Q2,Q3 si Q4 ce nu se suprapun. Aceste 4 clock-uri constituie un ciclu de o singura instructiune (numit de asemenea ciclu masina) in timpul careia o instructiune este executata.

Executarea instructiunii incepe prin apelarea unei instructiuni care este urmatoarea in linie. Instructiunea este apelata din memoria program la fiecare Q1 si este scrisa in registrul de instructiuni la Q4. Decodarea si executarea instructiunii sunt facute intre urmatoarele cicluri Q1 si Q4. In urmatoarea diagrama putem vedea relatia dintre ciclul instructiunii si clock-ul oscilatorului (OSC1) ca si aceea a clock-urilor interne Q1-Q4. Contorul de program (PC) retine informatia despre adresa urmatoarei instructiuni.

Fig.1.1.12

Pipelining

Ciclul de instructiuni consta din ciclurile Q1, Q2, Q3 si Q4. Ciclurile de instructiuni de apelare si executare sunt conectate intr-un asa fel incat pentru a face o apelare, este necesar un ciclu cu o instructiune, si este nevoie de inca una pentru decodare si executare. Totusi, datorita pipeline-ului sau liniei directe, fiecare instructiune este efectiv executata intr-un singur ciclu. Daca instructiunea cauzeaza o schimbare in contorul programului, si PC-ul nu directioneaza spre urmatoarea ci spre alte adrese (poate fi cazul cu subprogramele jumps sau de apelare), 2 cicluri sunt necesare pentru executarea unei instructiuni. Aceasta este pentru ca instructiunea trebuie procesata din nou, dar de data aceasta din partea adresei corecte. Ciclul incepe cu clock-ul Q1, prin scrierea intr-un registru (IR). Decodarea si executarea incepe cu clock-urile Q2, Q3 si Q4.

Fig.1.1.13

TYCO citeste instructiunea MOVLW 55h (nu are importanta pentru noi ce instructiune a fost executata, ce explica de ce nu este un dreptunghi in partea de jos).
TCYI executa instructiunea MOVLW 55h si citeste MOVWF PORTB.
TCY2 executa MOVWF PORT si citeste CALL SUB_1.
TCY3 executa o apelare a unui subprogram CALL SUB_1, si citeste instructiunea BSF PORTA, BIT3. Pentru ca instructiunea aceasta nu este aceea de care avem nevoie, sau nu este prima instructiune a unui subprogram SUB_1 a carui executie este urmatoarea in ordine, instructiunea trebuie citita din nou. Acesta este un bun exemplu a unei instructiuni avand nevoie de mai mult de un ciclu.
TCY4 ciclul instructiunii este total folosit pentru citirea primei instructiuni dintr-un subprogram la adresa SUB_1.
TCY5 executa prima instructiune dintr-un subprogram SUB_1 si citeste urmatoarea.

Semnificatia pinilor

PIC16F84 are un numar total de 18 pini. Cel mai adesea se gaseste intr-o capsula de tip DIP18 dar se poate gasi de asemenea si intr-o capsula SMD care este mai mica ca cea DIP. DIP este prescurtarea de la Dual In Package. SMD este prescurtarea de la  Surface Mount Devices sugerand ca gaurile pentru pini unde sa intre acestia , nu sunt necesare in lipirea acestui tip de componenta.

Fig.1.1.14

Pinii microcontrolerului PIC16F84 au urmatoarea semnificatie:

Pin nr.1 RA1 Al doilea pin la portul A. Nu are functie aditionala.
Pin nr.2 RA2 Al treilea pin la portul A. Nu are functi aditionala.
Pin nr.3 RA3 Al patrulea pin la portul A. TOCK1 care functioneaza ca timer se gaseste de asemenea la acest pin
Pin nr.4 MCLR Reseteaza intrarea si tensiunea de programare Vpp a microcontrolerului.
Pin nr.5 VSS Alimentare, masa.
Pin nr.6 RBO Pin de zero la portul B. Intrarea intrerupta este o functie aditionala.
Pin nr.7 RB1 Primul pin la portul B. Nu are functie aditionala.
Pin nr.8 RB2 Al doilea pin la portul B. Nu are functie aditionala.
Pin nr.9 RB3 Al treilea pin la portul B. Nu are functie aditionala.
Pin nr.10 RB4 Al patrulea pin la portul B.Nu are functie aditionala.
Pin nr.11 RB5 Al cincilea pin la portul B.  Nu are functie aditionala.
Pin nr.12 RB6 Al saselea pin la portul B. Linia de 'Clock' in mod programare.
Pin nr.13 RB7 Al saptelea pin la portul B. Linia 'Data' in mod programare.
Pin nr.14 Vdd Polul pozitiv al sursei.
Pin nr.15 OSC2 Pin desemnat pentru conectarea la un oscilator
Pin nr.16 OSC1 Pin desemnat pentru conectarea la un oscilator
Pin nr.17 RA2 Al doilea pin la portul A. Nu are functie aditionala.
Pin nr.18 RA1 Primul pin la portul A. Nu are functie aditionala.

1.2 Bobina. Metode de masurare a bobinei

Bobinajele se executa din materiale care se caracterizeaza prin conductivitate electrica ridicata, printr-o rezistenta mecanica suficienta, precum si prin rezistenta la eroziune chimica.Materialul cel mai des folosit in calitate de conductor este cuprul, care are conductivitate electrica foarte buna si nu prezinta dificultati la prelucrarea tehnologica.Conductoarele din aluminiu se folosesc numai pentru bobinele instalatiilor de putere.Suportul, pe care se infasoara conductorul bobinei, trebuie sa permita bobinarea usoara, efectuarea cu usurinta a conexiunilor, fixarea simpla si montarea comoda a miezului magnetic, prezentand in acelasi timp o rezistenta mecanica satisfacatoare.

Calculul inductivitatii

Calculul inductivitatii se face anterior realizarii bobinei, in general cu formule semiempirice.

-pentru bobine fara miez,cu un singur strat,spira langa spira:

L0= [μH]     (1.2.1)

d este diametrul mediu al bobinei in mm, l este lungimea in mm,iar n numarul de spire.

-pentru bobine cu mai multe straturi:

L0= [μH] (1.2.2)

d este diametrul mediu al bobinei in mm, l -lungimea in mm,h-inaltimea bobinei in mm.

Miezuri magnetice

Pentru obtinerea inductivitatilor de valori mari,infasurarea bobinei se dispune pe miezuri magnetice.Miezul magnetic impreuna cu eventualele intrefieruri formeaza un circuit magnetic care are calitatea de a concentra aproape integral liniile campului magnetic.

Ciclul histerezis

Materialele magnetice utilizate pentru miezurile bobinelor sunt neliniare din punctul de vedere al comportarii in camp magnetic exterior.Neliniaritatea se exprima prin dependenta inductieie magnetice B de intensitatea campului magnetic H, printr-o functie neliniara.Crescand intensitatea H a campului magnetic, inductia magnetica B creste, tinzand catre valoarea de saturatie B.

Atomii materialelor magnetice avand moment magnetic propiu, iar momentele atomice vecine fiind orientate identic, se formeaza domenii cu magnetizare spontana.Pe ansamblu, domeniile sunt astfel orientate, incat materialul prezinta magnetizare remanenta.La aplicarea unui camp magnetic exterior apare o deplasare a domeniilor magnetice, ceea ce macroscopic se manifesta printr-o dependenta de tip histerezis a inductiei magnetice B, de intensitate H a campului magnetic.Din punct de vedere al orientarii momenteleor magnetice atomice, materialele pot fi feromagnetice sau ferimagnetice.Feromagneticele au momentele magnetice elementare orientate toate in acelasi sens.Materialele ferimagnetice au in structura lor doua sau mai multe subretele magnetice, avand fiecare magnetizare spontana, momentele magnetice fiind orientate in sens contrar, dar unul dintre momente este mai mare in valoare absoluta.Magnetizarea spontana exista numai pana la o anumita temperatura T, numita temperatura Curie,a carei valoare depinde de material.Dupa depasirea temperaturii T energia termica a retelei depaseste energia interactiunii de schimb, domenile de magnetizare dispar, materialul fiind paramagnetic.Din punct ce vedere al ciclului de histerezis, materialele magnetice pot fi moi (cu campul coercitiv H<80A/m,permeabilitate mare, pierderi mici) sau dure (H>80A/m, pierderi mari, dar cu energie mare in intrefier).

Permeabilitatea magnetica

Interactiunea substantei cu campul magnetic este caracterizata de permeabilitatea complexa relativa:

= μ'-j μ'' (1.2.3)

B -inductia magnetica;

H-intensitaea campului magnetic;

μ =4π*10-7 -permeabilitatea vidului;

O bobina ideala, avand in vid inductivitatea L0, in care se introduce un miez magnetic de permeabilitate relativa complexa μ, pentru flux de scapari nul prezinta la borne impedanta:

Z=jωL= jωL0 μ = jω μ'L0 + μ'' ωL0=rm+ jωL (1.2.4)

Bobinele utilizate in echpamente electronice au miezurile realizate din materiale feromagnetice moi.

Inductivitatea bobinei

In cazul bobinelor cu miez inductivitatea este

L= μ efL0    (1.2.5)

Unde L0 este inductivitatea bobinei fara miez, iar μ este permeabilitatea efectiva a miezului, dependenta de permeabilitatea relativa, a materialului miezului, de geometrie si pozitia relativa a miezului fata de bobinaj. Permeabilitatea efectiva se poate calcula numai pentru anumite geometri, de regula se detremina experimental.

Parametrii bobinei

Fig.1.2.1

Parametrul caracteristic al unei bobine este inductivitatea L, definita ca raportul dintre fluxul magnetic propriu sigma si curentul I ce strabate bobina:

L=Ф/I (1.2.6)

Acesta este o marime specifica a bobinei, depinzand numai de forma, dimensiunile si numarul de spire al bobinei, precum si de permeabilitatea relativa a mediului. Pentru bobine dispuse in medii liniare si izotrope, L este constant.In cazul bobinelor cu miez magnetic inductivitatea variaza in functie de semnalul aplicat, datorita permeabilitatii relative cu intensitatea curentului ce strabate bobina.In functinarea cu semnal mic, permeabilitatea relativa este constanta.In functionarea cu semnal mare, inductivitatea variaza in limite largi si trebuie definita fie o inductivitate medie,fie o inductivitate pentru o anumita valoare a curentului.

Valoarea inductivitatii este usor dependenta si de temperatura de lucru atat prin dependenta inductivitatii relative de temperatura cat si prin modificarea dimensiunilor fizice ale bobinei la variatii mari de temperatura.

Un alt parametru al bobinei este rezistenta sa de pierderi r.Fiecare spira a bobinei comporta ca o rezistenta de pierderi in conductor r'e, si o rezistenta de pierderi in materialul magnetic r. Care inglobeaza atat pierderile datorite curentilor turbionari in miezul magnetic,al caror efect este proportional cu patratul frecventei de lucru,cat si pierderile prin histerezis al caror efect este proportional cu f.Pierderile r'c si r'm pot fi echivalate cu o rezitenta in serie cu inductivitatea L' a spirei.In paralel cu grupul serie apare rezistenta de izolare r'p.

Considerand toate cele n spire identice, se poate considera bobina, intr-o prima aproximatie, ca o inductivitate L=nL' in serie cu rc=nr'c si rm=nr'm, tot grupul fiind in paralel cu rp=nr'p.Transpunand efectul rezistentei de izolatie in serie, efectul total de pierderi in bobina este exprimat prin rezistenta serie a bobinei r.Inductivitatea L caracterizeaza comportarea utila a bobinei, ca element pur raectiv, in timp ce r caracterizeaza pierderile de putere activa.

La fiecare frecventa de lucru se defineste pentru bobina, factorul sau de calitate, ca fiind proportional cu raportul dintre energie maxima inmagazinata in campul magnetic al bobinei si energia disipata sub forma de caldura, intr-o perioada.Ca urmare,factorul de calitate se determina din relatia:

QL (1.2.7)

Wmax-energia maxima acumulata in campul magnetic al bobinei

Wj0,r-energia disipata prin efect Joule in perioada 0,T

ωL-reactanta bobinei la frecventa corespunzatoare pulsatiei ω=2πf

r -rezistenta echivalenta pierderilor in bobina;

I -valoarea eficace a curentului prin bobina;

QL = (1.2.8)-factorul de calitate al bobinei

Un alt parametru al bobinei este capacitatea sa parazita.Aceasta se datoreste capacitatii parazite C12 dintre doua spire alaturate, care apare in paralel cu L' si r pe fiecare spira, si capacitatilor C10 si C20 ale fiecarei spire fata de masa.Efectul total al acestor capacitati se inglobeaza intr-o capacitate echivalenta parazita Cp, in paralel pe bobina.

Solicitarea bobinei reale in tensiune si curent in functie de tensiune si curent

Curentul ce strabate o bobina si repectiv tensiunea la bornele sale depind de reactanta bobinei XL= ωL, deci vor depinde de frecventa.Pentru a evita deteriorarea bobinei ca urmare unor solicitari electrice, curentul si tensiunea la borne nu trebuie sa depaseasca, in functie de frecventa de lucru, anumite limite.

-in domeniul frecventelor joase solicitarea bobinei se datoreste in principal curentului care da nastere unor forte mecanice de respingere intre spire .In acest domeniu tensiunea la borne creste liniar cu frecventa.Deci pentru a se evita distrugerea bobinei, curentul nu trebuie sa depaseasca valoarea maxima admisibila Imax.

-de la o anumita frecventa f1, apare pericolul de distrugere termica a bobinei, deci trebuie limitata puterea maxima pe care o poate disipa bobina :

Pd max=UI tg∂ (1.2.9)

Deci la frecventa f1 va exista relatia: Pd max 1Imax2Ltg∂ (1.2.10)

- pentru o anumita frecventa f2 in domeniul frecventelor inalte depasirea unei tensiuni limitaUmax este interzisa, pentru strapungerile intre spire, deci curentul va avea alta lege de variatie I= Umax/ ωL.

Pmax =   

In functie de frecventa apar deci trei domenii in care se impun succesiv restrictii asupra curentului in domeniul frecventelor joase, pana la frecventa critica f1, asupra puterii disipate in domeniul f1- f2 si asupra tensiunii la frecvente mai mari de frecventa critica f2. Frecventele critice satisfac relatia:

f1 f2= (

Zgomotul bobinelor

Zgomotul unei impedante se datoreste agitatiei termice a electronilor liberi, de conductie in interiorul impedantei respective.Acest zgomot este un zgomot de fluctuatie, energia sa depinzand de energia cinetica a electronilor liberi, la randul sau determinata de temperatura absoluta a impedantei, independent de regimul electric in care este utilizata aceasta.Bobinele cu pierderi mici se comporta bine din punct de vedere al zgomotului. O sursa de zgomot propiu-zisa o constituie vibratiile mecanice ale miezului din tole nestranse suficient. In general contributia zgomotului nu este importanta.

Fiabilitatea bobinelor

Bobinele sunt elemente cu siguranta in functionare relativ scazuta, defectiunile lor putand conduce si la defectarea altor piese cu care sunt conectate sau alaturi de care sunt montate. La randul lor insa, defectiunile bobinelor pot fi provocate de defectarea altor componente ale sistemului.Fiabilitatea bobinelor este destul de variata in functie de tipul bobinei, domeniul de utilizare, conditiile de constructie, modul de intretinere si exploatare, dar, orientativ rata de defectare poate fi considerata λ=0,01/1000 h.Cele mai frecvente defectiuni sunt intreruperea conductorului sau scurtcircuitul intre spire, temperaturi inalte ce conduc la strapungerea termica a izolatiei, temperaturi prea joase care favorizeaza strapungerea deoarece materialele de etansare pot crapa si astfel este posibila patrunderea umiditatii.Pentru cresterea sigurantei bobinelor se pot lua masuri inca din fabriactie din etapa de proiectare, alegand tipul de bobinaj si de izolatie corespunzator frecventelor si tensiunilor de lucru, tipul de conductor corespunzator puterilor dezvoltate in circuit.

Circuit oscilant serie

Circuitul scilant serie este un dipol pasiv format ditr-o bobina si un condensator, conectate in serie.Impedanta acestui circuit depinde mult de frecventa, ceea ce ii confera propietati selective.Astfel ea atinge un minim la frecventa la care modulul reactantei inductive devine egal cu modulul reactantei capacitive si tinde spre valori foarte mari in afara acestei frecvente.Ca urmare,daca circuitul se excita cu un generator ideal de tensiune, curentul din circuit va depinde mult de frecventa si va atinge maxim pronuntat la freventa de rezonanta, determinand deci o comportare a circuitului.Daca circuitul s-ar excita cu un generator de curent, curentul prin circuit va fi practic constant si independent de frecventa deoarece impedanta circuitului va fi practic constant si independent de frecventa deoarece impedanta circuitului este practic neglijabila, in raport cu rezistenta interna a generatorului. Deci propietatile selective ale circuitului se pierd.

Fig.1.2.2

Comportarea circuitului serie propriu-zis

Se cosidera generatorul de tensiune ideal adica Rg=0

Impedanta circuitului serie Zs, are expresia:

Rs=RL (1.2.13) -rezistenta de pierderi serie a circuitului;

Xs=ωL- (1.2.14) -reactanta circuitului serie;

ZS= -modulul impedantei circuitului serie;

φs=arc tg( (1.2.16) -argumentul impedantei circuitului serie.

Expresia curentului I care se stabileste prin circuit este:

Tensiunea UL,UC,UR de la bornele inductantei, condensatorului si rezistorului serie, au expresiile:

UL=jXLI=jωLI (1.2.17)

UC=jXcI=-()I (1.2.18)

UR=Rs*I (1.2.19)

Rezonanta circuitului serie

Fenomenul de rezonanta se produce la frecventa ω0 la care:

X(ω0)= ω0L- (1.2.20)

De unde se poate deduce expresia frecventei de rezonanta, f0, sub forma:

f0=   

Deci rezonanta are loc atunci cand frecventa tensiunii de excitatie, produsa de genaerator, coincide cu frecventa proprie de oscilatie a circuitului.La rezonanta, impedanta circuitului serie este minima si pur rezistiva:

Zs0)=Rs    (1.2.22)

Iar curentul prin circuit este maxim si in faza cu tensiune la bornele circuitului:

I(ω0)=

De asemenea la rezonanta, tensiunile la bornele inductantei si ale condesatorului sunt maxime, egale, in opozitie de faza si de Q ori mai mari decat tensiunea la bornele circuitului :

0L    

Din propietatile circuitului oscilanta serie aratate rezulta si posibiltatile de utilizare a acestuiu circuit ca circuit selectiv sau ca circuit de rejectie.

Q= =QL    (1.2.25)

Caracteristicile de frecventa normate.Banda de trecere la 3dB

x ωL- )=βQ (1.2.26)

Q-factorul de calitate a circuitului la frecventa de rezonanta;

Β- escartul de frecventa generalizat

Se observa ca pentru x =1,curentul scade la 0,7 din valoarea de la rezonanta,iar modulul impedantei creste de 1,41 ori fata de valoarea de la rezonanta.

N1[dB]=10log N2[dB]=20log   

N1[dB]-nivelul in decibeli pentru puteri

N2[dB]-nivelul in decibeli pentru tensiuni, curenti, impedante sau admitante.

P(ω)-puterea la frecventa ω;

P (ω0) -puterea de referinta;

K (ω)-marimea la frecventa ω;

K (ω0)-marimea de referinta;

Bobine de audiofrecventa

    Se utilizeaza pentru filtru de joasa frecventa (filtre de retea, drosele de alimentare etc. ) Au inductante ce pot ajunge la zeci de Henry. Se realizeaza in general pe miezuri magnetice inchise, in forma de tole sau oale. Tolele se realizeaza din materiale cu permeabilitate magnetica cat mai ridicata (otel cu siliciu, permalloy, ferite, etc.). O particularitate a acestor bobine o constituie dependenta inductantei fata de nivelul tensiunii alternative si continue aplicate, precum si fata de frecventa. Bobinajele se executa pe carcase avand forma miezului, folosind conductor de cupru emailat cu diametru corespunzator curentului care le strabate. In cazul cand sunt strabatute si de o componenta de c.c. se intrerupe circuitul magnetic printr-un intrefier, care imbunatateste comportarea miezului, dar reduce permeabilitatea

Banda de trecere la 3dB

Deoarece, asa cum rezulta din relatia pentru x =1 curentul prin circuit se reduce la 1/√2 din valoarea sa maxima, rezulta ca la frecventele la care x =1, curentul se reduce cu 3dB fata de valoarea sa maxima posibila.Prin definitie, diferenta acestor frecvente corespunzatoare lui x =1 se numeste banda de trecere a circuitului la 3dB.Marimea acestei benzi caracterizeaza propietatile selective ale circutului.Cu cat aceasta banda este mai ingusta,cu atat circuitul este mai selectiv.

Circuitul oscilant derivatie

Circuitul oscilant derivatie este un dipol pasiv format din doua componente pasive reale,o bobina si un condensator,conectate in derivatie.Excitarea sa trebuie facuta cu un generator cu rezistenta interna mare, deoarece un generator cu rezistenta mica va mentine practic constanta tensiunea la bornele circuitului, indiferent de frecventa, astfel ca propietatile selective ale circuitului se pierd. In figura de mai jos se prezinta schema unui circuit derivatie alimentat de un generator pentru a carui reprezentare s-a utilizat schema echivalenta cu generator de curent.Conductanta de pierderi derivatie

Fig.1.2.3

Gd=Gg+GL+GC (1.2.28)

Gg-conductanta interna derivatie a generatorului

GL-conductanta de pierderi derivatie a bobinei

GC-conductanta de pierderi derivatie a condensatorului.

Pentru Q10se poate arata GL=

Q0- factorul de calitate in gol al bobinei

RL-rezistenta de pierderi serie a bobinei

Rezonanta circuitului derivatie

Rezonanta se produce la frecventa ω0 la care:

Bd 0) = ω0 C- (1.2.30)

f0=   

La rezonanta, admitanta circuitului derivatie este minima(deci impedanta maxima) si are expresia:

Yd0)=Gd (conductanta pura) (1.2.32)

Iar tensiunea la bornele circuitului este maxima si in faza cu curentul de alimentare I:

U(ω0)=    

La rezonanta circuitului derivatie, curentii prin inductanta si capacitate sunt maximi, egali in modul, in opozitie de faza si de Q ori mai mari decat curentul total debitat de generator, I:

IL0)=Ic0)= ω0CU=QI (1.2.34)

Q= 0Crd= (1.2.35)

Rd= -rezistenta de pierderi derivatie a circuitului (1.2.36)

Q= -factor de calitate (1.2.37)

Caracteristicile de frecventa normate:

x= )=βQ    (1.2.38)

1.3 Afisaj LCD

Multe dispozitive cu microcontroler folosesc LCD-uri inteligente pentru a afisa informatia vizuala. Urmatorul material se ocupa de conectarea unui afisaj LCD Hitachi la un microcontroler PIC. Afisajele LCD proiectate cu HD44780, modulul pentru LCD fabricat de Hitachi, nu sunt scumpe si sunt usor de folosit, si chiar posibil sa produca verificarea datelor afisate folosind cei 8x80 pixeli ai afisajului. Afisajele LCD Hitachi contin un set de caractere ASCII plus simboluri japoneze, grecesti si matematice.

16x2 LCD Hitachi HD44780

Fiecare dintre cei 640 de pixeli ai afisajului trebuie sa poata fi accesat individual si aceasta se poate realiza cu un numar de integrate SMD pentru control montate pe spatele afisajului. Aceasta ne salveaza de o cantitate enorma de fire si de un control adecvat astfel incat sunt necesare doar cateva linii pentru a accesa afisajul. Putem comunica cu afisajul prin intermediul unui bus de date pe 8 biti sau de 4 biti. Pentru un bus de 8 biti, afisajul are nevoie de o tensiune de alimentare de +5v si 11 linii I/O. Pentru un bus de 4 biti sunt necesare doar liniile de alimentare si 7 linii. Cand afisajul LCD nu este pornit liniile de date sunt TRI-STATE, ceea ce inseamna ca ele sunt in stare de inalta impedanta (ca si cum ar fi deconectate) si astfel nu interfereaza cu functionabilitatea microcontrolerului cand afisajul nu este adresat. LCDul necesita de altfel 3 linii de control de la microcontroler.

Linia Enable (E) permite accesul la afisaj prin intermediul liniilor R/W si RS. Cand aceasta linie este LOW, LCDul este dezactivat si ignora semnalele de la R/W si RS. Cand linia (E) este HIGH, LCDul verifica starea celor doua linii de control si raspunde corespunzator.

Linia Read/Write (R/W) stabileste directia datelor dintre LCD si microcontroler. Cand linia este LOW, datele sunt scrise in LCD. Cand este HIGH, datele sunt citite de la LCD.

Cu ajutorul liniei Register select (RS), LCD interpreteaza tipul datelor de pe liniile de date. Cand este LOW, o instructiune este scrisa in LCD. Cand este HIGH, un caracter este scris in LCD.

Starea logica a liniilor de control:

E: - 0  Accesul la LCD dezactivat;

- 1  Accesul la LCD activate;

R/W: - 0  Scrie date in LCD;
        - 1 Citeste date din LCD;

RS: - 0 Instructiuni;
- 1 Caracter;

Scrierea datelor in LCD se realizeaza in cativa pasi:

- se seteaza bitul R/W LOW;
- se seteaza bitul RS in 0 sau 1 logic (instructiune sau caracter);
- se trimit datele catre liniile de date (daca se executa o scriere);
- se seteaza linia E HIGH;
- se citesc datele de la liniile de date (daca se executa o citire).

Citirea datelor de la LCD se realizeaza similar, cu deosebirea ca linia de control R/W trebuie sa fie HIGH. Cand trimitem un HIGH catre LCD, el se va reseta si va accepta instructiuni. Instructiunile tipice care sunt transmise catre un afisaj LCD dupa reset sunt: pornirea afisajului, activarea cursorului si scrierea caracterelor de la stanga spre dreapta. In momentul in care un LCD este initializat, el este pregatit sa primeasca date sau instructiuni. Daca receptioneaza un caracter, el il va afisa si va muta cursorul un spatiu la dreapta. Cursorul marcheaza locatia urmatoare unde un caracter va fi afisat. Cand dorim sa scriem un sir de caractere, mai intai trebuie sa setam adresa de start, si apoi sa trimitem cate un caracter pe rand. Caracterele care pot fi afisate pe ecran sunt memorate in memoria video DD RAM (Data Display RAM). Capacitatea memoriei DD RAM este de 80 bytes.

Afisajul LCD mai contine 64 bytes CG RAM ( Character Generator RAM). Aceasta memorie este rezervata pentru caracterele definite de utilizator. Datele din CG RAM sunt reprezentate sub forma de caractere bitmap de 8 biti. Fiecare caracter ocupa maxim 8 bytes in CG RAM, astfel numarul total de caractere pe care un utilizator poate sa le defineasca este 8. Pentru a afisa caracterul bitmap pe LCD, trebuie setata adresa CG RAM la punctul de start (de obicei 0) si apoi sa fie scrise datele in afisaj. Definirea unui caracter ,special' este exemplificata in figura.

Fig.1.3.1

Inainte de a accesa DD RAM, dupa definirea unui caracter special, programul trebuie sa seteze adresa in DD RAM. Orice scriere si citire a datelor din memoria LCD este realizata de la ultima adresa care a fost setata, folosind instructiunea set-adress. Odata ce adresa DD RAM este setata, un caracter nou va fi afisat in locul potrivit pe ecran. Pana acum am discutat operatia de scriere si citire a memoriei unui LCD ca si cum ar fi o memorie obisnuita. Acest lucru nu este adevarat. Controlerul LCD are nevoie de 40 pana la 120 microsecunde (us) pentru scriere si citire. Alte operatii pot dura pana la 5 ms. In acest timp microcontrolerul nu poate accesa LCDul, astfel un program trebuie sa stie cand un LCD este ocupat. Putem rezolva aceasta in doua metode.

Fig.1.3.2

O metoda este verificarea bitului BUSY de pe linia de date D7. Aceasta nu este cea mai buna metoda pentru ca LCDul se poate bloca si programul va sta intr-o bucla infinita verificand bitul BUSY. O alta metoda este introducerea unei intarzieri in program. Intarzierea trebuie sa fie destul de lunga pentru ca LCDul sa termine operatia in desfasurare. Instructiunile pentru scriere si citire cu memoria LCDului sunt afisate mai sus. La inceput am mentionat ca avem nevoie de 11 linii I/O pentru a comunica cu un LCD. Oricum, putem comunica cu un LCD printr-un bus de 4 linii. Putem reduce numarul total de linii de comunicatie la 7. Schema pentru conectarea printr-un bus de 4 biti este in imaginea de mai jos. In acest exemplu folosim un afisaj LCD cu 2x16 caractere, denumit LM16x212 fabricat de producatorul japonez Sharp. Mesajul ,character' este scris pe prima linie urmat de doua caractere speciale ,~' si ,}'. Pe a doua linie este scris cuvantul ,mikroElektronika'.

Fig.1.3.3 Conectarea unui afisaj la un microcontroler

Metode de programare a microcontrolerului

Abilitatea de a comunica este de mare importanta in orice domeniu. Totusi, este posibila numai daca amandoi partenerii de comunicare cunosc acelasi limbaj, sau urmaresc aceleasi reguli in timpul comunicarii. Folosind aceste principii ca un punct de plecare, putem de asemenea defini comunicarea ce are loc intre microcontrolere si om. Limbajul pe care microcontrolerul si omul il folosesc pentru a comunica este numit 'limbaj de asamblare'. Titlul insusi nu are un inteles deosebit, si este analog numelor altor limbaje, de ex. engleza si franceza. Mai precis, 'limbajul de asamblare' este doar o solutie trecatoare. Programele scrise in limbaj de asamblare trebuie traduse intr-un 'limbaj de zero-uri si unu-uri' pentru ca un microcontroler sa-l inteleaga. 'Limbajul de asamblare' si 'assembler-ul' sau asamblorul sunt doua notiuni diferite. Primul reprezinta un set de reguli folosite in scrierea unui program pentru un microcontroler, iar celalalt este un program in computerul personal care traduce limbajul de asamblare intr-un limbaj de zero-uri si unu-uri. Un program ce este tradus in 'zero-uri' si 'unu-uri' este numit 'limbaj masina'.

Fig.1.3.4

Fizic, 'Program' reprezinta un fisier pe discul computerului (sau in memorie daca este citit intr-un microcontroler), si este scris conform cu regulile de asamblare sau ale altui limbaj pentru programarea microcontrolerului.  Omul poate intelege pentru ca este constituit din semne si cuvinte ale alfabetului. Cand se scrie un program, trebuie urmarite unele reguli pentru a se obtine un  efect dorit. Un Translator interpreteaza fiecare instructiune scrisa in limbajul de asamblare ca o serie de zero-uri si unu-uri ce au o semnificatie pentru logica interna a microcontrolerului.

 Sa luam de exemplu instructiunea 'RETURN' pe care microcontrolerul o foloseste pentru a se intoarce dintr-un sub-program.

Cand asamblorul il traduce, obtinem o serie de zero-uri si unu-uri pe care microcontroleul stie cum sa-l interpreteze.

Exemplu RETURN 00 0000 0000 1000

Similar propozitiei de mai sus, fiecare instructiune de asamblare este interpretata ca si corespunzand unei serii de zero-uri si unu-uri.

Locul unde aceasta traducere a limbajului de asamblare se gaseste , se numeste un fisier de  'executie'. Vom intalni adesea numele de fisier 'HEX'. Acest nume vine de la o reprezentare hexazecimala a acelui fisier, ca si de la apendicele 'hex' din titlu, de ex. 'run through.hex'. Odata ce este generat, fisierul de executie este citit in microcontroler printr-un programator.

Limbaj de Asamblare

Elementele de baza ale limbajului de asamblare sunt:

  • Label-uri sau Etichete
  • Instructiuni
  • Operanzi
  • Directive
  • Comentarii

Eticheta

Un Label este o desemnare textuala (in general un cuvant usor de citit) pentru o linie intr-un program, sau sectiunea unui program unde micro-ul poate sari - sau chiar inceputul unui set de linii a unui program. Poate fi folosit de asemenea pentru a executa ramificare de program (ca Goto...) si programul poate chiar avea o conditie ce trebuie indeplinita pentru ca  instructiunea Goto sa fie executata. Este important pentru un label de a incepe cu o litera a alfabetului sau cu o subliniere '_'. Lungimea label-ului poate fi de pana la 32 caractere. Este de asemenea important ca un label sa inceapa de la primul rand.

Fig.1.3.5

Instructiuni

Instructiunile sunt deja definite prin folosirea unui microcontroler specific, asa ca ne ramane doar sa urmam instructiunile pentru folosirea lor in limbajul de asamblare. Modul in care scriem o instructiune mai este numit 'sintaxa' instructiunii. In exemplul urmator putem recunoaste o greseala in scriere pentru ca instructiunile movlp si goto nu exista pentru microcontrolerul PIC16F84.

Operanzi

Operanzii sunt elemente ale instructiunii pentru instructiunea ce este executata. Ei sunt de obicei registri sau variabile sau constante. Constantele sunt numite 'literal-e'. Cuvantul literal inseamna 'numar'.

Comentarii

Comentariul este o serie de cuvinte pe care programatorul le scrie pentru a face programul mai clar si mai usor de citit. Se plaseaza dupa o instructiune , si trebuie sa inceapa cu punct si virgula';'.

Directive

O directiva este similara unei instructiuni, dar spre deosebire de o instructiune este independenta de modelul microcontrolerului, si reprezinta o caracteristica a limbajului de asamblare insusi. Directivelor le sunt date uzual intelesuri de scop prin variabile si registri. De exemplu, LEVEL poate fi o desemnatie pentru o variabila in memoria RAM la adresa 0Dh. In felul acesta, variabila la acea adresa poate fi accesata prin desemnatia LEVEL. Aceasta este mult mai usor pentru un programator sa inteleaga decat sa incerce sa-si aduca aminte ca adresa 0Dh contine informatii despre LEVEL.

Cap. 2 Partea tehnica

2.1 Schema bloc

Schema bloc a L - metrului este formata din :

Fig. 2.1.1 Schema bloc a L-metrului

Principiul de masurare este prezentat in figura 2.2.2.

Acest bloc este format din :

-2 oscialtoare OSC1,OSC2 care au frecventa de oscilatie dependenta de inductanta bobinei masurata dupa relatia L=

un formator de semnal TTL (cu trigher smith) care preia semnalul generat de oscilatorul OSC2 si genereaza la iesire un semnal de nivel TTL. Pentru OSC1 nu este necesar un oscilator de semnal intrucat LM339 genereaza direct semnal TTL.

-2 divizoare de frecventa sunt de 4 respectiv 256 cu rolul de a micsora frecventa semnalului masurat astefel incat sa fie mult mai mica decat frecventa de functionare a picului astfel incat sa fie mult mai mare Tx>Tref

- un multiplexor care selecteaza in functie de semnalul RA1 ,unul din semnalele S1 sau S2

- un microcontroler care are rolul de a detecta o perioada din semnalulu al carei frecventa se masoara pe baza formulei L=. Si comada afisajul LCD in vederea afisarii valorii L.

-un comutator K1 care permite schimabarea gamei de masura.LED-ul indicand in ce gama ne aflam.Daca LED-ul este aprins ne aflam in gama 100nH < L < 5 μH iar daca Led-ul este stins se masoara in gama

2.2 Blocul oscilator

Blocul oscilator de joasa frecventa LM339:

Fig.2.2.1

Lx,C1 impune frecventa de oscilatie a oscilatorului.

fx= (2.2.1)

Rx-rezistenta serie a bobinei

Experimental s-a constat ca oscilatorul functioneaza stabil daca Rx<5.

Condensatorul C2 este un condensator de cuplaj al circuitului oscilant derivatie cu etajul comparator.Iar R1 si R2 se aleg astfel incat intrarea neinversoare a comaparatorului sa fie polarizata static la o valoare de

Valoarea lor trebuie sa suficient de mare pentru a nu amortiza curentul acordat derivatiei.

Din catalog R1-R2=100K

Pentru a asigura un coeficient de variatie pozitiva mare adica un oscilator static alegem si R3=100K

Iesirea comparatorului este de tip open colector .

R5 se alege astfel incat curentul pe iesire sa fie mic.Alegem I0=5mA iar R5= =1K

Pentru a functiona stabil constanta de timp R4*C3>TX=

Se alege R4=47 K si stabilim fX>500Hz de unde avem TX=<= Tmax

Alegem C3 astfel incat R4*C3=100*Tmax de unde C3=

Se alege la fel si C2 iar C1=506nF astfel incat oscilatorul sa functioneze stabil in gama 1μH<Lx<250mH

Blocul oscilator de inalta frecventa cu FET

Fig.2.2.2

Schema bloc a unui oscilator este

Fig.2.2.3

Oscialtorul este un amplificator cu reactie pozitiva.

Conditia de oscilatie este x=1 (2.2.2)

1) conditia de amplitudine: x=1 (2.2.3)

2)conditia de faza: (2.2.4)

In schema amplificatorul este un etaj de amplificare cu transistor FET cu sarcina distributive.Reactia pozitiva este asigurata cu un amplificator cu inversor CMOS.Amplificatorul ce introduce un defazaj de iar iar inversoru in defazaj de deci de 2 si se indeplineste conditia de faza.

Pentru a se indeplinii si conditia de amplitudine este necesar:

Poarta CMOS sa fie polarizata in zona tensiuni de tranzitieVT cu ajutorul unei rezistenta R5care se determina experimental R5=1.5K

Fig.2.2.4 caracteristica de transfer a puntii CMOS

Polarizarea intrarii puntii CMOS aproape de VT =2.5V se realizeaza si prin reglajul rezistentei din schema FET.

Tranzistorul FET trebuie polarizat in regiunea de saturatie

Caracteristicile statice FET-ului sunt:

   

Fig.2.2.5 Fig.2.2.6

Fig.2.2.7

Id=ISS(1-)2 0<VGS<VT (2.2.5)

VGS=-IdxP2 (2.2.6)

Alegand un transistor FET BF256 cu VT=--3V si un curent Id=2mA se obtine P2=500 ohmi.

Si P1=4,7K care se regleaza astfel incat sa se indeplineasca conditia de amplitudine pentru a exista oscilatii.

Grupul R6siC4 se allege asfel incat impedanta cat mai putin decat a puntii Cmos sa influenteze cat mai putin Q (factorul de calitate) al circuitului acordat Lx,C5 si oscilatorul sa functioneze stabil.

Limitarea amplitudinii se face prin folosirea caracteristicii neliniare a tranzistorului cu efect de camp.

Rezultatele de simulare a acestei scheme in ORCAD sunt prezentate in fig..

Fig. 2.2.8 Rezultate de simulare pentru oscilatorul cu FET

2.3 Divizoarele de frecventa

Divizoarele de frecventa sunt realizate cu numaratoarele IC2, IC6 respectiv SN74LS393 . Schema interna a circuitului SN74LS393 este prezentata mai jos:

Fig.2.2.9 Shema interna a SN74LS393

Utilizarea divizoarelor de frecventa :IC2 este un divizor cu 4 respectiv IC6 divizor cu 256 sunt necesare pentru a micsora frecventa semnalului masurat.Durata unei instructiuni este de 0,5μs.Frecventa oscilatorului cu cuart care proiecteaza microcontrolerul este de 8Mhz .

Calculul frecventei de oscilatie

1.Cu oscilatorul de joasa frecventa(LM339)

f=; Kdiv=2 (2.2.7)

2.Cu oscilatorul de inalta frecventa(FET)

f=; Kdiv=256 (2.2.8)

2.4 Multiplexorul

Un dispozitiv care permite transferul unor fluxuri multiple de date printr-un mediu comun.

Fig.2.4.1

S1-semnalul generat de IC2 (pin4)

S2-semnalul generat de IC6 (pin8)

Tabelul de adevar asociat multiplexorului :

S1

S2

RA1

RB0

X

Selecteaza semnalul S1

X

X

Selecteaza semnalul S2

X

S1-semnalul generat de oscilatorul de joasa frecventa

S2-semnalul generat de oscilatorul de inalta frecventa

RA1

S1 S2

RB0=S1* +S2*RA1

Se implementeaza cu circuite SI-NU cu 2 intrari :

RB0=

RB0=

2.5 PIC 16F84

Functiile microcontrolerului

  • Initializarea si comanda a afisajul LCD 2X16 caractere;
  • Selecteaza gama de masura in functie de pozitia comutatorului;

K1 apasat:

RA0=0 -selecteaza gama de masura gama1:L = 100nH - 5μH;

K1 neapasat:

RA0=1 -se selecteaza gama de masura gama2:L=5μH - 500mH;

  • Semnalizeaza prin aprinderea LED-ului conectat la RA2 gama de masurat

-LED aprins gama1

-LED stins gama2

  • Selecteaza o perioada din semnalul generat de oscilatorul si aplicat apoi pe RB0;
  • Efectueaza calculele matematice in vederea obtinerii valorii inductantei si frecventei semnalului generat de oscillator;
  • Comanda afisajul LCD in vederea afisarii corecte a rezultatului.

Semnalul cu frecvente necunoscute Tx generat de oscilator este preluat la pinul RA0 de catre microcontrolerul care functioneaza in regim de intreruperi la pinul RB0 si la valori 0xFF a TMR0. Schema bloc echivalenta a uC este prezentata in figura..

Fig.2.5.1

Calculul inductantei

f0=*=    (2.5.1)

daca RL <<1;

RL-rezistenta bobinei;

-Factorul de calitate al bobinei la freecventa de rezonanta

Q=; ω0=    (2.5.2)

Impedanta la frecventa de rezonanta

Z0===Q*L* ω0=    (2.5.3)

Microcontrolerul calculeaza frecventa in 2 moduri in functie de oscilator.

1.Pentru oscilatorul de joasa frecventa(LM339)

Tx=2π→ Lx==*()2 (2.5.4)

Tx=n*TRef ; n-numarul de impulsuri masurate de microcontroler

TRef=1μs

Notam cu K

Alegand C=506nF (470nF+33nF)

K=200239,4934=2,00239493*105(F-1)

Lx=K ()2=K*()2=K*10-12()2 (2.5.5)

Lx=2*105*10-12*()2; (2.5.6) Lx=*10-7[H] (2.5.7)

In registrele TMRO, NUMB; NUMB2 se gaseste numarul ()in forma binara.

Kdiv=4 deoarece este dat de divizorul de frecventa

Microcontrolerul calculeaza iar de coeficientul 10-7 se tine cont cand face afisarea.

2.Pentru oscilatorul de joasa frecventa

Lx=*()2= (2.5.8)

TRef=1μs

Kdiv=256 deoarece este dat de divizorul cu 256

Lx=m*10-12*n2 (2.5.9)

Se alege condensatorul astfel incat m sa fie numar intreg.

-pentru m=100 se determina C=    (2.5.9)

C=3,865*10-9F=3.865 nF

Lx=m*10-2*n2=10-10*n2 (2.5.10)

Lx=10-10*n2 ; (2.5.11)

Microcontrolerul calculeaza n2 iar de coeficientul 10-10 se tine cont cand se face afisarea.

2.6 Initializare LCD

Schema logica a subrutinei de initializare a LCD-ului este


Fig.2.6.1

LCD

D777

D6666

D5

D4

En

R/W

RS

P2

15

14

13

12

11

10

9

Wait_15ms

0

0

1

1

0

0

0

0x3000

0

0

1

1

0

0

0

Enable

0

0

0

0

0

0

0

wait

wait 5ms

0

0

1

1

0

0

0

0x30

0

0

1

1

1

0

0

Enable

wait

0

0

1

1

0

0

0

wait

0

0

1

1

0

0

0

0x30

0

0

1

1

1

0

0

Enable

wait

0

0

1

1

0

0

0

wait

0

0

1

0

0

0

0

0x20

0

0

1

0

1

0

0

Enable

wait

0

0

1

0

0

0

0

wait

0

0

1

0

0

0

0

0x20

0

0

1

0

1

0

0

Enable

wait

0

0

1

0

0

0

0

wait

1

1

0

0

0

0

0

0xC0

wait

1

1

0

0

0

0

0

Enable

1

1

0

0

1

0

0

wait

1

1

0

0

0

0

0

wait

0

0

0

0

0

0

0

0x00

0

0

0

0

1

0

0

Enable

wait

0

0

0

0

0

0

0

wait

1

1

0

1

0

0

0

0xD0

1

1

0

1

1

0

0

Enable

wait

1

1

0

1

0

0

0

0

0

0

0

0

0

0

0x00

0

0

0

0

1

0

0

Enable

wait

0

0

0

0

0

0

0

wait

0

0

0

1

0

0

0

0x40

0

0

0

1

1

0

0

Enable

wait

0

0

0

1

0

0

0

wait

0

0

0

0

0

0

0

0x00

0

0

0

0

1

0

0

Enable

wait

0

0

0

0

0

0

0

wait

0

1

1

0

0

0

0

0X60

0

1

1

0

1

0

0

Enable

wait

0

1

1

0

0

0

0

wait

Fig.2.6.2

2.7 Schema logica a programului

Fig.2.7.1

Organigrama Programului PIC


Fig.2.7.2


Subrutina de calcul a frecventei


2.8 Sursa de alimentare

Schema electrica a sursei de alimentare

Pentru calculul transformatorului de retea se porneste de la marimile electrice,care se presupun cunoscute:

Up=220V

US=9V

IS=1A

Puterea din secundar se calculeaza astfel:

PS=US*IS

PS=9V*1A de unde PS=9VA

Puterea din primarul transformatorului este

PP=PS/n

PP=9VA/0.85

PP=10.6VA

Curentul din primar:

IP=PP/UP

IP=10.6/220

IP=50mA

Sectiunea miezului transformatorului este

S2=1.22* PP

S2=1.44*10.6

S2=4cm2

Se alege tipul de tole determinand parametrul a:

a2=4.72*S

a2=22.09*4

a=10mm

Grosimea pachetului de tole:

h=50*S/a

h=50*4/10

h=20mm

Numarul de spire pe volt:

n0=45/S

n0=11.24sp/V

Numarul de spire al infasurarilor transformatorului:

NP= n0*Up NP=2473sp

NS= n0*US NS=102sp

Diametrul conductoarelor transformatorului :

d2p=0.712*IP d2p=0.5*0.05 dp=0.15mm

d2s=0.712*IS d2S=0.5*1 dS=0.7mm

Deci primarul va avea 2473 spire cu sarma de Cu de 0.15mm,iar secundarul va avea 102 spire cu sarma de Cu de 0.7mm,bobinajul realizaduse pe o carcasa cu sectiunea de 4 cm2.

Redresorul si filtrul

Redresarea tensiunii alternative data de transformator este facuta cu ajutorul puntii redresoare PR.Filtrul capacitiv realizat cu condensatorul C1,realizeaza aplatizarea riplului dat de PR.Fiultrul de C2,C3 si R1 este necesar pentru stabilirea functionarii circuitului LM7805.

Stabilizatorul ULN 7805

In general alimentarea corecta este de o importanta maxima pentru functionarea corecta a sistemului cu microcontroller.Poate fi usor comparata cu respiratia unui om in aer.Este mai probabil ca un om care respire aer curat va trai mai mult decat un om care locuieste intr-un mediu poluat.Pentru o functionare corecta a oricarui microcontroller este necesar sa oferim o sursa stabile de alimentare.Conform specificatiilor tehnice oferite de producatorul microcontrolerului PIC,tensiune de alimentare ar trebui sa se incadreze intre 2V si 6V pentru toate versiunile.Cea mai simpla solutie este folosirea stabilizatorului de tensiune LM7805 care ofera tensiunea stabile de +5V la iesire.

A1 Schema electronica a L-metrului

A.2.Lista de componente

C1 500mF

C2,C3 68μF

R1,R2 100K

R3 100K

R4 47K

LM339

C6 100nF

SN74LS393

R5 1,7K

R6 2,2M

C4 330pF

C5 3,8nF

R7 1M

P1 4,7K

BF256

P2 500

SN74HC14

C7 100nF

R9 1K

LED

R8 1K

R10 10K

C8 100nF

C9 220nF

P4 5K

R12 110

P3 1K

ULN7805

LCD 2X16 Display

A.3 Cablajul

A.4.Listingul programului in limbaj de asamblare

list p=16F84A

radix hex

PORTA equ 0x05

PORTB equ 0x06

TRISA equ 0x85

TRISB equ 0x86

TMR0 equ 0x01

STATUS     equ 0x03

OPTIONS equ 0x81

INTCON equ 0x0B

W_temp equ 0x17

STATUS_temp equ 0x18

COUNT1    equ 0x1A

COUNT2    equ 0x1B

LCD    equ 0x1C

COUNT equ 0x0C

INDICE equ 0x19

NUMB1 equ 0x20

NUMB2 equ 0x21

NUMB3 equ 0x22

NUMB4 equ 0x23

NUMZ1 equ 0x24

NUMZ2 equ 0x25

NUMZ3 equ 0x26

NUMZ4 equ 0x27

CARRY equ 0x28

CARRY1    equ 0x29

CARRY2    equ 0x2A

CARRY3    equ 0x2B

CARRY4    equ 0x2C

NRBITI equ 0x2D

CARRY12 equ 0x2E

CARRY13 equ 0x2F

CARRY14 equ 0x30

ACCaLO equ 0x31

ACCaHI equ     0x32

ACCbLO equ 0x33

ACCbHI equ     0x34

ACCcLO equ 0x35

ACCcHI equ     0x36

ACCdLO equ 0x37

ACCdHI equ     0x38

temp equ 0x39

;sign equ 0x3A

#define RS PORTB,1

#define RW PORTB,2

#define EN     PORTB,3

org 0x000

goto main

ISR_adr org 0x04

;bcf PORTA,3;-------

;clrf TMR0

btfsc INTCON,7

goto ISR_adr

;call PUSH

btfsc INTCON,1

goto ISR_rb0

btfsc INTCON,2

goto ISR_tmr

main

clrwdt

bsf STATUS,5

movlw b'00000000'

movwf OPTIONS

movlw 0x01 ;--

movwf TRISB

movlw 0x19

movwf TRISA

bcf STATUS,5

clrf PORTA

;clrf PORTB

clrf NUMB1

clrf NUMB2

clrf NUMB3

clrf NUMB4

call init_lcd

call stergere

call scrie_proiect

call stergere

call scrie_mesaj

;-- valdeaza intrerupere RB0

;bcf INTCON,2

bcf INTCON,1

bsf INTCON,4

bcf INTCON,3

bcf INTCON,5

clrf INDICE

bsf INTCON,7

loop ;call init_lcd

;call scrie_mesaj

goto loop

;goto main

ISR_rb0   

btfsc INDICE,0

goto rb01

clrf TMR0

bcf INTCON,1

bcf INTCON,2

bsf INTCON,5

bsf INDICE,0

retfie

rb01 movf TMR0,0

movwf NUMB1

bcf INTCON,7

;movf TMR0,0

;movwf NUMB1

;bcf INTCON,7

;--conversie, calcule, afisare

call init_lcd

;call scrie_mesaj

call stergere

call poz_cursor

;movf NUMB4,0

;call afis_nibble_sup

;movf NUMB4,0

;call afis_nibble_inf

;movf NUMB3,0

;call afis_nibble_sup

;movf NUMB3,0

;call afis_nibble_inf

;movf NUMB2,0

;call afis_nibble_sup

;movf NUMB2,0

;call afis_nibble_inf

;movf NUMB1,0

;call afis_nibble_sup

;movf NUMB1,0

;call afis_nibble_inf

;call delay_1s

;call delay_1s

;call delay_1s

;call delay_1s

;call delay_1s

;call delay_1s

;call delay_1s

;call delay_1s

;clrf NUMB4

;clrf NUMB3

; calculeaza NxN

movf NUMB2,0

movwf ACCbHI

movf NUMB1,0

movwf ACCbLO

call multiply

call div_cu_doi2

call div_cu_doi2

call div_cu_doi2

call stergere

call poz_cursor

call conbinbcd

movf NUMZ4,0

call afis_nibble_sup

movf NUMZ4,0

call afis_nibble_inf

movf NUMZ3,0

call afis_nibble_sup

movf NUMZ3,0

call afis_nibble_inf

movf NUMZ2,0

call afis_nibble_sup

movf NUMZ2,0

call afis_nibble_inf

movf NUMZ1,0

call afis_nibble_sup

movf NUMZ1,0

call afis_nibble_inf

call delay_1s

call delay_1s

call delay_1s

call delay_1s

;call delay_1s

;call delay_1s

;call delay_1s

;call delay_1s

;goto loop

; afiseaza rezultatul

call stergere

call poz_cursor

movlw 'L'

call afisare

movlw '='

call afisare

movf NUMZ4,0

bcf STATUS,2

andlw 0xF0

btfss STATUS,2

goto eror

movf NUMZ4,0

bcf STATUS,2

andlw 0x0F

btfss STATUS,2

;goto teo1

goto sute_mH

movf NUMZ3,0

bcf STATUS,2

andlw 0xF0

btfss STATUS,2

;goto teo2

goto zeci_mH

movf NUMZ3,0

bcf STATUS,2

andlw 0x0F

btfss STATUS,2

;goto teo3

goto unit_mH

movf NUMZ2,0

bcf STATUS,2

andlw 0xF0

btfss STATUS,2

;goto teo3

goto sute_uH

movf NUMZ2,0

bcf STATUS,2

andlw 0x0F

btfss STATUS,2

;goto teo3

goto zeci_uH

goto unit_uH

eror

call poz_cursor

movlw 'E'

call afisare

movlw 'r'

call afisare

movlw 'o'

call afisare

movlw 'a'

call afisare

movlw 'r'

call afisare

movlw 'e'

call afisare

goto teo

sute_mH   

movf NUMZ4,0

call afis_nibble_inf

movf NUMZ3,0

call afis_nibble_sup

movf NUMZ3,0

call afis_nibble_inf

movlw '.'

call afisare

movf NUMZ2,0

call afis_nibble_sup

movlw 'm'

call afisare

movlw 'H'

call afisare

goto teo

zeci_mH   

movf NUMZ3,0

call afis_nibble_sup

movf NUMZ3,0

call afis_nibble_inf

movlw '.'

call afisare

movf NUMZ2,0

call afis_nibble_sup

movlw 'm'

call afisare

movlw 'H'

call afisare

goto teo

unit_mH

movf NUMZ3,0

call afis_nibble_inf

movlw '.'

call afisare

movf NUMZ2,0

call afis_nibble_sup

movf NUMZ2,0

call afis_nibble_inf

movlw 'm'

call afisare

movlw 'H'

call afisare

goto teo

sute_uH   

movf NUMZ2,0

call afis_nibble_sup

movf NUMZ2,0

call afis_nibble_inf

movf NUMZ1,0

call afis_nibble_sup

movlw '.'

call afisare

movf NUMZ1,0

call afis_nibble_inf

movlw 'u'

call afisare

movlw 'H'

call afisare

goto teo

zeci_uH

movf NUMZ2,0

call afis_nibble_inf

movf NUMZ1,0

call afis_nibble_sup

movlw '.'

call afisare

movf NUMZ1,0

call afis_nibble_inf

movlw 'u'

call afisare

movlw 'H'

call afisare

goto teo

unit_uH

movf NUMZ1,0

call afis_nibble_sup

movlw '.'

call afisare

movf NUMZ1,0

call afis_nibble_inf

movlw 'u'

call afisare

movlw 'H'

call afisare

teo call delay_1s

call delay_1s

call delay_1s

;call delay_1s

;call delay_1s

;call delay_1s

call sterge_reg

call stergere

call scrie_mesaj

bcf INDICE,0

;-- valideaza intreruperile

clrf TMR0

bcf INTCON,1

bcf INTCON,5

bsf INTCON,4

;bsf INTCON,7

retfie

;goto loop

ISR_tmr    ;bsf INTCON,7

incf NUMB2,1

btfss STATUS,2

goto iesire

;bcf STATUS,2

incf NUMB3,1

btfss STATUS,2

goto iesire

;bcf STATUS,2

incf NUMB4,1

;btfss STATUS,2

;goto iesire

;incf NUM5

iesire bcf INTCON,2

bsf INTCON,5

;call POP

;bsf PORTA,3;-----

;call POP

retfie

sterge_reg   

clrf NUMB1

clrf NUMB2

clrf NUMB3

clrf NUMB4

return

stergere

bcf RS

bcf RW

movlw 0x00

movwf PORTB

call enable

movlw 0x10

movwf PORTB

call enable

call delay_15m

;8Meg

;call delay_15m

return

D_add

bcf STATUS,0

movf ACCaLO,0

addwf ACCbLO,1

btfsc STATUS,0

incf ACCbHI,1

btfsc STATUS,0

bsf STATUS,0

movf ACCaHI,0

addwf ACCbHI,1

btfsc STATUS,0

bsf STATUS,0

retlw 0

multiply   

movf NUMB2,0

movwf ACCaHI

movf NUMB1,0

movwf ACCaLO

call setup

mloop    rrf ACCdHI,1

rrf ACCdLO,1

btfsc STATUS,0

call D_add

rrf ACCbHI,1

rrf ACCbLO,1

rrf ACCcHI,1

rrf ACCcLO,1

decfsz temp,1

goto mloop

movf ACCbHI,0

movwf NUMB4

movf ACCbLO,0

movwf NUMB3

movf ACCcHI,0

movwf NUMB2

movf ACCcLO,0

movwf NUMB1

return

setup

movlw .16

movwf temp

movf ACCbHI,0

movwf ACCdHI

movf ACCbLO,0

movwf ACCdLO

clrf ACCbHI

clrf ACCbLO

retlw 0

inm_cu_doi2; impartirea cu doi a unui numar in baza 2

bcf STATUS,0

rlf NUMB1,1

rlf NUMB2,1

rlf NUMB3,1

rlf NUMB4,1

return

div_cu_doi2; impartirea cu doi a unui numar in baza 2

bcf STATUS,0

rrf NUMB4,1

rrf NUMB3,1

rrf NUMB2,1

rrf NUMB1,1

return

init_lcd

call delay_1s

bcf RS

bcf RW

movlw 0x30

movwf PORTB

call enable

call delay_15m

;8Meg

;call delay_125m

call enable

;call delay_125m

call delay_1.5m

call enable;

movlw 0x20

movwf PORTB

call enable

call enable;

bcf RS

bcf RW

movlw 0xC0

movwf PORTB

call enable

movlw 0x00

movwf PORTB

call enable

movlw 0xC0

movwf PORTB

call enable

movlw 0x00

movwf PORTB

call enable

movlw 0x10

movwf PORTB

call enable

movlw 0x00

movwf PORTB

call enable

bcf RS

bcf RW

movlw 0x60

movwf PORTB

call enable

movlw 0x00

movwf PORTB

call enable;

bcf RS

bcf RW

movlw 0xF0

movwf PORTB

call enable

call delay_15m

;8Meg

;call delay_125m

return

scrie_proiect

call poz_cursor

movlw 'P'

call afisare

movlw 'r

call afisare

movlw 'o'

call afisare

movlw 'i'

call afisare

movlw 'e'

call afisare

movlw 'c'

call afisare

movlw 't'

call afisare

movlw ' '

call afisare

movlw 'd'

call afisare

movlw 'e'

call afisare

call poz_lin_2

movlw 'd'

call afisare

movlw 'e'

call afisare

movlw ' '

call afisare

movlw 's'

call afisare

movlw 't

call afisare

movlw 'a'

call afisare

movlw 't

call afisare

call delay_1s

call delay_1s

call delay_1s

call delay_1s

call delay_1s

return

poz_cursor

bcf RS

bcf RW

movlw 0x00

movwf PORTB

call enable

movlw 0x10

movwf PORTB

call enable

call delay_15m

;8Meg

;call delay_15m

bcf RS

bcf RW

movlw 0x80

movwf PORTB

call enable

movlw 0x30

movwf PORTB

call enable

call delay_15m

;8Meg

;call delay_15m

return

poz_lin_2

movlw 0xC0

movwf PORTB

call enable

movlw 0x30

movwf PORTB

call enable

call delay_15m

return

scrie_mesaj

;scrie M

bcf RS

bcf RW

movlw 0x00

movwf PORTB

call enable

movlw 0x10

movwf PORTB

call enable

call delay_15m

;8Meg

;call delay_15m

bcf RS

bcf RW

movlw 0x80

movwf PORTB

call enable

movlw 0x30

movwf PORTB

call enable

call delay_15m

movlw 'C'

call afisare

movlw 'o'

call afisare

movlw 'n'

call afisare

movlw 'e'

call afisare

movlw 'c'

call afisare

movlw 't'

call afisare

movlw 'a'

call afisare

movlw 't'

call afisare

movlw 'i'

call afisare

call poz_lin_2

movlw 'i'

call afisare

movlw 'n'

call afisare

movlw 'd'

call afisare

movlw 'u'

call afisare

movlw 'c'

call afisare

movlw 't'

call afisare

movlw 'a'

call afisare

movlw 'n'

call afisare

movlw 't'

call afisare

movlw 'a'

call afisare

return

;goto main

afisare   

movwf LCD

movlw 0xF0

andwf LCD,0

addlw 0x02

movwf PORTB

call enable

swapf LCD,1

movlw 0xF0

andwf LCD,0

addlw 0x02

movwf PORTB

call enable

call delay_15m

;8Meg

;call delay_15m

return

afis_nibble_inf

;movf NUMB1,0

movwf LCD

movlw 0x0F

andwf LCD,1

movlw 0x30

addwf LCD,0

call afisare

return

afis_nibble_sup

movwf LCD

swapf LCD,1

movlw 0x0F

andwf LCD,1

movlw 0x30

addwf LCD,0

call afisare

return

enable

bsf EN

bcf EN

nop

nop

; nop

; nop

; nop

; nop

;-- 8Mhz

call delay_1125

nop

;nop

; nop

; nop

; nop

; nop

;nop

;nop

; nop

; nop

; nop

; nop

return

delay_15m; nu realizeaza i intarziere de 15200us

movlw 0x04

movwf COUNT

loop15 decfsz COUNT,1

goto loop115

goto exit15

loop115 call delay_1.5m

goto loop15

exit15    call delay_1.5m

return

delay_1.5m ; intarzierea = 3 x count1 +3 x count2 +12

; cu call si return

; intarzierea este 1.5ms

nop

nop

nop

nop

nop

nop

movlw 0xFF

movwf COUNT1

movlw 0xFF

movwf COUNT2

loop1.5 decfsz COUNT1,1

goto loop1.5

loop21.5 decfsz COUNT2,1

goto loop21.5

return

delay_1s; la 4Mhz

call delay_125m

call delay_125m

call delay_125m

call delay_125m

call delay_125m

call delay_125m

call delay_125m

call delay_125m

return

delay_125m; realizeaza o intarziere de 125ms

movlw 0xFA

movwf COUNT

loop125 decfsz COUNT,1

goto loop1125

goto exit125

loop1125 call delay_1125

goto loop125

exit125 call delay_1125

return

delay_1125

nop

nop

nop;--

nop

nop

nop

nop

nop

nop

movlw 0x51

movwf COUNT1

movlw 0x4F

movwf COUNT2

loop11125 decfsz COUNT1,1

goto loop11125

loop21125 decfsz COUNT2,1

goto loop21125

return

conbinbcd   

clrf NUMZ1

clrf NUMZ2

clrf NUMZ3

clrf NUMZ4

movlw 0x21

movwf NRBITI

bucla1    decfsz NRBITI,1

goto bucla2

goto bucla3

bucla2 call rotleft

call bcd_ori_doi

goto bucla1

bucla3    return

rotleft

bcf STATUS,0

rlf NUMB1,1

rlf NUMB2,1

rlf NUMB3,1

rlf NUMB4,1

movf STATUS,0

movwf CARRY

movlw 0x01

andwf CARRY

return

bcd_ori_doi;inmultirea cu 2 a unui numar de la 09

bcf STATUS,0

bcf STATUS,1

clrf CARRY1

clrf CARRY12

clrf CARRY13

clrf CARRY14

clrf CARRY2

clrf CARRY3

clrf CARRY4

movf NUMZ1,0

addwf NUMZ1,1

btfss STATUS,0

goto doi1

movlw 0x01

movwf CARRY1

doi1 btfss STATUS,1

goto doi2

bcf STATUS,0

movlw 0x06

addwf NUMZ1,1

goto doi3

doi2 bcf STATUS,0

bcf STATUS,1

movlw 0x0A

subwf NUMZ1,0

btfss STATUS,1

goto doi3

;goto doi52

movlw 0x06

addwf NUMZ1,1

doi3 btfss CARRY1,0

goto doi5

doi6 bcf STATUS,0

bcf STATUS,1

movlw 0x60

addwf NUMZ1,1

btfss STATUS,0

goto doi7

bsf CARRY1,0

goto doi7

doi5 movlw 0xA0

subwf NUMZ1,0

btfss STATUS,0

goto doi7

goto doi6

doi7 movf NUMZ2,0

addwf NUMZ2,1

btfss STATUS,0

goto doi8

movlw 0x01

movwf CARRY2

doi8 btfss STATUS,1

goto doi9

bcf STATUS,0

movlw 0x06

addwf NUMZ2,1

goto doi10

doi9 bcf STATUS,0

bcf STATUS,1

movlw 0x0A

subwf NUMZ2,0

btfss STATUS,1

goto doi10

;goto doi52

movlw 0x06

addwf NUMZ2,1

doi10 btfss CARRY2,0

goto doi11

doi12 bcf STATUS,0

bcf STATUS,1

movlw 0x60

addwf NUMZ2,1

btfss STATUS,0

goto doi13

bsf CARRY2,0

goto doi13

doi11 movlw 0xA0

subwf NUMZ2,0

btfss STATUS,0

goto doi13

goto doi12

doi13 movf CARRY1,0

addwf NUMZ2,1

btfss STATUS,0

goto doi14

movlw 0x01

movwf CARRY12

doi14 btfss STATUS,1

goto doi15

bcf STATUS,0

movlw 0x06

addwf NUMZ2,1

goto doi16

doi15 bcf STATUS,0

bcf STATUS,1

movlw 0x0A

subwf NUMZ2,0

btfss STATUS,1

goto doi16

;goto doi52

movlw 0x06

addwf NUMZ2,1

doi16 btfss CARRY12,0

goto doi17

doi18 bcf STATUS,0

bcf STATUS,1

movlw 0x60

addwf NUMZ2,1

btfss STATUS,0

goto doi19

bsf CARRY12,0

goto doi19

doi17 movlw 0xA0

subwf NUMZ2,0

btfss STATUS,0

goto doi19

goto doi18

doi19 movf CARRY12,0

addwf CARRY2,1

movf NUMZ3,0

addwf NUMZ3,1

btfss STATUS,0

goto doi20

movlw 0x01

movwf CARRY3

doi20

btfss STATUS,1

goto doi21

bcf STATUS,0

movlw 0x06

addwf NUMZ3,1

goto doi22

doi21 bcf STATUS,0

bcf STATUS,1

movlw 0x0A

subwf NUMZ3,0

btfss STATUS,1

goto doi22

;goto doi52

movlw 0x06

addwf NUMZ3,1

doi22 btfss CARRY3,0

goto doi23

doi24 bcf STATUS,0

bcf STATUS,1

movlw 0x60

addwf NUMZ3,1

btfss STATUS,0

goto doi25

bsf CARRY3,0

goto doi25

doi23 movlw 0xA0

subwf NUMZ3,0

btfss STATUS,0

goto doi25

goto doi24

doi25 movf CARRY2,0

addwf NUMZ3,1

btfss STATUS,0

goto doi26

movlw 0x01

movwf CARRY13

doi26 btfss STATUS,1

goto doi27

bcf STATUS,0

movlw 0x06

addwf NUMZ3,1

goto doi28

doi27 bcf STATUS,0

bcf STATUS,1

movlw 0x0A

subwf NUMZ3,0

btfss STATUS,1

goto doi28

;goto doi52

movlw 0x06

addwf NUMZ3,1

doi28 btfss CARRY13,0

goto doi29

doi30 bcf STATUS,0

bcf STATUS,1

movlw 0x60

addwf NUMZ3,1

btfss STATUS,0

goto doi31

bsf CARRY13,0

goto doi31

doi29 movlw 0xA0

subwf NUMZ3,0

btfss STATUS,0

goto doi31

goto doi30

doi31 movf CARRY13,0

addwf CARRY3,1

movf NUMZ4,0

addwf NUMZ4,1

btfss STATUS,0

goto doi32

movlw 0x01

movwf CARRY4

doi32

btfss STATUS,1

goto doi33

bcf STATUS,0

movlw 0x06

addwf NUMZ4,1

goto doi34

doi33 bcf STATUS,0

bcf STATUS,1

movlw 0x0A

subwf NUMZ4,0

btfss STATUS,1

goto doi34

;goto doi52

movlw 0x06

addwf NUMZ4,1

doi34 btfss CARRY4,0

goto doi35

doi36 bcf STATUS,0

bcf STATUS,1

movlw 0x60

addwf NUMZ4,1

btfss STATUS,0

goto doi37

bsf CARRY4,0

goto doi37

doi35 movlw 0xA0

subwf NUMZ4,0

btfss STATUS,0

goto doi37

goto doi36

doi37 movf CARRY3,0

addwf NUMZ4,1

btfss STATUS,0

goto doi38

movlw 0x01

movwf CARRY14

doi38 btfss STATUS,1

goto doi39

bcf STATUS,0

movlw 0x06

addwf NUMZ4,1

goto doi40

doi39 bcf STATUS,0

bcf STATUS,1

movlw 0x0A

subwf NUMZ4,0

btfss STATUS,1

goto doi40

;goto doi52

movlw 0x06

addwf NUMZ3,1

doi40 btfss CARRY14,0

goto doi41

doi42 bcf STATUS,0

bcf STATUS,1

movlw 0x60

addwf NUMZ4,1

btfss STATUS,0

goto doi43

bsf CARRY14,0

goto doi43

doi41 movlw 0xA0

subwf NUMZ4,0

btfss STATUS,0

goto doi43

goto doi42

doi43 movf CARRY14,0

addwf CARRY4,1

doi45 btfss CARRY4,0

goto doi46

movlw 0x99

movwf NUMZ1

movwf NUMZ2

movwf NUMZ3

movwf NUMZ4

goto doi47

;return

doi46 btfss CARRY,0

goto doi47

call addbcd_1

doi47 return

addbcd_1; aduna cu 1 in cod BCD

bcf STATUS,1

movlw 0x01

addwf NUMZ1,1

movlw 0x0A

subwf NUMZ1,0

btfss STATUS,1

goto star

bcf STATUS,0

bcf STATUS,1

movlw 0x06

addwf NUMZ1,1

;movlw 0x10

;addwf NUMZ1,1

movlw 0xA0

subwf NUMZ1,0

btfss STATUS,0

goto star

bcf STATUS,0

bcf STATUS,1

movlw 0x60

addwf NUMZ1,1

movlw 0x00

subwf NUMZ1,0

btfss STATUS,0

goto star

movlw 0x01

addwf NUMZ2,1

movlw 0x0A

subwf NUMZ2,0

btfss STATUS,1

goto star

bcf STATUS,0

bcf STATUS,1

movlw 0x06

addwf NUMZ2,1

;movlw 0x10

;addwf NUMZ1,1

movlw 0xA0

subwf NUMZ2,0

btfss STATUS,0

goto star

bcf STATUS,0

bcf STATUS,1

movlw 0x60

addwf NUMZ2,1

movlw 0x00

subwf NUMZ2,0

btfss STATUS,0

goto star

movlw 0x01

addwf NUMZ3,1

movlw 0x0A

subwf NUMZ3,0

btfss STATUS,1

goto star

bcf STATUS,0

bcf STATUS,1

movlw 0x06

addwf NUMZ3,1

;movlw 0x10

;addwf NUMZ1,1

movlw 0xA0

subwf NUMZ3,0

btfss STATUS,0

goto star

bcf STATUS,0

bcf STATUS,1

movlw 0x60

addwf NUMZ3,1

movlw 0x00

subwf NUMZ3,0

btfss STATUS,0

goto star

movlw 0x01

addwf NUMZ4,1

movlw 0x0A

subwf NUMZ4,0

btfss STATUS,1

goto star

bcf STATUS,0

bcf STATUS,1

movlw 0x06

addwf NUMZ4,1

;movlw 0x10

;addwf NUMZ1,1

movlw 0xA0

subwf NUMZ4,0

btfss STATUS,0

goto star

bcf STATUS,0

bcf STATUS,1

movlw 0x60

addwf NUMZ4,1

movlw 0x00

subwf NUMZ4,0

btfss STATUS,0

goto star

movlw 0x99

movwf NUMZ1

movwf NUMZ2

movwf NUMZ3

movwf NUMZ4

star return

end



Politica de confidentialitate | Termeni si conditii de utilizare



DISTRIBUIE DOCUMENTUL

Comentarii


Vizualizari: 8074
Importanta: rank

Comenteaza documentul:

Te rugam sa te autentifici sau sa iti faci cont pentru a putea comenta

Creaza cont nou

Termeni si conditii de utilizare | Contact
© SCRIGROUP 2024 . All rights reserved