En Eagle, a menudo prefiero enrutar algunos cables (power, xtal, UBS, etc.) y dejar el resto en la ruta automática. Cuando no estoy satisfecho con el resultado, enruto un poco más y dejo que la ruta automática vuelva a intentarlo.
Mi problema es deshacer el trabajo de la ruta automática, sin deshacer mi propio trabajo. La forma básica de hacer esto es simplemente no guardar la versión autorrutada y luego volver a cargar la placa. Pero una vez que cometo el error de guardar la versión autorrutada (y purgar las copias de seguridad) todavía quiero poder volver a la versión preautorizada.
Un intento de hacer esto es identificar todos los cables enrutados automáticamente en un ULP y crear la cadena de comando para RIPUPAR estos segmentos. Puedo hacer arreglos para que el ULP identifique los cables enrutados automáticamente, por ejemplo, dándoles un ancho diferente. Pero el comando RIPUP parece rasgar el segmento de cable seleccionado Y LOS SEGMENTOS ADJACENTES. Hasta ahora no he encontrado un comando que rasgue solo el segmento de cable seleccionado.
Así que supongo que tengo dos preguntas: - ¿Cómo se combinan el enrutamiento manual y el enrutamiento automático de forma iterativa (prueba y error)? - ¿Hay alguna manera (probablemente usando ULP y comandos) para extraer un subconjunto de segmentos de cable?
(actualización) Intenté el enfoque opuesto: en un ULP, reúna todos los segmentos de cables que quiero conservar, realice una extracción completa y luego restaure los segmentos de cables (usando el comando ROUTE). Sin éxito, los segmentos deben estar en un orden específico para los comandos de ruta (no en el orden en que ULP los encuentra :(), primero se deben realizar las vías y algunos problemas más.
GRRRR, debe haber una manera fácil de hacer esto, ¿o soy demasiado optimista?
fuente
Respuestas:
Odio responder mi propia pregunta, pero aquí voy. Espero no obtener puntos por responder, eso sería extraño, ¿solo por aceptar una respuesta? (Por cierto, no recibí ninguna respuesta en el foro Element14).
La solución es usar el comando DRAW, no ROUTE. DIBUJO colocará un segmento de cable, exactamente donde lo especifique (a diferencia de RUTA, que intenta conectarse a un cable aéreo no enrutado. RUTA es esencialmente inútil en un guión). El siguiente problema es la vía: no puedo (o no quiero) distinguir entre una vía manual y una vía autorutada, así que mantengo todas las vías que conectan dos (o más) segmentos de cable manual. Se eliminan otras vías.
Entonces, lo que hace mi guión final es:
Tenga en cuenta que probablemente no funcionará para más de dos capas, ni para otras cosas que no sean segmentos de alambre en la capa de cobre.
En mi humilde opinión, todo el concepto del águila ULP y los lenguajes de comando es problemático. Un ULP se ejecuta en un entorno de solo lectura, la única forma en que puede afectar el circuito, la placa o la biblioteca es creando una lista de comandos. Esto elimina algunas técnicas de programación útiles, pero lo peor es que los comandos no fueron diseñados para crearse fácilmente desde un ULP. Necesita todo tipo de transformaciones (en este caso: coordenadas, nombres de formas) para traducir del mundo ULP al mundo CMD.
(editar) Antes de ejecutar este ULP, configure la selección de 'curva de alambre' para permitir ángulos arbitrarios, de lo contrario, Eagle intentará adaptar los alambres resucitados a los ángulos permitidos, lo que puede provocar un desorden sangriento. En mi humilde opinión, este es otro ejemplo del problema con ULP / SCR.
Este es el código ULP:
fuente
Wouter No vi tu pregunta antes porque estaba en Masters la semana pasada.
La forma en que trato esto es guardar una copia de la placa con un nombre diferente justo antes de ejecutar el enrutador automático. Siempre lo llamo SAVE.BRD, que se puede eliminar de forma segura una vez hecho todo.
Mi flujo de trabajo de enrutamiento parece ser muy similar al suyo. Enruto las partes críticas manualmente, me aseguro de que las clases de red estén configuradas razonablemente, luego ejecuto el enrutador automático. Luego busco problemas como cuando el enrutador automático no pudo encontrar una solución, terminó haciendo algo inconveniente, etc. Vuelvo a la versión guardada (antes del enrutamiento automático), hago algunos cambios manuales con suerte para que el enrutador automático no obtenga en problemas, luego intente nuevamente. Esto puede repetirse 5-10 veces, dependiendo de la complejidad del tablero. Los primeros pocos pases de ruta automática son principalmente para ver si hay una solución y aproximadamente para encontrar los puntos problemáticos. Para eso ni siquiera uso ningún pase de optimización. Las rutas automáticas posteriores tienen una optimización completa, que para mí suele ser de 8 pases con costos que cambian sobre esos pases para obtener las características que quiero.
Aunque guardo en SAVE.BRD antes de cada paso de ruta automática (y luego vuelvo a abrir el archivo original para continuar con eso), trato de no guardar el resultado en ruta automática hasta que estoy contento con todo. Guardar la instantánea en SAVE.BRD cada vez es una copia de seguridad en caso de que mis dedos accidentalmente salven antes de pensarlo.
Sería bueno si Eagle tuviera una opción de extracción para el último pase de ruta automática, pero no existe tal cosa.
fuente
Si el archivo de datos de Eagle sigue el mismo enfoque que los anteriores con los que he jugado (p. Ej., El viejo Autotrax de DOS), entonces cada segmento de pista tiene una línea en sí mismo. Las líneas son "independientes" y pueden editarse o eliminarse sin afectar a nada más. Los sistemas "mejores" más nuevos pueden no tener una simplicidad tan poderosa.
Si las pistas son independientes, como se indicó anteriormente, y si los anchos de las pistas son únicos, [tm] debería ser fácil identificar los segmentos de las pistas y eliminar las líneas correspondientes.
La memoria tenue me dice que en una etapa escribí una rutina para identificar las etiquetas de los componentes y cambiarles el tamaño, rotarlos y moverlos en relación con el cuerpo del componente. La identificación de pistas suena fácil en comparación. ¡Guarde una copia antes de ejecutar el programa! :-).
fuente