49 lines
		
	
	
		
			766 B
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			49 lines
		
	
	
		
			766 B
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								:- object(_ ** _,
							 | 
						||
| 
								 | 
							
									implements(symdiffp)).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									:- info([
							 | 
						||
| 
								 | 
							
										authors is 'Paulo Moura',
							 | 
						||
| 
								 | 
							
										version is 1.0,
							 | 
						||
| 
								 | 
							
										date is 1999/12/29,
							 | 
						||
| 
								 | 
							
										parnames is ['Expression', 'Power'],
							 | 
						||
| 
								 | 
							
										comment is 'Symbolic differentiation and simplification of **/2 expressions.',
							 | 
						||
| 
								 | 
							
										source is 'Example based on the Clocksin and Mellish Prolog book.']).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									diff(Diff) :-
							 | 
						||
| 
								 | 
							
										this(X ** Y),
							 | 
						||
| 
								 | 
							
										once(diff(X, Y, Diff)).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									diff(X, Y, Y * X ** Y2 * DX) :-
							 | 
						||
| 
								 | 
							
										integer(Y),
							 | 
						||
| 
								 | 
							
										Y2 is Y - 1,
							 | 
						||
| 
								 | 
							
										X::diff(DX).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									diff(X, Y, Y * X ** Y2 * DX) :-
							 | 
						||
| 
								 | 
							
										Y2 = Y - 1,
							 | 
						||
| 
								 | 
							
										X::diff(DX).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									simplify(S) :-
							 | 
						||
| 
								 | 
							
										this(X ** Y),
							 | 
						||
| 
								 | 
							
										once(simplify(X, Y, S)).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									simplify(_, 0, 1).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									simplify(X, 1, X).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									simplify(X, Y, S ** Y) :-
							 | 
						||
| 
								 | 
							
										integer(Y),
							 | 
						||
| 
								 | 
							
										X::simplify(S).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									simplify(X, Y, SX ** SY) :-
							 | 
						||
| 
								 | 
							
										X::simplify(SX),
							 | 
						||
| 
								 | 
							
										Y::simplify(SY).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								:- end_object.
							 |