Software Carpentry Revisited

By Nicole Hemsoth

July 18, 2011

Software engineering is still something that gets too little attention from the technical computing community, much to the detriment of the scientists and engineers writing the applications. Greg Wilson has been on a mission to remedy that, mainly through his efforts at Software Carpentry, where he is the project lead. HPCwire asked Wilson about the progress he’s seen over the last several years and what remains to be done.

HPCwire: We last spoke five years ago about Software Carpentry — your work to improve the software development skills of scientists and engineers. Have you been able to see any progress along this front?

Greg Wilson: Yes, on a small scale, but no, not in general. A lot of students and professionals have used the Software Carpentry materials — we get several hundred hits a day, mostly via Google searches — and based on their feedback, they do find them useful. Elsewhere, we have seen a growing number of conscientious scientists worrying about the problems of sharing and reproducibility, and other courses like Software Carpentry springing up, primarily in bioinformatics and astronomy.

Overall, though, I have to say that most scientists and engineers don’t use computers any more proficiently today than they did twenty years ago, never mind five. For example, I would bet that the percentage of grad students in science and engineering departments using version control to keep track of what they did when, and to share their work with colleagues, hasn’t shifted in that time.

HPCwire: What hasn’t improved?

Wilson: Fundamentally, what hasn’t improved is people’s ability to do math. Suppose that picking up some basic computational skills—version control, testing, Make, the shell, using a debugger, and so on—takes five full-time weeks. Whether that’s one five-week marathon, or the time is spread out over several months, it still costs roughly 10 percent of the scientist’s annual salary, if you’re thinking like an administrator, or 10 percent of their annual published output, if you’re thinking like a grad student’s supervisor.

If we assume our scientist only keeps doing research for another 10 years (which I hope is pessimistic), and a depreciation rate of 20 percent (which I also hope is pessimistic), then this only has to improve the scientist’s productivity by 2.4 percent in order to pay for itself. That works out to just under an hour per week during those ten years; anything above that is money or time in the bank. Looking at the results of the survey we did in 2008, even scientists who _aren’t_ primarily computationalists are spending a lot more time than that wrestling with software.

Now suppose the feedback we get from people who’ve taken the course is right, and that these skills save them a day a week or more. Let’s assume the average scientist or engineer costs $75,000 a year. 20 percent of their time over ten years, at the same 20 percent discount rate, works out to roughly $63,000; at a more realistic discount rate of 10 percent, it’s roughly $93,000. That’s roughly a ten-fold return on $7,500 — five weeks of their time right now at the same annual salary.

So why don’t people do it? Or to put a sharper point on it, why don’t their bosses and supervisors require them to? I think there are four reasons:

(1) Time and money spent show up in the budget; time and money saved through higher productivity don’t. Of course, this is a problem for more than just computational skills training.

(2) Sure, if I knew some Perl, I could solve this problem in five minutes instead of an hour, but learning that much Perl will take two days, and the deadline for this paper is tomorrow. And then I have to prepare a mid-term for the course I’m teaching, or fill in my benefits paperwork.  Something that pays off in the long run is not useful if all our deadlines are short-term.

(3) It’s a case of the blind leading the blind. If most of the people around you don’t know how to automate tasks using Make and the shell, for example, you’re unlikely to start doing it yourself. And yes, there are lots of good tutorials on the web, but it’s hard to find the right ones if you don’t know what keywords the cognoscenti use to describe these things, and even harder to understand them.

(4) Institutionally, the people who fight for scientific computing resources are usually those doing HPC, and because of (3), they almost always fight for more hardware, rather than the skills to use that hardware effectively. Most HPC vendors aren’t any more enlightened, which is shortsighted. If more people knew how to do simple things well, more of them would try advanced things, which would lead pretty quickly to increased sales. Right now, though, it’s easier to get a million dollars for a new cluster than a hundred thousand to train people how to use computers effectively.

HPCwire: Are there software development skills or practices that turned out to be more difficult to impart to non-computer science types than you first thought?

