On Thu, Oct 8, 2015 at 2:58 PM, William Stein <wst...@gmail.com> wrote: > > > On Thursday, October 8, 2015, David Joyner <wdjoy...@gmail.com> wrote: >> >> Before this thread drops off the radar, I have a question. How hard >> would it be to rebuild (not port) Sage starting with windows Python, >> then adding windows GAP, windows SIngular, networkxx, and >> SymPy+friends, of which GAP+Singular communicate with the Sage >> terminal via pexpect? Call it WinSage 1.0:-) > > > Just curious - what do you mean by "the sage terminal"? >
I was referring to some sort of cygwin command line (since I hardly ever use anything else), but if people prefer an ipython notebook-like interface then that's fine too. > Also to stop people jumping on pexpect which doesn't at all make sense or > work natively on Windows, replace that by "some sort of IPC". > > > >> >> >> I don't even use windows so really this is a totally naive question. >> >> >> On Thu, Oct 8, 2015 at 7:01 AM, Bill Hart <goodwillh...@googlemail.com> >> wrote: >> > >> > >> > On Wednesday, 7 October 2015 17:38:00 UTC+2, bluescarni wrote: >> >> >> >> Some random thoughts: >> >> >> >> - I am not so convinced the strategy of automatic long -> long long >> >> patching is actually feasible, I think in practice this is gonna be a >> >> big >> >> can of worms. Pushing upstream to fix their code is a much better >> >> long-term >> >> solution IMO (and I'd rather have nothing to do with projects which >> >> refuse >> >> portability and code-quality patches, but that's just me :) >> >> - mingw-w64 is a high quality compiler. I recently had to develop for a >> >> while on a Windows 64 machine, and had to recompile a full stacks of >> >> dependencies (MPFR, GMP, Boost, etc.). It was not so easy (most issues >> >> were >> >> related to build systems), but the end result was pretty impressive >> >> performance-wise. >> >> - While for C code you can probably interoperate with libraries >> >> compiled >> >> with MSVC, for C++ you will end up having issues related, e.g., to >> >> different >> >> implementations of exception handling. My suggestion would be to forget >> >> about MSVC and compile the full stack of dependencies exclusively with >> >> mingw. >> >> - Python on windows 64 does not play properly with mingw due to some >> >> long-standing issues in some header files. If you want to compile >> >> Python >> >> C/C++ extensions on Win64 you will have to patch slightly the Python >> >> headers >> >> and re-generate the definitions of the Python library. The issue is >> >> explored, e.g., here: >> >> >> >> >> >> >> >> http://ascend4.org/Setting_up_a_MinGW-w64_build_environment#Setup_Python_for_compilation_of_extensions >> > >> > >> > Someone has asked me off list to point out the following: >> > >> > "the MSYS2 project have ported CPython and have provided four packages >> > that >> > don't use MSVC: mingw-w64-{i686,x86_64}-ptython{2,3} (as well as ones >> > that >> > link to msys-2.0.dll)." >> > >> > I see that there is a list of packages here: >> > >> > http://sourceforge.net/p/msys2/wiki/Packages/ >> > >> >> >> >> >> >> Generally speaking, mingw-w64 is a really good option for C/C++ >> >> development on Windows. The biggest problem is the proliferation of >> >> distributions (mingw-w64, TDM mingw, mingw-build, msys2, etc.), but the >> >> toolchain is solid. clang is getting there as well, so it's worth >> >> keeping it >> >> in mind for the future. >> >> >> >> Cheers, >> >> >> >> Francesco. >> >> >> >> >> >> On 7 October 2015 at 16:35, Bill Hart <goodwi...@googlemail.com> wrote: >> >>> >> >>> HI all, >> >>> >> >>> William Stein recently bemoaned the fact that SageMath currently only >> >>> runs natively on some brands of Linux, and not natively on the latest >> >>> Windows or OSX (that is to say nothing of BSD). [1] >> >>> >> >>> Until recently, a port of SageMath to Windows has seemed like a pipe >> >>> dream. However, things have changed a lot, and I think it would now be >> >>> possible to achieve this (for some definition of the word "native"). >> >>> >> >>> I've tried VM's before and it has always ended in disaster. They >> >>> either >> >>> screw up my networking, they have performance issues, or don't support >> >>> my >> >>> mouse properly, or change my keyboard layout, or it's impossible to >> >>> get >> >>> files from my hard drive into the system easily, or they take up too >> >>> much >> >>> disk space or need to be constantly downloaded to update them, or some >> >>> features don't work, or people stop supporting them, etc. The >> >>> disadvantages >> >>> of VMs are so numerous I hardly need to enumerate them. And even if it >> >>> is a >> >>> solution for users, it's hardly a solution for serious Windows >> >>> developers. >> >>> >> >>> As some people know, I've been recently working on a Julia based >> >>> "computer algebra system" for a much more limited subset of "computer >> >>> algebra" than Sage targets. What people may not know is that that >> >>> entire >> >>> technology stack works natively on Windows. >> >>> >> >>> I can't express how fantastic it was to be sitting on a train >> >>> recently, >> >>> with no web access whatsoever and to be able to do work on my Windows >> >>> 10 (64 >> >>> bit) laptop on the train. And everything ran as fast, or in some cases >> >>> faster, than my Linux server. That's the first time that has happened >> >>> since >> >>> I started doing computational stuff about 10 years ago! >> >>> >> >>> MSYS2 as a solution >> >>> ================ >> >>> >> >>> The new technology that makes all this work is MSYS2. Here are some of >> >>> its features: >> >>> >> >>> * Installing MSYS2 on Windows couldn't be easier. [2] >> >>> * It supports proper Windows exception handling protocols. >> >>> * It has an amazing command line package manager called Pacman, which >> >>> Just Works TM. >> >>> * Unlike Cygwin, it's very minimal, and takes little time to install. >> >>> * It's fast. Very fast. >> >>> * Parallel make works. >> >>> * The resulting binaries are fast, sometimes faster on my laptop than >> >>> on >> >>> the Linux server I usually use for development. >> >>> * MSYS2 provides a posix layer! (Applications can be distributed with >> >>> an >> >>> MSYS2 dll for this.) >> >>> * Multithreading using pthreads Just Works TM (Applications can be >> >>> distributed with a winthreads dll for this. I've actually used this, >> >>> no >> >>> patching required, so I am not speaking theoretically here.) >> >>> * Like native Windows, sizeof(long) = 4 and sizeof(long long) = 8 on >> >>> MSYS2. This means interop with native Windows applications or assembly >> >>> objects is a cynch. >> >>> * The resulting applications can be run on Windows as essentially >> >>> native >> >>> applications. They don't have to be run from within the MSYS2 shell. >> >>> They >> >>> can also be distributed as binary packages for those that don't care >> >>> about >> >>> the source code. But here's the thing: it's not *necessary* to >> >>> distribute >> >>> them as binary packages. It's now quite feasible for developers to >> >>> actually >> >>> *build* packages on Windows. And let's face it, this is the type of >> >>> developer we actually want on the Windows platform. Simply supporting >> >>> users >> >>> and not developers is just going to increase the maintenance burden >> >>> for >> >>> people who work on other platforms. We want actual Windows developers, >> >>> not >> >>> just users! >> >>> >> >>> The only bad thing about MSYS2 is that autotools is still incredibly >> >>> slow >> >>> (Flint roll-your-own configure takes 5s at most on Windows, whereas >> >>> autotools can take some minutes to configure a package). Note: make is >> >>> not >> >>> slow (at least not on Windows 64 -- it's not as fast on 32 bit >> >>> Windows, but >> >>> fortunately almost no one is using Windows 32 any more anyway). >> >>> >> >>> Proposal >> >>> ======= >> >>> >> >>> What I propose is to begin porting Sage dependencies to Windows (note >> >>> that by Windows, I mean Windows 64, i.e. what everyone is using). What >> >>> this >> >>> would mean is porting them to MSYS2 (at least initially). Note it's >> >>> not a >> >>> big step from there to MinGW or MSVC if people want to do that later. >> >>> Microsoft have made MSVC much, much more friendly to GNU conventions, >> >>> recently. (For some users, porting to Windows natively is synonymous >> >>> with >> >>> supporting MSVC using Visual Solution files. But I'm not suggesting we >> >>> do >> >>> that.) >> >>> >> >>> Since we know that many upstream projects simply will not accept >> >>> thousands of patches to their repositories for supporting Windows 64, >> >>> much >> >>> less do they have developer resources to support them on an ongoing >> >>> basis, >> >>> here is what I think needs to be done: >> >>> >> >>> 1) Automagically patch their source trees at build time so that long >> >>> becomes long long and unsigned long becomes unsigned long long on >> >>> Windows. >> >>> 2) Automagically patch their source trees at build time so that >> >>> printf/scanf("%ld") becomes printf/scanf("%lld") on Windows. >> >>> 3) Send a very small number of "Windows" patches upstream for the few >> >>> instances of nonportable code that probably doesn't work anywhere >> >>> except >> >>> Linux, let alone on Windows. >> >>> >> >>> Is this feasible? >> >>> >> >>> Yes it is. Note that libpari still works today on Windows 64 (actually >> >>> natively with MinGW, not just with MSYS). On Windows 64 their build >> >>> automagically patches their source tree. As far as I know, this hasn't >> >>> been >> >>> touched in years, and it still works today as well as the day it was >> >>> written >> >>> (modulo a couple of trivial bugs in their actual build system)! >> >>> >> >>> [Optionally, we should investigate the feasibility of providing >> >>> Makefiles >> >>> for Windows, automatically generated by autotools, but stored on a >> >>> server so >> >>> that they do not have to be generated at build time (of course the >> >>> user >> >>> still has the option of doing that if they really want). This may not >> >>> be >> >>> feasible, but it's worth investigating. Obviously paths would have to >> >>> be >> >>> patched on a per user basis. But Windows is a very homogeneous >> >>> environment, >> >>> so most of what autotools actually does on Windows is pretty >> >>> pointless.] >> >>> >> >>> What we've done so far >> >>> ================== >> >>> >> >>> So far, the following packages (and probably many more) work fine on >> >>> Windows 64, with the provisions noted: >> >>> >> >>> * MPIR-2.7.0 >> >>> * MPFR-3.1.3 >> >>> * Flint-2.4.5 >> >>> * libpari-2.7.4 -- GP is not patched, and there are some bugs in the >> >>> Pari >> >>> build script, but I've been able to hack them to get libpari to build >> >>> on >> >>> Windows 64. The %ld -> %lld patching is not done yet. >> >>> * Antic >> >>> * OpenBLAS (the Julia people already build this on Windows, since they >> >>> use it heavily) >> >>> >> >>> Python must also work, since I use IJulia on my Windows 64 laptop, >> >>> which >> >>> is basically the same thing as the IPython notebook. This I download >> >>> as part >> >>> of the Anaconda distribution currently. >> >>> >> >>> You can find Windows 32 and 64 dlls for most of the packages mentioned >> >>> above, here: >> >>> >> >>> http://nemocas.org/binaries/ >> >>> >> >>> My intention is to publish a note every time I update this collection >> >>> of >> >>> dlls and to gradually expand them to cover more packages. We'd >> >>> eventually >> >>> want to use dlltray, or the OpenSUSE cross platform build service [3] >> >>> for >> >>> hosting these (the latter is not trivial at the moment, since their >> >>> package >> >>> management system doesn't handle some of the complexities of building >> >>> packages that Sage would rely on). >> >>> >> >>> It would be fantastic if others were to join me in extending this list >> >>> over time. I'd be happy to host the dlls there (actually the machine >> >>> is >> >>> provided by William Stein), at least until the hosting requirements >> >>> start to >> >>> become nontrivial. >> >>> >> >>> The only requirement would be to send dlls for Window 32 and 64 and a >> >>> tarball of the source used to generate them (or alternatively a git >> >>> repo I >> >>> can clone), so that we aren't violating anyone's GPL. We'd also have >> >>> to >> >>> agree on what exception handling protocol to use. It would be very >> >>> convenient for me should that match the one used by the Julia project. >> >>> >> >>> We will shortly be porting Arb to Windows 64. I'll post an update when >> >>> that is done. >> >>> >> >>> Note that Julia itself works on Windows and they have an interest in >> >>> porting lots of stuff to work natively on Windows. So it's possible >> >>> some >> >>> joint effort could be mutually beneficial. >> >>> >> >>> MPIR vs GMP >> >>> ========== >> >>> >> >>> One of MPIR's dirty little secrets is we abandon the GMP interface on >> >>> Windows 64, for good reason. They make all their _ui and _si function >> >>> take >> >>> an unsigned long/long instead of an unsigned long long/long long, even >> >>> though limbs are 64 bits on Windows. >> >>> >> >>> In some timings I did recently, this slows some operations down by a >> >>> factor of 6, and in Flint we have to supply a GMP compatibility >> >>> header, so >> >>> that we can use GMP in the same way we use MPIR on Windows 64 (which >> >>> is >> >>> pretty time consuming to write and obviously a performance sink). >> >>> >> >>> As I'm not interested in just having something that works on Windows >> >>> but >> >>> doesn't care about performance, I personally believe that such an >> >>> effort >> >>> should be based on MPIR not GMP for the time being. >> >>> >> >>> Final note >> >>> ======== >> >>> >> >>> The Julia project targeted Windows very early on, and they have >> >>> attracted >> >>> serious, extremely knowledgeable Windows developers (who have been >> >>> very >> >>> helpful to me). I think this speaks for itself. >> >>> >> >>> Bill. >> >>> >> >>> [1] https://plus.google.com/115360165819500279592/posts/HiXvz9bjumu >> >>> [2] https://msys2.github.io/ >> >>> [3] https://build.opensuse.org/ >> >>> >> >>> -- >> >>> You received this message because you are subscribed to the Google >> >>> Groups >> >>> "sage-devel" group. >> >>> To unsubscribe from this group and stop receiving emails from it, send >> >>> an >> >>> email to sage-devel+...@googlegroups.com. >> >>> To post to this group, send email to sage-...@googlegroups.com. >> >>> Visit this group at http://groups.google.com/group/sage-devel. >> >>> For more options, visit https://groups.google.com/d/optout. >> >> >> >> >> > -- >> > You received this message because you are subscribed to the Google >> > Groups >> > "sage-devel" group. >> > To unsubscribe from this group and stop receiving emails from it, send >> > an >> > email to sage-devel+unsubscr...@googlegroups.com. >> > To post to this group, send email to sage-devel@googlegroups.com. >> > Visit this group at http://groups.google.com/group/sage-devel. >> > For more options, visit https://groups.google.com/d/optout. >> >> -- >> You received this message because you are subscribed to the Google Groups >> "sage-devel" group. >> To unsubscribe from this group and stop receiving emails from it, send an >> email to sage-devel+unsubscr...@googlegroups.com. >> To post to this group, send email to sage-devel@googlegroups.com. >> Visit this group at http://groups.google.com/group/sage-devel. >> For more options, visit https://groups.google.com/d/optout. > > > > -- > Sent from my massive iPhone 6 plus. > > -- > You received this message because you are subscribed to the Google Groups > "sage-devel" group. > To unsubscribe from this group and stop receiving emails from it, send an > email to sage-devel+unsubscr...@googlegroups.com. > To post to this group, send email to sage-devel@googlegroups.com. > Visit this group at http://groups.google.com/group/sage-devel. > For more options, visit https://groups.google.com/d/optout. -- You received this message because you are subscribed to the Google Groups "sage-devel" group. To unsubscribe from this group and stop receiving emails from it, send an email to sage-devel+unsubscr...@googlegroups.com. To post to this group, send email to sage-devel@googlegroups.com. Visit this group at http://groups.google.com/group/sage-devel. For more options, visit https://groups.google.com/d/optout.