Jupiter moons
An animation of the moons of Jupiter that I build in class to teach object-oriented programming.

About Programming for Scientists

Programming for Scientists is a course that was founded by Carl Kingsford and that I have adapted greatly over the past several years. It provides a practical introduction to programming for students with little or no prior programming experience who are interested in scientific applications of programming, especially those taken from computational biology.

Programming topics are motivated from the ground up using scientific problems, so that the course never loses sight of an application. For example, a transition to object-oriented programming is motivated by building a gravity simulator, which we then apply to the moons of Jupiter (see animation above). Homework assignments are also scientific in nature. The only other course I am aware of that attempts to teach programming from the ground up from within a scientific discipline is the CS5 green project at Harvey Mudd College.

Since 2015, I have taught a graduate version of the course that is largely taken by MS students in the Computational Biology Department. I have also taught an undergraduate version of the course for students interested in scientific majors at Carnegie Mellon.

In addition to a collection of programming assignments, students in Programming for Scientists are expected to work in teams to complete a project on a scientific problem by writing a few thousand lines of code in addition to assembling an essay describing their work. I’ve sampled a few project essays that I have found particularly well written as part of our project “Ring of Honor” below.

Find us online: Programming for Lovers

I have enjoyed teaching this course so much that it inspired me to build an online course for learners who are interested in learning how to program while seeing programming applied to scientific examples. That online course grew into the Programming for Lovers project.

Establishing a Programming Bootcamp

In the past, I taught the course without any prerequisites, but I noticed that students who had not previously programmed tended to be overwhelmed with the start of the course, when they are learning to think computationally for the first time. Yet many of these students managed to perform very well in the latter half of the course. At the same time, students who had programmed previously were bored to tears with the first month of the course, which covered programming basics.

To help reconcile these two groups and provide a gradual on-ramp for students, I now require students taking the course to complete the first four modules of Programming for Lovers as part of a “programming bootcamp” that they can complete at their own pace over a few months in advance of the course. This ensures more of a level playing field at the start of the course, alleviates boredom, and allows us to delve into deeper and more fun topics in the course itself.

Programming for Scientists Student Testimonials

“It’s the most interesting and helpful programming course I’ve ever taken. Phillip demonstrated the materials in a very clear and inspiring way which helped us have a good understanding. The recitation sessions provided by the TAs were also helpful.”

“Great instructor to introduce new concepts to people from non-coding background. He shoots to rewire our brains to think computationally and HE SCORES! Dr. Phillip Compeau is hands down the best professor that I have ever had. I knew him from his coursera course before I got here. I really appreciate his passion for teaching. How many people do you know of, that don’t mind dressing up in costumes (KILLER costumes, by the way) to peak students’ interest in topics that matter? One of the tiny but significant reasons I did the course was to find out what new costume and concept he had in store for us and how he would tie them together. He is brilliant at tying things together. He leaves no loose ends. If I ever find anything that I am half as passionate about as he is about his work, and half as good at it, I know I’ll fare well in life. Thank you, Dr. Compeau. More than you can comprehend.”

“[I have] taken a few ‘intro to programming’ courses, really think this is the way programming should be taught to anyone looking to start programming.”

“Phillip is one of the best professors I’ve had. He was part of the reason I chose to come to CMU, and I’m now all the happier I did. Have to admit, he’s a bit intimidating, but that’s probably just the combination of his height and his IQ.”

“Class has been so much fun – I’ve definitely never been taught programming in such a novel but effective way. Thank you!!”

“I really enjoyed the passion behind each lesson, and especially the contextualization as to how we should use these skills for good (e.g. being wary of algorithmic bias).”

Scientific Topics Covered

In the course, we approach many different real-world questions taken from different scientific disciplines with a computational slant. Here is a sampling of potential current topics.

Biology:

  • Where in the genome does a bacterium start replication?
  • How do we construct evolutionary trees?
  • How do we assemble genomes from millions of tiny pieces of DNA?
  • How do we align biological sequences to compare them?
Mathematics:

  • How do we find large prime numbers using a computer?
  • What is the world’s first algorithm?
  • How do we generate a sequence of numbers that seem random?
  • What are cellular automata?
  • How can we send an encrypted message?
Chemistry:

  • Can we find a “best” folded shape of a protein?
  • How do we simulate a chemical reaction?
Physics:

  • How do we simulate motions of heavenly bodies?
Computer Science:

  • Guiding principles of object-oriented programming
  • How do we program multiple cores of a computer to work in parallel?
  • What are the fundamental limits of computing?
  • What is P vs. NP and why is it important?
  • What is really going on inside of a computer?
Social Science:

  • Does Cooperation Really Exist? (Introductory Game Theory)
  • Can we write a language simulator that can fool a human?
  • How do we program a computer to play a game?

Programming for Scientists Project Ring of Honor

GoMol: A 3D Protein Analysis & Visualization Tool

Project authors: Tyler Katz, Darin Boyes, Minhyek Jeon, and Shivank Sadasivan.

group5gomol_109412_10543509_GoMol-Final-Essay-1

Predicting Protein Secondary Structure

Project authors: Jonathan Potter, Andrew Lutsky, Rohit Nandakumar, and Shashank Katiyar.

group10crabmasters_109433_10543049_P4S-Project-Final-Report-1

De Novo Genome Assembly

Project authors: Lilin Huang, Tianyue Zhang, and Wenduo Cheng.

huanglilin_98864_8988870_Programming-Project-2

Swimbots

Project authors: Sarah Baalbaki, Dylan Estep, William Hsu, and Tanxin Qiao.

baalbakisarah_96114_8988050_Final-Paper-1

Ab Initio Secondary Structure Prediction

Project authors: Arth Banka, Riti Bhatia, Sanchitha Kuthethoor, Sumeet Kothare

group2abinitiostructureprediction_126524_12100936_PfS_Group2_FinalReport

Efficient Computational Simulation of Chladni Patterns from Raw Audio

Project authors: Claude An, Luci Lu, and Shiyu Wang

groupboops_125884_12099696_final_report_v0.4
Page Contents