Pesquisar neste blog

31/05/2018

CONVERSÃO DIGITAL - ANALÓGICA

K = Saída analógica / Entrada Digital

Vout = K . Entrada Digital


1) Um DAC de cinco bits tem saída em corrente. Para entrada digital de 10100, é gerada corrente de saída de 10 mA. Qual será o Iout para uma entrada digital de 11101 ?

Solução:

(10100)2 = (20)10
(11101)2 = (29)10

K = Fator de proporcionalidade

K = 10 mA / 20 = 0,5 mA

Iout = 0,5 mA . 29 = 14,5 mA


2) Qual o maior valor de tensão de saída de um DAC de 8 (oito) bits que gera 1 V para uma entrada digital de 110010 ?

Solução:

(110010)2 = (50)10

Maior tensão de saída  8 bits = (11111111)2 = (255)10

ou
210 -1 = (255)10

K = 1V / 50 = 0,02 V

Vout = K . Entrada Digital = 0,02V . 255 = 5,1V


RESOLUÇÃO (Tamanho do degrau)

3) Um DAC de 10 bits tem tamanho de degrau de 10 mV. Determine a tensão de saída de fundo de escala e a resolução percentual.

Resolução:

% Resolução = (tamanho do degrau / fundo de escala(F . S)) . 100%

210 -1 = 1023 degraus de 10 mV
Saída de fundo = 10 mV . 1023 = 10,23 V

% Res = (0,01V / 10,23 V ). 100 = 0,0977 % = ± 1%

29/05/2018

Exercício lógico combinacional

Projete um circuito lógico que controla uma porta de elevador em um prédio de três andares . O circuito tem 4 entradas em que M é um sinal lógico que indica quando o elevador está se movendo (M = 1) ou parado (M = 0) , F1, F2, F3 são os sinais indicadores dos andares que são normalmente nível BAIXO, passando para o nível ALTO apenas quando o elevador estiver posicionado em determinado andar.

Solução:






















































































28/05/2018

Contadores e Registradores

Um contador é necessário para contar o número de intens que passam por uma esteira de transporte. Uma fotocélula combinada a uma fonte de luz é usada para gerar um único pulso cada vez que um item passa pelo feixe de luz. O contador tem de ser capaz de contar mil itens. Quantos FFs são necessários ?

Solução:

Determinando o valor de N de modo que 2N ≥ 1000
29 = 512, logo: Não são o suficiente
210  = 1024 , portanto 10 FFs produzem um contador que conta até 1111111111 = ( 1023 em decimal)
10 FFs são necessários.

11/05/2018

Exercicios resolvidos com ponteiro em C/C++

#include <stdio.h>

#include <stdlib.h>



/* 1 - ESCREVA UM PROGRAMA QUE DECLARE UM INTEIRO, UM REAL E UM CHAR, E PONTEIROS PARA INTEIRO, REAL, E CHAR. ASSOCIE AS VARIÁVEIS AOS PONTEIROS(USE &). MODIFIQUE OS VALORES DE CADA VARIÁVEL USANDO PONTEIROS. IMPRIMA OS VALORES DAS VARIÁVEIS ANTES E APÓS A MODIFICAÇÃO.*/



main (void){



int num = 15;



double valor= 20.77;



char letra = 'h';



int *Endint = &num;



float *Endfloat = &valor;



char *Endchar = &letra; 



printf("Variavel inteiro = %d \nEndereco ponteiro inteiro = %i\n\n", num, Endint);



printf("Variavel float  =  %.2f\nEndereco do ponteiro float = %i\n\n",valor, Endfloat);



printf("Variavel char  = %c\nEndereco do ponteiro  char = %i\n\n",letra, &letra);



printf("\tAPOS MODIFICACAO:\n");



*Endint = 22;



*Endfloat = 50.35;



*Endchar = 'k';



printf("\nEndereco do ponteiro: %d\nAlterado para o valor: %d\n\n", Endint, *Endint);



printf("Endereco do ponteiro: %d\nAlterado para o valor: %d\n\n", Endfloat, *Endfloat);



printf("Endereco do ponteiro: %i\nAlterado para o caracter: %c\n\n", Endchar, *Endchar);



return EXIT_SUCCESS;



}







