From 62c4ddef4557ceb65e50a76e8736eea90956416e Mon Sep 17 00:00:00 2001 From: Zeno Rogue Date: Thu, 7 Oct 2021 13:46:40 +0200 Subject: [PATCH] made bt wider by default to match Binary3 and Solv --- binary-tiling.cpp | 34 +++++++++++++++++----------------- 1 file changed, 17 insertions(+), 17 deletions(-) diff --git a/binary-tiling.cpp b/binary-tiling.cpp index db1e8821..797bcec4 100644 --- a/binary-tiling.cpp +++ b/binary-tiling.cpp @@ -484,18 +484,18 @@ EX namespace bt { transmatrix adj(heptagon *h, int dir) override { if(geometry == gBinaryTiling) switch(dir) { case bd_up: return xpush(-log(2)); - case bd_left: return parabolic(-1); - case bd_right: return parabolic(+1); + case bd_left: return parabolic(-2); + case bd_right: return parabolic(+2); case bd_down: if(h->type == 6) return xpush(log(2)); /* case bd_down_left: */ - return parabolic(-1) * xpush(log(2)); + return parabolic(-2) * xpush(log(2)); case bd_down_right: - return parabolic(+1) * xpush(log(2)); + return parabolic(+2) * xpush(log(2)); case bd_up_left: - return xpush(-log(2)) * parabolic(-1); + return xpush(-log(2)) * parabolic(-2); case bd_up_right: - return xpush(-log(2)) * parabolic(1); + return xpush(-log(2)) * parabolic(2); default: throw hr_exception("unknown direction"); } @@ -633,9 +633,9 @@ EX namespace bt { auto &x = h[0], &y = h[1], &z = h[2]; switch(geometry) { case gBinaryTiling: case gBinary4: - return bt::parabolic(y/2) * xpush(x*z2); + return bt::parabolic(y) * xpush(x*z2*2); case gTernary: - return bt::parabolic(y/2) * xpush(x*z3); + return bt::parabolic(y) * xpush(x*z3*2); #if CAP_SOLV case gSol: return xpush(bwh*x) * ypush(bwh*y) * zpush(z2*z); @@ -699,18 +699,18 @@ EX namespace bt { use_direct = (1 << (S7-1)) - 1; if(geometry == gBinary4) { use_direct = 3; - direct_tmatrix[0] = xpush(-log(2)) * parabolic(-0.5); - direct_tmatrix[1] = xpush(-log(2)) * parabolic(+0.5); - direct_tmatrix[2] = parabolic(1); - direct_tmatrix[4] = parabolic(-1); + direct_tmatrix[0] = xpush(-log(2)) * parabolic(-1); + direct_tmatrix[1] = xpush(-log(2)) * parabolic(+1); + direct_tmatrix[2] = parabolic(2); + direct_tmatrix[4] = parabolic(-2); use_direct = 1+2+4+16; } if(geometry == gTernary) { - direct_tmatrix[0] = xpush(-log(3)) * parabolic(-1); + direct_tmatrix[0] = xpush(-log(3)) * parabolic(-2); direct_tmatrix[1] = xpush(-log(3)); - direct_tmatrix[2] = xpush(-log(3)) * parabolic(+1); - direct_tmatrix[3] = parabolic(1); - direct_tmatrix[5] = parabolic(-1); + direct_tmatrix[2] = xpush(-log(3)) * parabolic(+2); + direct_tmatrix[3] = parabolic(2); + direct_tmatrix[5] = parabolic(-2); use_direct = 1+2+4+8+32; } if(geometry == gBinary3) { @@ -1026,7 +1026,7 @@ EX int celldistance3(heptagon *c1, heptagon *c2) { EX int celldistance3(cell *c1, cell *c2) { return celldistance3(c1->master, c2->master); } EX hyperpoint get_horopoint(ld y, ld x) { - return xpush(-y) * bt::parabolic(x) * C0; + return xpush(-y) * bt::parabolic(x*2) * C0; } EX hyperpoint get_horopoint(hyperpoint h) {