logoalt Hacker News

Functional Data Structures and Algorithms: a Proof Assistant Approach

104 pointsby SchwKatzetoday at 2:04 AM17 commentsview on HN

Comments

dwohnitmoktoday at 6:00 AM

IIRC this book unfortunately only proves correctness directly and not runtime. Its runtime proofs are based off an abstraction of the algorithm suitable for direct manipulation by proofs rather than the actual implementation in code.

Does anybody know of any languages that let you prove properties about the runtime of a function directly implemented in the language?

show 3 replies
zkmontoday at 6:13 AM

Some algorithms such as binary search give an incorrect view of the overall cost. The search has a prerequisite of sorting. So, the assumption is, the data is sorted once, and searched several times, making the sorting cost insignificant.

What if the data is used for only a single lookup? For this case, actually a sequential search would have lower cost compared to sorting and binary search. Infact, sequential search may beat sorting and binary search for upto about 100 lookups. So I think it is important to consider overall cost.

show 2 replies