[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.1 and 1.5

version 1.1, 1999/12/03 07:39:08 version 1.5, 2001/04/19 04:52:41
Line 1 
Line 1 
 /* $OpenXM: OpenXM/src/asir99/engine/F.c,v 1.1.1.1 1999/11/10 08:12:26 noro Exp $ */  /*
    * Copyright (c) 1994-2000 FUJITSU LABORATORIES LIMITED
    * All rights reserved.
    *
    * FUJITSU LABORATORIES LIMITED ("FLL") hereby grants you a limited,
    * non-exclusive and royalty-free license to use, copy, modify and
    * redistribute, solely for non-commercial and non-profit purposes, the
    * computer program, "Risa/Asir" ("SOFTWARE"), subject to the terms and
    * conditions of this Agreement. For the avoidance of doubt, you acquire
    * only a limited right to use the SOFTWARE hereunder, and FLL or any
    * third party developer retains all rights, including but not limited to
    * copyrights, in and to the SOFTWARE.
    *
    * (1) FLL does not grant you a license in any way for commercial
    * purposes. You may use the SOFTWARE only for non-commercial and
    * non-profit purposes only, such as academic, research and internal
    * business use.
    * (2) The SOFTWARE is protected by the Copyright Law of Japan and
    * international copyright treaties. If you make copies of the SOFTWARE,
    * with or without modification, as permitted hereunder, you shall affix
    * to all such copies of the SOFTWARE the above copyright notice.
    * (3) An explicit reference to this SOFTWARE and its copyright owner
    * shall be made on your publication or presentation in any form of the
    * results obtained by use of the SOFTWARE.
    * (4) In the event that you modify the SOFTWARE, you shall notify FLL by
    * e-mail at risa-admin@sec.flab.fujitsu.co.jp of the detailed specification
    * for such modification or the source code of the modified part of the
    * SOFTWARE.
    *
    * THE SOFTWARE IS PROVIDED AS IS WITHOUT ANY WARRANTY OF ANY KIND. FLL
    * MAKES ABSOLUTELY NO WARRANTIES, EXPRESSED, IMPLIED OR STATUTORY, AND
    * EXPRESSLY DISCLAIMS ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS
    * FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT OF THIRD PARTIES'
    * RIGHTS. NO FLL DEALER, AGENT, EMPLOYEES IS AUTHORIZED TO MAKE ANY
    * MODIFICATIONS, EXTENSIONS, OR ADDITIONS TO THIS WARRANTY.
    * UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY, TORT, CONTRACT,
    * OR OTHERWISE, SHALL FLL BE LIABLE TO YOU OR ANY OTHER PERSON FOR ANY
    * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, PUNITIVE OR CONSEQUENTIAL
    * DAMAGES OF ANY CHARACTER, INCLUDING, WITHOUT LIMITATION, DAMAGES
    * ARISING OUT OF OR RELATING TO THE SOFTWARE OR THIS AGREEMENT, DAMAGES
    * FOR LOSS OF GOODWILL, WORK STOPPAGE, OR LOSS OF DATA, OR FOR ANY
    * DAMAGES, EVEN IF FLL SHALL HAVE BEEN INFORMED OF THE POSSIBILITY OF
    * SUCH DAMAGES, OR FOR ANY CLAIM BY ANY OTHER PARTY. EVEN IF A PART
    * OF THE SOFTWARE HAS BEEN DEVELOPED BY A THIRD PARTY, THE THIRD PARTY
    * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,
    * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.
    *
    * $OpenXM: OpenXM_contrib2/asir2000/engine/F.c,v 1.4 2000/08/22 05:04:04 noro Exp $
   */
 #include "ca.h"  #include "ca.h"
 #include <math.h>  #include <math.h>
   
Line 90  DCP *dcp;
Line 138  DCP *dcp;
         adjsgn(f,dc0); *dcp = dc0;          adjsgn(f,dc0); *dcp = dc0;
 }  }
   
   #if 0
 void adjsgn(p,dc)  void adjsgn(p,dc)
 P p;  P p;
 DCP dc;  DCP dc;
