commented functionality - not working yet
parent
c9a8ad0ac6
commit
7bf0d8ebf1
|
|
@ -163,13 +163,14 @@ void LevenbergMarquardtOptimizer::iterate() {
|
||||||
// linearizedCostChange = oldCost - newLinearizedCost = f'f/2 - 1/2 [ f'f + 2f'J * step + step' * J' * J * step]
|
// linearizedCostChange = oldCost - newLinearizedCost = f'f/2 - 1/2 [ f'f + 2f'J * step + step' * J' * J * step]
|
||||||
// = -f'J * step - step' * J' * J * step / 2 = -(f' + modelResidual') * (modelResidual)
|
// = -f'J * step - step' * J' * J * step / 2 = -(f' + modelResidual') * (modelResidual)
|
||||||
// (with modelResidual = J * step)
|
// (with modelResidual = J * step)
|
||||||
Errors modelResidualList = (*linear) * delta; // modelResidual = A * delta
|
/* Errors modelResidualList = (*linear) * delta; // modelResidual = A * delta
|
||||||
Vector modelResidual = concatVectors(modelResidualList); // TODO: is this an ordered list?
|
Vector modelResidual = concatVectors(modelResidualList); // TODO: is this an ordered list?
|
||||||
Vector residuals = - linear->jacobian().second; // TODO: optimize this computation, TODO: is there a minus sign?
|
Vector residuals = - linear->jacobian().second; // TODO: optimize this computation, TODO: is there a minus sign?
|
||||||
double linearizedCostChange = dot(- modelResidual, (residuals + modelResidual / 2.0) );
|
double linearizedCostChange = dot(- modelResidual, (residuals + modelResidual / 2.0) );
|
||||||
|
|
||||||
// Measure of mismatch between original (usually nonlinear) system and its linearized version
|
// Measure of mismatch between original (usually nonlinear) system and its linearized version
|
||||||
modelMismatch = costChange / linearizedCostChange;
|
modelMismatch = costChange / linearizedCostChange;
|
||||||
|
*/
|
||||||
|
|
||||||
if (error <= state_.error) {
|
if (error <= state_.error) {
|
||||||
state_.values.swap(newValues);
|
state_.values.swap(newValues);
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue