| 
									
										
										
										
											2009-02-20 11:44:00 +00:00
										 |  |  | #include <stdio.h>
 | 
					
						
							|  |  |  | #include <stdlib.h>
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #include <assert.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-24 08:21:37 +00:00
										 |  |  | #include <YapInterface.h>
 | 
					
						
							| 
									
										
										
										
											2009-02-20 11:44:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "Yap.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "rtree.h"
 | 
					
						
							|  |  |  | #include "clause_list.h"
 | 
					
						
							|  |  |  | #include "rtree_udi_i.h"
 | 
					
						
							|  |  |  | #include "rtree_udi.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-25 00:13:45 +00:00
										 |  |  | static int YAP_IsNumberTerm (Term term, YAP_Float *n) | 
					
						
							| 
									
										
										
										
											2009-02-20 11:44:00 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   if (YAP_IsIntTerm (term) != FALSE) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     if (n != NULL) | 
					
						
							|  |  |  |       *n = (YAP_Float) YAP_IntOfTerm (term); | 
					
						
							|  |  |  |     return (TRUE); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (YAP_IsFloatTerm (term) != FALSE) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     if (n != NULL) | 
					
						
							|  |  |  |       *n = YAP_FloatOfTerm (term); | 
					
						
							|  |  |  |     return (TRUE); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return (FALSE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-25 00:13:45 +00:00
										 |  |  | static rect_t RectOfTerm (Term term) | 
					
						
							| 
									
										
										
										
											2009-02-20 11:44:00 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   YAP_Term tmp; | 
					
						
							|  |  |  |   rect_t rect; | 
					
						
							|  |  |  |   int i; | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   if (!YAP_IsPairTerm(term)) | 
					
						
							|  |  |  |     return (RectInit()); | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   for (i = 0; YAP_IsPairTerm(term) && i < 4; i++) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       tmp = YAP_HeadOfTerm (term); | 
					
						
							|  |  |  |       if (!YAP_IsNumberTerm(tmp,&(rect.coords[i]))) | 
					
						
							|  |  |  |         return (RectInit()); | 
					
						
							|  |  |  |       term = YAP_TailOfTerm (term); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return (rect); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-25 00:13:45 +00:00
										 |  |  | control_t *RtreeUdiInit (Term spec, | 
					
						
							| 
									
										
										
										
											2009-02-20 11:44:00 +00:00
										 |  |  |                          void * pred, | 
					
						
							|  |  |  |                          int arity){ | 
					
						
							|  |  |  |   control_t *control; | 
					
						
							|  |  |  |   YAP_Term arg; | 
					
						
							|  |  |  |   int i, c; | 
					
						
							|  |  |  |   /*  YAP_Term mod;  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /*  spec = Yap_StripModule(spec, &mod); */ | 
					
						
							|  |  |  |   if (! YAP_IsApplTerm(spec)) | 
					
						
							|  |  |  |     return (NULL); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   control = (control_t *) malloc (sizeof(*control)); | 
					
						
							|  |  |  |   assert(control); | 
					
						
							|  |  |  |   memset((void *) control,0, sizeof(*control)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   c = 0; | 
					
						
							|  |  |  |   for (i = 1; i <= arity; i ++) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       arg = YAP_ArgOfTerm(i,spec); | 
					
						
							|  |  |  |       if (YAP_IsAtomTerm(arg) | 
					
						
							|  |  |  |           && strcmp("+",YAP_AtomName(YAP_AtomOfTerm(arg))) == 0) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |            | 
					
						
							|  |  |  |           (*control)[c].pred = pred; | 
					
						
							|  |  |  |           (*control)[c++].arg = i; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-02 17:34:42 +01:00
										 |  |  | /*  for (i = 0; i < NARGS; i++)
 | 
					
						
							| 
									
										
										
										
											2009-02-20 11:44:00 +00:00
										 |  |  |     printf("%d,%p\t",(*control)[i].arg,(*control)[i].tree); | 
					
						
							| 
									
										
										
										
											2009-04-02 17:34:42 +01:00
										 |  |  |   printf("\n"); */ | 
					
						
							| 
									
										
										
										
											2009-02-20 11:44:00 +00:00
										 |  |  |    | 
					
						
							|  |  |  |   return control; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-25 00:13:45 +00:00
										 |  |  | control_t *RtreeUdiInsert (Term term,control_t *control,void *clausule) | 
					
						
							| 
									
										
										
										
											2009-02-20 11:44:00 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   int i; | 
					
						
							|  |  |  |   rect_t r; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   assert(control); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (i = 0; i < NARGS && (*control)[i].arg != 0 ; i++) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       r = RectOfTerm(YAP_ArgOfTerm((*control)[i].arg,term)); | 
					
						
							|  |  |  |       if (!(*control)[i].tree) | 
					
						
							|  |  |  |         (*control)[i].tree = RTreeNew(); | 
					
						
							|  |  |  |       RTreeInsert(&(*control)[i].tree,r,clausule); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /*  printf("insert %p\n", clausule); */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return (control); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int callback(rect_t r, void *data, void *arg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   callback_m_t x; | 
					
						
							|  |  |  |   x = (callback_m_t) arg; | 
					
						
							|  |  |  |   return Yap_ClauseListExtend(x->cl,data,x->pred); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*ARGS ARE AVAILABLE*/ | 
					
						
							|  |  |  | void *RtreeUdiSearch (control_t *control) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   rect_t r; | 
					
						
							|  |  |  |   int i; | 
					
						
							|  |  |  |   struct ClauseList clauselist; | 
					
						
							|  |  |  |   struct CallbackM cm; | 
					
						
							|  |  |  |   callback_m_t c; | 
					
						
							|  |  |  |   YAP_Term Constraints; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /*RTreePrint ((*control)[0].tree);*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (i = 0; i < NARGS && (*control)[i].arg != 0 ; i++) | 
					
						
							|  |  |  |     if (YAP_IsAttVar(YAP_A((*control)[i].arg))) | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /*get the constraits rect*/ | 
					
						
							|  |  |  |         Constraints = YAP_AttsOfVar(YAP_A((*control)[i].arg)); | 
					
						
							|  |  |  |         /*        Yap_DebugPlWrite(Constraints); */ | 
					
						
							|  |  |  |         r = RectOfTerm(YAP_ArgOfTerm(2,Constraints)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         c = &cm; | 
					
						
							|  |  |  |         c->cl = Yap_ClauseListInit(&clauselist); | 
					
						
							|  |  |  |         c->pred = (*control)[i].pred; | 
					
						
							|  |  |  |         if (!c->cl) | 
					
						
							|  |  |  |           return NULL; /*? or fail*/ | 
					
						
							|  |  |  |         RTreeSearch((*control)[i].tree, r, callback, c); | 
					
						
							|  |  |  |         Yap_ClauseListClose(c->cl); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (Yap_ClauseListCount(c->cl) == 0) | 
					
						
							|  |  |  |           { | 
					
						
							|  |  |  |             Yap_ClauseListDestroy(c->cl); | 
					
						
							|  |  |  |             return Yap_FAILCODE(); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (Yap_ClauseListCount(c->cl) == 1) | 
					
						
							|  |  |  |           { | 
					
						
							|  |  |  |             return Yap_ClauseListToClause(c->cl); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return Yap_ClauseListCode(c->cl); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   return NULL; /*YAP FALLBACK*/ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int RtreeUdiDestroy(control_t *control) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   int i; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   assert(control); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (i = 0; i < NARGS && (*control)[i].arg != 0; i++) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       if ((*control)[i].tree) | 
					
						
							|  |  |  |         RTreeDestroy((*control)[i].tree); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   free(control); | 
					
						
							|  |  |  |   control = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return TRUE; | 
					
						
							|  |  |  | } |