ayuda con programa

Iniciado por yersonugarte, 21 Agosto 2015, 05:07 AM

0 Miembros y 1 Visitante están viendo este tema.

yersonugarte

hola gente del foro, resulta que mi nivel de c no es de lo mas avanzado y me dieron un programa que tengo que ver como trabaja, lo que hace es: se tiene el pic que recibe una señal proveniente de un microfono y usa un conversor analogo-digital y la señal la almacena en una memoria externa y hace que se repita infinitas veces y se puede controlar la velocidad de las repeticiones todo esto presionando un boton pero hay varios codigos que no entiendo bien seria genial si me podrian echar una manito. aqui va el programa, de antemano muchas gracias....  :laugh:

[ MOD] Para publicar codigo se debe usar las etiquetas GeShi.



#include <16F877a.h>

#device ADC=8
#fuses NOWDT,HS,NOPROTECT,NOBROWNOUT
#use delay(clock=20000000)
#include "spi_hardware1.h"

unsigned int8 valor = 0; unsigned int8 i;
unsigned int8 variable1, variable2;
int8 cambio_pulso;
int8 movimiento1,movimiento2,movimiento3;
short estado_de_pulso;
signed int8 cambio_1 = 0;  

  int8 registro_1 = 0;
 

void DACout(int8 valores_bytes) {
  output_b(valores_bytes);
}
#INT_RTCC                         //se utiliza interrupcion con el timer 0
void playback() {
  delay_us(42);
  set_rtcc(128+cambio_1);
  if(movimiento3) movimiento3--;
  else output_low(PIN_E2);
  variable2++;
  if(variable2==255) {
     variable1++;
     movimiento1++;
  }
  if(variable1==registro_1) variable1=0;
  if(movimiento1 == movimiento2) {
     movimiento1 = 0;
     output_high(PIN_E2);
     movimiento3 = 5;
  }  
     
  if(input_state(PIN_D0) != estado_de_pulso) i++; // Boton presionado
  else i=(i==0)?i-1:0;


  valor = readByte(variable1,variable2);
  output_b(valor);
  cambio_1 = read_adc()/2 - cambio_pulso;
       
}


void main() {
  short dir=0;
  set_tris_b(0x00);

  output_low(PIN_E1); // initially set relay to full bypass

  for(i=0;i<6;i++) {
     output_toggle(PIN_E0);
     delay_ms(50);
  }



  setup_adc(ADC_CLOCK_DIV_2);
  setup_adc_ports(AN0_AN1_AN2_AN3_AN4);

  setup_timer_0(RTCC_INTERNAL|RTCC_DIV_2);
  enable_interrupts(GLOBAL);
     

  setup_spi(SPI_MASTER|SPI_L_TO_H|SPI_XMIT_L_TO_H|SPI_CLK_DIV_4);
     
  valor = 0;
 

  while(1) {
     set_adc_channel(0);

     

     variable1=0;
     variable2=0;

     estado_de_pulso = input_state(PIN_D0);
 
     // "Wait" phase

     while(1) {
        if(input_state(PIN_D0) != estado_de_pulso) i++;
        else i=(i==0)?i-1:0;
        if(i==100) break;

        valor = read_adc();
        output_b(valor);
        delay_us(20);
     }  
     estado_de_pulso = !estado_de_pulso;
     delay_ms(50);
     set_adc_channel(2);
     registro_1 = read_adc()/2 + 1;
     set_adc_channel(0);

     // Recording phase

     if(input_state(PIN_D7)) while(1) { // if(input_state(PIN_D7)) to read from LOOP/BURST switch
        variable2++;
        if(variable2==255) variable1++;
        if(variable2==registro_1) break;

        valor = read_adc();
        output_b(valor);
        delay_us(50);
        delay_us(30);
        writeByte(variable1,variable2,valor);
     }
     else while(1) {
        variable2++;
        if(variable2==255) variable1++;
        if(variable1==128) break;

        if(input_state(PIN_D0) != estado_de_pulso) i++;
        else i=(i==0)?i-1:0;
        if(i==100) {
           estado_de_pulso = !estado_de_pulso;
           break;
        }
       
        valor = read_adc();
        output_b(valor);
        delay_us(50);
        delay_us(25);
        writeByte(variable1,variable2,valor);
     }

     registro_1 = variable1;
     
     play:
     set_adc_channel(1);
     output_high(PIN_E1); // engage relay, switch to playback mode
     delay_us(50);
     cambio_pulso = read_adc()/2;
     variable1=variable2=dir=0;
     output_high(PIN_E2);
     enable_interrupts(INT_TIMER0);
     movimiento1=0;movimiento2=registro_1/4;
     movimiento3 = 5;
     set_rtcc(0);
     while(1) {
        if(i==100) break;
        delay_us(200);
     }
     estado_de_pulso = !estado_de_pulso;
     disable_interrupts(INT_TIMER0);
     output_low(PIN_E1); // disengage relay, return to full bypass
  }

  return;
}




pomada_de_la_campana

Es muy difícil responder tu pregunta, tienes que dar mas información, al menos que microcontrolador es el que usas, el compilador, etc. Si es que tienes suerte y alguien a programado para esa arquitectura a lo mejor te pueden ayudar.

Lo que te puedo recomendar es leer la documentación que trae el compilador del pic. Esta suele ser muy completa y ayuda a entender el código.