Wilson: Most of the difficulty has actually been our misconceptions of what scientists and engineers want, rather than difficulties on their side. Scientists and engineers _do_ tend to be fairly smart people. As a computer scientist, I always want to teach fundamental principles of computing that can be widely applied. As per point (2) above, what students can actually invest time in is solutions to the specific problems they face today. They’re happy to have the general principles explained after the fact, if ever, and even happier to infer those general principles themselves from lots of useful worked examples.

It’s sometimes possible to find a happy medium, and I think our lectures on regular expressions and SQL do so. But in other areas, where the payoff takes longer, it’s really hard to find a path where every step is immediately rewarding. For example, object-oriented programming doesn’t solve any problem that people writing hundred-line programs realize they have.

This is all complicated by the fact that for a lot of people in engineering, neuroscience, and other fields, computing means computing in a specific platform like R, SPSS, SAS, or MATLAB — and even then, “MATLAB” might actually mean a large domain-specific package on top of MATLAB itself. Most of our course materials are in Python, and while it’s an easy language to learn, someone who whose colleagues work exclusively in R will quite rightly think that learning a new language is a high price to pay for some insights whose value isn’t immediately apparent.

Reaching those people would require an retooling for every single language, which we simply don’t have the resources to do.  However, these people can and do benefit from generic material on version control, the shell, and databases, so that’s where more of our effort is currently going.

HPCwire: HPC practitioners seem to be of two minds about optimizing software workflow. Some believe the emphasis needs to be on minimizing development time, while others believe maximizing runtime performance is paramount. Often these two approaches are at odds with one another. Where do you stand on this dynamic?

Wilson: It’s a false dichotomy, and a dangerous one to boot. Given the complexity of modern architectures, the only way to make something fast is to get it working, build some tests so that you can tell when subsequent changes break things, and then start tweaking it based on performance profiling. Maximizing runtime performance therefore doesn’t compete with minimizing development time; it _requires_ it, particularly if you’re then going to have to move it to a slightly different chip set, or maybe, a few years down the road, port it to a very different architecture.

HPCwire: You recently performed a study on how scientists develop and use software? What were the major findings?

Wilson: Yes, in the fall of 2008 we did an online survey of how scientists and engineers use computers, where they learned what they know, and so on.  1,972 people responded, and we published the results in 2009. The major finding, in my opinion, was to confirm that almost everyone in science and engineering is primarily self-taught when it comes to computing, and that they’re spending a lot of time banging their heads against software problems.

HPCwire: Based on the study results, what do you think needs to be done now to help scientists adopt better software practices?

Wilson: The easy answer is, “Put more computing lab courses in undergraduate programs,” but that’s not realistic. As a physicist once said to me, “What should we take out to make room — thermodynamics or quantum mechanics?” Another solution would be to require people to pass something like a driving test before letting them use big iron, but that will never fly politically — as much as people working in HPC centers might want it to.

Realistically, I think there are only two possibilities. The first is for HPC vendors to start emphasizing these skills as a prerequisite for getting your money’s worth out of that shiny new cluster you just bought. The second is for journal editors to start requiring some evidence of competence when people submit work with a large computational component. I don’t think full reproducibility is a realistic goal, but [something like] “All of our code is under version control, it can be built with a single command, or with two commands, if there’s a separate configuration step, and we have a test suite that exercises at least _some_ of its functionality,” would be an excellent start.

Subscribe to HPCwire's Weekly Update!

Be the most informed person in the room! Stay ahead of the tech trends with industy updates delivered to you every week!

Takeaways from the Milwaukee HPC User Forum

September 19, 2017

Milwaukee’s elegant Pfister Hotel hosted approximately 100 attendees for the 66th HPC User Forum (September 5-7, 2017). In the original home city of Pabst Blue Ribbon and Harley Davidson motorcycles the agenda addresse Read more…

By Merle Giles

NSF Awards $10M to Extend Chameleon Cloud Testbed Project

September 19, 2017

The National Science Foundation has awarded a second phase, $10 million grant to the Chameleon cloud computing testbed project led by University of Chicago with partners at the Texas Advanced Computing Center (TACC), Ren Read more…

By John Russell

NERSC Simulations Shed Light on Fusion Reaction Turbulence

