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

Diff for /OpenXM_contrib2/asir2000/builtin/dp.c between version 1.32 and 1.39

version 1.32, 2003/06/19 07:08:18 version 1.39, 2003/09/05 13:20:13
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/builtin/dp.c,v 1.31 2003/04/25 04:25:08 ohara Exp $   * $OpenXM: OpenXM_contrib2/asir2000/builtin/dp.c,v 1.38 2003/09/04 08:35:08 noro Exp $
 */  */
 #include "ca.h"  #include "ca.h"
 #include "base.h"  #include "base.h"
Line 89  void Pdp_weyl_set_weight();
Line 89  void Pdp_weyl_set_weight();
 void Pdp_set_weight();  void Pdp_set_weight();
 void Pdp_nf_f(),Pdp_weyl_nf_f();  void Pdp_nf_f(),Pdp_weyl_nf_f();
 void Pdp_lnf_f();  void Pdp_lnf_f();
   void Pnd_gr(),Pnd_gr_trace();
   void Pnd_weyl_gr(),Pnd_weyl_gr_trace();
   void Pnd_nf();
   
 LIST remove_zero_from_list(LIST);  LIST remove_zero_from_list(LIST);
   
Line 129  struct ftab dp_tab[] = {
Line 132  struct ftab dp_tab[] = {
         {"dp_gr_mod_main",Pdp_gr_mod_main,5},          {"dp_gr_mod_main",Pdp_gr_mod_main,5},
         {"dp_gr_f_main",Pdp_gr_f_main,4},          {"dp_gr_f_main",Pdp_gr_f_main,4},
         {"dp_gr_checklist",Pdp_gr_checklist,2},          {"dp_gr_checklist",Pdp_gr_checklist,2},
           {"nd_gr",Pnd_gr,4},
           {"nd_gr_trace",Pnd_gr_trace,5},
           {"nd_weyl_gr",Pnd_weyl_gr,4},
           {"nd_weyl_gr_trace",Pnd_weyl_gr_trace,5},
           {"nd_nf",Pnd_nf,5},
   
         /* F4 algorithm */          /* F4 algorithm */
         {"dp_f4_main",Pdp_f4_main,3},          {"dp_f4_main",Pdp_f4_main,3},
Line 1476  LIST *rp;
Line 1484  LIST *rp;
                 error("dp_gr_mod_main : invalid argument");                  error("dp_gr_mod_main : invalid argument");
         create_order_spec(ARG4(arg),&ord);          create_order_spec(ARG4(arg),&ord);
         dp_gr_mod_main(f,v,homo,m,&ord,rp);          dp_gr_mod_main(f,v,homo,m,&ord,rp);
   }
   
   void Pnd_gr(arg,rp)
   NODE arg;
   LIST *rp;
   {
           LIST f,v;
           int m,homo;
           struct order_spec ord;
   
           do_weyl = 0;
           asir_assert(ARG0(arg),O_LIST,"nd_gr");
           asir_assert(ARG1(arg),O_LIST,"nd_gr");
           asir_assert(ARG2(arg),O_N,"nd_gr");
           f = (LIST)ARG0(arg); v = (LIST)ARG1(arg);
           f = remove_zero_from_list(f);
           if ( !BDY(f) ) {
                   *rp = f; return;
           }
           m = QTOS((Q)ARG2(arg));
           create_order_spec(ARG3(arg),&ord);
           nd_gr(f,v,m,&ord,rp);
   }
   
   void Pnd_gr_trace(arg,rp)
   NODE arg;
   LIST *rp;
   {
           LIST f,v;
           int m,homo;
           struct order_spec ord;
   
           do_weyl = 0;
           asir_assert(ARG0(arg),O_LIST,"nd_gr_trace");
           asir_assert(ARG1(arg),O_LIST,"nd_gr_trace");
           asir_assert(ARG2(arg),O_N,"nd_gr_trace");
           asir_assert(ARG3(arg),O_N,"nd_gr_trace");
           f = (LIST)ARG0(arg); v = (LIST)ARG1(arg);
           f = remove_zero_from_list(f);
           if ( !BDY(f) ) {
                   *rp = f; return;
           }
           homo = QTOS((Q)ARG2(arg));
           m = QTOS((Q)ARG3(arg));
           create_order_spec(ARG4(arg),&ord);
           nd_gr_trace(f,v,m,homo,&ord,rp);
   }
   
   void Pnd_weyl_gr(arg,rp)
   NODE arg;
   LIST *rp;
   {
           LIST f,v;
           int m,homo;
           struct order_spec ord;
   
           do_weyl = 1;
           asir_assert(ARG0(arg),O_LIST,"nd_weyl_gr");
           asir_assert(ARG1(arg),O_LIST,"nd_weyl_gr");
           asir_assert(ARG2(arg),O_N,"nd_weyl_gr");
           f = (LIST)ARG0(arg); v = (LIST)ARG1(arg);
           f = remove_zero_from_list(f);
           if ( !BDY(f) ) {
                   *rp = f; return;
           }
           m = QTOS((Q)ARG2(arg));
           create_order_spec(ARG3(arg),&ord);
           nd_gr(f,v,m,&ord,rp);
   }
   
   void Pnd_weyl_gr_trace(arg,rp)
   NODE arg;
   LIST *rp;
   {
           LIST f,v;
           int m,homo;
           struct order_spec ord;
   
           do_weyl = 1;
           asir_assert(ARG0(arg),O_LIST,"nd_weyl_gr_trace");
           asir_assert(ARG1(arg),O_LIST,"nd_weyl_gr_trace");
           asir_assert(ARG2(arg),O_N,"nd_weyl_gr_trace");
           asir_assert(ARG3(arg),O_N,"nd_weyl_gr_trace");
           f = (LIST)ARG0(arg); v = (LIST)ARG1(arg);
           f = remove_zero_from_list(f);
           if ( !BDY(f) ) {
                   *rp = f; return;
           }
           homo = QTOS((Q)ARG2(arg));
           m = QTOS((Q)ARG3(arg));
           create_order_spec(ARG4(arg),&ord);
           nd_gr_trace(f,v,m,homo,&ord,rp);
   }
   
   void Pnd_nf(arg,rp)
   NODE arg;
   P *rp;
   {
           P f;
           LIST g,v;
           struct order_spec ord;
   
           do_weyl = 0;
           asir_assert(ARG0(arg),O_P,"nd_nf");
           asir_assert(ARG1(arg),O_LIST,"nd_nf");
           asir_assert(ARG2(arg),O_LIST,"nd_nf");
           asir_assert(ARG4(arg),O_N,"nd_nf");
           f = (P)ARG0(arg);
           g = (LIST)ARG1(arg); g = remove_zero_from_list(g);
           if ( !BDY(g) ) {
                   *rp = f; return;
           }
           v = (LIST)ARG2(arg);
           create_order_spec(ARG3(arg),&ord);
           nd_nf_p(f,g,v,QTOS((Q)ARG4(arg)),&ord,rp);
 }  }
   
 /* for Weyl algebra */  /* for Weyl algebra */

Legend:
Removed from v.1.32  
changed lines
  Added in v.1.39

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