On Jan 17, 2009, at 5:45 AM, mhampton wrote:

> Currently Phcpack is an optional package for sage.  Its main purpose
> is to numerically compute isolated solutions of polynomial systems,
> although it has some other functionality as well (e.g. computing mixed
> volumes, witness sets for higher-dimensional solution components).
>
> I have wanted Phcpack to be standard in Sage for a while, but have
> been blocked by concerns about portability.  Phcpack is written in
> Ada.  Recently Jan Verschelde (the author of Phcpack) and his students
> have added some C and Python interfaces, which help integration
> efforts but don't solve the portability issue.
>
> I discussed this situation recently with Jan (who I am cc'ing on this
> email in case he has clarifications or corrections) and he seems
> willing to work with me on porting Phcpack into Sage as a native
> program.  Although Phcpack is pretty fast, there are closed source
> programs that seem quite a bit faster at the moment (although its not
> a simple comparison, they different strengths and weaknesses).  A Sage
> implementation could be quite a bit faster by taking advantage of
> Sage's linear algebra and other components.
>
> My plan for doing this is to move in the functionality piece by piece
> starting in late Febuary (earlier if I can magically find extra
> time).  The first piece will be a parameter-homotopy path tracker,
> since I understand that part the best at the moment and its relatively
> straightforward.  This would take as input a polynomial start system
> and a list of solutions to the start system, and a target system.  The
> algorithm would deform the start system and its solutions into the
> target system and its corresponding solutions.  There is quite a bit
> of literature on how to do this, and if Jan helps me understand how
> Phcpack does this I think it won't be hard to get something running.
> Optimizing it will probably take longer but I know there are some Sage
> developers out there who might find it fun to help.
>
> After the parameter homotopy, we would need:
>
> 1) A way to compute mixed volumes and the cells of a mixed
> subdivision.  Jan ported a C implementation in Ada to do this, so he
> thinks it might be fairly easy for him to do this.
>
> 2) Create ways to generate start systems and their solutions.  The
> main way is to use the mixed subdivision from (1), but there are some
> alternatives.
>
> 3) Routines for "endgames" - issues that arise at the end of
> homotopies, where solutions might be degenerate in various senses.
>
> 4) Techniques for higher-dimensional solution components.
>
> I imagine that Jan and I and our students will do most of this, but we
> will need some help and I am soliciting it in advance.  One thing I
> need is a deeper knowledge of Cython, which will be crucial in getting
> our implementation competitive with closed source alternatives.

This sounds great. The math is (as far as I know) outside my field of  
expertise, but I'm always up for learning something new (subject to  
time constraints) and I do know quite a bit about Cython. At some  
point, this sounds like it would make a good coding sprint project at  
a Sage Days too. The site http://wiki.sagemath.org/SageDays has a  
listing but seems out of date.

- Robert



--~--~---------~--~----~------------~-------~--~----~
To post to this group, send email to sage-devel@googlegroups.com
To unsubscribe from this group, send email to 
sage-devel-unsubscr...@googlegroups.com
For more options, visit this group at http://groups.google.com/group/sage-devel
URLs: http://www.sagemath.org
-~----------~----~----~----~------~----~------~--~---

Reply via email to