abc-master
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros
cols.c File Reference
#include "sparse_int.h"

Go to the source code of this file.

Functions

ABC_NAMESPACE_IMPL_START sm_colsm_col_alloc ()
 
void sm_col_free (sm_col *pcol)
 
sm_colsm_col_dup (sm_col *pcol)
 
sm_elementsm_col_insert (sm_col *pcol, int row)
 
void sm_col_remove (sm_col *pcol, int row)
 
sm_elementsm_col_find (sm_col *pcol, int row)
 
int sm_col_contains (sm_col *p1, sm_col *p2)
 
int sm_col_intersects (sm_col *p1, sm_col *p2)
 
int sm_col_compare (sm_col *p1, sm_col *p2)
 
sm_colsm_col_and (sm_col *p1, sm_col *p2)
 
int sm_col_hash (sm_col *pcol, int modulus)
 
void sm_col_remove_element (sm_col *pcol, sm_element *p)
 
void sm_col_print (FILE *fp, sm_col *pcol)
 

Function Documentation

ABC_NAMESPACE_IMPL_START sm_col* sm_col_alloc ( )

Definition at line 21 of file cols.c.

22 {
23  register sm_col *pcol;
24 
25 #ifdef FAST_AND_LOOSE
26  if (sm_col_freelist == NIL(sm_col)) {
27  pcol = ALLOC(sm_col, 1);
28  } else {
29  pcol = sm_col_freelist;
30  sm_col_freelist = pcol->next_col;
31  }
32 #else
33  pcol = ALLOC(sm_col, 1);
34 #endif
35 
36  pcol->col_num = 0;
37  pcol->length = 0;
38  pcol->first_row = pcol->last_row = NIL(sm_element);
39  pcol->next_col = pcol->prev_col = NIL(sm_col);
40  pcol->flag = 0;
41  pcol->user_word = NIL(char); /* for our user ... */
42  return pcol;
43 }
sm_col * next_col
Definition: sparse.h:65
sm_element * last_row
Definition: sparse.h:64
int length
Definition: sparse.h:61
char * user_word
Definition: sparse.h:67
#define NIL(type)
Definition: avl.h:25
#define ALLOC(type, num)
Definition: avl.h:27
sm_element * first_row
Definition: sparse.h:63
int flag
Definition: sparse.h:62
int col_num
Definition: sparse.h:60
typedefABC_NAMESPACE_HEADER_START struct sm_element_struct sm_element
Definition: sparse.h:21
sm_col * prev_col
Definition: sparse.h:66
sm_col* sm_col_and ( sm_col p1,
sm_col p2 
)

Definition at line 247 of file cols.c.

249 {
250  register sm_element *q1, *q2;
251  register sm_col *result;
252 
253  result = sm_col_alloc();
254  q1 = p1->first_row;
255  q2 = p2->first_row;
256  if (q1 == 0 || q2 == 0) return result;
257  for(;;) {
258  if (q1->row_num < q2->row_num) {
259  if ((q1 = q1->next_row) == 0) {
260  return result;
261  }
262  } else if (q1->row_num > q2->row_num) {
263  if ((q2 = q2->next_row) == 0) {
264  return result;
265  }
266  } else {
267  (void) sm_col_insert(result, q1->row_num);
268  if ((q1 = q1->next_row) == 0) {
269  return result;
270  }
271  if ((q2 = q2->next_row) == 0) {
272  return result;
273  }
274  }
275  }
276 }
sm_element * first_row
Definition: sparse.h:63
typedefABC_NAMESPACE_HEADER_START struct sm_element_struct sm_element
Definition: sparse.h:21
static int result
Definition: cuddGenetic.c:125
sm_element * sm_col_insert(sm_col *pcol, int row)
Definition: cols.c:100
ABC_NAMESPACE_IMPL_START sm_col * sm_col_alloc()
Definition: cols.c:21
int sm_col_compare ( sm_col p1,
sm_col p2 
)

Definition at line 218 of file cols.c.

