PUBLICIDAD Muy Sistema GPS bien. Lo que necesitamos ahora es un ... Módulo SmartGPS conectado al Sistema de Desarrollo EasyPIC5 Por Dusan Mihajlovic Departamento de Hardware – MikroElektronika El Sistema de Posicionamiento Global (Global Positioning System, o GPS) es actualmente una de las principales tecnologías utilizadas para fines de navegación. Está muy extendido en los sistemas de navegación para automóviles. Aquí describiremos la conexión entre un receptor GPS y el microcontrolador, así como la determinación de latitud y longitud. El Sistema de Posicionamiento Global (GPS) se basa en un gran número satélites que radian señales de microondas, que son captadas por los receptores GPS que determinan así su posición actual, el tiempo o la velocidad. Los receptores GPS pueden comunicarse con un microcontrolador o un PC de diferentes maneras. Un camino habitual es a través del puerto serie, mientras que el protocolo más utilizado para la transmisión de datos se llama NMEA. Principio de funcionamiento El protocolo NMEA se basa en cadenas. Cada cadena se inicia con el signo $ (código ASCII 36) y termina con una secuencia de signos que comienza con una nueva línea, tales como CR (código ASCII 13) y LF (código ASCII 10). El significado de toda la cadena depende de la primera palabra. Por ejemplo, una cadena que comienza con $GPGLL da información acerca de la latitud y la longitud, la hora exacta (Tiempo Universal Coordinado), la validez de los datos (A - Activo o V - Prohibido) y la suma de verificación (“checksum”) que nos permite comprobar si los datos se recibieron correctamente. Los datos individuales de cada elemento están separados por una coma “,”. Cada segundo se envía un conjunto de cadenas NMEA al microcontrolador. En el caso de que los datos sobre latitud y longitud no sean fijos (por ejemplo, si un receptor GPS falla a la hora de determinar su posición) o cuando los datos no sean determinados, el receptor GPS mantendrá en su salida el mismo juego de cadenas, dejando de lado cualquier dato perdido. Aquí tenemos una cadena generada por el receptor GPS que ha fallado al determinar su posición: $GPGLL,,,,,,V,N*64 A continuación se muestra un ejemplo de una cadena NMEA completa: El circuito La conexión entre el microcontrolador y el receptor GPS es muy sencilla. Para ello, sólo es necesario proporcionar dos líneas, RX y TX. Consultar el Esquema 1. La línea RX se utiliza para enviar datos desde un receptor GPS al microcontrolador, mientras que la línea TX puede usarse para el envío de comandos específicos del microcontrolador al receptor GPS. Para este proyecto se utiliza el receptor U-Blox LEA-5S. Como en la mayoría de los receptores GPS, la tensión de alimentación de este receptor es de 3V. Artículo publicitario de MikroElektronika www.mikroe.com mikroBASIC® y mikroBASIC PRO® son marcas registradas de MikroElektronika. Reservados todos los derechos. ... making it simple SOFTWARE AND HARDWARE SOLUTIONS FOR EMBEDDED WORLD Esquema Eléctrico 1. Conexión del módulo LEA-5S al PIC18F4520 Dado que el microcontrolador PIC18F4520 utiliza una fuente de alimentación de 5V para funcionar, es necesario utilizar un conversor de nivel de tensión para convertir la tensión de nivel “Lógico Uno” de 3,3V a 5V. El programa En este ejemplo, una pantalla gráfica con una resolución de 128x64 píxeles, muestra un mapa del mundo con el cursor apuntando su posición en el globo. Como podemos ver, el código del programa que se introduce en el microcontrolador es muy corto. Casi la mitad del código constituye un mapa de bits convertido en un conjunto de datos adecuados. Esa conversión permite que el microcontrolador muestre el mapa. El resto del código se compone de la recepción de las cadenas NMEA desde el receptor GPS, el cálculo de la latitud y la longitud, el escalado de los datos para que coincida con la resolución de pantalla de 128x64 píxeles y la colocación del cursor en la posición especificada. mikroBASIC PRO para el editor de librerías PIC® con librerías listas para usar, como: GLCD, Ethernet, CAN, SD/MMC etc. program Smart_GPS const World_bmp as byte[1024] = ( 255,129, 1, 1, 1,129,129,129,129,193,129,129,129,129,129,129, 129,129,129,129,129,225,161,161, 97, 97,209,209,129, 49, 49,201, 201,201,201, 97,205,205,129,137, 25, 57, 57, 57,121,249,249,249, 249,249,253,253,121,121,113, 9, 9, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 17, 17,145,145,145,145,129,129,129, 1, 1, 1, 1, 9, 73, 73, 73, 73,193, 65, 65,129,129,193,193,129,193,193,241, 241,241,241,225,225,225,193,193,193,193,193,193,193,193,193,129, 193,193,225,225,129,129,129,129,129,129,129,129,129,129,129,255, 255, 1, 33, 17, 17, 15, 15, 15, 15, 15, 7, 7, 7, 7, 15, 15, 31, 63, 63, 63, 63,255,255,255,255,255,255,255,255,251,251,240, 240,240,240,226,252,252,249,249,250,240,240, 1, 1, 1, 1, 3, 1, 1, 0, 0, 0, 0, 0, 2, 2, 0, 0, 0, 24, 24,224,224, 224,224,244,239,239,255,255,255,255,255,255,255,255,255,254,254, 255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, 255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, 95, 95, 3, 3, 3, 3, 63, 15, 15, 3, 3, 3, 3, 3, 1,255, 255, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 15, 63, 63,255,255,255,255,255, 63, 63, 63, 63, 63, 63, 63,135,135, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,192,192,192,243,243,251,251, 251,251,251,247,231,231,243,247,247,247,230,236,124,124,255,255, 220, 60, 61, 61, 63,126,255,255,255,255,255,255,255,255,255,255, 255,255,255,255,255,255,255,255,255, 59, 59, 3, 7, 3, 27, 12, 7, 7, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,255, 255, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 3, 6, 6, 13, 13, 13, 13, 17,242,242,242,242,240,224,224,192,192,192,192, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 31, 31, 31, 63, 63, 63, 63, 63, 63,255,255,255,255,255,255,255,255,255,255,248,248,247,247, 55, 3, 3, 3, 3, 0, 1, 1, 3, 3, 15, 15, 7, 0, 0, 1, 1, 3, 3,239, 15, 15, 1,129,224,174, 46,128, 0,128, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,255, 255, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 63, 63,255,255,255,255,255,255,255,255,255,255, 254,254, 12, 12, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1,255,255,255,255,255,255,255,255,255, 63, 63,193,193, 240, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 3, 4, 9,129,193,192,225,224,226,224,242, 227,227,228,228, 8, 8, 0, 0, 0, 0, 0, 0, 0, 0, 0,255, 255, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,255,255,255, 31, 31, 15, 15, 15, 15, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 3, 15, 15, 15, 15, 15, 3, 3, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 15, 15, 7, 7, 7, 7, 7, 31, 31,127,127, 70, 70, 0, 0, 0, 0, 0, 0,208,208, 0,255, 255, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, Q Funciones usadas en el programa Glcd_box() Dibuja un cuadro y lo rellena Glcd_circle() Dibuja un círculo Glcd_Dot() Dibuja un punto* Glcd_Fill() Borra/Rellena pantalla* Glcd_H_Line() Dibuja una línea horizontal Glcd_Image() Importa imagen* Glcd_Init() Inicialización de la pantalla LCD* Glcd_Line() Dibuja una línea Glcd_Read_Data() Lee datos desde la pantalla LCD Glcd_Rectangle() Dibuja un rectángulo Glcd_Set_Font() Selecciona fuente* Glcd_Set_Page() Selecciona página Glcd_Set_Side() Selecciona el lado de la pantalla Glcd_Set_X() Determina la coordenada X Glcd_V_line() Dibuja una línea vertical Glcd_Write_Char() Escribe el carácter Glcd_Write_Data() Escribe el dato Glcd_Write_Text() Escribe el texto * Funciones de la librería Glcd usada en el programa Otras funciones mikroBASIC PRO for PIC usadas en el programa: GO TO [ Ejemplo 1: Programa para demostrar el funcionamiento del módulo LEA -5S. Usart_Init() strstr() Usart_Read() Delay_ms() El código para este ejemplo escrito para microcontroladores PIC® en C, Basic y Pascal, así como los programas escritos para microcontroladores dsPIC® y AVR® los pueden encontrar en nuestra página web: www.mikroe.com/en/article/ www.mikroe.com el r en ribi or Escmpilad co ASIC roB k i m IC for P O R P 0, 0, 0, 0, 0, 0,135,135,193, 64, 68, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 128,128,128,128,128,128, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,128,128,128,128,128,128, 0, 0, 0, 0, 0, 0,128, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,255, 255,240,240,240,240,248,248,248,248,248,248,248,248,248,252,252, 252,252,252,252,252,252,252,252,252,252,252,252,252,252,252,252, 252,252,252,252,254,254,255,255,255,252,252,248,248,248,248,248, 248,248,248,248,248,248,252,252,252,254,254,254,254,254,255,255, 255,255,255,255,255,255,255,255,255,255,255,255,254,254,255,255, 255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, 255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, 255,255,255,255,255,255,255,255,255,250,250,250,216,216,248,255) dim txt as char[768] str_ as string[40] tmpStr as string[10] latitude, longitude, nmbByte, i, g, cnt as integer ready as byte dim GLCD_Dataport as byte at PORTD dim GLCD_CS1 as sbit at RB0_bit GLCD_CS1_Direction as sbit at TRISB0_bit GLCD_CS2 as sbit at RB1_bit GLCD_CS2_Direction as sbit at TRISB1_bit GLCD_RS as sbit at RB2_bit GLCD_RS_Direction as sbit at TRISB2_bit GLCD_RW as sbit at RB3_bit GLCD_RW_Direction as sbit at TRISB3_bit GLCD_EN as sbit at RB4_bit GLCD_EN_Direction as sbit at TRISB4_bit GLCD_RST as sbit at RB5_bit GLCD_RST_Direction as sbit at TRISB5_bit sub function search_str2_in_str1(dim byref s1 as string[4000], dim byref s2 as string[4000]) as word dim i, j as word aa, bb as byte i = 0 j = 0 aa = s1[0] bb = s2[0] result = 0xFFFF while(aa <> 0) while(aa = bb) if (i = 0) then result = j end if i = i + 1 j = j + 1 aa = s1[j] bb = s2[i] if (bb = 0) then exit end if wend i = 0 j = j + 1 aa = s1[j] bb = s2[i] result = 0xFFFF wend end sub sub procedure interrupt() ‘ if interrupt is generated by TMR1IF if (PIR1.0=1) then T1CON.0 = 0 ready = 1 i= 0 PIR1.0 = 0 ‘ Set Timer1 on, Set data ready, reset array counter, Clear TMR1IF end if ‘ if interrupt is generated by RCIF if (PIR1.5 = 1) then txt[i] = UART1_Read() Inc(i) if (i = 768) then i= 0 end if T1CON.0=0 TMR1L=0xB0 TMR1H=0x3C T1CON.0=1 PIR1.5=0’ Stop Timer 1, Timer1 counts from 15536, Start timer 1, Set RCIF to 0 end if end sub sub procedure Display_Cursor(dim lat as integer, dim lon as integer) dim latitude_y, longitude_x as integer latitude_y = ((61*(90 - lat))/180) + 1 longitude_x = ((125*(lon + 180))/360) +1 Glcd_Dot(longitude_x,latitude_y,2) Glcd_Dot(longitude_x-1,latitude_y,2) ‘ Centar, Left, Right dot Glcd_Dot(longitude_x,latitude_y-1,2) Glcd_Dot(longitude_x+1,latitude_ y,2) ‘ Right, Upper dot Glcd_Dot(longitude_x,latitude_y+1,2) Delay_ms(500) Glcd_Image( @ world_bmp ) ’ Lower dot, display World map end sub main: ADCON1 = 0x0F GLCD_Init() Glcd_Set_Font(@font5x7, 5, 7, 32) ‘ Set AN pins to Digital I/O Glcd_Fill(0x00) Delay_ms(100) ready = 0 T1CON.5 = 1 T1CON.4 = 1 ‘Set Timer1 Prescaler to 1:8 PIE1.0 = 1 TMR1L = 0xB0 TMR1H = 0x3C ‘ Enable Timer1 interrupt, Timer1 starts counting from 15536 PIR1.0 = 0 UART1_Init(9600) PIE1.5 = 1 ‘Clear Timer1 interrupt flag, Enable Usart Receiver interrupt INTCON.7 = 1 INTCON.6 = 1 ‘ Enable Global interrupt and Peripheral interrupt T1CON.0 = 1 Glcd_Image(@world_bmp) ‘ Start Timer 1,Display World map on the GLCD while TRUE RCSTA.1 = 0 RCSTA.2 = 0 if (ready = 1) then ‘ if the data in txt array is ready do: ready = 0 nmbByte = search_str2_in_str1(txt,”$GPGLL”) cnt = 0 for g = nmbByte to nmbByte+39 str_[cnt] = txt[g] inc(cnt) next g if (nmbByte <> 0xFFFF) then if (str_[7] <> “,”) then latitude = (str_[7]-48)*10 + (str_[8]-48) longitude = (str_[20]-48)*100 + (str_[21]-48)*10 + (str_[22]-48) if(str_[18] = “S”) then latitude = 0 - latitude end if if(str_[32] = “W”) then longitude = 0 - longitude end if Display_Cursor(latitude, longitude) end if end if end if wend end. Microchip®, el logotipo y combinaciones de los mismos, PIC® y otros, son marcas registradas o marcas de Microchip Corporation o sus subsidiarias. Otros términos y nombres de productos pueden ser marcas de otras compañías.