+void dump_bitmaps(struct individual *individual)
+{
+ bool *bitmap = malloc(page_width_int * page_height_int * sizeof(bool));
+ printf("Bitmap size is %d\n", page_width_int * page_height_int);
+ for (int i=0; i<page_height_int; i++)
+ for (int j=0; j<page_width_int; j++)
+ bitmap[i*page_width_int + j] = 0;
+
+ for (uns i=0; i<GARY_SIZE(individual->placements); i++)
+ {
+fprintf(stderr, "%d-th placement\n", i);
+ struct placement *p = &(individual->placements[i]);
+ struct point_variant *v = NULL;
+
+ switch (p->request->type)
+ {
+ case REQUEST_SEGMENT: ;
+ struct request_segment *rs = (struct request_segment *) p->request;
+ v = rs->variant;
+ break;
+ case REQUEST_POINT: ;
+ struct request_point *rp = (struct request_point *) p->request;
+ v = &(rp->variants[p->variant_used]);
+ break;
+ case REQUEST_AREA: ;
+ struct request_area *ra = (struct request_area *) p->request;
+ printf("Using %d-th of %d variants\n", p->variant_used, GARY_SIZE(ra->variants));
+ v = &(ra->variants[p->variant_used]);
+ break;
+ default:
+ printf("Testing request type (dump_bitmaps): %d\n", p->request->type);
+ ASSERT(p->request->type != REQUEST_INVALID);
+ continue;
+ }
+
+ printf("Got after with %d-th placement of request type %d\n", i, p->request->type);
+
+ printf("Rendering %d-th label %d x %d (w x h)\n", i, v->width, v->height);
+ for (int row = max2(p->y, 0); row < min2(p->y + v->height, page_height_int); row++)
+ {
+ for (int col = max2(p->x, 0); col < min2(p->x + v->width, page_width_int); col++)
+ {
+ printf("Writing to %d\n", row*page_width_int + col);
+ bitmap[row * page_width_int + col] = 1;
+ }
+ }
+ }
+
+ errno = 0;
+ FILE *fd_dump = fopen("dump.pbm", "w");
+ fprintf(fd_dump, "P1\n");
+ fprintf(fd_dump, "%d %d\n", page_width_int, page_height_int);
+ for (int i=0; i<page_height_int; i++)
+ {
+ for (int j=0; j<page_width_int; j++)
+ {
+ fprintf(fd_dump, "%d", bitmap[(int) (i*page_width_int + j)] ? 1 : 0);
+ }
+ fprintf(fd_dump, "\n");
+ }
+ fclose(fd_dump);
+}
+
+void dump_individual(struct individual *individual)
+{
+printf("*** Dumping INDIVIDUAL ***\n");
+printf("(There are %d requests)\n", num_requests);
+ for (uns i=0; i<GARY_SIZE(individual->placements); i++)
+ {
+ struct placement *p = &(individual->placements[i]);
+
+ switch (p->request->type)
+ {
+ case REQUEST_POINT:
+ printf("Point at [%.2f; %.2f] on %u\n", p->x, p->y, ((struct request_point *) p->request)->zindex);
+ break;
+ case REQUEST_LINE: ;
+ struct request_line *rl = (struct request_line *) p->request;
+ printf("Line: ");
+ print_label(rl->sections[0].segments[0].label);
+ break;
+ case REQUEST_SECTION: ;
+ printf("*");
+ break;
+ case REQUEST_SEGMENT: ;
+ if (p->variant_used >= 0)
+ printf("Segment placed at [%.2f; %.2f] on %u\n", p->x, p->y, ((struct request_segment *) p->request)->zindex);
+ else
+ printf("Segment not placed\n");
+ break;
+ case REQUEST_AREA: ;
+ struct request_area *ra = (struct request_area *) p->request;
+ printf("Area label ");
+ print_label(ra->label);
+ printf(" at [%.2f; %.2f] on %u\n", p->x, p->y, ((struct request_area *) p->request)->zindex);
+ break;
+ default:
+ printf("Testing request type (dump_individual)\n");
+ ASSERT(p->request->type != 0);
+ }
+ }
+ printf("\nTotal penalty: %d\n", individual->penalty);
+}
+