-
Notifications
You must be signed in to change notification settings - Fork 70
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
LibTomMath backend support #155
base: master
Are you sure you want to change the base?
Conversation
Enable with ./configure -tommath Requires LibTomMath 1.2.0. Not all Zarith functions are supported. Not fully tested. This backend is also slower than the GMP / MPIR version.
Building against the develop branch of LibTomMath is necessary on Windows as get mp_get_float is missing in 1.2.0. However, due to API changes, this version does not compile against 1.2.0 anymore.
Z.backend is a string with value "GMP", "MPIR" or "LibTomMath". Test zq.ml continues after uncountering unimplemented functions. Test zq.ml now has backend-dependent reference outputs.
independent from the digit size used by LibTomMath.
- reverted the hashing function in LibTomMath backend (simple and fast, but not GMP compatible) - the tests now depends on the digit_bits value - some infomration about LibTomMath in the README
shoud help with compilation on Windows
Add unsigned int support for `fits_` and `to_` functions
early clearning of LibTomMath integers check for memory leaks
I'd be interested in some (even light) feedback on this PR, as we have interested users for a LibTomMath backend (this is available on Windows, unlike GMP, and still developed, unlike MPIR). @xavierleroy, what do you think? |
Well, you're adding a 2500-line C file that is mostly a cut-and-paste from a 3500-line C file (caml_z.c), so it's going to be hard to maintain. Also, GMP is available on Windows, see e.g. So, I need to better understand the Windows problem this PR is trying to solve. |
(The CI is running the testsuite on windows, with the mingw OCaml port and gmp) |
Well, I know some users that rely on Visual Studio on Windows, for better or worse. LibTomMath has an official and maintained support for compilation with VS. As far as I understand, this is not really the case for GMP nor MPIR (what I see currently are mainly one-off efforts that are a bit hackey, and repositories stuck to an old version of GMP). |
Maybe we should setup the CI to test the msvc port of OCaml then. |
I asked @dra27 about where to find a GMP package after his talk on OPAM for Windows, and the short answer was: Relatedly, there seems to be a binary package of GMP for MSVC provided by vcpkg: https://vcpkg.io/en/package/gmp . With luck, that may be enough to build Zarith with ocaml-msvc. At any rate. I'd like the people who really want Zarith with MSVC to explore these possibilities, before we embark into adding 2500 lines of C code to support an obscure alternative to GMP. |
With #157, I was able to build a tests-passing Zarith using MSVC 5.2.0 from opam and this {
"dependencies": [ "gmp" ],
"builtin-baseline": "68d349964cb4e8da561fd849d9491e6ba11c5681",
"overrides": []
} Having done $ PKG_CONFIG_PATH=/cygdrive/c/Devel/Zarith/vcpkg_installed/x64-windows/lib/pkgconfig ./configure and then edited the resulting $ make
$ PATH="/cygdrive/c/Devel/Zarith/vcpkg_installed/x64-windows/bin:$PATH" make tests The good bit is that including vcpkg in opam shouldn't take as long as I thought it might (i.e. it won't need opam 3.0...), but it will take a bit longer than this train journey... |
Very nice! Thanks a lot for the experiment and for #157. Long train journeys are great :-) |
Hi, the point why we at AbsInt prefer the extra backend is that we can build the upstream tommath on all platforms without any third party patches with both MSVC and clang-cl. This highly increases the trust in that lib there. With gmp or mpir that is not feasible. I see above links to forks and the https://vcpkg.io/en/package/gmp.html but still the project itself is not interested in that and has no mainline support for MSVC and Co. I see the point that this adds complexity here. |
Hi, I still don't think that a patched GMP is a good replacement. The GMP people ignore Windows and even that patched stuff only compiles with msys https://github.com/microsoft/vcpkg/blob/f6a91a80e349fbe31d1d72813a011acfc0acaf86/ports/gmp/portfile.cmake Compared to that tommath both just works there with the plain makefiles or the CMake stuff they officially ship. Another benefit for commercial users is the public domain licensing that allows static linking for distribution. |
I also find that the techniques to compile GMP on Windows with VS are not really satisfactory on the long-term. They are "one-off" efforts that work today but are fragile. I'm not convinced they can be maintained by their authors, e.g., for new versions of GMP, of Visual Studio, etc., and it's not something I would like to maintain myself (not being much of a Windows developer). The burden of finding new ways to compile GMP each time the old ones are broken would rely on the library user, which I don't like either. With LibToMath, there is indeed the disadvantage of adding a lot of lines to our codebase. But, at least, I can envisage maintaining the LIbToMath backend of Zarith as long as necessary, especially because I can test it on Linux or and be hopeful that it is sufficient to fix most bugs. We can keep this in a separate branch for now. The current slow pace of evolution in Zarith makes it easy to keep that branch up to date. I'm also open to trade LibToMath for a less obscure, fully maintained, cross-platform library if you know of one! |
It's fine to maintain this PR as a separate branch, or maybe even as a fork to Zarith that would also include the LibTomMath source code, so as to fit AbsInt's needs. I still get bad vibrations from LibTomMath (not actively developed, amount of testing unknown, performance unknown, ...) and the 2500-line C wrapper contained in this PR. Zarith is used, directly or indirectly, by hundreds of OPAM packages, the whole OPAM ecosystem is getting much better Windows support, both Mingw and MSVC. I'll wait for a clear message from the OPAM-on-Windows team before deciding that GMP is not usable for Zarith under Windows. |
This PR adds LibTomMath support as alternative backend to GMP and MPIR.
This is especially useful for compilation under Windows.
Using LibTomMath is enabled using the
-tommath
option inconfigure
.Tested under Linux with LibTomMath versions 1.2.1 and 1.3.0.
Caveats:
mp_expt_u32
; however, 1.2.1 does not have the replacement function and I did not find any convenient way to check the library version number!