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:
parent
711efc3be4
commit
d986ed7617
21
goldberg.cpp
21
goldberg.cpp
@ -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?
|
||||||
|
|
||||||
|
2
hyper.h
2
hyper.h
@ -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);
|
||||||
|
10
hypgraph.cpp
10
hypgraph.cpp
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user