Quiero comenzar a estudiar Perl, específicamente para verificar los archivos de salida de verilog. ¿Hay algún tutorial específico para decir Perl para los ingenieros de Verilog o algo así?¿Hay un tutorial de Perl para los ingenieros de Verilog?
Respuesta
Me temo que tampoco sé nada sobre Verilog, aunque observo que hay un Verilog Distribution en el CPAN, y contiene una gran cantidad de módulos que pueden ser relevantes para su trabajo. Hacer una búsqueda en search.cpan.org también puede proporcionar algún beneficio.
En cualquier caso, tendrá que aprender a caminar antes de poder correr. Es excelente tener un objetivo al aprender un nuevo idioma, pero los módulos no lo ayudarán a menos que primero comprenda la sintaxis y la semántica de Perl.
Si está buscando un buen libro para aprender, entonces el ya mencionado Learning Perl (por Stackoverflow Regular brian d foy) es excelente; agarra la última edición que puedes encontrar. Si quiere comenzar a aprender en este momento, entonces le recomendaría descargar Perl Training Australia 's Programming Perl course manual. Ambos recursos contienen muchos ejemplos detallados, enlaces a más información y ejercicios que pueden intentar cimentar su conocimiento. También hay una lista de recommended online tutorials en el Perl 5 wiki.
Divulgación: Soy coautor de los manuales de curso de Perl Training Australia, y admiro a Brian Foy como uno de los héroes de la comunidad de Perl. También soy colaborador ocasional de la wiki de Perl 5.
Todo lo mejor,
Paul
No sé nada sobre Verilog, pero si ya está familiarizado con otro lenguaje de programación, entonces recomiendo Learning Perl.
También puede consultar this page para más tarde.
No estoy seguro de analizar el resultado, (debe ser más específico sobre cómo se ve) pero parece que hay un good guide to existing Verilog-based modules que se ha actualizado recientemente.
Verilog puerta a nivel de archivos de listas de conexiones son sólo archivos de texto, por lo general emitidos desde algún software como Synopsys diseño compilador, por lo que son muy adecuadas para ser analizada por Perl.
Siendo simples archivos de texto, no hay nada especial en ellos con respecto a Perl. Estudie cualquier tutorial de Perl que le presente los conceptos básicos de la sintaxis de Perl y las expresiones regulares, y lo que aprenderá debe ser fácilmente adaptable a sus tareas relacionadas con Verilog. Ver por ejemplo: http://perldoc.perl.org/perlintro.html - para una introducción general. http://perldoc.perl.org/perlretut.html - para un buen tutorial de expresiones regulares.
Sin embargo, incluso un programa simple puede tener muchas fallas ocultas. Por ejemplo, digamos que usted desea imprimir todos los nombres de los módulos de su jerárquica Verilog lista de conexiones:
use strict;
use warnings;
my $infile = $ARGV[0] or die "$0 Usage:\n\t$0 <input verilog file>\n\n";
open(my $in_fh , '<' , $infile) or die "$0 Error: Couldn't open $infile for reading: $!\n";
while(<$in_fh>) {
if (m/^module\s+(\S+)/) {
print "$1\n";
}
}
close($in_fh) or die "$0 Error: Couldn't close $infile after reading: $!\n";
Incluso este ejemplo corto está lleno de errores potenciales: ¿y si el nombre del módulo no está en la misma línea que el " módulo "palabra clave? ¿Qué pasa si no hay espacio entre la apertura "(" del módulo y el nombre del módulo?¿Qué pasa si hay un espacio (o espacios) entre el comienzo de la línea y la palabra clave "módulo"?
Debe tener en cuenta estos desafíos. Si todo lo que necesita es una solución simple y única para una tarea específica relacionada con Verilog, un simple script de Perl como la solución anterior es una buena solución, siempre que esté debidamente documentado para advertir a los futuros usuarios de sus deficiencias conocidas.
Si necesita algo más complejo, que implique un análisis más complejo del código Verilog, tal vez intente ver si alguna de sus herramientas existentes (compilador, linter, comprobador de equivalencia formal, simulador, etc.) le da acceso a la datos que necesita Todas estas herramientas incluyen analizadores Verilog maduros y de trabajo, optimizados para velocidad/memoria y con frecuencia proporcionan una interfaz basada en Tcl para acceder a los datos.
Algunas de las personas que están arriba de mí han recomendado Verilog-Perl. Lo probé y descubrí que es extremadamente lento. Si está manejando listas de redes de más de 100MB, no usaría esta solución, pero su kilometraje puede variar.
Creo que está buscando Verilog Perl. Para una clase de pago en Perl para Verilog/VHDL, considere this from Doulos. En segundo lugar, el voto para el manual del curso Perl Programming Perl Training Australia para el aprendizaje de Perl en general.
El Perl Intro en perldoc es la forma en que lo aprendí por primera vez. Es un resumen del idioma realmente rápido y fácil. Todos los principiantes que ya conocen un lenguaje de programación deberían comenzar aquí. Puedes leerlo en aproximadamente media hora y estar listo para comenzar a codificar.
Usted puede encontrar uno en la sección de Perl http://pickatutorial.com
- 1. ¿Hay algún tutorial para los programadores de Ruby que quieran aprender Perl?
- 2. ¿Hay un buen tutorial sobre los scripts de MSBuild?
- 3. ¿Hay un ORM para Perl?
- 4. ¿Hay un plugin de Perl para IntelliJ?
- 5. Recursos para aprender Verilog
- 6. ¿Hay un Perl portátil?
- 7. ¿Hay algún tutorial/guía para usar Firebug?
- 8. ¿Hay algún buen video tutorial para Hibernate?
- 9. ¿Hay algún Tutorial para Protobuf-net?
- 10. ¿Hay algún tutorial de animación de Android útil para principiantes?
- 11. ¿Dónde hay un tutorial para usar XML con Delphi?
- 12. Operador de interrogación Verilog (?)
- 13. ¿Un tutorial para libjingle?
- 14. ¿Hay un límite de longitud de línea para los archivos de texto creados desde Perl?
- 15. ¿Hay un tutorial de función de hash suave?
- 16. Necesito un tutorial para DotNetOpenAuth
- 17. ¿Hay un complemento jQuery para los globos de ayuda para los usuarios noveles de un sitio?
- 18. ¿Hay un tutorial apropiado de Drupal 7 form api managed_file?
- 19. ¿Hay algún tutorial sobre giza ++?
- 20. ¿Hay alguna convención para escribir comentarios de POD para Perl?
- 21. División en verilog
- 22. Verilog generate/genvar en un bloque siempre
- 23. Módulo Verilog VPI simple para abrir archivos de audio
- 24. convertir un valor de cable a un entero en verilog
- 25. Pasar la jerarquía a un módulo Verilog
- 26. Tarea automática Verilog
- 27. ¿Hay un equivalente PHP de WWW :: Mechanize de Perl?
- 28. ¿Hay un operador perl "no en"?
- 29. ¿Hay un módulo Equivlant Perl para el módulo pydbg?
- 30. ¿Hay alguna revisión actual de módulos estadísticos para Perl?
datos Munging con Perl por Dave Cruz también es un buen libro para la gente que es el uso principal de Perl es simplemente tirando cosas fuera de texto. –