mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-11 18:00:34 +00:00
rv::som:: even better animations
This commit is contained in:
parent
7624dadb71
commit
065666a5a1
@ -365,6 +365,9 @@ void distribute_neurons() {
|
|||||||
setindex(false);
|
setindex(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int last_analyze_step;
|
||||||
|
int analyze_each;
|
||||||
|
|
||||||
void analyze() {
|
void analyze() {
|
||||||
|
|
||||||
initialize_neurons();
|
initialize_neurons();
|
||||||
@ -389,6 +392,7 @@ void analyze() {
|
|||||||
if(!noshow) distribute_neurons();
|
if(!noshow) distribute_neurons();
|
||||||
|
|
||||||
coloring();
|
coloring();
|
||||||
|
last_analyze_step = t;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool show_rings = true;
|
bool show_rings = true;
|
||||||
@ -646,19 +650,6 @@ void step() {
|
|||||||
|
|
||||||
double sigma = maxdist * tt;
|
double sigma = maxdist * tt;
|
||||||
|
|
||||||
if(qpct) {
|
|
||||||
int pct = (int) ((qpct * (t+.0)) / tmax);
|
|
||||||
if(pct != lpct) {
|
|
||||||
lpct = pct;
|
|
||||||
analyze();
|
|
||||||
}
|
|
||||||
|
|
||||||
// if(gaussian)
|
|
||||||
// println(hlog, format("t = %6d/%6d %3d%% sigma=%10.7lf maxudist=%10.7lf\n", t, tmax, pct, sigma, maxudist));
|
|
||||||
// else
|
|
||||||
// println(hlog, format("t = %6d/%6d %3d%% dispid=%5d maxudist=%10.7lf\n", t, tmax, pct, dispid, maxudist));
|
|
||||||
// }
|
|
||||||
} //
|
|
||||||
int id = hrand(samples);
|
int id = hrand(samples);
|
||||||
neuron& n = winner(id);
|
neuron& n = winner(id);
|
||||||
whowon.resize(samples);
|
whowon.resize(samples);
|
||||||
@ -714,8 +705,7 @@ void step() {
|
|||||||
n2.debug = 0;
|
n2.debug = 0;
|
||||||
} */
|
} */
|
||||||
|
|
||||||
t--;
|
t--; if(t == 0) analyze();
|
||||||
if(t == 0) analyze();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int initdiv = 1;
|
int initdiv = 1;
|
||||||
@ -1400,7 +1390,7 @@ void steps() {
|
|||||||
if(t1 > t) {
|
if(t1 > t) {
|
||||||
initialize_rv();
|
initialize_rv();
|
||||||
set_neuron_initial();
|
set_neuron_initial();
|
||||||
t = tmax;
|
last_analyze_step = t = tmax;
|
||||||
}
|
}
|
||||||
while(t > t1) kohonen::step();
|
while(t > t1) kohonen::step();
|
||||||
setindex(false);
|
setindex(false);
|
||||||
@ -1624,7 +1614,7 @@ int readArgs() {
|
|||||||
else if(argis("-somrun")) {
|
else if(argis("-somrun")) {
|
||||||
initialize_rv();
|
initialize_rv();
|
||||||
set_neuron_initial();
|
set_neuron_initial();
|
||||||
t = tmax;
|
t = last_analyze_step = tmax;
|
||||||
}
|
}
|
||||||
|
|
||||||
// #3: load the neuron data (usually without #2)
|
// #3: load the neuron data (usually without #2)
|
||||||
@ -1799,6 +1789,7 @@ auto hooks4 = addHook(hooks_clearmemory, 100, clear)
|
|||||||
param_b(show_rings, "som_show_rings");
|
param_b(show_rings, "som_show_rings");
|
||||||
param_b(animate_once, "som_animate_once");
|
param_b(animate_once, "som_animate_once");
|
||||||
param_b(animate_loop, "som_animate_loop");
|
param_b(animate_loop, "som_animate_loop");
|
||||||
|
param_i(analyze_each, "som_analyze_each");
|
||||||
param_f(dispersion_precision, "som_dispersion")
|
param_f(dispersion_precision, "som_dispersion")
|
||||||
-> set_reaction([] { state &=~ KS_DISPERSION; });
|
-> set_reaction([] { state &=~ KS_DISPERSION; });
|
||||||
});
|
});
|
||||||
@ -1810,6 +1801,10 @@ bool mark(cell *c) {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void analyzer() {
|
||||||
|
if(t < last_analyze_step - analyze_each) analyze();
|
||||||
|
}
|
||||||
|
|
||||||
void initialize_rv() {
|
void initialize_rv() {
|
||||||
if(state & KS_ROGUEVIZ) return;
|
if(state & KS_ROGUEVIZ) return;
|
||||||
init(RV_GRAPH | RV_HAVE_WEIGHT);
|
init(RV_GRAPH | RV_HAVE_WEIGHT);
|
||||||
@ -1821,6 +1816,7 @@ void initialize_rv() {
|
|||||||
rv_hook(rogueviz::hooks_rvmenu, 100, showMenu);
|
rv_hook(rogueviz::hooks_rvmenu, 100, showMenu);
|
||||||
rv_hook(hooks_readcolor, 100, kohonen_color);
|
rv_hook(hooks_readcolor, 100, kohonen_color);
|
||||||
rv_hook(hooks_drawcell, 100, coloring_3d);
|
rv_hook(hooks_drawcell, 100, coloring_3d);
|
||||||
|
rv_hook(anims::hooks_anim, 100, analyzer);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1371,13 +1371,13 @@ auto khook = arg::add3("-kst-keys", [] { rv_hook(hooks_handleKey, 150, kst_key);
|
|||||||
}
|
}
|
||||||
vid.linewidth /= 3;
|
vid.linewidth /= 3;
|
||||||
})
|
})
|
||||||
+ addHook(anims::hooks_record_anim, 100, [] (int i, int noframes) {
|
+ arg::add3("-kst-animate", [] { rv_hook(anims::hooks_record_anim, 100, [] (int i, int noframes) {
|
||||||
bool steps = false;
|
bool steps = false;
|
||||||
ld nf = noframes;
|
ld nf = noframes;
|
||||||
while(t * nf > (nf - i) * tmax)
|
while(t * nf > (nf - i) * tmax)
|
||||||
step(), steps = true;
|
step(), steps = true;
|
||||||
if(steps) analyze();
|
if(steps) analyze();
|
||||||
});
|
}); });
|
||||||
|
|
||||||
}}
|
}}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user