mirror of
				https://github.com/zenorogue/hyperrogue.git
				synced 2025-10-23 01:47:39 +00:00 
			
		
		
		
	rogueviz::dhrg::routing:: export some functions
This commit is contained in:
		| @@ -12,6 +12,7 @@ vector<vector<char> > actual; | |||||||
| vector<pairdata> pairs; | vector<pairdata> pairs; | ||||||
|  |  | ||||||
| vector<int> last_goal; | vector<int> last_goal; | ||||||
|  | vector<int> next_stop; | ||||||
|  |  | ||||||
| void prepare_pairs() { | void prepare_pairs() { | ||||||
|   pairs.resize(N); |   pairs.resize(N); | ||||||
| @@ -37,6 +38,8 @@ void prepare_pairs() { | |||||||
|     } |     } | ||||||
|   last_goal.clear(); |   last_goal.clear(); | ||||||
|   last_goal.resize(N, -1); |   last_goal.resize(N, -1); | ||||||
|  |   next_stop.clear(); | ||||||
|  |   next_stop.resize(N, -1); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| void route_from(int src, int goal, const vector<ld>& distances_from_goal) { | void route_from(int src, int goal, const vector<ld>& distances_from_goal) { | ||||||
| @@ -44,6 +47,7 @@ void route_from(int src, int goal, const vector<ld>& distances_from_goal) { | |||||||
|   if(src == goal) { |   if(src == goal) { | ||||||
|     pairs[src].success = 1; |     pairs[src].success = 1; | ||||||
|     pairs[src].route_length = 0; |     pairs[src].route_length = 0; | ||||||
|  |     next_stop[src] = -1; | ||||||
|     } |     } | ||||||
|   else { |   else { | ||||||
|     ld bestd = distances_from_goal[src] - 1e-5; |     ld bestd = distances_from_goal[src] - 1e-5; | ||||||
| @@ -65,6 +69,9 @@ void route_from(int src, int goal, const vector<ld>& distances_from_goal) { | |||||||
|       pairs[src].success += pairs[c].success / isize(candidates); |       pairs[src].success += pairs[c].success / isize(candidates); | ||||||
|       pairs[src].route_length += (1 + pairs[c].route_length) / isize(candidates); |       pairs[src].route_length += (1 + pairs[c].route_length) / isize(candidates); | ||||||
|       } |       } | ||||||
|  |  | ||||||
|  |     if(isize(candidates) > 0) next_stop[src] = candidates[0]; | ||||||
|  |     else next_stop[src] = -1; | ||||||
|     // iprintf("success = %f, route = %f\n", pairs[src].success, pairs[src].route_length); |     // iprintf("success = %f, route = %f\n", pairs[src].success, pairs[src].route_length); | ||||||
|     // indent -= 2; |     // indent -= 2; | ||||||
|     } |     } | ||||||
| @@ -76,8 +83,7 @@ struct iddata { | |||||||
|   iddata() { tot = suc = routedist = bestdist = 0; } |   iddata() { tot = suc = routedist = bestdist = 0; } | ||||||
|   } datas[6]; |   } datas[6]; | ||||||
|  |  | ||||||
| template<class T> void greedy_routing(int id, const T& distance_function) { | template<class T> void greedy_routing_to(int id, int goal, const T& distance_function) { | ||||||
|   for(int goal=0; goal<N; goal++) { |  | ||||||
|   vector<ld> distances_from_goal(N); |   vector<ld> distances_from_goal(N); | ||||||
|   for(int src=0; src<N; src++) |   for(int src=0; src<N; src++) | ||||||
|     distances_from_goal[src] = distance_function(goal, src); |     distances_from_goal[src] = distance_function(goal, src); | ||||||
| @@ -94,6 +100,9 @@ template<class T> void greedy_routing(int id, const T& distance_function) { | |||||||
|     d.bestdist += p * actual[goal][j]; |     d.bestdist += p * actual[goal][j]; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  | template<class T> void greedy_routing(int id, const T& distance_function) { | ||||||
|  |   for(int goal=0; goal<N; goal++) greedy_routing_to(id, goal, distance_function); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| void routing_test(string s) { | void routing_test(string s) { | ||||||
| @@ -147,4 +156,22 @@ void routing_test(string s) { | |||||||
|   println(hlog, "RES;", separated(";", values), ";", N, ";", cgi.expansion->get_growth()); |   println(hlog, "RES;", separated(";", values), ";", N, ";", cgi.expansion->get_growth()); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  | int current_goal; | ||||||
|  | void prepare_goal(int goal) { | ||||||
|  |   greedy_routing_to(0, current_goal = goal, [] (int i, int j) { return hdist(vertexcoords[i], vertexcoords[j]); }); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  | vector<int> path(int src) { | ||||||
|  |   vector<int> res; | ||||||
|  |   while(src != -1) { | ||||||
|  |     res.push_back(src); | ||||||
|  |     src = next_stop[src]; | ||||||
|  |     } | ||||||
|  |   return res; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  | int get_actual(int src) { | ||||||
|  |   return actual[src][current_goal]; | ||||||
|  |   } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Zeno Rogue
					Zeno Rogue