- sylvan_init_package(1LL<<21, 1LL<<27, 1LL<<20, 1LL<<26);
- sylvan_init_bdd(6);
-
- encode_screen(screen);
-
- sokoban_free(screen);
-
- switch(strat){
- case COORD:
- DPRINT("Encoding coordinate based\n");
+ sylvan_init_package(1LL<<21, 1LL<<27, 1LL<<20, 1LL<<26);
+ sylvan_init_bdd(6);
+
+ //Encode screen
+ time_start_scr = clock();
+ state *init = encode_screen(screen);
+ time_end_scr = clock();
+
+ //Encode goal
+ time_start_goal = clock();
+ state *goal = encode_goal(screen);
+ time_end_goal = clock();
+
+ //Encode transitions
+ time_start_rel = clock();
+ rels *rls = encode_rel(screen);
+ time_end_rel = clock();
+
+
+ //Actually solve
+ time_start_solve = clock();
+ BDD old = sylvan_false;
+ BDD new = init->bdd;
+ //Do lurd
+ for(unsigned int i = 0; i<strlen(lurd); i++){
+ switch(lurd[i]){
+ case 'l':
+ new = subsolve(rls->rell, new);