This workshop is concerned with the development of: <ul><li>Scientific software applications, where the focus is on directly solving scientific problems. These applications include, but are not limited to, large parallel models/simulations of the physical world (high performance computing systems).</li><li>Applications that support scientific endeavors. Such applications include, but are not limited to, systems for managing and/or manipulating large amounts of data.</li></ul> A particular software application might fit into both categories (for example, a weather forecasting system might both run climatology models and produce visualisations of big data sets) or just one (for example, nuclear simulations fit into the first category and laboratory information management software into the second). For brevity, we refer to both categories under the umbrella title of ′Computational Science and Engineering (CS&E)′.<br>Despite its importance in our everyday lives, CS&E has historically attracted little attention from the software engineering community. Indeed, the development of CS&E software differs significantly from the development of business information systems, from which many of the software engineering best practices, tools and techniques have been drawn. These differences include, for example: <ul><li>CS&E projects are often exploring unknown science, making it difficult to determine a concrete set of requirements a priori.</li><li>For the same reason, a test oracle may not exist (for example, the physical data needed to validate a simulation may not exist). The lack of an oracle clearly poses challenges to the development of a testing strategy.</li><li>The software development process for CS&E application development may differ profoundly from traditional software engineering processes. For example, one scientific computing workflow, dubbed the ″lone researcher″, involves a single scientist developing a system to test a hypothesis. Once the system runs correctly and returns its results, the scientist has no further need of the system. This approach contrasts with more typical software engineering lifecycle models, in which the useful life of the software is expected to begin, not end, after the first correct execution.</li><li>CS&E applications often require more computing resources than are available on a typical workstation. Existing solutions for providing more computational resources (e.g., clusters, supercomputers, grids) can be difficult to use, resulting in additional software engineering challenges.</li><li>CS&E developers may have no formal knowledge of software engineering tools and techniques, and may be developing software in a very isolated fashion. For example, it is common for a single scientist in a lab to take on the (formal or informal) role of software developer and to have to rely solely on web resources to acquire the relevant development knowledge.</li></ul> Recent endeavors to bring the software engineering and CS&E communities together include two special issues of IEEE Software (July/August 2008 and January 2009) and this current ICSE workshop series. The <a href=″http://www.cs.ua.edu/%7ESECSE08″>2008 workshop</a> brought together computational scientists, software engineering researchers and software developers to explore issues such as: <ul><li>Those characteristics of CS&E which distinguish it from general business software development;</li><li>The different contexts in which CS&E developments take place;</li><li>The quality goals of CS&E;</li><li>How the perceived chasm between the CS&E and software engineering communities might be bridged.</li></ul> This 2009 workshop will build on the results of the previous workshop.<br>Similar to the format of the 2008 workshop, in addition to presentation and discussion of the accepted position papers, significant time during the 2009 workshop will be devoted to the continuation of discussions from previous workshops and to general open discussion.
Abbrevation
SECSE
City
Vancouver
Country
Canada
Deadline Paper
Start Date
End Date
Abstract