mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-10-24 02:17:40 +00:00
replaced atan2 and spin(alpha) by rspintox -- works in 3D now!
This commit is contained in:
@@ -180,7 +180,7 @@ namespace flocking {
|
|||||||
|
|
||||||
// distance and azimuth to m2
|
// distance and azimuth to m2
|
||||||
ld di = hdist0(ac);
|
ld di = hdist0(ac);
|
||||||
ld alpha = -atan2(ac);
|
transmatrix alphaspin = rspintox(ac); // spin(-atan2(ac));
|
||||||
|
|
||||||
color_t col = 0;
|
color_t col = 0;
|
||||||
|
|
||||||
@@ -197,13 +197,13 @@ namespace flocking {
|
|||||||
// azimuthal equidistant projection of ac
|
// azimuthal equidistant projection of ac
|
||||||
// (thus the cohesion force pushes us towards the
|
// (thus the cohesion force pushes us towards the
|
||||||
// average of azimuthal equidistant projections)
|
// average of azimuthal equidistant projections)
|
||||||
coh += spin(alpha) * hpxyz(di, 0, 0);
|
coh += alphaspin * hpxyz(di, 0, 0);
|
||||||
coh_count++;
|
coh_count++;
|
||||||
col |= 0xFF40;
|
col |= 0xFF40;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(di < sep_range) {
|
if(di < sep_range && di > 0) {
|
||||||
sep -= spin(alpha) * hpxyz(1 / di, 0, 0);
|
sep -= alphaspin * hpxyz(1 / di, 0, 0);
|
||||||
sep_count++;
|
sep_count++;
|
||||||
col |= 0xFF000040;
|
col |= 0xFF000040;
|
||||||
}
|
}
|
||||||
@@ -221,7 +221,8 @@ namespace flocking {
|
|||||||
|
|
||||||
// hypot2 is the length of a vector in R^2
|
// hypot2 is the length of a vector in R^2
|
||||||
vels[i] = hypot_d(2, velvec);
|
vels[i] = hypot_d(2, velvec);
|
||||||
ld alpha = -atan2(velvec);
|
|
||||||
|
transmatrix alphaspin = rspintox(velvec); // spin(-atan2(velvec));
|
||||||
|
|
||||||
if(vels[i] > max_speed) {
|
if(vels[i] > max_speed) {
|
||||||
velvec = velvec * (max_speed / vels[i]);
|
velvec = velvec * (max_speed / vels[i]);
|
||||||
|
Reference in New Issue
Block a user