1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-01-04 06:20:34 +00:00

improved adj_minefield_cells to avoid relative_matrix

This commit is contained in:
Zeno Rogue 2021-07-12 20:54:45 +02:00
parent c4e85c16d3
commit dd5035184b

View File

@ -1293,20 +1293,25 @@ EX vector<cell*> adj_minefield_cells(cell *c) {
const vector<hyperpoint>& vertices = ss.vertices_only_local; const vector<hyperpoint>& vertices = ss.vertices_only_local;
manual_celllister cl; manual_celllister cl;
cl.add(c); cl.add(c);
vector<transmatrix> M = {Id};
for(int i=0; i<isize(cl.lst); i++) { for(int i=0; i<isize(cl.lst); i++) {
cell *c1 = cl.lst[i]; cell *c1 = cl.lst[i];
bool shares = false; bool shares = false;
transmatrix T = M[i];
if(c != c1) { if(c != c1) {
transmatrix T = currentmap->relative_matrix(c1->master, c->master, C0);
auto& ss1 = currentmap->get_cellshape(c1); auto& ss1 = currentmap->get_cellshape(c1);
auto& vertices1 = ss1.vertices_only_local; auto& vertices1 = ss1.vertices_only_local;
for(hyperpoint h: vertices) for(hyperpoint h2: vertices1) for(hyperpoint h: vertices) for(hyperpoint h2: vertices1)
if(hdist(h, T * h2) < 1e-6) shares = true; if(hdist(h, T * h2) < 1e-6) shares = true;
if(shares) res.push_back(c1); if(shares) res.push_back(c1);
} }
if(shares || c == c1) forCellEx(c2, c1) cl.add(c2); if(shares || c == c1) forCellIdEx(c2, i, c1) {
if(cl.listed(c2)) continue;
cl.add(c2);
M.push_back(T * currentmap->adj(c1, i));
} }
println(hlog, "adjacent to ", c, " = ", isize(res)); }
// println(hlog, "adjacent to ", c, " = ", isize(res), " of ", isize(M));
adj_memo[c] = res; adj_memo[c] = res;
} }
return res; return res;