Introduction

The creation and adoption of software has become an integral aspect of current research practices []. Today, software is commonly used to plan and design research, to obtain funds and approvals, to create instruments and tools, to collect and analyze data, and to publish and archive results and other research resources. Simultaneously, the new capabilities spawned from the development and adoption of software also offer new challenges for progress in science. Much of today’s science infrastructure, or cyberinfrastructure, is dependent on software [], which often is used throughout the research lifecycle to create and utilize the resources needed for science. Systems, programs, scripts, workflows, and processes are commonly made from software that is needed to discover, render, or use science artifacts in digital form. Designing systems that enable the use of research resources requires the use of similar or compatible software to access the data, instruments, and tools that were previously created []. Furthermore, the exact version of software may be needed to replicate or reproduce the results of previous research []. Without software, many current research practices could not be conducted for collecting, discovering, and analyzing data to produce results. For example, conducting research using geospatial data is largely dependent on geospatial information systems and remote sensing software. Software has become an essential aspect of science that is necessary to maintain and advance current research practices and infrastructure.

Science software must be sustainable and reliable to contribute to future science practices. The dependency of science on software necessitates expeditious efforts by the research community to ensure the sustainability of science software. Likewise, the research community needs to ensure that science software can be relied upon to reproduce research results []. With such dependencies, unsustainable and unreliable science software reduces the potential for using current research resources in the future and for the reproducibility of science. In addition, utilizing science software that is not sustainable has the potential to increase risks, over time, to the use of scientific instruments, tools, and data. Using unsustainable science software also increases risk to the credibility of science []. Developing and managing science software to be sustainable contributes to the potential for enabling ongoing use of research resources and to the reduction of potential risks to the future of science.

Identifying improvements for science software sustainability practices can contribute to the sustainability of science software. The future use of current research resources will depend on capabilities to develop and manage sustainable science software. The research community will need to identify and adopt ways to improve upon current practices for science software development and management. To address these challenges, a focus group study was conducted to identify ways to improve the science software sustainability practices of the Earth science community.

Over the last 15 years, the Federation of Earth Science Information Partners (ESIP), a broad-based community of science data and information technology practitioners, has worked at the forefront of improving sustainable practices along the data lifecycle [, ]. Since it has been recognized that communities are integral to the development and sustainability of scientific software [, ] and given the ESIP community history and the natural connections between data management and software development [], it is not surprising that more recently, the ESIP membership has turned to examine the issues related to software and the benefits that can be attained from the sustainability of scientific software.

Starting in the summer of 2013, the ESIP semi-annual meeting included a panel and breakout session on the topic of sustainable software. From these activities, ESIP formed a cluster devoted to science software. Over the last year, these efforts evolved to become the central theme of the ESIP 2014 Summer Meeting, in Copper Mountain, Colorado. The theme — “Linking It Together: Sustainable Software Advancing Science Data and Services” — was set forth and discussed during the plenary presentations and carried through to a lunchtime roundtable that engaged approximately 300 meeting attendees in 8-person focus group discussions. The outcomes of these discussions were captured and have been analyzed to identify recommendations from the community to improve practices for scientific software sustainability.

Methodology

The focus group method was employed for data collection as it has been used in various fields of social science to enable the elicitation of in-depth perspectives and ideas on a topic of interest that emerge from interactive discussions among participants []. The roundtable lunch discussion on the sustainability of scientific software was held during the main conference day after a series of plenary speakers focused on sustainable software issues. Prior to the roundtable lunch activity, 36 meeting contributors were each asked to serve as a discussion facilitator for an assigned table. Facilitation included reading the questions to participants at the table and capturing ideas generated during the discussion. The remaining 250 Earth Science community representatives (including data distributers, providers of data and information products, developers of tools for earth science, data users, and funding agency representatives) were each sequentially assigned, from an alphabetized list, to one of 36 tables, with eight participants at each table.

For this study, each table was considered a focus group. Focus groups are valuable for obtaining empirical observations on various topics, including complex issues, such as software engineering [] and health science research []. The table assignments provided a reasonable sample size of eight attendees for each of the focus groups [].

Three sets of questions guided the discussion at each table. The first set pertained to the definition of sustainable scientific software and the second set elicited perspectives on various aspects of sustainable scientific software. The third set of questions requested recommendations for activities that the ESIP community might consider for the near future to improve practices for the sustainability of scientific software. The participants were not asked to identify themselves and any responses that contained the names of participants were de-identified prior to analysis. The initial results, described here, reflect responses to the third question that participants have recommended for the ESIP community to improve scientific software sustainability practices.

Initial Results

We received responses from 28 of the 36 invited tables. Initial analysis revealed the following actionable activities recommended for the ESIP community to improve the sustainability of scientific software. ESIP contributors, including ESIP’s Science Software Cluster, are actively working to define approaches to implementing the recommendations going forward.

Collaboration

Participants in the summer meeting recommended that ESIP work with other science and informatics organizations to develop and co-sponsor new activities that encourage collaborations between members of the various communities that focus on ways to increase the sustainability of scientific software. A number of other community groups were mentioned including the International Council for Science Committee on Data (CODATA), the World Data System (WDS), the Research Data Alliance (RDA), Earth Cube, and COOPEUS. Participants also recommended working to increase the number of scientists and end users that attend ESIP meetings to gain more of an end user perspective on software sustainability.

