mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2024-12-25 01:20:37 +00:00
reg3:: extra_verification
This commit is contained in:
parent
906c47c511
commit
2d7571034b
18
reg3.cpp
18
reg3.cpp
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user