1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-01-12 02:10:34 +00:00

reg3:: extra_verification

This commit is contained in:
Zeno Rogue 2020-07-05 00:45:25 +02:00
parent 906c47c511
commit 2d7571034b

View File

@ -27,6 +27,8 @@ EX namespace reg3 {
inline short& altdist(heptagon *h) { return h->emeraldval; } inline short& altdist(heptagon *h) { return h->emeraldval; }
#endif #endif
EX int extra_verification;
EX bool ultra_mirror_on; EX bool ultra_mirror_on;
EX bool ultra_mirror_in() { return (cgflags & qULTRA) && ultra_mirror_on; } EX bool ultra_mirror_in() { return (cgflags & qULTRA) && ultra_mirror_on; }
@ -753,6 +755,20 @@ EX namespace reg3 {
return quotient_map->allh[h->fieldval]; return quotient_map->allh[h->fieldval];
} }
void verify_neighbors(heptagon *alt, int steps, const hyperpoint& hT) {
ld err;
for(auto& p2: altmap[alt]) if((err = intval(tC0(p2.second), hT)) < 1e-3) {
println(hlog, "FAIL");
exit(3);
}
if(steps) {
dynamicval<eGeometry> g(geometry, gBinary3);
dynamicval<hrmap*> cm(currentmap, binary_map);
for(int i=0; i<alt->type; i++)
verify_neighbors(alt->cmove(i), steps-1, currentmap->iadj(alt, i) * hT);
}
}
heptagon *create_step(heptagon *parent, int d) override { heptagon *create_step(heptagon *parent, int d) override {
auto& p1 = reg_gmatrix[parent]; auto& p1 = reg_gmatrix[parent];
if(DEB) println(hlog, "creating step ", parent, ":", d, ", at ", p1.first, tC0(p1.second)); if(DEB) println(hlog, "creating step ", parent, ":", d, ", at ", p1.first, tC0(p1.second));
@ -819,6 +835,8 @@ EX namespace reg3 {
return p2.first; return p2.first;
} }
if(extra_verification) verify_neighbors(alt, extra_verification, hT);
if(DEB) println(hlog, "-> not found"); if(DEB) println(hlog, "-> not found");
int d2 = 0, fv = isize(reg_gmatrix); int d2 = 0, fv = isize(reg_gmatrix);
#if CAP_FIELD #if CAP_FIELD