September 19, 2017

Understanding fusion reactions in detail – particularly plasma turbulence – is critical to the effort to bring fusion power to reality. Recent work including roughly 70 million hours of compute time at the National E Read more…

HPE Extreme Performance Solutions

HPE Prepares Customers for Success with the HPC Software Portfolio

High performance computing (HPC) software is key to harnessing the full power of HPC environments. Development and management tools enable IT departments to streamline installation and maintenance of their systems as well as create, optimize, and run their HPC applications. Read more…

Kathy Yelick Charts the Promise and Progress of Exascale Science

September 15, 2017

On Friday, Sept. 8, Kathy Yelick of Lawrence Berkeley National Laboratory and the University of California, Berkeley, delivered the keynote address on “Breakthrough Science at the Exascale” at the ACM Europe Conferen Read more…

By Tiffany Trader

Takeaways from the Milwaukee HPC User Forum

September 19, 2017

Milwaukee’s elegant Pfister Hotel hosted approximately 100 attendees for the 66th HPC User Forum (September 5-7, 2017). In the original home city of Pabst Blu Read more…

By Merle Giles

Kathy Yelick Charts the Promise and Progress of Exascale Science

September 15, 2017

On Friday, Sept. 8, Kathy Yelick of Lawrence Berkeley National Laboratory and the University of California, Berkeley, delivered the keynote address on “Breakt Read more…

By Tiffany Trader

DARPA Pledges Another $300 Million for Post-Moore’s Readiness

September 14, 2017

The Defense Advanced Research Projects Agency (DARPA) launched a giant funding effort to ensure the United States can sustain the pace of electronic innovation vital to both a flourishing economy and a secure military. Under the banner of the Electronics Resurgence Initiative (ERI), some $500-$800 million will be invested in post-Moore’s Law technologies. Read more…

By Tiffany Trader

IBM Breaks Ground for Complex Quantum Chemistry

September 14, 2017

IBM has reported the use of a novel algorithm to simulate BeH2 (beryllium-hydride) on a quantum computer. This is the largest molecule so far simulated on a quantum computer. The technique, which used six qubits of a seven-qubit system, is an important step forward and may suggest an approach to simulating ever larger molecules. Read more…

By John Russell

Cubes, Culture, and a New Challenge: Trish Damkroger Talks about Life at Intel—and Why HPC Matters More Than Ever

September 13, 2017

Trish Damkroger wasn’t looking to change jobs when she attended SC15 in Austin, Texas. Capping a 15-year career within Department of Energy (DOE) laboratories, she was acting Associate Director for Computation at Lawrence Livermore National Laboratory (LLNL). Her mission was to equip the lab’s scientists and research partners with resources that would advance their cutting-edge work... Read more…

By Jan Rowell

EU Funds 20 Million Euro ARM+FPGA Exascale Project

September 7, 2017

At the Barcelona Supercomputer Centre on Wednesday (Sept. 6), 16 partners gathered to launch the EuroEXA project, which invests €20 million over three-and-a-half years into exascale-focused research and development. Led by the Horizon 2020 program, EuroEXA picks up the banner of a triad of partner projects — ExaNeSt, EcoScale and ExaNoDe — building on their work... Read more…

By Tiffany Trader

MIT-IBM Watson AI Lab Targets Algorithms, AI Physics

September 7, 2017

Investment continues to flow into artificial intelligence research, especially in key areas such as AI algorithms that promise to move the technology from speci Read more…

By George Leopold

Need Data Science CyberInfrastructure? Check with RENCI’s xDCI Concierge

September 6, 2017

For about a year the Renaissance Computing Institute (RENCI) has been assembling best practices and open source components around data-driven scientific researc Read more…

By John Russell

How ‘Knights Mill’ Gets Its Deep Learning Flops

June 22, 2017

