Skip to content

Commit

Permalink
i.smap: fix possible pole error with log in extract function
Browse files Browse the repository at this point in the history
Using logarithm function call with zero argument will lead to
a pole error, which occurs if the mathematical function has
an exact infinite result.

Refactor the conditional to only execute the code when number
of subclasses are more than 1, which would preemptively stop
us from getting into situation where log would have a zero
argument. In cases where number of subclasses are <= 0, set
the default value to 0. This is necessary as `ll` points to
malloc'd memory and can contain renadom value.

Signed-off-by: Mohan Yelugoti <[email protected]>
  • Loading branch information
ymdatta committed Oct 17, 2024
1 parent cbc3ff4 commit 4d30fc3
Showing 1 changed file with 3 additions and 1 deletion.
4 changes: 3 additions & 1 deletion imagery/i.smap/model.c
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,7 @@ void extract(DCELL ***img, /* multispectral image, img[band][i][j] */
ll[i][j][m] = subll[0];
}
/* compute mixture likelihood */
else {
else if (C->nsubclasses > 1) {
/* find the most likely subclass */
for (k = 0; k < C->nsubclasses; k++) {
if (k == 0)
Expand All @@ -156,6 +156,8 @@ void extract(DCELL ***img, /* multispectral image, img[band][i][j] */
subsum += exp(subll[k] - maxlike) * C->SubSig[k].pi;

ll[i][j][m] = log(subsum) + maxlike;
} else {
ll[i][j][m] = 0.0;
}
}
}
Expand Down

0 comments on commit 4d30fc3

Please sign in to comment.