mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-19 21:53:04 +00:00
stretch < -1 (seems not to be working correctly)
This commit is contained in:
parent
c35705cc5c
commit
29c7faa264
@ -843,7 +843,7 @@ EX void showEuclideanMenu() {
|
|||||||
XLAT(
|
XLAT(
|
||||||
"Stretch the metric along the fibers. This can currently be done in rotation spaces and in 8-cell, 24-cell and 120-cell. "
|
"Stretch the metric along the fibers. This can currently be done in rotation spaces and in 8-cell, 24-cell and 120-cell. "
|
||||||
"Value of 0 means not stretched, -1 means S2xE or H2xE (works only in the limit). "
|
"Value of 0 means not stretched, -1 means S2xE or H2xE (works only in the limit). "
|
||||||
"Only the raycaster is implemented for stretched geometry, so you will see only walls."
|
"Only the raycaster is implemented for stretched geometry, so you will see only walls. (Must be > -1)"
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
dialog::reaction = ray::reset_raycaster;
|
dialog::reaction = ray::reset_raycaster;
|
||||||
|
@ -2082,12 +2082,20 @@ EX namespace stretch {
|
|||||||
return translate(at) * vel;
|
return translate(at) * vel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
EX ld squared() {
|
||||||
|
return abs(1 + factor);
|
||||||
|
}
|
||||||
|
|
||||||
|
EX ld not_squared() {
|
||||||
|
return sqrt(squared());
|
||||||
|
}
|
||||||
|
|
||||||
hyperpoint isometric_to_actual(const hyperpoint at, const hyperpoint velocity) {
|
hyperpoint isometric_to_actual(const hyperpoint at, const hyperpoint velocity) {
|
||||||
return mulz(at, velocity, 1/sqrt(1+factor));
|
return mulz(at, velocity, 1/not_squared());
|
||||||
}
|
}
|
||||||
|
|
||||||
hyperpoint actual_to_isometric(const hyperpoint at, const hyperpoint velocity) {
|
hyperpoint actual_to_isometric(const hyperpoint at, const hyperpoint velocity) {
|
||||||
return mulz(at, velocity, sqrt(1+factor));
|
return mulz(at, velocity, not_squared());
|
||||||
}
|
}
|
||||||
|
|
||||||
hyperpoint christoffel(const hyperpoint at, const hyperpoint velocity, const hyperpoint transported) {
|
hyperpoint christoffel(const hyperpoint at, const hyperpoint velocity, const hyperpoint transported) {
|
||||||
@ -2227,7 +2235,7 @@ EX namespace nisot {
|
|||||||
auto fix = [&] (hyperpoint& h, ld& m) {
|
auto fix = [&] (hyperpoint& h, ld& m) {
|
||||||
h = stretch::itranslate(at) * h;
|
h = stretch::itranslate(at) * h;
|
||||||
h[3] = 0;
|
h[3] = 0;
|
||||||
ld m1 = h[0] * h[0] + h[1] * h[1] + h[2] * h[2] * (1 + stretch::factor);
|
ld m1 = h[0] * h[0] + h[1] * h[1] + h[2] * h[2] * stretch::squared();
|
||||||
h /= sqrt(m1/m);
|
h /= sqrt(m1/m);
|
||||||
h = stretch::translate(at) * h;
|
h = stretch::translate(at) * h;
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user