220 {
221  register sm_element *q1, *q2;
222 
223  q1 = p1->first_row;
224  q2 = p2->first_row;
225  while(q1 != 0 && q2 != 0) {
226  if (q1->row_num != q2->row_num) {
227  return q1->row_num - q2->row_num;
228  }
229  q1 = q1->next_row;
230  q2 = q2->next_row;
231  }
232 
233  if (q1 != 0) {
234  return 1;
235  } else if (q2 != 0) {
236  return -1;
237  } else {
238  return 0;
239  }
240 }
sm_element * first_row
Definition: sparse.h:63
typedefABC_NAMESPACE_HEADER_START struct sm_element_struct sm_element
Definition: sparse.h:21
int sm_col_contains ( sm_col p1,
sm_col p2 
)

Definition at line 165 of file cols.c.

167 {
168  register sm_element *q1, *q2;
169 
170  q1 = p1->first_row;
171  q2 = p2->first_row;
172  while (q1 != 0) {
173  if (q2 == 0 || q1->row_num < q2->row_num) {
174  return 0;
175  } else if (q1->row_num == q2->row_num) {
176  q1 = q1->next_row;
177  q2 = q2->next_row;
178  } else {
179  q2 = q2->next_row;
180  }
181  }
182  return 1;
183 }
sm_element * first_row
Definition: sparse.h:63
typedefABC_NAMESPACE_HEADER_START struct sm_element_struct sm_element
Definition: sparse.h:21
sm_col* sm_col_dup ( sm_col pcol)

Definition at line 82 of file cols.c.

84 {
85  register sm_col *pnew;
86  register sm_element *p;
87 
88  pnew = sm_col_alloc();
89  for(p = pcol->first_row; p != 0; p = p->next_row) {
90  (void) sm_col_insert(pnew, p->row_num);
91  }
92  return pnew;
93 }
static Llb_Mgr_t * p
Definition: llb3Image.c:950
sm_element * first_row
Definition: sparse.h:63
typedefABC_NAMESPACE_HEADER_START struct sm_element_struct sm_element
Definition: sparse.h:21
sm_element * sm_col_insert(sm_col *pcol, int row)
Definition: cols.c:100
ABC_NAMESPACE_IMPL_START sm_col * sm_col_alloc()
Definition: cols.c:21
sm_element* sm_col_find ( sm_col pcol,
int  row 
)

Definition at line 146 of file cols.c.

149 {
150  register sm_element *p;
151 
152  for(p = pcol->first_row; p != 0 && p->row_num < row; p = p->next_row)
153  ;
154  if (p != 0 && p->row_num == row) {
155  return p;
156  } else {
157  return NIL(sm_element);
158  }
159 }
static Llb_Mgr_t * p
Definition: llb3Image.c:950
#define NIL(type)
Definition: avl.h:25
sm_element * first_row
Definition: sparse.h:63
typedefABC_NAMESPACE_HEADER_START struct sm_element_struct sm_element
Definition: sparse.h:21
void sm_col_free ( sm_col pcol)

Definition at line 53 of file cols.c.

55 {
56 #if defined(FAST_AND_LOOSE) && ! defined(COLS)
57  if (pcol->first_row != NIL(sm_element)) {
58  /* Add the linked list of col items to the free list */
59  pcol->last_row->next_row = sm_element_freelist;
60  sm_element_freelist = pcol->first_row;
61  }
62 
63  /* Add the col to the free list of cols */
64  pcol->next_col = sm_col_freelist;
65  sm_col_freelist = pcol;
66 #else
67  register sm_element *p, *pnext;
68 
69  for(p = pcol->first_row; p != 0; p = pnext) {
70  pnext = p->next_row;
71  sm_element_free(p);
72  }
73  FREE(pcol);
74 #endif
75 }
static Llb_Mgr_t * p
Definition: llb3Image.c:950
#define sm_element_free(e)
Definition: sparse_int.h:113
sm_col * next_col
Definition: sparse.h:65
sm_element * last_row
Definition: sparse.h:64
#define NIL(type)
Definition: avl.h:25
sm_element * first_row
Definition: sparse.h:63
#define FREE(obj)
Definition: avl.h:31
typedefABC_NAMESPACE_HEADER_START struct sm_element_struct sm_element
Definition: sparse.h:21
int sm_col_hash ( sm_col pcol,
int  modulus 
)

Definition at line 279 of file cols.c.

