1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-01-26 00:47:00 +00:00

euclid:: fixed relative_matrix

This commit is contained in:
Zeno Rogue 2019-11-28 22:15:39 +01:00
parent 91875f2b74
commit 30329df05c

View File

@ -191,34 +191,30 @@ EX namespace euclid3 {
} }
} }
transmatrix warppush(coord dif) {
auto v = getcoord(dif);
for(int i: {0, 1})
if(T0[i][i])
v[i] = gmod(v[i] + T0[i][i] / 2, T0[i][i]) - T0[i][i] / 2;
return eupush3(v[0], v[1], v[2]);
}
transmatrix relative_matrix(heptagon *h2, heptagon *h1, const hyperpoint& hint) override { transmatrix relative_matrix(heptagon *h2, heptagon *h1, const hyperpoint& hint) override {
if(twisted) { if(twisted) {
if(h1 == h2) return Id; if(h1 == h2) return Id;
for(int s=0; s<S7; s++) if(h2 == h1->move(s)) return adj(h1, s); for(int s=0; s<S7; s++) if(h2 == h1->move(s)) return adj(h1, s);
coord c1 = ispacemap[h1]; coord c1 = ispacemap[h1];
coord c2 = ispacemap[h2]; coord c2 = ispacemap[h2];
transmatrix T = warppush(c2 - c1); transmatrix T = eumove(c2 - c1);
for(int d: {-1, 1}) {
transmatrix I = Id; transmatrix I = Id;
coord cs = c1; coord cs = c1;
for(int s=0; s<3; s++) { for(int s=0; s<4; s++) {
cs += d * T0[2][2] * main_axes[2]; for(int a=-1; a<=1; a++)
I = I * eupush3(0, 0, d * T0[2][2]); for(int b=-1; b<=1; b++) {
auto dummy = getcoord(0); if(b && WDIM == 2) continue;
bool dm = false; transmatrix T1 = I * eumove((c2 - cs) + a*ascoord(T0[0]) + b*ascoord(T0[1]));
cs = twist(cs, dummy, I, dm);
transmatrix T1 = I * warppush(c2 - cs);
if(hdist0(tC0(T1)) < hdist0(tC0(T))) if(hdist0(tC0(T1)) < hdist0(tC0(T)))
T = T1; T = T1;
} }
auto co = ascoord(T0[WDIM-1]);
cs += co;
I = I * eumove(co);
auto dummy = getcoord(0);
bool dm = false;
cs = twist(cs, dummy, I, dm);
} }
return T; return T;
} }