27

A calculator that doesn't round

> Hans Boehm built a Java library for this in the 1980s and 90s

Hans is such a prolific programmer that he wrote a Java library before Java was even invented?

3 hours ago__alexs

The article has so many of the hallmarks of LLM writing, naturally it will have some hallucinated factoids too. "What that gives you: [bullet list]", "What got ported: [bullet list]", "foo: x, y, just z"

Boehm's Java library has copyright dates of 1999 and 2001-2004. https://www.hboehm.info/new_crcalc/CR.java

The whitepaper was only published in 2005: https://www.sciencedirect.com/science/article/pii/S156783260...

I have a dimview now of the blog, and of this Swift port of the library, indeed.

3 hours agotomjakubowski

Thank you. Of course the dates were out of order. The Java library (com.hp.creals) is 1999-2004, paper is from 2005. Unfortunate price of LLM-assisted development. Corrected.

13 minutes agodimview
[deleted]
3 hours ago

Well, you know, you go into your Smalltalk-80 workstation for a hack sesh, and an all-nighter later you end up with an implementatkon of Swing...

3 hours agonxobject

Author here. I could not find a constructive‑reals calculator on iPhone, so I ported the engine Android uses: Hans Boehm's com.hp.creals plus AOSP's UnifiedReal/BoundedRational. Used Opus 4.8 to do the port and Fable 5 for the review.

Fable 5 caught a couple of real concurrency bugs the port introduced while adapting Java's synchronized/AsyncTask to Swift concurrency, including one that was a memory‑safety bug on shared singletons like π, not just a wrong digit. None would have shown up in the unit tests. Writeup has the details.

It's an early iPhone TestFlight beta (link in the post); happy to go deep on either the constructive‑reals side or the AI‑assisted‑dev side.

3 days agodimview

Maybe you should correct the errors in your post before worrying about the code.

3 hours agoNetMageSCW

Corrected the dates, thank you! What are the other errors?

6 minutes agodimview

The old HP calculators, and their emulators, have a computer algebra system, for symbolic maths, that supported this. The user interfaces leave much to be desired, but some also have reverse Polish notation!

3 hours agonomel

This is different from a CAS. For example, if you ask it to do exp(100)+1-exp(100), it does not rearrange and cancel out the two exp(100)s. Instead, it does exp, addition, and subtraction, all with as many digits as you ask for.

27 minutes agodimview

> I built one, by porting Boehm’s engine. > It’s 2026, so I didn’t hand-write the port. I directed Opus 4.8 to translate the source line by line into Swift

I wish I could filter out stuff like this. Cool work by Hans Boehm, but what's the value add in this blog post.

3 hours agobla3

Read. Guy knows what he's doing.

2 hours agoB1FF_PSUVM

I don't get why this is a big deal. All the calculators I've used have been rectangle.

3 hours agoquixoticelixer-

Very interesting, thank you for posting! I'm curious - roughly how many tokens do you think you used during the initial port and subsequent bug hunting and fixes?

4 hours agojagraff

It would also be fun to have a full computer algebra system (like maxima) on a phone

4 hours agopiinbinary

That should be doable, too. Maybe as a next project.

22 minutes agodimview

btw if you turn the iphone calc into landscape mode and switch you scientific calc it does Ramanujan's constant without rounding, but stops after the twelve 9s.

3 hours agohtx80nerd

Correct, but if you don't know the next digit is 2, you can think it's all 9s, another representation of an integer number.

31 minutes agodimview

Edit: Whoops. My bad. This must have been a HN "second chance" winner.

3 hours agoJblx2

That looks like a link right back to this thread?

3 hours agobadc0ffee

Er, that's this submission.

3 hours agoColinWright
[deleted]