Line 105  DCP dc;
Line 154  DCP dc;
                 chsgnp(COEF(dc),&c); COEF(dc) = c;                  chsgnp(COEF(dc),&c); COEF(dc) = c;
         }          }
 }  }
   #else
   void adjsgn(p,dc)
   P p;
   DCP dc;
   {
           int sgn;
           DCP dct;
           P c;
   
           if ( headsgn(COEF(dc)) != headsgn(p) ) {
                   chsgnp(COEF(dc),&c); COEF(dc) = c;
           }
           for ( dct = NEXT(dc); dct; dct = NEXT(dct) )
                   if ( headsgn(COEF(dct)) < 0 ) {
                           chsgnp(COEF(dct),&c); COEF(dct) = c;
                   }
   }
   #endif
   
 int headsgn(p)  int headsgn(p)
 P p;  P p;
 {  {
Line 206  VL vl;
Line 273  VL vl;
 P p;  P p;
 DCP *dcp;  DCP *dcp;
 {  {
         int i,j,k,*win,np;          int i,j,k,*win,np,x;
         VL nvl,tvl;          VL nvl,tvl;
         VN vn,vnt,vn1;          VN vn,vnt,vn1;
         P p0,f,g,f0,g0,s,t,lp,m;          P p0,f,g,f0,g0,s,t,lp,m;
         P *fp0,*fpt,*l,*tl;          P *fp0,*fpt,*l,*tl;
         DCP dc,dc0,dcl;          DCP dc,dc0,dcl;
         int count,nv;          int count,nv;
           int *nonzero;
   
         if ( !cmpq(DEG(DC(p)),ONE) ) {          if ( !cmpq(DEG(DC(p)),ONE) ) {
                 NEWDC(dc); DEG(dc) = ONE; COEF(dc) = p; NEXT(dc) = 0;                  NEWDC(dc); DEG(dc) = ONE; COEF(dc) = p; NEXT(dc) = 0;
Line 222  DCP *dcp;
Line 290  DCP *dcp;
         for ( nv = 0, tvl = nvl; tvl; tvl = NEXT(tvl), nv++);          for ( nv = 0, tvl = nvl; tvl; tvl = NEXT(tvl), nv++);
         W_CALLOC(nv,struct oVN,vn); W_CALLOC(nv,struct oVN,vnt);          W_CALLOC(nv,struct oVN,vn); W_CALLOC(nv,struct oVN,vnt);
         W_CALLOC(nv,struct oVN,vn1);          W_CALLOC(nv,struct oVN,vn1);
           W_CALLOC(nv,int,nonzero);
   
         for ( i = 0, tvl = NEXT(nvl); tvl; tvl = NEXT(tvl), i++ )          for ( i = 0, tvl = NEXT(nvl); tvl; tvl = NEXT(tvl), i++ )
                 vn1[i].v = vn[i].v = tvl->v;                  vn1[i].v = vn[i].v = tvl->v;
         vn1[i].v = vn[i].v = 0;          vn1[i].v = vn[i].v = 0;
   
           /* determine a heuristic bound of deg(GCD(p,p')) */
           while ( 1 ) {
                   for ( i = 0; vn1[i].v; i++ )
                           vn1[i].n = ((unsigned int)random())%256+1;
                   substvp(nvl,LC(p),vn1,&p0);
                   if ( p0 ) {
                           substvp(nvl,p,vn1,&p0);
                           if ( sqfrchk(p0) ) {
                                   ufctr(p0,1,&dc0);
                                   if ( NEXT(NEXT(dc0)) == 0 ) {
                                           NEWDC(dc); DEG(dc) = ONE; COEF(dc) = p; NEXT(dc) = 0;
                                           *dcp = dc;
                                           return;
                                   } else {
                                           for ( dc0 = NEXT(dc0), np = 0; dc0; dc0 = NEXT(dc0), np++ );
                                           break;
                                   }
                           }
                   }
           }
   
           for ( i = 0; vn1[i].v; i++ ) {
                   x = vn1[i].n; vn1[i].n = 0;
                   substvp(nvl,LC(p),vn1,&p0);
                   if ( !p0 )
                           vn1[i].n = x;
                   else {
                           substvp(nvl,p,vn1,&p0);
                           if ( !sqfrchk(p0) )
                                   vn1[i].n = x;
                           else {
                                   ufctr(p0,1,&dc0);
                                   for ( dc0 = NEXT(dc0), j = 0; dc0; dc0 = NEXT(dc0), j++ );
                                   if ( j > np )
                                           vn1[i].n = x;
                           }
                   }
           }
           for ( i = 0; vn1[i].v; i++ )
                   if (vn1[i].n )
                           nonzero[i] = 1;
   
         count = 0;          count = 0;
         while  ( 1 ) {          while  ( 1 ) {
                 while ( 1 ) {                  while ( 1 ) {
Line 248  DCP *dcp;
Line 361  DCP *dcp;
                                                 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;
                                                 return;                                                  return;
                                         } else                                          } else {
                                                 goto MAIN;                                                  for ( dc = NEXT(dc0), i = 0; dc; dc = NEXT(dc), i++ );
                                 }                                                  if ( i <= np )
                                                           goto MAIN;
                                                   if ( i < np )
                                                           np = i;
                                           }
                                   }
                         }                          }
                         if ( nextbin(vnt,j) )                          if ( nextbin(vnt,j) )
                                 break;                                  break;
                 }                  }
                 next(vn);                  while ( 1 ) {
                           next(vn);
                           for ( i = 0; vn[i].v; i++ )
                                   if ( nonzero[i] && !vn[i].n )
                                           break;
                           if ( !vn[i].v )
                                   break;
                   }
         }          }
 MAIN :  MAIN :
 #if 0  #if 0