Intel, the subject of much speculation regarding the delayed, rewritten or potentially canceled “Aurora” contract (the Argonne Lab part of the CORAL “ Read more…

By Tiffany Trader

Reinders: “AVX-512 May Be a Hidden Gem” in Intel Xeon Scalable Processors

June 29, 2017

Imagine if we could use vector processing on something other than just floating point problems.  Today, GPUs and CPUs work tirelessly to accelerate algorithms Read more…

By James Reinders

NERSC Scales Scientific Deep Learning to 15 Petaflops

August 28, 2017

A collaborative effort between Intel, NERSC and Stanford has delivered the first 15-petaflops deep learning software running on HPC platforms and is, according Read more…

By Rob Farber

Russian Researchers Claim First Quantum-Safe Blockchain

May 25, 2017

The Russian Quantum Center today announced it has overcome the threat of quantum cryptography by creating the first quantum-safe blockchain, securing cryptocurrencies like Bitcoin, along with classified government communications and other sensitive digital transfers. Read more…

By Doug Black

Oracle Layoffs Reportedly Hit SPARC and Solaris Hard

September 7, 2017

Oracle’s latest layoffs have many wondering if this is the end of the line for the SPARC processor and Solaris OS development. As reported by multiple sources Read more…

By John Russell

Google Debuts TPU v2 and will Add to Google Cloud

May 25, 2017

Not long after stirring attention in the deep learning/AI community by revealing the details of its Tensor Processing Unit (TPU), Google last week announced the Read more…

By John Russell

Six Exascale PathForward Vendors Selected; DoE Providing $258M

June 15, 2017

The much-anticipated PathForward awards for hardware R&D in support of the Exascale Computing Project were announced today with six vendors selected – AMD Read more…

By John Russell

Top500 Results: Latest List Trends and What’s in Store

June 19, 2017

Greetings from Frankfurt and the 2017 International Supercomputing Conference where the latest Top500 list has just been revealed. Although there were no major Read more…

By Tiffany Trader

Leading Solution Providers

IBM Clears Path to 5nm with Silicon Nanosheets

June 5, 2017

Two years since announcing the industry’s first 7nm node test chip, IBM and its research alliance partners GlobalFoundries and Samsung have developed a proces Read more…

By Tiffany Trader

Nvidia Responds to Google TPU Benchmarking

April 10, 2017

Nvidia highlights strengths of its newest GPU silicon in response to Google's report on the performance and energy advantages of its custom tensor processor. Read more…

By Tiffany Trader

Graphcore Readies Launch of 16nm Colossus-IPU Chip

July 20, 2017

A second $30 million funding round for U.K. AI chip developer Graphcore sets up the company to go to market with its “intelligent processing unit” (IPU) in Read more…

By Tiffany Trader

Google Releases Deeplearn.js to Further Democratize Machine Learning

August 17, 2017

Spreading the use of machine learning tools is one of the goals of Google’s PAIR (People + AI Research) initiative, which was introduced in early July. Last w Read more…

By John Russell

EU Funds 20 Million Euro ARM+FPGA Exascale Project

September 7, 2017

At the Barcelona Supercomputer Centre on Wednesday (Sept. 6), 16 partners gathered to launch the EuroEXA project, which invests €20 million over three-and-a-half years into exascale-focused research and development. Led by the Horizon 2020 program, EuroEXA picks up the banner of a triad of partner projects — ExaNeSt, EcoScale and ExaNoDe — building on their work... Read more…

By Tiffany Trader

Cray Moves to Acquire the Seagate ClusterStor Line

July 28, 2017

This week Cray announced that it is picking up Seagate's ClusterStor HPC storage array business for an undisclosed sum. "In short we're effectively transitioning the bulk of the ClusterStor product line to Cray," said CEO Peter Ungaro. Read more…

By Tiffany Trader

Amazon Debuts New AMD-based GPU Instances for Graphics Acceleration

September 12, 2017

Last week Amazon Web Services (AWS) streaming service, AppStream 2.0, introduced a new GPU instance called Graphics Design intended to accelerate graphics. The Read more…

By John Russell

GlobalFoundries: 7nm Chips Coming in 2018, EUV in 2019

June 13, 2017

GlobalFoundries has formally announced that its 7nm technology is ready for customer engagement with product tape outs expected for the first half of 2018. The Read more…

By Tiffany Trader

  • arrow
  • Click Here for More Headlines
  • arrow
Share This