Publications and Presentations

Activities were recommended for the ESIP community to increase awareness, visibility and understanding of scientific software sustainability issues within the Earth science community. Participants recommended producing publications and presentations to inform the Earth science community about these issues, suggesting that community members propose AGU sessions focused on software sustainability, offering conceptual information that is less technical. Likewise, submitting papers to Eos and to the WSSSPE also were recommended to inform the Earth science community about the importance of scientific software sustainability.

Workshops, Training & Best Practices

The participants recommended raising awareness of software sustainability and facilitating different levels of training. Suggestions included developing training modules for simple software lifecycle skills and learning modules to improve understanding about the sustainability of scientific software, similar to the Data Management Training Modules developed by the ESIP Federation []. Participants also recommended conducting training on agile development techniques and convening software carpentry events, like those offered during the 2014 ESIP Federation Summer Meeting (http://commons.esipfed.org/2014SummerMeeting).

Develop and Document Best Practices

Recommendations included examining incentives, policies, and practices and highlighting examples of good scientific software sustainability. Activities would include creating software management plans and recommendations for organizations and individuals for improving software sustainability, establishing criteria for the sustainability of scientific software, documenting use cases and good sustainable examples, and developing impact metrics for software. Promoting practices for provenance, modularity, and version control also was suggested. Participants recommended developing a science software sustainability model or even a simple checklist or matrix for scientific software sustainability. They also suggested establishing metadata standards and profiles for workflows and software to ensure that best practices are followed for the sustainability of software components and their dependencies. The community-developed and vetted, ESIP Data Citation Guidelines, are such an example related to data []. These guidelines and other resources are developed and reviewed by teams of volunteers who are members of clusters, working groups, and committees that are open to the entire ESIP community for contributions. Completed resources are voted upon for approval during a Business Meeting of the ESIP Assembly.

Incentives and Motivation

The meeting participants suggested offering incentives including awards and citations to recognize contributions to the sustainability of scientific software. Offering awards would stimulate recognition for individuals who contribute to scientific software sustainability within their organizations. Participants also recommended improving attribution by developing templates and guidance for software citation, which could offer motivation for reusing such software. Incentives also were suggested to motivate scientists and developers to proactively produce good documentation and guidance for improving provenance and version control. Opportunities for funding also were recommended for refactoring of identified useful software as well as for research examining software sustainability issues.

Reviewed Software Repository

Participants recommended that ESIP members might create a curated and reviewed software repository that includes an ESIP “stamp of approval” for reviewed software. The repository could utilize a taxonomy of different types of software and measurable characteristics of sustainability to serve as a clearinghouse for scientific software and as a central ‘vetter’ of reusable standards and software. Such a repository also could serve as an inventory for software reviewed by expert users who rate and measure the sustainability of submitted software, applying tools, such as the Reuse Readiness Levels [] and the Technology Readiness Levels [], to conduct such reviews.

Discussion & Conclusion

Organizing and facilitating multiple, informal roundtable discussions to elicit recommendations for improving scientific software sustainability provided opportunities for various perspectives, including those of Earth science researchers and data science practitioners, to be shared by and among the ESIP community members who participated in the focus group study. In addition, the semi-structured organization of the questionnaire on science software sustainability issues enabled each table of participants to provide responses in accordance with the interests and perspectives represented within their focus group. Since the participants who contributed to the roundtable discussions represent the Earth science informatics community, the recommendations for improving scientific software sustainability that were elicited from the participants could reflect perspectives that come from the practices and culture of that community. Organizing similar roundtable discussions or focus groups to elicit recommendations from other scientific communities may reveal different perspectives for improving scientific software sustainability that reflect the practices and cultures of the represented communities.

The recommendations offered by the participants suggest three broad themes that could improve the sustainability of scientific software: (1) Community and collaboration is crucial both within ESIP and beyond to partners to move sustainable software forward; (2) There is a need for training and best practices around sustainable software; (3) In order to enable sustainable software there must be recognition for the work through incentives like awards and citations.

As the ESIP community pivots towards examining issues related to sustainable software, such as devoting a semi-annual meeting theme to the topic of software sustainability and creating a group to work on the topic, it has almost by definition begun to move the sustainable software agenda forward within the Earth science informatics community. The content of the meeting sensitized the immediate ESIP meeting attendees and by extension the broader research community to the importance of sustainable software. The roundtable activity created opportunities to operationalize sustainable software concepts.

In this paper our goal has been to describe recommendations observed for improving the sustainability of science software. These conclusions grow from the ESIP community focus on sustainable science software as reflected in the ESIP Summer 2014 meeting. Even though the participants largely represented the Earth science informatics community, these recommendations also apply to other communities and we look forward to making those connections.

Competing Interests

RRD currently serves as a volunteer member of the Board of Directors of the Foundation for Earth Science, the non-profit organization that provides managerial support for the Federation of Earth Science Information Partners (ESIP).

WCL previously served as the volunteer President of the ESIP Federation.

ER currently serves as the Executive Director of the Foundation for Earth Science.

ED currently serves as the volunteer Chair of the ESIP Information Technology and Interoperability Committee.

NW currently serves as the student intern for the ESIP Science Software Cluster.