Refactor prob_diff_update_savings_search_model
Change-Id: Icfab58e880285d5af00985dc20db2174a67d1fe8
This commit is contained in:
Родитель
432136ef56
Коммит
580e815f3b
|
@ -143,8 +143,10 @@ int vp10_prob_diff_update_savings_search_model(const unsigned int *ct,
|
||||||
vpx_prob *bestp,
|
vpx_prob *bestp,
|
||||||
vpx_prob upd,
|
vpx_prob upd,
|
||||||
int stepsize) {
|
int stepsize) {
|
||||||
int i, old_b, new_b, update_b, savings, bestsavings, step;
|
int i, old_b, new_b, update_b, savings, bestsavings;
|
||||||
int newp;
|
int newp;
|
||||||
|
const int step_sign = *bestp > oldp[PIVOT_NODE] ? -1 : 1;
|
||||||
|
const int step = stepsize * step_sign;
|
||||||
vpx_prob bestnewp, newplist[ENTROPY_NODES], oldplist[ENTROPY_NODES];
|
vpx_prob bestnewp, newplist[ENTROPY_NODES], oldplist[ENTROPY_NODES];
|
||||||
vp10_model_to_full_probs(oldp, oldplist);
|
vp10_model_to_full_probs(oldp, oldplist);
|
||||||
memcpy(newplist, oldp, sizeof(vpx_prob) * UNCONSTRAINED_NODES);
|
memcpy(newplist, oldp, sizeof(vpx_prob) * UNCONSTRAINED_NODES);
|
||||||
|
@ -155,9 +157,10 @@ int vp10_prob_diff_update_savings_search_model(const unsigned int *ct,
|
||||||
bestsavings = 0;
|
bestsavings = 0;
|
||||||
bestnewp = oldp[PIVOT_NODE];
|
bestnewp = oldp[PIVOT_NODE];
|
||||||
|
|
||||||
if (*bestp > oldp[PIVOT_NODE]) {
|
assert(stepsize > 0);
|
||||||
step = -stepsize;
|
|
||||||
for (newp = *bestp; newp > oldp[PIVOT_NODE]; newp += step) {
|
for (newp = *bestp; (newp - oldp[PIVOT_NODE]) * step_sign < 0;
|
||||||
|
newp += step) {
|
||||||
if (newp < 1 || newp > 255)
|
if (newp < 1 || newp > 255)
|
||||||
continue;
|
continue;
|
||||||
newplist[PIVOT_NODE] = newp;
|
newplist[PIVOT_NODE] = newp;
|
||||||
|
@ -173,25 +176,6 @@ int vp10_prob_diff_update_savings_search_model(const unsigned int *ct,
|
||||||
bestnewp = newp;
|
bestnewp = newp;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
step = stepsize;
|
|
||||||
for (newp = *bestp; newp < oldp[PIVOT_NODE]; newp += step) {
|
|
||||||
if (newp < 1 || newp > 255)
|
|
||||||
continue;
|
|
||||||
newplist[PIVOT_NODE] = newp;
|
|
||||||
vp10_model_to_full_probs(newplist, newplist);
|
|
||||||
for (i = UNCONSTRAINED_NODES, new_b = 0; i < ENTROPY_NODES; ++i)
|
|
||||||
new_b += cost_branch256(ct + 2 * i, newplist[i]);
|
|
||||||
new_b += cost_branch256(ct + 2 * PIVOT_NODE, newplist[PIVOT_NODE]);
|
|
||||||
update_b = prob_diff_update_cost(newp, oldp[PIVOT_NODE]) +
|
|
||||||
vp10_cost_upd256;
|
|
||||||
savings = old_b - new_b - update_b;
|
|
||||||
if (savings > bestsavings) {
|
|
||||||
bestsavings = savings;
|
|
||||||
bestnewp = newp;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
*bestp = bestnewp;
|
*bestp = bestnewp;
|
||||||
return bestsavings;
|
return bestsavings;
|
||||||
|
|
|
@ -142,8 +142,10 @@ int vp9_prob_diff_update_savings_search_model(const unsigned int *ct,
|
||||||
vpx_prob *bestp,
|
vpx_prob *bestp,
|
||||||
vpx_prob upd,
|
vpx_prob upd,
|
||||||
int stepsize) {
|
int stepsize) {
|
||||||
int i, old_b, new_b, update_b, savings, bestsavings, step;
|
int i, old_b, new_b, update_b, savings, bestsavings;
|
||||||
int newp;
|
int newp;
|
||||||
|
const int step_sign = *bestp > oldp[PIVOT_NODE] ? -1 : 1;
|
||||||
|
const int step = stepsize * step_sign;
|
||||||
vpx_prob bestnewp, newplist[ENTROPY_NODES], oldplist[ENTROPY_NODES];
|
vpx_prob bestnewp, newplist[ENTROPY_NODES], oldplist[ENTROPY_NODES];
|
||||||
vp9_model_to_full_probs(oldp, oldplist);
|
vp9_model_to_full_probs(oldp, oldplist);
|
||||||
memcpy(newplist, oldp, sizeof(vpx_prob) * UNCONSTRAINED_NODES);
|
memcpy(newplist, oldp, sizeof(vpx_prob) * UNCONSTRAINED_NODES);
|
||||||
|
@ -154,9 +156,10 @@ int vp9_prob_diff_update_savings_search_model(const unsigned int *ct,
|
||||||
bestsavings = 0;
|
bestsavings = 0;
|
||||||
bestnewp = oldp[PIVOT_NODE];
|
bestnewp = oldp[PIVOT_NODE];
|
||||||
|
|
||||||
if (*bestp > oldp[PIVOT_NODE]) {
|
assert(stepsize > 0);
|
||||||
step = -stepsize;
|
|
||||||
for (newp = *bestp; newp > oldp[PIVOT_NODE]; newp += step) {
|
for (newp = *bestp; (newp - oldp[PIVOT_NODE]) * step_sign < 0;
|
||||||
|
newp += step) {
|
||||||
if (newp < 1 || newp > 255)
|
if (newp < 1 || newp > 255)
|
||||||
continue;
|
continue;
|
||||||
newplist[PIVOT_NODE] = newp;
|
newplist[PIVOT_NODE] = newp;
|
||||||
|
@ -172,25 +175,6 @@ int vp9_prob_diff_update_savings_search_model(const unsigned int *ct,
|
||||||
bestnewp = newp;
|
bestnewp = newp;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
step = stepsize;
|
|
||||||
for (newp = *bestp; newp < oldp[PIVOT_NODE]; newp += step) {
|
|
||||||
if (newp < 1 || newp > 255)
|
|
||||||
continue;
|
|
||||||
newplist[PIVOT_NODE] = newp;
|
|
||||||
vp9_model_to_full_probs(newplist, newplist);
|
|
||||||
for (i = UNCONSTRAINED_NODES, new_b = 0; i < ENTROPY_NODES; ++i)
|
|
||||||
new_b += cost_branch256(ct + 2 * i, newplist[i]);
|
|
||||||
new_b += cost_branch256(ct + 2 * PIVOT_NODE, newplist[PIVOT_NODE]);
|
|
||||||
update_b = prob_diff_update_cost(newp, oldp[PIVOT_NODE]) +
|
|
||||||
vp9_cost_upd256;
|
|
||||||
savings = old_b - new_b - update_b;
|
|
||||||
if (savings > bestsavings) {
|
|
||||||
bestsavings = savings;
|
|
||||||
bestnewp = newp;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
*bestp = bestnewp;
|
*bestp = bestnewp;
|
||||||
return bestsavings;
|
return bestsavings;
|
||||||
|
|
Загрузка…
Ссылка в новой задаче