[BACK]Return to F.c CVS log [TXT][DIR] Up to [local] / OpenXM_contrib2 / asir2000 / engine

Diff for /OpenXM_contrib2/asir2000/engine/F.c between version 1.6 and 1.9

version 1.6, 2001/04/20 02:34:21 version 1.9, 2001/07/04 07:19:19
Line 45 
Line 45 
  * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,   * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,
  * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.   * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.
  *   *
  * $OpenXM: OpenXM_contrib2/asir2000/engine/F.c,v 1.5 2001/04/19 04:52:41 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/engine/F.c,v 1.8 2001/05/28 08:25:31 noro Exp $
 */  */
 #include "ca.h"  #include "ca.h"
 #include <math.h>  #include <math.h>
   
 void homfctr();  void homfctr();
   void mfctr_wrt_v();
   
   int use_new_hensel;
   
 void fctrp(vl,f,dcp)  void fctrp(vl,f,dcp)
 VL vl;  VL vl;
 P f;  P f;
Line 75  DCP *dcp;
Line 78  DCP *dcp;
         }          }
 }  }
   
   void fctr_wrt_v_p(vl,f,v,dcp)
   VL vl;
   P f;
   V v;
   DCP *dcp;
   {
           VL nvl;
           DCP dc;
   
           if ( !f || NUM(f) ) {
                   NEWDC(dc); COEF(dc) = f; DEG(dc) = ONE;
                   NEXT(dc) = 0; *dcp = dc;
                   return;
           } else if ( !qpcheck((Obj)f) )
                   error("fctrp : invalid argument");
           else {
                   clctv(vl,f,&nvl);
                   if ( !NEXT(nvl) )
                           ufctr(f,1,dcp);
                   else
                           mfctr_wrt_v(nvl,f,v,dcp);
           }
   }
   
 void homfctr(vl,g,dcp)  void homfctr(vl,g,dcp)
 VL vl;  VL vl;
 P g;  P g;
Line 138  DCP *dcp;
Line 165  DCP *dcp;
         adjsgn(f,dc0); *dcp = dc0;          adjsgn(f,dc0); *dcp = dc0;
 }  }
   
   void mfctr_wrt_v(vl,f,v,dcp)
   VL vl;
   P f;
   V v;
   DCP *dcp;
   {
           DCP dc,dc0,dct,dcs,dcr;
           P p,pmin,ppmin,cmin,t;
           VL nvl,mvl;
           Q c;
   
           ptozp(f,1,&c,&p);
           NEWDC(dc0); dc = dc0; COEF(dc) = (P)c; DEG(dc) = ONE; NEXT(dc) = 0;
           msqfr(vl,p,&dct);
           for ( ; dct; dct = NEXT(dct) ) {
                   clctv(vl,f,&nvl);
                   reordvar(nvl,v,&mvl);
                   reorderp(mvl,vl,f,&pmin);
                   pcp(mvl,pmin,&ppmin,&cmin);
                   if ( !NUM(cmin) ) {
                           mfctrmain(mvl,cmin,&dcs);
                           for ( dcr = dcs; dcr; dcr = NEXT(dcr) ) {
                                   DEG(dcr) = DEG(dct);
                                   reorderp(vl,mvl,COEF(dcr),&t); COEF(dcr) = t;
                           }
                           for ( ; NEXT(dc); dc = NEXT(dc) );
                           NEXT(dc) = dcs;
                   }
                   mfctrmain(mvl,ppmin,&dcs);
                   for ( dcr = dcs; dcr; dcr = NEXT(dcr) ) {
                           DEG(dcr) = DEG(dct);
                           reorderp(vl,mvl,COEF(dcr),&t); COEF(dcr) = t;
                   }
                   for ( ; NEXT(dc); dc = NEXT(dc) );
                   NEXT(dc) = dcs;
           }
           adjsgn(f,dc0); *dcp = dc0;
   }
   
 #if 0  #if 0
 void adjsgn(p,dc)  void adjsgn(p,dc)
 P p;  P p;
Line 463  DCP *dcp;
Line 529  DCP *dcp;
         else if ( iscycp(p) )          else if ( iscycp(p) )
                 cycp(VR(p),UDEG(p),dcp);                  cycp(VR(p),UDEG(p),dcp);
         else {          else {
                 hensel(5,5,p,&list);                  if ( use_new_hensel )
                           hensel2(5,5,p,&list);
                   else
                           hensel(5,5,p,&list);
                 if ( list->n == 1 ) {                  if ( list->n == 1 ) {
                         NEWDC(dc); DEG(dc) = ONE; COEF(dc) = p; NEXT(dc) = 0;                          NEWDC(dc); DEG(dc) = ONE; COEF(dc) = p; NEXT(dc) = 0;
                         *dcp = dc;                          *dcp = dc;
Line 854  DCP *dcp;
Line 923  DCP *dcp;
                                 *dcp = dc;                                  *dcp = dc;
                                 return;                                  return;
                         } else {                          } else {
                                 d = d1;                                  d = d1+1; /* XXX : try searching better evaluation */
                                 found = 1;                                  found = 0;
                                 sp0 = p0; sdc0 = dc0;  
                                 bcopy((char *)vn1,(char *)svn1,(int)(sizeof(struct oVN)*nv));  
                                 break;                                  break;
                         }                          }
                 }                  }

Legend:
Removed from v.1.6  
changed lines
  Added in v.1.9

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>