Line 709  DCP *dcp;
Line 834  DCP *dcp;
         for ( i = 0, tvl = NEXT(nvl); tvl; tvl = NEXT(tvl), i++ )          for ( i = 0, tvl = NEXT(nvl); tvl; tvl = NEXT(tvl), i++ )
                 vn1[i].v = vn[i].v = tvl->v;                  vn1[i].v = vn[i].v = tvl->v;
         vn1[i].v = vn[i].v = 0;          vn1[i].v = vn[i].v = 0;
   
           /* determine a heuristic bound of deg(GCD(p,p')) */
           while ( 1 ) {
                   for ( i = 0; vn1[i].v; i++ )
                           vn1[i].n = ((unsigned int)random())%256+1;
                   substvp(nvl,LC(p),vn1,&tmp);
                   if ( tmp ) {
                           substvp(nvl,p,vn1,&p0);
                           usqp(p0,&dc0);
                           for ( d1 = 0, dc = dc0; dc; dc = NEXT(dc) )
                                   if ( DEG(dc) )
                                           d1 += (QTOS(DEG(dc))-1)*UDEG(COEF(dc));
                           if ( d1 == 0 ) {
                                   /* p is squarefree */
                                   NEWDC(dc); DEG(dc) = ONE; COEF(dc) = p; NEXT(dc) = 0;
                                   *dcp = dc;
                                   return;
                           } else {
                                   d = d1;
                                   break;
                           }
                   }
           }
   
         for  ( dcr0 = 0, g = p, d = deg(VR(g),g), found = 0; ; ) {          for  ( dcr0 = 0, g = p, d = deg(VR(g),g), found = 0; ; ) {
                 while ( 1 ) {                  while ( 1 ) {

Legend:
Removed from v.1.1  
changed lines
  Added in v.1.5

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