mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-11 18:00:34 +00:00
atz now better -- uses rotator
This commit is contained in:
parent
3051f59746
commit
f652992602
@ -523,6 +523,7 @@ hpcshape
|
|||||||
vector<array<array<array<transmatrix, 6>, GOLDBERG_LIMIT>, GOLDBERG_LIMIT>> Tf;
|
vector<array<array<array<transmatrix, 6>, GOLDBERG_LIMIT>, GOLDBERG_LIMIT>> Tf;
|
||||||
transmatrix corners;
|
transmatrix corners;
|
||||||
transmatrix corners_for_triangle;
|
transmatrix corners_for_triangle;
|
||||||
|
transmatrix rotator;
|
||||||
ld alpha;
|
ld alpha;
|
||||||
int area;
|
int area;
|
||||||
int pshid[3][8][GOLDBERG_LIMIT][GOLDBERG_LIMIT][8];
|
int pshid[3][8][GOLDBERG_LIMIT][GOLDBERG_LIMIT][8];
|
||||||
|
36
goldberg.cpp
36
goldberg.cpp
@ -576,29 +576,26 @@ EX namespace gp {
|
|||||||
|
|
||||||
EX bool gp_style = true; /** disable for the old implementation which did not support fake */
|
EX bool gp_style = true; /** disable for the old implementation which did not support fake */
|
||||||
|
|
||||||
hyperpoint atz(const transmatrix& T, const transmatrix& corners, loc at, int cornerid = 6, ld cf = 3) {
|
/** for h in corner cordinates, rotate until it is in the correct triangle, and return the number of rotations needed */
|
||||||
|
int rotate_to_correct(hyperpoint& h) {
|
||||||
int sp = 0;
|
int sp = 0;
|
||||||
again:
|
while(h[1] < -1e-6 || h[2] < -1e-6) {
|
||||||
auto corner = corners * (loctoh_ort(at) + (corner_coords[cornerid] / cf));
|
h = cgi.gpdata->rotator * h;
|
||||||
if(corner[1] < -1e-6 || corner[2] < -1e-6) {
|
|
||||||
at = at * eudir(1);
|
|
||||||
if(cornerid < SG6) cornerid = (1 + cornerid) % SG6;
|
|
||||||
sp++;
|
sp++;
|
||||||
goto again;
|
|
||||||
}
|
}
|
||||||
if(sp>SG3) sp -= SG6;
|
if(sp>SG3) sp -= SG6;
|
||||||
|
return sp;
|
||||||
|
}
|
||||||
|
|
||||||
|
hyperpoint atz(const transmatrix& T, const transmatrix& corners, loc at, int cornerid = 6, ld cf = 3) {
|
||||||
|
|
||||||
|
auto corner = corners * (loctoh_ort(at) + (corner_coords[cornerid] / cf));
|
||||||
|
int sp = rotate_to_correct(corner);
|
||||||
|
|
||||||
if(gp_style && corner[0] < -1e-6) {
|
if(gp_style && corner[0] < -1e-6) {
|
||||||
auto ac = corner; ac[1] = 1 - corner[1]; ac[2] = 1 - corner[2]; ac[0] = -ac[0];
|
auto ac = corner; ac[1] = 1 - corner[1]; ac[2] = 1 - corner[2]; ac[0] = -ac[0];
|
||||||
hyperpoint ctr = normalize(cornmul(T, hyperpoint(0, 0.5, 0.5, 0)));
|
hyperpoint ctr = normalize(cornmul(T, hyperpoint(0, 0.5, 0.5, 0)));
|
||||||
int sp2 = 0;
|
int sp2 = rotate_to_correct(ac);
|
||||||
while(ac[1] < -1e-6 || ac[2] < -1e-6) {
|
|
||||||
auto xac = inverse(corners) * ac;
|
|
||||||
xac = xac[0] * loctoh_ort(eudir(1)) + xac[1] * loctoh_ort(eudir(2)); xac[2] = 1; xac[3] = 0;
|
|
||||||
ac = corners * xac;
|
|
||||||
sp2++;
|
|
||||||
}
|
|
||||||
if(sp2>SG3) sp2 -= SG6;
|
|
||||||
return spin(TAU*sp/S7) *
|
return spin(TAU*sp/S7) *
|
||||||
rgpushxto0(ctr) * rgpushxto0(ctr) * spin(M_PI + TAU*sp2/S7) *
|
rgpushxto0(ctr) * rgpushxto0(ctr) * spin(M_PI + TAU*sp2/S7) *
|
||||||
normalize(cornmul(T, ac));
|
normalize(cornmul(T, ac));
|
||||||
@ -636,6 +633,15 @@ EX namespace gp {
|
|||||||
S3 == 4 ? (loctoh_ort(param * loc(1,-1)) + C02)/2 : (loctoh_ort(loc(0,0)) + loctoh_ort(param) + loctoh_ort(param * loc(0,1) * loc(0,1) * loc(0,1) * loc(0,1) * loc(0,1))) / 3,
|
S3 == 4 ? (loctoh_ort(param * loc(1,-1)) + C02)/2 : (loctoh_ort(loc(0,0)) + loctoh_ort(param) + loctoh_ort(param * loc(0,1) * loc(0,1) * loc(0,1) * loc(0,1) * loc(0,1))) / 3,
|
||||||
C03
|
C03
|
||||||
));
|
));
|
||||||
|
for(int i=0; i<MDIM; i++) {
|
||||||
|
auto ac = Hypc; ac[i] = 1;
|
||||||
|
auto xac = inverse(cgi.gpdata->corners) * ac;
|
||||||
|
xac = xac[0] * loctoh_ort(eudir(1)) + xac[1] * loctoh_ort(eudir(2)); xac[2] = 1; xac[3] = 0;
|
||||||
|
ac = cgi.gpdata->corners * xac;
|
||||||
|
set_column(cgi.gpdata->rotator, i, ac);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
cgi.gpdata->Tf.resize(S7);
|
cgi.gpdata->Tf.resize(S7);
|
||||||
|
|
||||||
/* should work directly without flipping but it does not... flipping for now */
|
/* should work directly without flipping but it does not... flipping for now */
|
||||||
|
Loading…
Reference in New Issue
Block a user