282 {
283  register int sum;
284  register sm_element *p;
285 
286  sum = 0;
287  for(p = pcol->first_row; p != 0; p = p->next_row) {
288  sum = (sum*17 + p->row_num) % modulus;
289  }
290  return sum;
291 }
static Llb_Mgr_t * p
Definition: llb3Image.c:950
sm_element * first_row
Definition: sparse.h:63
typedefABC_NAMESPACE_HEADER_START struct sm_element_struct sm_element
Definition: sparse.h:21
sm_element* sm_col_insert ( sm_col pcol,
int  row 
)

Definition at line 100 of file cols.c.

103 {
104  register sm_element *test, *element;
105 
106  /* get a new item, save its address */
107  sm_element_alloc(element);
108  test = element;
109  sorted_insert(sm_element, pcol->first_row, pcol->last_row, pcol->length,
110  next_row, prev_row, row_num, row, test);
111 
112  /* if item was not used, free it */
113  if (element != test) {
114  sm_element_free(element);
115  }
116 
117  /* either way, return the current new value */
118  return test;
119 }
#define sm_element_free(e)
Definition: sparse_int.h:113
sm_element * last_row
Definition: sparse.h:64
int length
Definition: sparse.h:61
sm_element * first_row
Definition: sparse.h:63
typedefABC_NAMESPACE_HEADER_START struct sm_element_struct sm_element
Definition: sparse.h:21
#define sm_element_alloc(newobj)
Definition: sparse_int.h:110
int sm_col_intersects ( sm_col p1,
sm_col p2 
)

Definition at line 190 of file cols.c.

192 {
193  register sm_element *q1, *q2;
194 
195  q1 = p1->first_row;
196  q2 = p2->first_row;
197  if (q1 == 0 || q2 == 0) return 0;
198  for(;;) {
199  if (q1->row_num < q2->row_num) {
200  if ((q1 = q1->next_row) == 0) {
201  return 0;
202  }
203  } else if (q1->row_num > q2->row_num) {
204  if ((q2 = q2->next_row) == 0) {
205  return 0;
206  }
207  } else {
208  return 1;
209  }
210  }
211 }
sm_element * first_row
Definition: sparse.h:63
typedefABC_NAMESPACE_HEADER_START struct sm_element_struct sm_element
Definition: sparse.h:21
void sm_col_print ( FILE *  fp,
sm_col pcol 
)

Definition at line 308 of file cols.c.

311 {
312  sm_element *p;
313 
314  for(p = pcol->first_row; p != 0; p = p->next_row) {
315  (void) fprintf(fp, " %d", p->row_num);
316  }
317 }
static Llb_Mgr_t * p
Definition: llb3Image.c:950
sm_element * first_row
Definition: sparse.h:63
typedefABC_NAMESPACE_HEADER_START struct sm_element_struct sm_element
Definition: sparse.h:21
void sm_col_remove ( sm_col pcol,
int  row 
)

Definition at line 126 of file cols.c.

129 {
130  register sm_element *p;
131 
132  for(p = pcol->first_row; p != 0 && p->row_num < row; p = p->next_row)
133  ;
134  if (p != 0 && p->row_num == row) {
135  dll_unlink(p, pcol->first_row, pcol->last_row,
136  next_row, prev_row, pcol->length);
137  sm_element_free(p);
138  }
139 }
static Llb_Mgr_t * p
Definition: llb3Image.c:950
#define sm_element_free(e)
Definition: sparse_int.h:113
sm_element * last_row
Definition: sparse.h:64
int length
Definition: sparse.h:61
#define dll_unlink(p, first, last, next, prev, count)
Definition: sparse_int.h:76
sm_element * first_row
Definition: sparse.h:63
typedefABC_NAMESPACE_HEADER_START struct sm_element_struct sm_element
Definition: sparse.h:21
void sm_col_remove_element ( sm_col pcol,
sm_element p 
)

Definition at line 297 of file cols.c.

300 {
301  dll_unlink(p, pcol->first_row, pcol->last_row,
302  next_row, prev_row, pcol->length);
304 }
static Llb_Mgr_t * p
Definition: llb3Image.c:950
#define sm_element_free(e)
Definition: sparse_int.h:113
sm_element * last_row
Definition: sparse.h:64
int length
Definition: sparse.h:61
#define dll_unlink(p, first, last, next, prev, count)
Definition: sparse_int.h:76
sm_element * first_row
Definition: sparse.h:63