File r37/packages/algint/algfn.red artifact b36aac9257 part of check-in a57e59ec0d


MODULE ALGFN;

% Author: James H. Davenport.

% Check if an expression is in a pure algebraic extension of
% Q(all "constants")(var).


EXPORTS ALGFNPL,ALGEBRAICSF;

IMPORTS SIMP,INTERR,DEPENDSP,DEPENDSPL;

SYMBOLIC PROCEDURE ALGFNP(PF,VAR);
   IF ATOM PF THEN T
    ELSE IF NOT ATOM CAR PF THEN INTERR "Not prefix form"
    ELSE IF CAR PF EQ '!*SQ THEN ALGFNSQ(CADR PF,VAR)
      ELSE IF CAR PF EQ 'EXPT
       THEN IF NOT algint!-RATNUMP CADDR PF
	      THEN (NOT DEPENDSP(CADR PF,VAR))
		AND (NOT DEPENDSP(CADDR PF,VAR))
	     ELSE ALGFNP(CADR PF,VAR)
    ELSE IF NOT MEMQ(CAR PF,'(MINUS PLUS TIMES QUOTIENT SQRT))
	   % JPff fiddle
     THEN NOT DEPENDSPL(CDR PF,VAR)
    ELSE ALGFNPL(CDR PF,VAR);

SYMBOLIC PROCEDURE ALGFNPL(P!-LIST,VAR);
   NULL P!-LIST OR ALGFNP(CAR P!-LIST,VAR) AND ALGFNPL(CDR P!-LIST,VAR);

SYMBOLIC PROCEDURE ALGFNSQ(SQ,VAR);
   ALGFNSF(NUMR SQ,VAR) AND ALGFNSF(DENR SQ,VAR);

SYMBOLIC PROCEDURE ALGFNSF(SF,VAR);
   ATOM SF
 OR ALGFNP(MVAR SF,VAR) AND ALGFNSF(LC SF,VAR) AND ALGFNSF(RED SF,VAR);

SYMBOLIC PROCEDURE algint!-RATNUMP Q;
   IF ATOM Q THEN NUMBERP Q
    ELSE CAR Q EQ 'QUOTIENT AND (NUMBERP CADR Q) AND (NUMBERP CADDR Q);

SYMBOLIC PROCEDURE ALGEBRAICSF U;
   IF ATOM U THEN NIL
    ELSE ALGEBRAICP MVAR U OR ALGEBRAICSF LC U OR ALGEBRAICSF RED U;

SYMBOLIC PROCEDURE ALGEBRAICP U;
   IF ATOM U THEN NIL
    ELSE IF CAR U EQ 'EXPT THEN 1 NEQ DENR SIMP CADDR U
    ELSE CAR U EQ 'SQRT;

ENDMODULE;

END;



REDUCE Historical
REDUCE Sourceforge Project | Historical SVN Repository | GitHub Mirror | SourceHut Mirror | NotABug Mirror | Chisel Mirror | Chisel RSS ]