In her “diagram of development,” Lovelace gives the
fourth operation as v5 / v4. But the correct ordering
here is v4 / v5.
1843!I was recently at the Musee des arts et metiers in Paris, and they have several original Pascalines on display. So many marvels packed into a very tight space, it is one of my favorite in Paris and I would highly recommend it. I'm not sure what they have on Lovelace, I'll admit I was pretty overwhelmed with the collection. Their computer collection alone is a museums worth, and they cover much, much more than just computer history (a lot of mechanical engineering for starters). If they don't have this algorithm on display, they absolutely should.
A leather-bound first edition Lovelace including this algorithm recently sold for about $120,000. That actually seems like a bargain when you think about the level of the accomplishment. [1]
I agree with OP that most likely the bug is in the transcription and not present in the original manuscript.
[1] - https://www.theguardian.com/books/2018/jul/24/ada-lovelace-f...
It's also debated whether these were bugs from Ada or transcription errors. But, yes, it does seem like an interesting milestone
Transcription errors would make this the first bug due to bit rot in a special sense! Still quite remarkable :)
Quiet and completely excellent, The Museum of Heritage and Architecture. https://www.unjourdeplusaparis.com/en/paris-culture/musee-ci...
The Army Museum is worth a visit - it is interesting to see a less Anglo centric view of the wars, particularly WW1. The paintings are deeply grim - not ideal if you have young kids. https://en.m.wikipedia.org/wiki/Musée_de_l%27Armée
The Museum of the Middle Ages is currently being renovated but is well regarded. https://en.m.wikipedia.org/wiki/Musée_de_Cluny_–_Musée_natio...
Probably a candidate for best museum in the world, the Louvre is a great way to completely waste a day with massive crowds, sore feet, food and water shortages, closed exhibits, intense heat and even more crowds. Get a map ahead of time and check that the things you want to see aren’t closed before you go.
If you're into modern art and/or architecture, it's a must-see. The center itself is a beautiful mess of industrial design, and they have everything ranging from modern paintings to furniture to contemporary sculptures to technological inventions.
Two of the current exhibitions are an installation by Ryoji Ikeda [2], which is one of the most superb audiovisual pieces I've seen (you sit in a completely dark room and watch a huge projection) and Coder Le Monde [3], a history of generative art (digital 2D and 3D, as well as physical), computer graphics and visualization. Both are fantastic.
The nearby Palais de Tokyo is also fun, as is the Museum of Modern Art, which is next door to it.
Everyone mentions the Louvre, but it is incredibly crowded and touristy, and the 90% of the paintings are portraits of 19th century nobility. The gardens surrounding the Louvre are much enjoyable than the inside, in my (possibly unpopular) opinion.
[1] https://www.centrepompidou.fr/en
[2] https://www.centrepompidou.fr/cpv/agenda/event.action?param....
[3] https://www.centrepompidou.fr/cpv/agenda/event.action?param....
Used to go there all the time as a kid, especially to read 2600 magazine in the library.
To be the first, you have to believe Babbage designed a general purpose computer that could accept instructions and never wrote any instructions.
https://www.bbvaopenmind.com/en/ada-lovelace-original-and-vi...
“I confirm that the manuscript evidence clearly shows that Babbage wrote ‘programs’ for his Analytical Engine in 1836-7 i.e. 6-7 years before the publication of Lovelace’s article in 1843. There are about 24 of such ‘programs’ and they have the identical features of the Lovelace’s famous ‘program’,” adds Swade. The historian says that the new tests are “unarguable” and that they “do not support, indeed they contradict the claim that Lovelace was the ‘first programmer’.”
Ada Lovelace was the first to realise that the analytical engine would perform arbitrary tasks and wrote programs for those arbitrary task, beyond computational operations. Of course Babbage who designed the hardware had some idea of what programs it could run and presented examples, but he did not have the forethought to go beyond as Lovelace is quoted in your articles, "an original understanding of where the power and potential of computers lay."
There has always been a controversy of how much of Lovelace's work is hers and how much is Babbage's in the Menabrea papers, and I don't think Babbage writing a few simple programs settles this controversy one way or another. Lovelace had unique and original insights that should not be downplayed.
A [computer] program is a sequence of instructions executable by a machine (the computer).
> Would you argue that the Euclidean algorithm from two millenia prior was a program?
It's in the name: EA is an algorithm.
"Babbage also wrote more than twenty programs that he never published.19 So it’s not quite accurate to say that Lovelace wrote or published the first program, though there’s always room to quibble about what exactly constitutes a “program.” Even so, Lovelace’s program was miles ahead of anything else that had been published before. The longest program that Menabrea presented was 11 operations long and contained no loops or branches; Lovelace’s program contains 25 operations and a nested loop (and thus branching)..."
http://blog.plan28.org/2016/10/how-we-got-to-where-we-are.ht...
http://rclab.de/rclab/_media/analyticalengine/aal_noteg_glas...
Also note that apparently Babbage later did consider exactly the implementation of the said missing hardware functionality:
http://blog.plan28.org/2016/10/how-we-got-to-where-we-are.ht...
The author is saying that Ada deserves the title of first programmer both because she did publish an elaborate algorithm and because she understood the potential of the Analytical Engine better than Babbage and Menabrea.
Jonathan Blow's presentation is more about that second point and how computers (or rather, sufficiently complex dynamical systems) can "give you something back that you didn't put in".
System theory is nothing new so it might not be exact equivalent of thinking about engines that can compose music in 1842, but it seems to me that it is not a widespread and well-understood concept as it should be, and that the public opinion is re-discovering it mainly through Deep Learning advancements.
>in the context of manufacturing methods Babbage calculates that the total number of teeth to be formed for a store with 1,000 registers would be 1,800,000.
[1] http://blog.plan28.org/2018/05/spring-2018-report-to-compute...
https://gist.github.com/sinclairtarget/ad18ac65d277e453da5f4...
It's definitely far from being trivial!
Also note the use of floats in the C version. A lot of simpler CPUs didn't and still don't have floats.
Fascinatingly, the Analytical Engine's number representation was 40 digits (and later: 50)(!) base 10 (but not "floating" but "fixed" point):
https://www.fourmilab.ch/babbage/authentic.html
Moreover, a lot of simpler CPUs also don't have the "division" in the "instruction set", the Engine has it!
Given the emulator already existing, maybe somebody will now create the cards from Lovelace's program, and run it as intended?
https://en.wikipedia.org/wiki/The_Thrilling_Adventures_of_Lo...
10 PRINT "HELLO WORLD"
Even the horrible crap I wrote as an novice is probably less embarrassing to me that the stuff I wrote as a journeyman who shoulda known better.
Thankfully, the most embarrassing things are, like, spending 2 days configuring postfix and not realizing that I could just read the log files and it tells me specifically what isn't working. A valuable lesson, but embarrassment has its cost.
mov ah, 2
mov dl, 7
int 21
int 20
Discovering that I could write my own programs with debug.com was earth shaking. Picked up some decade old book on it at Half Price Books (which went well with my decade old machine -- an 80s model IBM with integrated monochrome green screen) and never looked back. jmp FFF0
The client was amazed that I'd figured out a way to automate the ctrl-alt-del monkeys that had been hired to reboot everyones machines, for some reason, every night ..Does anyone know what "should repeat" means? Was the machine capable of repeating or does this mean the human operator needed to do the repeating?
If you're interested in that kind of thing I wrote a description of the entire instruction set a while back: http://h14s.p5r.org/2012/11/punched-cards.html.
Thanks for the in-depth, and wonderfully clear write-up.
The London Science Museum built a fully working Difference Engine, to Victorian tolerances so it could have actually worked.
I heard of a project to build a modern working replica but I don't know if anything ever came of it.
It's really just a series of mathematical steps with a store of values in between. Notions that would have clearly taken it from being a series of mathematical steps, to a program, such as branching, looping, or jumping are left completely unspecified. So her 'loop' was specified literally as "here follows a repetition of operations 13-23".
In other words, "should repeat" is left an as exercise to the reader.