|
|
Subscribe / Log in / New account

Algorithms

Algorithms

Posted Jun 10, 2009 1:14 UTC (Wed) by jlokier (guest, #52227)
In reply to: No, and ... by sepreece
Parent article: Donald Knuth: Mathematical Ideas, or Algorithms, Should Not Be Patented (Groklaw)

Algorithms don't have to terminate. Consider a program which prints out the digits of Pi one after another. It does not terminate, but it's implementing an algorithm to calculate those digits.

Algorithms don't have to be deterministic. Consider optimisation algorithms which use randomness like genetic algorithms and simulated annealing. They can use pseudo-randomness, but that's not part of the algorithm (usually), it's part of the implementation, and true external randomness is allowed too. Some algorithms only work if they have a source of randomness, and thus are non-deterministic. If the randomness is not truly random, they fail to terminate for some inputs.

Consider also parallel algorithms; a lot of them have non-deterministic behaviour because the global executation order is inherently not determined.

Perhaps there is some definition of "algorithm" which requires termination and determinism, and perhaps it was always like that in the distant origins of the word (before computers...), but it's not a definition I'm familiar with.


to post comments

Algorithms

Posted Jun 11, 2009 14:01 UTC (Thu) by sepreece (guest, #19270) [Link]

The definition of "algorithm" I used in my original comment was Knuth's definition, from Volume 1 of The Art of Programming. I posted a synopsis of the definition in another response.


Copyright © 2025, Eklektix, Inc.
Comments and public postings are copyrighted by their creators.
Linux is a registered trademark of Linus Torvalds