Electrónica, Microcontroladores y Delphi
Bueno, es nada más para decir, que si alguien necesita ayuda con la parte de HARDWARE experimental o proyectos que involucren electrónica y microntroladores, estoy a disposición para colaborar. Soy técnico en robótica, por lo que este apartado de asembler es mi debilidad. Si necesitan diseñar circuitos, etc, no duden en consultarme.
Saludos |
Hola
Pues yo necesito unos cuantos robots que reemplacen a mi personal, cuando empiezo el curso.:D:D:D Saludos |
Cita:
|
Cita:
|
Hola.
De robótica nada, pero trabajo con microcontroladores (la línea PIC de Microchip, programándolos en Pascal) y también uso Delphi. (Los dos chips grandes de la foto...tienen código generado con un compilador de Pascal...cada chip tiene 32 Kb de memoria para programa y 2 Kb de RAM) :) Intento ganarme la vida en la parte de electrónica e informática industrial. Me interesa todo lo referido a control, adquisición de datos, monitoreo, automatización. Así que intentaré aportar lo que se pueda al foro y por supuesto, aprender de otros. Saludos ! |
Hola Amigos.
(la línea PIC de Microchip, programándolos en Pascal) Suena interesante, me gustaria aprender. Un Saludo. |
Cita:
Saludos |
Desde la universidad que no programo microcontroladores. Mi proyecto de fin de carrera lo hice en ensamblador y delphi, en cuanto al hardware la pieza principal era un PIC 16876, lo echo de menos :(
|
Cita:
El unico problema, es que estamos en ASM, faltaría el subforo Electrónica & Delphi como para no desvirtuar el asunto. Salutes |
Hola mamu.
Mi comentario anterior fue una broma jejejeje es que me resulto curioso lo de programar un micro en Pascal. (la línea PIC de Microchip, programándolos en Pascal) Claro yo entendi lo que queria decir el amigo. Yo estoy de acuerdo contigo en que algunos copiladores solo generan mas codigo de lo que en realidad hace falta.Yo entre en el mundo de los microcontroladores a principio de la decada de los 80s y aprendi de una forma poco usual (metiendo hex uno a uno) pero fue la unica forma de entenderlos en esa epoca.Luego llegaron los Dallas DS5000 con sus Dinamic Rams y fue mas facil la cosa ya me permitia programar sobre lo programado y usando otras herramientas. Mis primeros programas eran creados en programadores universales y hex a hex, con las instruciones mcs-51 a mi lado para entender que estaba haciendo y que queria hacer en cada funcion.Eso hoy dia suena a tecnologia atrasada jajajaja y estoy de acuerdo.Pero eso me ayudo a entenderlos mejor y poder hoy dia mirando una linea de codigo "hex" o "Intelhex" saber que hace o que espera.Cuando uno domina las instruciones de un micro en particular solo hace falta un notepad y un copilador como el Tasm-51 para MS-DOS window.Creo mi programita asm lo guardo como tal llamo a tasm-51 miprogramita.asm miprogramita.hex y enter. Ya este me genera mi intelhex y a ponerlo al chip. En microcontroladores el espacio de memoria es importante y eso se logra reduciendo al maximo el codigo.Asm es el camino para eso aunque suene tecnologia atrasada. Un Saludo. |
[quote=mamu;273118]a. Al igual que en C, es muy cómodo, pero yo prefiero el assembler, es cuestión de gusto y de costumbre, pero a veces es cuestión de espacio.
[quote] |
Cita:
Por ejemplo en esa placa que mostré (es la placa principal de un equipo de balanceo) usa cálculos angulares y de tensión con punto flotante (incluyendo cálculos trigonométricos), manejo de strings ("campos de edición" numéricos y alnanuméricos en un display LCD), almacenamiento de una tabla de piezas (con sus correspondientes campos), comunicación con la PC, etc. Si no hubiera usado un lenguaje de alto nivel todavía estaría programando. Ejemplo de un procedimiento de ingreso numérico de datos por teclado, con validación (máximo y mínimo): Código:
// Mostrar campo de entrada de datos numéricos validado (tipo Word, 5 caracteres de largo) Código:
// Código:
Procedure Ensayo_Automatico; End; |
Hola rretamar.
Entiendo el punto y lo complejo de la aplicacion.Veo dos microcontroladores, un 232 y algunos otros integrados en tu tableta. Pero al final por mas complejo que lo puedas ver. Un microcontrolador es un encapsulado monolitico " no inteligente " que recorrera toda su memoria ejecutando intruciones y tomando diferentes vias de acuerdo a lo establecido en su programa y otros eventos internos y externos. Limitados a algunas manipulaciones Borleanas.Ya la parte mas profunda en las matematicas esas son para una pc y por eso la presencia del 232 en esa tableta. Un Saludo. |
El diseño inicial estaba basado en una Panel-PC y un microcontrolador externo, que con la ayuda de un ADC de 12 bits más un encoder, se encargaria de la adquisición de datos. Pero el cliente pidió que no se use una PC y se terminó usando dos micros, un teclado de membrana y un display LCD de texto:
En cuanto al tamaño del código generado, obviamente será más extenso un compilado que el ensamblador "a pelo", pero los microcontroladores de gama alta tienen generosas cantidades de memoria (en 64 Kb se puede meter MUCHO código en Pascal). Y hay microcontroladores con bastante más de 64 k, (a precios más que accesibles, incluso con conexión USB o ethernet) así que el espacio no es un problema. Este tipo de proyectos los realizo estilo "open source", o sea entrego los planos (esquemas electrónicos) y el código fuente del software al cliente. PD: Me uno a la petición de un foro "electrónica & Delphi". ¿ A quién hay que hablarle ?. Saludetes ! :D |
rretamar, es muy cierto lo que decis de los uC, sobre todo de los más nuevos. Yo prefiero el assembler, y apoyo mucho la programación de uC en otros lenguajes, ya que da la oportunidad de incorporar grandes mentes al mundo de los uC, exelentes programadores con escaso conocimiento de assembler.
Soy partidario que un buen programador de uC independientemente del lenguaje, debe estar familiarizado con la electrónica misma. Podriamos hacer muchísimos tutoriales de técnicas de interface, donde se incluya la electrónica paso a paso, y su correspondiente ejemplo de control en delphi, pero no se en que espacio se ubicarían. Estoy más que convencido que unos cuantos colegas foristas empezarían a buscar "cablecitos" :D. Saludos |
Cita:
Saludos ! |
Hola mamu y rretamar.
Veo que les agradaria la idea de un foro de electronica.Foros de electronica en la web son los que sobran.A mi me gustaria un foro de microcontroladores orientados a trabajar con aplicasiones Delphi.Algo asi como crear programas en donde se emplearan uC y Delphi. Eso estaria mas de acuerdo con la estructura de este foro. Es solo una opinion. Se puede estudiar la cosa y pues elevar la idea a San Emilio a ver si nos concede el milagrito.;) Un Saludo. |
Cita:
Yo soy moderador de un foro de electrónica, pero es exclusivo de electrónica, y he tocado muchas veces el control mediante Pascal de algunas interfases. Saludos |
Cita:
Llegaron lo de gama alta y los más usados son el 18F2550 y el 18F4550 EDIT: - Sobre la electrónica, aquí también se basa en electrónica para microcontroladores y asm. Pueden poner algo en youtube, ahora estoy practicando con los pic, ver ejemplo simple y básico. http://es.youtube.com/watch?v=lB9TyErcVU4 - Sobre me MAX232, si no quieres que sean identificado de lejos por los 4 condensadores, hay uno que se llama MAX233 que es igual que el MAX232 con la diferencia que los condensadores son internos y que este IC cuesta más que el MAX232 junto con los 4 C. - Sobre las imágenes de arriba, si tiene más imágenes, las pone para verlas, ya me he guardado las dos que pusiste. No se para qué usar dos pic de 40 pines habiendo uno de 80 y 100. Un saludos. |
Lo de los dos PICs es un error de diseño que lo pagué muy caro (en cuestión de tiempo de desarrollo). Por un lado me permitió que el uC principal delegue tareas al otro uC, eos me permitió dividir el problema en dos partes bien diferenciadas, pero por otro, tuve que implementar un rudimentario protocolo de comunicaciones entre ambos y hacer que "dialoguen entre sí").
Hoy en día no haría eso; como bien decís, usaría un uC grande "todo-en-uno" pero a veces hay que "quemarse" para aprender la lección. Saludos ! |
Cita:
En lo personal nunca he trabajado dos uC tan serca uno del otro (en una misma placa) pero si en un mismo sistema y no existe uC alguno por muchos puertos y memoria que tenga.Lo que pueden hacer varios uC en un mismo sistema controlados por un master. Un ejemplo las alarmas de fuego por zonas.Cada zona es controlada por un uC y cuando tiene algo que compartir con el master, entonces se produce la comunicacion.Un sistema de 20 zonas por ejemplo.Tiene cada zona su uC que se esta comunicando con los distintos componentes( detectores de humo por ejemplo) y si todo marcha bien el master no tiene que enterarce de lo que pasa, pero si alguno de estos detectores de humo se va en alarma o no se comunica con el uC rutina que se hace cada unos cuantos segundos como medida de supervision, entonce si hay algo que comunicar al master. Solo una de las tantas aplicaciones en las que un solo uC por muy potente que sea no puede hacer solito.;) Un saludo y ese trabajo que muestras en la placa con tus dos uC es una obra de arte. |
Lo que dije arriba de usar un μC de 80 pines o 100 lo dije porque dos pic al lado me parecía raro, pudiendo poner uno.
Si están mucho más separado ya se entiende. Eso si, es un reto hacer funcionar dos pic juntos. Lo entendería mejor si usara un pic para funciones y el otro para avisos de LED y LCD, cosas así. Bueno, ya están los PIC32 que dicen ser muy buenos, ahora a 80MHz, antes 72Mhz, ya no se venden. PD: Si tienes má imágenes de tus proyecto sea cual sea, lo pones por aquí para verlo, me llaman la atención estas cosas. PD2: Por cierto, ¿qué cursos has hecho para hacer esos proyectos de calidad profesional? |
En ese desarrollo la idea fue dividir las tareas principales en dos microcontroladores, a saber:
uC #1: encargado de tomar muestras de tensión desde un ADC, analizar esos datos, y al mismo tiempo la posición angular de un rotor a través de un encoder incremental. También mide la velocidad de giro del rotor. uC #2: hace la "glue-logic", esto es: manejo de teclado, display LCD, acceso al RTC (reloj/calendario, a través de un chip externo), lectura de pulsadores adicionales, comunicación con la PC, impresión de etiquetas en una impresora de puntos LX300+, comnicación con una tercera placa que se encarga (mediante un set de 15 comandos) de controladr un variador de velocidad, rutina de auto-ensayo para calibración y obviamente recibe e interpreta los datos provenientes del primer uC. Esta es la placa controladora de variador de velocidad, también basada en un PIC y con código generado por el compilador de Pascal: En cuanto a cursos...mi formación al respecto es completamente autodidacta, ya que no tengo estudios "formales" en electrónica (soy técnico electromecánico y analista de sistemas...nada que ver...) y además de la práctica en sí, todo lo adquirí (y lo sigo haciendo) por medio de biblografía. Libros, libros y más libros (pdf y papel). :D Lindo ladrillo me salió... Saludos ! |
Muchas gracias por responder mucho y la nueva imagen, otra foto guardada en mi PC.
Pues tienes mucho talento, también soy autodidacta y estoy aprendiendo con un libro en ASM puro y duro, le estoy cogiendo el gustillo aunque admito que es más complicado que en C. ¿Cómo hace esa placa PCB perfecta? Es decir, el color verde así y los símbolos blancos. Parece hecha de fábrica. ¿Sabes alguna Web que te explique cómo se hace la PCB en verde? Lo que he encontrado por www.google.com la verdad no son de calidad como la tuya ni tampoco verde. Si has hecho toda esta placa tu sólo, vales más de lo que crees. La verdad es que has hecho un buen trabajo. EDIT: Cómo se llaman estas cosas señalada en color aquí abajo para comprarlas. Lo he manejado en prácticas de empresas pero no recuerdo sus nombres, tampoco el alicate especial para los conectores. Saludos. |
Hola.
Respondo por partes: La placa se hace con un software (un CAD) para diseño de circuitos impresos. Hay varios, libres y privativos: Protel, Eagle, Kicad, Orcad, etc. Esos CAD te generan un archivo que lo envias a una empresa que se encarga de hacer el circuito impreso. Estos procesos se hacen con máquinas automáticas y por ende estas empresas te piden un mínimo de dos o tres placas para encargar (a más placas, el coste se abarata). Hay métodos para hacer circuitos impresos "caseros" pero ni se acercan a la terminación de uno hecho a máquina, además de que el diseño que podés hacer así es muy limitado (nada de máscara antisoldante, ni estañado, ni perforaciones metalizadas, ni serigrafía del lado de los componentes, ni nada...). La parte de la placa que posteaste muestra una bornera de tres contactos (flecha roja) y los cables intertados en la misma tienen terminales TIF en los extremos. Estos terminales se consiguen (vienen en bolsas de 100, en diferentes diámetros) en las tiendas de electricidad, y las borneras para soldar en circuito impreso las compras en tiendas de electrónica. Además de un mejor acabado (cubren el extremo de la vaina plástica de los cables) , permiten un mejor contacto ya que la presión de los contactos de la bornera sobre el conductor es más uniforme. Cuando el equipo/máquina se pone "en producción", luego de uno o dos meses de funcionar les doy un reajuste a las borneras con un destornillador. Terminal TIF similar al de la foto (tercero y cuarto, primera fila, de izq. a derecha). Hay que pedir URGENTE si se puede crear un foro de "Delphi & Pascal y electrónica". Saludos ! ;) |
Gracias amigo.
¿Y la empresa de hacer placas cómo se llama, dónde está o su web? Has dicho Protel, ahora se llama Altium Designer y me parece el mejor para hacer PCB. Lo de pedir como mínimo placas que son 3, ¿Cuánto puede costar? Sobre todo si es el tamaño de un grabador de pic TE 20x? Aproximadamente 10x20 cm. Por cierto, ¿cómo se llaman esos alicates especiales para trabar las borneras en los cables? Tenía intención de comprar una fresadora como esta que se muestra abajo pero economicamente no puedo. Deja ver si encuentro uno más barata. Si por casualidad alguien encuentra una fresadora de PCB a un precio razonable, nos avisa por aquí. Fuente: http://www.elektor.es/extra/profiler...t.264487.lynkx Vídeo: http://mx.youtube.com/watch?v=vkmoy1YdZIA |
En cuanto al costo de las placas, deberías consultar a empresas de tu país. Yo vivo en Argentina, así que esa información no te servirá de mucho (para no decir DE NADA). ;)
Saludos ! |
Cita:
Linda plaqueta, Jeje Saludos |
Cita:
Desentrañando el misterio de la plaqueta: Efectivamente, se trata de un DAC de 16 bits implementado con una red R-2R basada en resistencias al 1%. Es algo aparatoso pero cumple su cometido (puedo controlar la velocidad de giro con una resolución de 1 rpm). El problema es que no disponía en el mercado de un DAC de suficiente resolución (al menos 10 bits) y como me suele suceder a veces, hay que diseñar al revés: se estudian los requerimientos y luego se hace la implementación según lo que se consiga en el mercado. Se que hay chips dedicados que hacen lo mismo y de forma mucho más simple, pero en este país no los comercializan. De esa forma tengo una salida analógica lineal que me permite controlar el variador de velocidad en forma muy exacta. El optoacoplador blanco (cuáduple) se encarga de controlar las entradas digitales. Todo muy "artesanal", pero ya está hecho...y funciona !. Para los curiosos, este es el esquema de la famosa :p plaqueta oscura: http://www.hrservicios.com.ar/Convertidor_DA.pdf.zip Saludos ! |
Muy buena aportaciones.
Por si le pica la curiosidad a alguien, me ha llegado un LCD hoy mismo en 3 días, a ver si lo manejo. Mientras tanto, estaba antes mismo con la barra de led. http://es.youtube.com/watch?v=00IpV2dPV1U |
Hola rehome, me uno a este hilo. Soy muy bueno programando PIC's en varios lenguajes empezando por asm. Ultimamente me he dedicado a MikroC for PIC.
LEs cuento que me di cuenta que es importante conoser los tres lenguajes basicos de programacion de alto nivel en microcontroladores C Basic y Pascal. El lenguaje C lo recomiendo mucho, por que debido a su gran difucion todos los micros en diferentes marcas tienen compiladores en C. Por ejemplo Freescale semiconductors los antiguos motorolas tienen un compilador c gratuito asta 16k mas que suficiente para aplicaciones avansadas. El compilador CCS es lo mejor de lo mejor pero asi tambien es muy caro, pero altamente eficiente. Es por eso que este compilador es considerado de de desarrollo o de uso empresarial. Los compiladores de Mikroelectronica son muy buenos pero poco eficientes. La eficiencia de un compilador para microcontrolador es un factor muy importante a tener en cuenta dados los escasos recursos en los micros como es la memoria de programa y la memoria ram de datos. Una novedad ahora es el compilador Mikroc For 8051 con una interfas muy interesante. Todabia me falta probarla bien para decidir si es bueno pero si no para eso tenemos el Keil C51 un compilador del estilo ccs muy bueno y famoso para la linea 8051. PAra los AVR tenemos muchos de mikroelectronica a exepcion del Mikro C For AVR :mad: Con los avr y los 8051 somos mas afortunados ya que cuentan con compiladores libres en lengueje C aunque un poco complicados como el SDCC para 8051 y el WINAVR que se integra perfectamente con AVR Studio. Unos compilador muy bueno y economicos son el CodeVision avr y el RKIT. Bueno y muchos mas la mayoria utilizan el C por lo cual el lenguaje C es la mejor opcion si uno quiere programar muchas clases de microcontroladores. Ademas el C es un lenguaje mucho mas sercano al ASM que es lo mas eficiente en generacion de codigo. Un saludo a todos y mi mensage es que no solo existen los PIC pero por algo se comienza. :D |
Hola amigo.
Bueno, el otro día en otros foros hablamos de CCS no puedes ejecutar todas las instrucciones del PIC sobre todo si es nuevo, a veces hay que esperar un año, para ello puedes meter ASM por medio de C como parte del código. No se si es verdad, ya que sólo uso ASM con MPLAB. ¿Y MPLAB no incluye C para los PIC? He leído que si, pero pagando. PArace que los C todos son de pagos y los gratuitos dejan mucho que desear. Al menos en ASM hago lo que me da la gana. |
Cita:
Saludos |
Hola rehome te aclaro que los microcontroladores sobre todo los pic tienen un numero fijo de instrucciones y solo varia de familia a familia.
Los pic cuentan con varias familias entre ellas los PIC16xx los cuales tienen un numero de 35 instrucciones fijas las cuales no varian de modelo a modelo lo que si cambia son los perifericos que maneja. Hacerca del asm algunos compiladores como el ccs cuentan con seudoinstrucciones asm que el compilador las reinterpreta como asm. Pero eso si todo buen compilador debe permitir la inclucion de codigo asm incluso el ccs y el mikroc. Aunque las comandos del mplab no los interpreta como la instruccion banksel entre otras. Es decir que se puede y un buen programador de Microcodigo debe saber utilisar asm dentro de su codigo ya sea C Basic o Pascal. ¿Por que el asm? muchas veses por que el compilador no nos da todas las obciones o cuando nesesitamos hacer mas eficiente nuestro codigo. hasta luego:cool: |
Hola. Lo primero un saludo a todos los foreros. No conocia la existencia de este foro y ha sido para mi una agradable sorpresa.
Y despues del saludo os cuento. Yo llevo trabajando con microcontroladores desde que salió el i8748 a finales de los 80, siempre en assembler, y tengo unos cuantos proyectos funcionando por ahi. Nunca he programado uC en lenguajes de alto nivel porque no me fio de que la programacion sea tan eficiente como la que yo puedo hacer en assembler, es mas, para el 16F84 me hice mi propio entorno integrado (editor de texto/compilador/grabador flash) todo en uno. Pena que no me funciona en XP y tengo que recurrir a una maquina que tengo con W98 para hacerlo funcionar. |
Hola Delano.
El 8748 no lo conosco, pero si trabaje el 87C51 que era un 8051 pero con uv (ultra violeta) window para borrarlo. Ufff llovio mucho desde entonces jejejeje. Yo desde que entre en el mundo de los uC en el 1986 solo trabajo los 8051 y sus parientes Dallas, Atmel,etc. Y estoy de acuerdo en que nada como un codigo asm, reduces el peso del file y evitas las repeticiones de subrutinas. Un Saludo. |
Cita:
Saludos y ánimos, cada vez somos más los uControleros :D |
Efectivamente, no funciona la parte de E/S a los ports, y por otra grave imposibilidad, los tiempos de los pulsos de grabacion son del orden de uSeg, y eso lo hacía programando el oscilador del altavoz y esperando el fin de tiempo en un bucle hasta aparecer la bandera de IRQ del chip, pero con los problemas de E/S se multiplica el problema. Estoy trabajando en ello.
|
Cita:
|
Hola Delano.
En el 1980 salio el 8051 con EEProm y el 87C51 con uVProm.A mediados de los 80 la Dallas saco el DS5000 con memoria Volatil y bateria para retener la memoria.esto permitia programar sobre lo programado sin tener que borrar todo el chip.Se podia programar un byte o todos si querias. El DS5000 me ayudo mucho a practicar codigo asm para los 8051 por la rapides en cambiar algo y rodarlo de inmediato. Un Saludo. |
La franja horaria es GMT +2. Ahora son las 15:14:17. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi