# the module phcpy.phcpy2c3¶

The Python scripts in the package phcpy call the wrappers for the C interface to the Ada code in PHCpack. Below is the list of all functions exported by the shared object file phcpy2c3.so. The source code provides more detailed documentation.

## design of the Python to C interface¶

The design of phcpy depends on PHClib, a library of various collections of C functions, originally developed for message passing with the MPI library. This design is sketched in Fig. 17.

Fig. 17 The design of phcpy through the C interface to Ada code.

PHClib interfaces to the Ada routines through one single Ada procedure use_c2phc.adb. The collection of parallel distibuted memory programs (MPI2phc) using message passing (MPI) depends on PHClib. All C functions that are exported to the Python interface have their prototypes in the header file phcpy2c.h while the definitions in phcpy2c3.c call the proper routines in PHClib.

## the interface to PHCpack¶

The module interface collects the functions that parse the string representations for polynomials and solutions to pass their data through the C interface to the Ada code of PHCpack. The reverse operations return the string representations for polynomials and solutions as stored internally in PHCpack.

The functions exported by phcpy.interface concern the movement of data between Python and PHCpack. The store_ methods parse strings representing polynomials and solutions into the corresponding internal data structures. The corresponding load_ methods take the internal data structures for polynomials and solutions, stored in containers, and show their corresponding representations as Python strings. For example, consider the session

>>> from phcpy.interface import store_standard_system, load_standard_system
>>> store_standard_system(['x^2 - 1/3;'])
['x^2 - 3.33333333333333E-01;']


The session above illustrates the parsing of a system one could use to approximate the square root of 1/3. With standard double precision, the 1/3 is approximated to about 15 decimal places.

## wrappers to the C interface to PHCpack¶

A basic application of the primitive operations in phcpy2c3 is an interactive reading of a polynomial system. Assume the file example at /tmp/ contains a polynomial system, then we can do the following:

>>> from phcpy.phcpy2c3 import py2c_syscon_read_standard_system as readsys
>>> from phcpy.phcpy2c3 import py2c_syscon_write_standard_system as writesys

Is the system on a file ? (y/n/i=info) y

Reading the name of the input file.
Give a string of characters : /tmp/example
0
>>> writesys()
2
x^2+4*y^2-4;
2*y^2-x;
0
>>> from phcpy.phcpy2c3 import py2c_solve_system as solve
>>> solve(0)

ROOT COUNTS :

total degree : 4
general linear-product Bezout number : 4
based on the set structure :
{ x y }{ x y }
{ x y }{ y }
mixed volume : 4
stable mixed volume : 4
4
>>> from phcpy.phcpy2c3 import py2c_solcon_write_standard_solutions as writesols
>>> writesols()
4 2
===========================================================================
solution 1 :
t :  1.00000000000000E+00   0.00000000000000E+00
m : 1
the solution for t :
x :  1.23606797749979E+00  -9.91383530201425E-119
y :  7.86151377757423E-01   4.95691765100713E-119
== err :  1.567E-16 = rco :  3.067E-01 = res :  3.331E-16 ==
solution 2 :
t :  1.00000000000000E+00   0.00000000000000E+00
m : 1
the solution for t :
x :  1.23606797749979E+00  -9.91383530201425E-119
y : -7.86151377757423E-01  -4.95691765100713E-119
== err :  1.567E-16 = rco :  3.067E-01 = res :  3.331E-16 ==
solution 3 :
t :  1.00000000000000E+00   0.00000000000000E+00
m : 1
the solution for t :
x : -3.23606797749979E+00   3.17242729664456E-117
y : -1.58621364832228E-117   1.27201964951407E+00
== err :  3.703E-16 = rco :  1.515E-01 = res :  4.441E-16 ==
solution 4 :
t :  1.00000000000000E+00   0.00000000000000E+00
m : 1
the solution for t :
x : -3.23606797749979E+00   3.17242729664456E-117
y :  1.58621364832228E-117  -1.27201964951407E+00
== err :  3.703E-16 = rco :  1.515E-01 = res :  4.441E-16 ==
0
>>>


With these primitive operations in phcpy2c3 we can bypass the writing and the parsing to strings.