Wednesday, June 26, 2013

Un paseo por C++11

Ayer tuve el placer de compartir con la tarde con un buen número de desarrolladores C++.

Amablemente, la empresa Indizen, organizó un evento al que asistieron, además de sus propios desarrolladores, otros de varias entidades financieras. Ya sabía yo, que en el sector financiero C++ es un lenguaje muy usado, pero no me esperaba tal éxito de asitencia. Durante dos horas un buen número de desarrolladores soportaron mi presentación sobre C++11 y todavía tuvieron energí para comenzar un turno de preguntas cuando eran las nueve de la noche.

Posteriormente pudimos compartir un vino español, también por gentileza de Indizen. Les estoy muy agradecido por una excelente organización, así como por la elección de un lugar tan agradable como el museo del ferrocarril.

Evidentemente, en dos horas solamente se pueden dar unas pinceladas de C++11, pero creo que la audiencia pudo obtener una visión general de los cambios. Y más de uno dijo en español, aquello que yo ya había oido a Herb Sutter (C++ feels like a new language). Y realmente lo es.

Comenzamos la presentación dando una visión general del propio proceso de normalización del lenguaje y poniéndolo en contexto.

Continuamos viendo algunas características que hacen C++11 algo más fácil de aprender y enseñar. Por supuesto, esto de la facilidad es opinable, pero hablamos de la nueva sintaxis de iniciación uniforme, la inferencia de tipos, los bucles basados en rango, las expresiones constantes, y los literales definidos por el usuario. Tratándose de desarrolladores para el sector financiero, y sabiendo que en esos entornos las simulaciones estocásticas en general (y las de Monte Carlo en particular) son una práctica habitual, no me pude resistir a comentar algo sobre la nueva biblioteca para generación de números y distribuciones aleatorias.

Dediqué otro bloque de la charla al patrón por excelencia en C++: RAII. Recordamos como el uso sistemático de este patrón es una buena receta para evitar los problemas de goteos de memoria en particular y de recursos en general. De aquí, pasamos a ver como la semántica de movimiento contribuye a simplificar este enfoque.

En cuanto a genericidad vimos las ventajas que introducen el uso de expresiones lambda y cómo esto permite hacer uso de los algoritmos genéricos de la STL de una forma más simple. Vimos algún uso de las plantillas con número variable de parámetros. También vimos ejemplos del uso de los alias de plantillas. Finalmente realizamos una pequeña introducción al modelo de concurrencia de C++11.

Apreveché la ocasión para presentar resultados concretos de como se puede hacer uso de nuevas prestaciones de C++11 para optimizar el rendimiento de aplicaciones y los resultados obtenidos en un caso concreto.

Finalmente, anuncié la celebración de un nuevo evento: el Dia C++, que celebraremos el próximo octubre ( noviembre) de 2013. Además, presenté el contenido de un curso de C++11 para desarrolladores C++. Es un curso intensivo de 20 horas que el grupo ARCOS ya ha impartido el pasado mayo como curso de formación interno en una empresa del sector de las telecomunicaciones.

Si tenéis interés, las transparencias están disponibles en:

https://sites.google.com/site/aviewoncomp/cpp11.pdf

Friday, June 7, 2013

Post-Doc position available at ARCOS research group



Yes. We are hiring!

I am glad to publicly announce that our REPARA proposal for an FP7-ICT project has been accepted and we will start next September. We are really very excited with this. REPARA is a 3 years project involving 4 academic partners and 2 industrial partners from (Germany, Hungary, Israel, Switzerland, and Spain) which will address real challenges on adapting C++ software for heterogeneous parallel computers.

Below you will find a preview of our job offer. If you are interested and you need additional information, please, make me know. The official job offer will be available in a few days.

Post-Doc Position: REPARA FP7-ICT Project

The ARCOS research group (University Carlos III of Madrid, Spain) is opening a Post-Doc position in the context of the FP7 project REPARA (Reengineering and Enabling Performance and poweR of Applications) which will start on September 2013 with a duration of 3 years.

The REPARA project aims to help the transformation and deployment of new and legacy applications in parallel heterogeneous computing architectures while maintaining a balance between application performance, energy efficiency and source code maintainability. To achieve this goal REPARA will combine multiple approaches for refactoring C++ source code to target multiple programming models for parallel heterogeneous architectures.

In this context we are looking for a researcher to help us in the development of language extensions for C++ compilers that can be used for semantic annotation of generic software components. In particular, tasks include

  1. To define mechanisms to restrict generic algorithms to type subsets, as well as techniques for algorithms overloading on type subsets. 
  2. To define mechanisms for specifying the semantic properties of a library in generic terms.
  3. To apply these techniques for specifying libraries identified by use cases to provide multiple implementations for specific processing elements.

The applicant should hold a PhD in Computer Science or Computer Engineering with a strong background in compiler design. A strong knowledge of the C++ programming language is required. Previous experience in development of compiler technologies with gcc or clang are a plus. Candidates should be fluent in English (written and spoken) and show their ability for team-working.

For more information, contact Prof. J. Daniel Garcia at josedaniel.garcia@uc3m.es