Académique Documents
Professionnel Documents
Culture Documents
h>
#device adc=10
#use delay(clock=8000000)
#include "LCD.c"
#include <math.h>
int16 CAD;
float VOLTAJELM35;
float TEMLM35, TEMPERATURA;
float E;
float T;
int1 bandera = 1;
int8 contador = 0;/*int8 es por variable de 8 bits*/
float Tdeseada = 0;
int16 cuentas = 0;
#INT_EXT
}
contador++;
//output_d(contador);
set_timer1(~cuentas);
SETUP_TIMER_1( T1_INTERNAL | T1_DIV_BY_2 );
}
#INT_TIMER1
void isr_timer1()
{
setup_timer_1(T1_DISABLED);
output_high(PIN_C0);//PONIENDO EN ALTO ESTE PINe
delay_us(25);//us es en micoseg
output_low(PIN_C0);
}
void main()
{
lcd_gotoxy(1,1);
lcd_putc("TA=");
lcd_gotoxy(1,2);
lcd_putc("TD=");
lcd_gotoxy(10,1);
lcd_putc("A=");
lcd_gotoxy(10,2);
lcd_putc("E=");
delay_ms(2000);
TEMPERATURA= T + TEMLM35;
lcd_gotoxy(4,1);
printf(lcd_putc, "%.1f",TEMPERATURA);
Tdeseada = 22+0.068*Tdes;
lcd_gotoxy(4,2);
printf(lcd_putc, "%.1f",Tdeseada);
error=Tdeseada-TEMPERATURA;
lcd_gotoxy(12,2);
printf(lcd_putc, "%.1f",error);
Angulo = 160-10*error;
lcd_gotoxy(12,1);
printf(lcd_putc, "%.1f",Angulo);
Angulo = 60;
lcd_gotoxy(12,1);
printf(lcd_putc, "%.1f",Angulo);
}
cuentas = (int16)(49.07*Angulo);
delay_ms(250);
}
}
Formula para encontrar la resistencia del moc3010
𝐼 = 17𝑚𝐴
𝑣𝑜𝑢𝑡 − 𝑣𝑅 − 𝑣𝐷 = 0
5 − 17𝑚𝐴 𝑅 − 1.3 = 0
−3.7
𝑅=
−17𝑚𝐴
𝑅 = 217.64Ω ≈ 220Ω
𝑣𝑠 − 𝐼𝑓 𝑅𝑆 − 𝑣𝐷 − 𝑣𝐷𝑜𝑝𝑡𝑜 = 0
−𝑣𝑠 + 𝑣𝐷 + 𝑣𝐷𝑜𝑝𝑡𝑜
𝑅𝑆 =
−𝐼𝑓
𝑣𝐶𝐶 −𝑣𝐶𝐸𝑠𝑎𝑡 − 𝑅𝐼 = 0
−𝑣𝐶𝐶 +𝑣𝐶𝐸𝑠𝑎𝑡
𝑅=
−𝐼
−5𝑣 + 0.2𝑣
𝑅2 = 𝑅 = = 48000Ω = 48𝑘Ω ≈ 47𝑘Ω
−0.1𝑚𝐴