tag:blogger.com,1999:blog-3722233.post3793941527979439087..comments2024-03-18T23:13:09.570-05:00Comments on Computational Complexity: Social Process and Proofs of Theorems and ProgramsLance Fortnowhttp://www.blogger.com/profile/06752030912874378610noreply@blogger.comBlogger10125tag:blogger.com,1999:blog-3722233.post-32232496052636670512007-09-05T17:50:00.000-05:002007-09-05T17:50:00.000-05:00Programmers out of necessity dot every i and cross...<I>Programmers out of necessity dot every i and cross every t, painstakingly debugging all their code, and don't whine about it, while theorists handwavingly skip all the details</I><BR/><BR/>I think you underestimate the extent to which many theorists painstakingly debug their proofs. (Some people are notoriously sloppy. For example, Lance Fortnow has had several serious bugs in his proofs. That's human nature - some programmers have lots of bugs, and this is only loosely correlated with how good their programs are by other measures. Lance has great ideas, but doesn't always implement them correctly.) Similarly, I think you overestimate how careful most programmers are. There are entire classes of bugs, like memory leaks or buffer overflows, that can exist only because of sloppiness.Anonymousnoreply@blogger.comtag:blogger.com,1999:blog-3722233.post-87491871728171776642007-09-05T17:44:00.000-05:002007-09-05T17:44:00.000-05:00I honestly don't see how anyone could think that w...<I>I honestly don't see how anyone could think that we'll ever get real confidence in the simple finite group classification theorem without it becoming computer-checkable.</I><BR/><BR/>We have extreme confidence in it because of its intrinsic structure. It's not just a random collection of logical implications (that would be humanly uncheckable); rather, it has a global structure that actually makes sense. There is admittedly a fair amount of case analysis where mistakes could conceivably creep in, but there aren't that many serious candidates for where new finite simple groups could be found. These candidates have been really thoroughly checked (during the 1970's many people <I>really</I> wanted to find their own finite simple group).<BR/><BR/>I do not believe any expert thinks the result might be wrong. (The closest I've heard is from John Conway. He's been known to say that he wishes there were more finite simple groups, because they are really interesting, but he acknowledges that there aren't.) There are undoubtedly some small gaps in the many papers, but the chances that they affect the overall structure of the proof are negligible.<BR/><BR/>It's the same with any sufficiently complicated computer program. Compilers frequently have bugs, but nobody siezes on that as evidence that there might not exist a bug-free compiler (even theoretically). If you understand what the compiler is doing, you recognize that some small variant of it must work in principle, even if the particular implementation is flawed.Anonymousnoreply@blogger.comtag:blogger.com,1999:blog-3722233.post-59062541054023137042007-09-05T16:34:00.000-05:002007-09-05T16:34:00.000-05:00I honestly don't see how anyone could think that w...<I>I honestly don't see how anyone could think that we'll ever get real confidence in the simple finite group classification theorem without it becoming computer-checkable.</I><BR/><BR/>Agreed.<BR/><BR/>OTH, it would be bad if we <I>only</I> did computer checking of proofs - not because of any reliability problem but because of the loss of what people learn by reading each other's proofs.Anonymousnoreply@blogger.comtag:blogger.com,1999:blog-3722233.post-62955929058775326892007-09-05T15:42:00.000-05:002007-09-05T15:42:00.000-05:00Programmers out of necessity dot every i and cross...<I>Programmers out of necessity dot every i and cross every t, painstakingly debugging all their code, and don't whine about it, while theorists handwavingly skip all the details, then have the audacity to claim that not only is this reasonable, but that human checking is more reliable than computer checking!</I><BR/><BR/>I don't think mathematicians would argue that human checking is more reliable than computer checking.<BR/><BR/>But maybe they would argue that it is more feasible given today's verification tools.<BR/><BR/>Moreover, I suspect that mathematicians like the status quo. They would hate their jobs if they had to verify their proofs with computers.Anonymousnoreply@blogger.comtag:blogger.com,1999:blog-3722233.post-88731046533022493572007-09-05T15:03:00.000-05:002007-09-05T15:03:00.000-05:00This attitude never ceases to astound me. Programm...This attitude never ceases to astound me. Programmers out of necessity dot every i and cross every t, painstakingly debugging all their code, and don't whine about it, while theorists handwavingly skip all the details, then have the audacity to claim that not only is this reasonable, but that human checking is more reliable than computer checking! Seriously, what planet are you people living on?<BR/><BR/>Are you aware of the computer-checkable proof of the four color theorem which has already been created? That theorem has now been vetted more thoroughly than almost any theorem of equivalent complexity. I honestly don't see how anyone could think that we'll ever get real confidence in the simple finite group classification theorem without it becoming computer-checkable.Anonymousnoreply@blogger.comtag:blogger.com,1999:blog-3722233.post-4771340067275022012007-09-05T09:26:00.000-05:002007-09-05T09:26:00.000-05:00With software, attempts at improving correctness a...With software, attempts at improving correctness are technology based: higher level languages, better testing tools, and better verification tools.<BR/><BR/>With math, attempts at improving correctness are people based: identify the most reliable researchers and take their work seriously.Anonymousnoreply@blogger.comtag:blogger.com,1999:blog-3722233.post-54934412481947862722007-09-05T09:03:00.000-05:002007-09-05T09:03:00.000-05:00When I met Robin Milner at IFIP'94 in Hamburg, I a...When I met <A HREF="http://en.wikipedia.org/wiki/Robin_Milner" REL="nofollow">Robin Milner</A> at IFIP'94 in Hamburg, I asked him how long it would take to have automated verification for the kind of theorems one proves in an undergraduate intro theory course.<BR/><BR/>He replied, "Maybe in 50 years" or "Not in 50 years". So at least 37 more to wait... :-)<BR/><BR/>My class yesterday was about proofs: I proved the language identity A(B U C) = AB U AC on the left-hand side of the blackboard, and down the right-hand side I ran an optically-similar "Poof" of the "Thro'em" A(B n C) = AB n AC. The bug was not easy for them to find! That precision is ultimately a human responsibility is a theme I emphasize.KWReganhttps://www.blogger.com/profile/09792573098380066005noreply@blogger.comtag:blogger.com,1999:blog-3722233.post-52572712472493123902007-09-05T02:25:00.000-05:002007-09-05T02:25:00.000-05:00It might very well be the case that most math theo...<I>It might very well be the case that most math theorems are false or have incorrect proofs.</I><BR/><BR/>It depends on the definition of "most". Most theorems anyone cares about are essentially correct (by which I mean correct except for typos and minor, immediately correctable misstatements). However, there's a lot of garbage out there. There are entire journals that as far as I know have never published a worthwhile paper. I don't want to name many examples, since I don't want to offend anyone or risk naming a journal that might be better than I think, but here's one example: the Southwest Journal of Pure and Applied Mathematics. SWJPAM was a free electronic journal that was published from 1995 to 2004; it ceased publication after publishing a ridiculous paper by a notorious internet crank. Maybe SWJPAM once published a paper someone cared about, but certainly not very often: for the 140 papers they published, there have been a total of 9 citations (according to Math Reviews), including self citations.<BR/><BR/>In any case, my guess is that at least half the papers in SWJPAM were never read by anyone but the authors and the referees, and they may never have been checked carefully by anyone at all. So who knows what the error rate is?<BR/><BR/>It's hard to know what to make of this. On the one hand, if we literally look at every mathematics paper out there, then the error rate may be quite a bit higher than anticipated. On the other hand, if nobody ever hears of these papers, who cares whether they are correct? (The garbage papers are generally segregated in journals nobody takes seriously.)<BR/><BR/>The real philosophical difficulty comes from subtle technicalities. In most traditional areas of mathematics, there is powerful intuition for where difficulties are likely to arise and how to circumvent them. (In analysis and geometry, mathematicians have spent centuries cultivating such intuition.) However, there are certain important areas in which we lack this intuition. For example, analysis of cryptographic protocols is extremely subtle, and so far thinking about it carefully requires painstaking effort. Certain parts of distributed computing are similar. Maybe someday we will have developed much better intuition for these things, but currently they are magnets for subtly defective proofs.Anonymousnoreply@blogger.comtag:blogger.com,1999:blog-3722233.post-35214186998428652982007-09-05T01:35:00.000-05:002007-09-05T01:35:00.000-05:00Just my two cents.It's true that many researchers ...Just my two cents.<BR/>It's true that many researchers have limited themselves to finding bugs. But there are still people working in program verification. The idea is not to build a fully automated program verifier, but build a tool that can help programmers develop proof interactively.Wei Huhttps://www.blogger.com/profile/13683552196436356037noreply@blogger.comtag:blogger.com,1999:blog-3722233.post-53454247910237933222007-09-04T22:30:00.000-05:002007-09-04T22:30:00.000-05:00One could argue that it is math that has a correct...One could argue that it is math that has a correctness crisis -- not software.<BR/><BR/>Software can always be tested. Math proofs are not generally checked by a computer.<BR/><BR/>It might very well be the case that most math theorems are false or have incorrect proofs.<BR/><BR/>Most software at least works to some extent.Anonymousnoreply@blogger.com