Refactor prob_diff_update_savings_search_model

Change-Id: Icfab58e880285d5af00985dc20db2174a67d1fe8
This commit is contained in:
hui su 2016-01-29 12:49:19 -08:00
Родитель 432136ef56
Коммит 580e815f3b
2 изменённых файлов: 40 добавлений и 72 удалений

Просмотреть файл

@ -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;