Save for later

LAFF – On Programming for Correctness

Is my program correct? Will it give the right output for all possible permitted inputs? Computers are now essential in everyday life. Incorrect programs lead to frustration in the best case and disaster in the worst. Thus, knowing how to construct correct programs is a skill that all who program computers must strive to master.

In this computer science course, we will present "goal oriented programming" the way Edsger Dijkstra, one of the most influential computer scientists, intended. You will learn how to derive programs hand-in-hand with their proofs of correctness. The course presents a methodology that illustrates goal-oriented programming, starting with the formalization of what is to be computed, and then growing the program hand-in-hand with its proof of correctness. The methodology demonstrates that, for a broad class of matrix operations, the development, implementation, and establishment of correctness of a program can be made systematic.

Since this technique focuses on program specifications, it often leads to clearer, correct programs in less time. The approach rapidly yields a family of algorithms from which you can then pick the algorithm that has desirable properties, such as attaining better performance on a given architecture.

The audience of this MOOC extends beyond students and scholars interested in the domains of linear algebra algorithms and scientific computing. This course shows how to make the formal derivation of algorithms practical and will leave you pondering how our results might extend to other domains.

As a result of support from MathWorks, learners will be granted access to MATLAB for the duration of the course.

What you'll learn

  • Develop assertions describing states in a program.
  • Prove programs correct using logic.
  • Build algorithms using goal-oriented programming techniques.
  • “Slice and dice” to discover families of loop-based algorithms for matrix computations.

Get Details and Enroll Now

OpenCourser is an affiliate partner of edX and may earn a commission when you buy through our links.

Get a Reminder

Send to:
Rating Not enough ratings
Length 7 weeks
Effort 7 weeks, 4–6 hours per week
Starts On Demand (Start anytime)
Cost $99
From The University of Texas at Austin, UTAustinX via edX
Instructors Robert van de Geijn, Maggie Myers, Devangi Parikh
Download Videos On all desktop and mobile devices
Language English
Subjects Programming Mathematics
Tags Computer Science Math

Get a Reminder

Send to:

Similar Courses

Careers

An overview of related careers and their average salaries in the US. Bars indicate income percentile.

Coordinator of Special Projects, International Programs $24k

Financial Aid Counselor - Graduate Programs $35k

Family Programs Specialist $41k

Educational Programs Specialist $46k

Recruiting Programs Coordinator $47k

Specialist, Alliances & International Programs $54k

Education & Public Programs Coordinator Manager $78k

Project Manager - Foreign Military Sales Programs $78k

Program Manager, Government Programs $106k

Programs Administrator/Security Officer $110k

Associate Dean,Graduate Programs $154k

Senior Head Worldwide Marketing Programs & Demand Generation - Mobile $193k

Write a review

Your opinion matters. Tell us what you think.

Rating Not enough ratings
Length 7 weeks
Effort 7 weeks, 4–6 hours per week
Starts On Demand (Start anytime)
Cost $99
From The University of Texas at Austin, UTAustinX via edX
Instructors Robert van de Geijn, Maggie Myers, Devangi Parikh
Download Videos On all desktop and mobile devices
Language English
Subjects Programming Mathematics
Tags Computer Science Math

Similar Courses

Sorted by relevance

Like this course?

Here's what to do next:

  • Save this course for later
  • Get more details from the course provider
  • Enroll in this course
Enroll Now