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

gp:: more concentrated tree

This commit is contained in:
Zeno Rogue 2018-07-10 18:01:42 +02:00
parent 711efc3be4
commit d986ed7617
3 changed files with 24 additions and 9 deletions

View File

@ -7,6 +7,10 @@ namespace hr { namespace gp {
ld alpha; ld alpha;
int area; int area;
int length(loc p) {
return eudist(p.first, p.second);
}
loc operator+(loc e1, loc e2) { loc operator+(loc e1, loc e2) {
return make_pair(e1.first+e2.first, e1.second+e2.second); return make_pair(e1.first+e2.first, e1.second+e2.second);
} }
@ -28,6 +32,7 @@ namespace hr { namespace gp {
cellwalker cw; cellwalker cw;
signed char rdir; signed char rdir;
signed char mindir; signed char mindir;
loc start;
}; };
loc eudir(int d) { loc eudir(int d) {
@ -199,6 +204,7 @@ namespace hr { namespace gp {
WHD( Xprintf(" md:%02d s:%d", wc.mindir, wc.cw.spin); ) WHD( Xprintf(" md:%02d s:%d", wc.mindir, wc.cw.spin); )
WHD( Xprintf(" connection %s/%d %s=%s ~ %s/%d ", disp(at), dir, dcw(wc.cw+dir), dcw(wcw), disp(at+eudir(dir)), dir1); ) WHD( Xprintf(" connection %s/%d %s=%s ~ %s/%d ", disp(at), dir, dcw(wc.cw+dir), dcw(wcw), disp(at+eudir(dir)), dir1); )
if(!wc1.cw.c) { if(!wc1.cw.c) {
wc1.start = wc.start;
if(peek(wcw)) { if(peek(wcw)) {
WHD( Xprintf("(pulled) "); ) WHD( Xprintf("(pulled) "); )
set_localwalk(wc1, dir1, wcw + wstep); set_localwalk(wc1, dir1, wcw + wstep);
@ -240,6 +246,7 @@ namespace hr { namespace gp {
goldberg_mapping_t& set_heptspin(loc at, heptspin hs) { goldberg_mapping_t& set_heptspin(loc at, heptspin hs) {
auto& ac0 = get_mapping(at); auto& ac0 = get_mapping(at);
ac0.cw = cellwalker(hs.h->c7, hs.spin, hs.mirrored); ac0.cw = cellwalker(hs.h->c7, hs.spin, hs.mirrored);
ac0.start = at;
WHD( Xprintf("%s : %s\n", disp(at), dcw(ac0.cw)); ) WHD( Xprintf("%s : %s\n", disp(at), dcw(ac0.cw)); )
return ac0; return ac0;
} }
@ -451,8 +458,18 @@ namespace hr { namespace gp {
wc.rdir = (dx+1)%4; wc.rdir = (dx+1)%4;
wc1.rdir = -1; wc1.rdir = -1;
wc2.rdir = dx%4; wc2.rdir = dx%4;
int bdir = -1;
int bdist = 100;
for(int d=0; d<4; d++) {
auto &wcm = get_mapping(at2 + eudir(d));
if(wcm.cw.c && length(wcm.start - at2) < bdist)
bdist = length(wcm.start - at2), bdir = d;
}
if(bdir != -1) conn(at2 + eudir(bdir), bdir ^ 2);
conn(at, (dx+1)%4); conn(at, (dx+1)%4);
conn(at2, dx%4); conn(at2, dx%4);
at = param * loc(1,0) + at * loc(0, 1);
} }
break; break;
} }
@ -775,10 +792,6 @@ namespace hr { namespace gp {
li.last_dir = fix7(li.last_dir - sp); li.last_dir = fix7(li.last_dir - sp);
} }
int length(loc p) {
return eudist(p.first, p.second);
}
// from some point X, (0,0) is in distance dmain, param is in distance d0, and param*z is in distance d1 // from some point X, (0,0) is in distance dmain, param is in distance d0, and param*z is in distance d1
// what is the distance of at from X? // what is the distance of at from X?

View File

@ -3496,7 +3496,7 @@ void queuestr(const hyperpoint& h, int size, const string& chr, int col, int fra
void queuechr(const transmatrix& V, double size, char chr, int col, int frame = 0); void queuechr(const transmatrix& V, double size, char chr, int col, int frame = 0);
extern bool just_gmatrix; extern bool just_gmatrix;
void drawrec(const heptspin& hs, hstate s, const transmatrix& V); void drawrec(const heptspin& hs, hstate s, const transmatrix& V, int boundary = 0);
bool haveLeaderboard(int id); bool haveLeaderboard(int id);
int get_currentscore(int id); int get_currentscore(int id);

View File

@ -555,7 +555,7 @@ void drawrec(cell *c, const transmatrix& V) {
} }
} }
void drawrec(const heptspin& hs, hstate s, const transmatrix& V) { void drawrec(const heptspin& hs, hstate s, const transmatrix& V, int boundary) {
// shmup::calc_relative_matrix(cwt.c, hs.h); // shmup::calc_relative_matrix(cwt.c, hs.h);
@ -585,12 +585,14 @@ void drawrec(const heptspin& hs, hstate s, const transmatrix& V) {
} }
} }
if(c->pathdist < PINFD && in_qrange(V)) if(c->pathdist < PINFD && in_qrange(V)) boundary = 0;
for(int d=0; d<S7; d++) { else if(S3 == 4 && gp::on) boundary++; else boundary += 2;
if(boundary < 2) for(int d=0; d<S7; d++) {
hstate s2 = transition(s, d); hstate s2 = transition(s, d);
if(s2 == hsError) continue; if(s2 == hsError) continue;
heptspin hs2 = hs + d + wstep; heptspin hs2 = hs + d + wstep;
drawrec(hs2, s2, V * heptmove[d]); drawrec(hs2, s2, V * heptmove[d], s);
} }
} }