#include <stdio.h>



#include <stdlib.h>



/*2- ESCREVA UM PROGRAMA QUE CONTENHA DUAS VARIÁVEIS INTEIRAS.COMPARE



SEUS ENDEREÇOS E EXIBA O MAIOR ENDEREÇO.*/



int main (void){



int a = 27, b = 77;



int *EndA = &a , *EndB = &b;



printf("\tA = %d     B = %d\n\n",a, b);



printf("Endereco de A = %d\nEndereco de B = %d\n",EndA, EndB);



if(EndA > EndB){



if(&a > &b) 



printf("\n\nEndereco %d de A eh maior: \n",EndA);



//printf("\n\nEndereco %d de A eh maior: \n", &a);



}else{



printf("\n\nEndereco %d de B eh maior: \n",EndB);



//printf("\n\nEndereco %d de B eh maior: \n",&b);



}



//ou



/*if(&a > &b){ 



printf("\n\nEndereco %d de A eh maior: \n", &a);



}else{



printf("\n\nEndereco %d de B eh maior: \n",&b);







printf("\n");*/



return EXIT_SUCCESS;



}



#include <stdio.h>



#include <stdlib.h>



/* 3 - Escreva um programa que contenha 2 variaveis inteiras. Leia 



essas variavéis do teclado. Em seguida, compare seus endereços



e exiba o maior endereço.*/



int main (void){



int a, b;



printf("\tDigite o valor de a: ");



scanf("%d",&a);



printf("\n\tDigite o valor b: ");



scanf("%d",&b);



printf("\nValor de a = %i\nValor de b = %i\n\n",a, b);



int *EndA = &a, *EndB = &b;



printf("Endereco de a = %i\nEndereco de b = %i\n\n",EndA, EndB);



if(EndA > EndB){



printf("\n\nEndereco %d de a eh maior:",EndA);



}else{



printf("\n\nEndereco %d de b eh maior:", EndB);



}



printf("\n\n");



return EXIT_SUCCESS;



}





#include <stdio.h>



#include <stdlib.h>



#define SIZE 5



/*4 - CRIE UM PROGRAMA QUE CONTENHA UM ARRAY DE 5 ELEMENTOS INTEIROS. lEIA



ESSE ARRAY DO TECLADO E IMPRIMA O ENDERECO DE POSICOES CONTENDO VALORES PARES.*/



int main (void){



int vet[SIZE], i;



int *Endvet;



Endvet = vet;



printf("\tDigite %d elementos:\n",SIZE);



for(i = 0; i < SIZE; i++){



printf("%d: ",i+1);



scanf("%d", &vet[i]);



}



printf("\n\tELEMENTOS:\n\n");



for(i = 0; i < SIZE; i++){



printf("%d  ",vet[i]);



}



printf("\n\nENDERECOS DO ARRAY:\n");



for(i = 0; i < SIZE; i++){



printf("%i : %i : %i\n",i+1, vet[i], Endvet++);







printf("\nENDERECOS DO ARRAY PAR:\n");



Endvet = vet;



for(i = 0; i < SIZE; i++){



if(vet[i] %2 == 0){



printf("\nNumero %d eh par : Posicao = %d",vet[i], Endvet);



}



Endvet++;



}



return EXIT_SUCCESS;



}



#include <stdio.h>



#include <stdlib.h>



#define SIZE 10



/* 5 - CRIE UM PROGRAMA QUE CONTENHA UM ARRAY DE FLOAT CONTENDO 10 ELEMENTOS.



IMPRIMA O ENDERECO DE CADA POSICAO DESSE ARRAY.*/



int main (void){



float vet[SIZE];



int i, *Endvet;



Endvet = vet;



printf("\tELEMENTOS:\n\n");



for(i = 0; i < SIZE; i++){



printf("[%.2f] ", (vet[i] = 10 + rand() %100) / 3.27);



}



printf("\n\nENDERECOS DO ARRAY:\n\n");



for(i = 0; i < SIZE; i++){



printf("%i : %.2f : %i\n",i+1, vet[i]/3.27, Endvet++);







return EXIT_SUCCESS;



}