Basic techniques and tools for development and maintenance of atomic-scale software
Location: Zaragoza, Spain
Organisers
The goal of the tutorial will be to improve the ability of the participants to produce software that will have a long life cycle, that is adequate for group software development, that is re-usable, that can better communicate with other atomic-scale software, that executes correctly and is portable, with an acceptable execution speed.
During the last decade, the standard of writing of such software has been steadily improving (also due to CECAM efforts), but it is felt that students and post-docs, with a physicist formation, who would like to start software development, while not having formally trained in software engineering, will benefit a lot from the proposed tutorial, especially tuned for atomic-scale software, and focusing on immediately useful concepts and tools.
We will focus on concepts and tools that are independent of the scientific programming language used by the developer (FORTRAN or C/C++). Although most of the examples will be taken from the software and standards developed within the European Theoretical Spectroscopy Facility (http://www.etsf.eu/), the tutorial will aim at a high level of applicability, and thus should benefit to every developer of atomic-scale software. Both the example software and the tools (at the exception of Xdb) that will be relied upon are available under a free software licence, so that the participants will encounter no barrier to immediately use what they have learned when back in their research institution.
Deadline for application: 1 April 2010
Plan of lectures
This five-day tutorial, is intended for an audience of scientists involved
in software development for atomic-scale simulations. The following topics will be covered :
Day 1
(1) Basic concepts of software maintenance
(concepts [1-4] ; coding rules, ROBODOC [5]) ;
(2) Version management tools
(concepts ; bzr [6] and svn [7]) ;
Day 2
(3) Scripting. Introduction to Python [8] ;
(4) Debugging and testing
(concepts - idb and gdb [9], buildbot [10] ) ;
Day 3
(5) Code re-use. Libraries.
(concepts ; NetCDF [11], ETSF_IO [12]) ;
(6) File formats. Conversion tools.
(concepts ; NetCDF [11] , ETSF FileFormat [12], ETSF_IO [12], XML [13]) ;
(7) The autotools
Day 4
(8) F90/C/Python bindings
(9) More libraries and file formats
Day 5
(10) Profiling and optimizing
Each theme will be addressed thanks to a mix of :
presentation of basic concepts, and general information ;
introduction to related specific tools, with examples ;
detailed presentation of how it works for selected atomic-scale software ;
prepared hands-on exercises ;
working sessions, during which the student work on a self-defined project ;
short presentations of the integration of these concepts for different atomic-scale software.
References
Xavier Gonze (UCLouvain) - Organiser
Matthieu Verstraete (University of Liege) - Organiser & speaker
France
Damien Caliste (CEA) - Organiser & speaker
Francesco Sottile (Ecole Polytechnique) - Organiser
Spain
Alberto Castro (ARAID Foundation) - Organiser & speaker
Yann Pouillon (CIC nanoGUNE) - Organiser & speaker