135 #include "allheaders.h" 138 static const l_int32 BinSizeArray[] = {2, 5, 10, 20, 50, 100, 200, 500, 1000,\
139 2000, 5000, 10000, 20000, 50000, 100000, 200000,\
140 500000, 1000000, 2000000, 5000000, 10000000,\
141 200000000, 50000000, 100000000};
142 static const l_int32 NBinSizes = 24;
145 #ifndef NO_CONSOLE_IO 146 #define DEBUG_HISTO 0 147 #define DEBUG_CROSSINGS 0 148 #define DEBUG_FREQUENCY 0 180 l_int32 i, j, n, hsize, len;
182 l_float32 *fa, *fas, *fad;
185 PROCNAME(
"numaErode");
188 return (
NUMA *)ERROR_PTR(
"nas not defined", procName, NULL);
190 return (
NUMA *)ERROR_PTR(
"size must be > 0", procName, NULL);
191 if ((size & 1) == 0 ) {
192 L_WARNING(
"sel size must be odd; increasing by 1\n", procName);
206 if ((fas = (l_float32 *)LEPT_CALLOC(len,
sizeof(l_float32))) == NULL)
207 return (
NUMA *)ERROR_PTR(
"fas not made", procName, NULL);
208 for (i = 0; i < hsize; i++)
210 for (i = hsize + n; i < len; i++)
213 for (i = 0; i < n; i++)
214 fas[hsize + i] = fa[i];
219 for (i = 0; i < n; i++) {
221 for (j = 0; j < size; j++)
222 minval = L_MIN(minval, fas[i + j]);
249 l_int32 i, j, n, hsize, len;
251 l_float32 *fa, *fas, *fad;
254 PROCNAME(
"numaDilate");
257 return (
NUMA *)ERROR_PTR(
"nas not defined", procName, NULL);
259 return (
NUMA *)ERROR_PTR(
"size must be > 0", procName, NULL);
260 if ((size & 1) == 0 ) {
261 L_WARNING(
"sel size must be odd; increasing by 1\n", procName);
275 if ((fas = (l_float32 *)LEPT_CALLOC(len,
sizeof(l_float32))) == NULL)
276 return (
NUMA *)ERROR_PTR(
"fas not made", procName, NULL);
277 for (i = 0; i < hsize; i++)
279 for (i = hsize + n; i < len; i++)
282 for (i = 0; i < n; i++)
283 fas[hsize + i] = fa[i];
288 for (i = 0; i < n; i++) {
290 for (j = 0; j < size; j++)
291 maxval = L_MAX(maxval, fas[i + j]);
320 PROCNAME(
"numaOpen");
323 return (
NUMA *)ERROR_PTR(
"nas not defined", procName, NULL);
325 return (
NUMA *)ERROR_PTR(
"size must be > 0", procName, NULL);
326 if ((size & 1) == 0 ) {
327 L_WARNING(
"sel size must be odd; increasing by 1\n", procName);
365 NUMA *nab, *nat1, *nat2, *nad;
367 PROCNAME(
"numaClose");
370 return (
NUMA *)ERROR_PTR(
"nas not defined", procName, NULL);
372 return (
NUMA *)ERROR_PTR(
"size must be > 0", procName, NULL);
373 if ((size & 1) == 0 ) {
374 L_WARNING(
"sel size must be odd; increasing by 1\n", procName);
417 PROCNAME(
"numaTransform");
420 return (
NUMA *)ERROR_PTR(
"nas not defined", procName, NULL);
423 return (
NUMA *)ERROR_PTR(
"nad not made", procName, NULL);
425 for (i = 0; i < n; i++) {
427 val = scale * (val + shift);
454 l_float32 sum, sumsq, val, mean, var;
456 PROCNAME(
"numaSimpleStats");
458 if (pmean) *pmean = 0.0;
459 if (pvar) *pvar = 0.0;
460 if (prvar) *prvar = 0.0;
461 if (!pmean && !pvar && !prvar)
462 return ERROR_INT(
"nothing requested", procName, 1);
464 return ERROR_INT(
"na not defined", procName, 1);
466 return ERROR_INT(
"na is empty", procName, 1);
467 first = L_MAX(0, first);
468 if (last < 0) last = n - 1;
470 return ERROR_INT(
"invalid first", procName, 1);
472 L_WARNING(
"last = %d is beyond max index = %d; adjusting\n",
473 procName, last, n - 1);
477 return ERROR_INT(
"first > last\n", procName, 1);
478 ni = last - first + 1;
480 for (i = first; i <= last; i++) {
490 var = sumsq / ni - mean * mean;
491 if (pvar) *pvar = var;
492 if (prvar) *prvar = sqrtf(var);
540 PROCNAME(
"numaWindowedStats");
543 return ERROR_INT(
"nas not defined", procName, 1);
545 L_WARNING(
"filter wider than input array!\n", procName);
547 if (!pnav && !pnarv) {
585 l_int32 i, n, n1, width;
587 l_float32 *fa1, *fad, *suma;
590 PROCNAME(
"numaWindowedMean");
593 return (
NUMA *)ERROR_PTR(
"nas not defined", procName, NULL);
597 L_WARNING(
"filter wider than input array!\n", procName);
606 if ((suma = (l_float32 *)LEPT_CALLOC(n1 + 1,
sizeof(l_float32))) == NULL) {
609 return (
NUMA *)ERROR_PTR(
"suma not made", procName, NULL);
613 for (i = 0; i < n1; i++) {
618 norm = 1. / (2 * wc + 1);
619 for (i = 0; i < n; i++)
620 fad[i] = norm * (suma[width + i] - suma[i]);
645 l_int32 i, n, n1, width;
647 l_float32 *fa1, *fad, *suma;
650 PROCNAME(
"numaWindowedMeanSquare");
653 return (
NUMA *)ERROR_PTR(
"nas not defined", procName, NULL);
657 L_WARNING(
"filter wider than input array!\n", procName);
666 if ((suma = (l_float32 *)LEPT_CALLOC(n1 + 1,
sizeof(l_float32))) == NULL) {
669 return (
NUMA *)ERROR_PTR(
"suma not made", procName, NULL);
673 for (i = 0; i < n1; i++) {
674 sum += fa1[i] * fa1[i];
678 norm = 1. / (2 * wc + 1);
679 for (i = 0; i < n; i++)
680 fad[i] = norm * (suma[width + i] - suma[i]);
717 l_float32 *fam, *fams, *fav, *farv;
720 PROCNAME(
"numaWindowedVariance");
722 if (pnav) *pnav = NULL;
723 if (pnarv) *pnarv = NULL;
725 return ERROR_INT(
"neither &nav nor &narv are defined", procName, 1);
727 return ERROR_INT(
"nam not defined", procName, 1);
729 return ERROR_INT(
"nams not defined", procName, 1);
733 return ERROR_INT(
"sizes of nam and nams differ", procName, 1);
748 for (i = 0; i < nm; i++) {
749 var = fams[i] - fam[i] * fam[i];
753 farv[i] = sqrtf(var);
783 NUMA *na1, *na2, *nad;
785 PROCNAME(
"numaWindowedMedian");
788 return (
NUMA *)ERROR_PTR(
"nas not defined", procName, NULL);
792 L_ERROR(
"filter too small; returning a copy\n", procName);
796 if (halfwin > (n - 1) / 2) {
797 halfwin = (n - 1) / 2;
798 L_INFO(
"reducing filter to halfwin = %d\n", procName, halfwin);
807 for (i = 0; i < n; i++) {
832 PROCNAME(
"numaConvertToInt");
835 return (
NUMA *)ERROR_PTR(
"nas not defined", procName, NULL);
839 return (
NUMA *)ERROR_PTR(
"nad not made", procName, NULL);
841 for (i = 0; i < n; i++) {
884 l_int32 i, n, ival, hval;
885 l_int32 iminval, imaxval, range, binsize, nbins, ibin;
886 l_float32 val, ratio;
889 PROCNAME(
"numaMakeHistogram");
892 return (
NUMA *)ERROR_PTR(
"na not defined", procName, NULL);
894 return (
NUMA *)ERROR_PTR(
"&binsize not defined", procName, NULL);
898 iminval = (l_int32)(val + 0.5);
900 imaxval = (l_int32)(val + 0.5);
901 if (pbinstart == NULL) {
904 return (
NUMA *)ERROR_PTR(
"all values < 0", procName, NULL);
908 range = imaxval - iminval + 1;
909 if (range > maxbins - 1) {
910 ratio = (l_float64)range / (l_float64)maxbins;
912 for (i = 0; i < NBinSizes; i++) {
913 if (ratio < BinSizeArray[i]) {
914 binsize = BinSizeArray[i];
919 return (
NUMA *)ERROR_PTR(
"numbers too large", procName, NULL);
924 nbins = 1 + range / binsize;
927 if (pbinstart && binsize > 1) {
929 iminval = binsize * (iminval / binsize);
931 iminval = binsize * ((iminval - binsize + 1) / binsize);
934 *pbinstart = iminval;
937 fprintf(stderr,
" imaxval = %d, range = %d, nbins = %d\n",
938 imaxval, range, nbins);
943 return (
NUMA *)ERROR_PTR(
"nai not made", procName, NULL);
950 return (
NUMA *)ERROR_PTR(
"nahist not made", procName, NULL);
954 for (i = 0; i < n; i++) {
956 ibin = (ival - iminval) / binsize;
957 if (ibin >= 0 && ibin < nbins) {
994 l_int32 i, n, imin, imax, irange, ibin, ival, allints;
995 l_float32 minval, maxval, range, binsize, fval;
998 PROCNAME(
"numaMakeHistogramAuto");
1001 return (
NUMA *)ERROR_PTR(
"na not defined", procName, NULL);
1002 maxbins = L_MAX(1, maxbins);
1013 if (allints && (maxval - minval < maxbins)) {
1014 imin = (l_int32)minval;
1015 imax = (l_int32)maxval;
1016 irange = imax - imin + 1;
1020 for (i = 0; i < n; i++) {
1031 range = maxval - minval;
1032 binsize = range / (l_float32)maxbins;
1042 for (i = 0; i < n; i++) {
1044 ibin = (l_int32)((fval - minval) / binsize);
1045 ibin = L_MIN(ibin, maxbins - 1);
1079 l_int32 i, n, nbins, ival, ibin;
1080 l_float32 val, maxval;
1083 PROCNAME(
"numaMakeHistogramClipped");
1086 return (
NUMA *)ERROR_PTR(
"na not defined", procName, NULL);
1088 return (
NUMA *)ERROR_PTR(
"binsize must be > 0.0", procName, NULL);
1089 if (binsize > maxsize)
1094 maxsize = L_MIN(maxsize, maxval);
1095 nbins = (l_int32)(maxsize / binsize) + 1;
1100 return (
NUMA *)ERROR_PTR(
"nad not made", procName, NULL);
1103 for (i = 0; i < n; i++) {
1105 ibin = (l_int32)(val / binsize);
1106 if (ibin >= 0 && ibin < nbins) {
1127 l_int32 i, j, ns, nd, index, count, val;
1128 l_float32 start, oldsize;
1131 PROCNAME(
"numaRebinHistogram");
1134 return (
NUMA *)ERROR_PTR(
"nas not defined", procName, NULL);
1136 return (
NUMA *)ERROR_PTR(
"newsize must be > 1", procName, NULL);
1138 return (
NUMA *)ERROR_PTR(
"no bins in nas", procName, NULL);
1140 nd = (ns + newsize - 1) / newsize;
1142 return (
NUMA *)ERROR_PTR(
"nad not made", procName, NULL);
1146 for (i = 0; i < nd; i++) {
1148 index = i * newsize;
1149 for (j = 0; j < newsize; j++) {
1176 l_float32 sum, factor, fval;
1179 PROCNAME(
"numaNormalizeHistogram");
1182 return (
NUMA *)ERROR_PTR(
"nas not defined", procName, NULL);
1184 return (
NUMA *)ERROR_PTR(
"tsum must be > 0.0", procName, NULL);
1186 return (
NUMA *)ERROR_PTR(
"no bins in nas", procName, NULL);
1189 factor = tsum / sum;
1192 return (
NUMA *)ERROR_PTR(
"nad not made", procName, NULL);
1195 for (i = 0; i < ns; i++) {
1259 l_float32 *pvariance,
1266 l_float32 minval, maxval, fval, mean, sum;
1269 PROCNAME(
"numaGetStatsUsingHistogram");
1271 if (pmin) *pmin = 0.0;
1272 if (pmax) *pmax = 0.0;
1273 if (pmean) *pmean = 0.0;
1274 if (pvariance) *pvariance = 0.0;
1275 if (pmedian) *pmedian = 0.0;
1276 if (prval) *prval = 0.0;
1277 if (phisto) *phisto = NULL;
1279 return ERROR_INT(
"na not defined", procName, 1);
1281 return ERROR_INT(
"numa is empty", procName, 1);
1285 if (pmin) *pmin = minval;
1286 if (pmax) *pmax = maxval;
1287 if (pmean || pvariance) {
1289 for (i = 0; i < n; i++) {
1293 mean = sum / (l_float32)n;
1294 if (pmean) *pmean = mean;
1298 for (i = 0; i < n; i++) {
1302 *pvariance = sum / (l_float32)n - mean * mean;
1305 if (!pmedian && !prval && !phisto)
1349 l_float32 *pxmedian,
1351 l_float32 *pxvariance)
1353 PROCNAME(
"numaGetHistogramStats");
1355 if (pxmean) *pxmean = 0.0;
1356 if (pxmedian) *pxmedian = 0.0;
1357 if (pxmode) *pxmode = 0.0;
1358 if (pxvariance) *pxvariance = 0.0;
1360 return ERROR_INT(
"nahisto not defined", procName, 1);
1363 pxmean, pxmedian, pxmode,
1400 l_float32 *pxmedian,
1402 l_float32 *pxvariance)
1405 l_float32 sum, sumval, halfsum, moment, var, x, y, ymax;
1407 PROCNAME(
"numaGetHistogramStatsOnInterval");
1409 if (pxmean) *pxmean = 0.0;
1410 if (pxmedian) *pxmedian = 0.0;
1411 if (pxmode) *pxmode = 0.0;
1412 if (pxvariance) *pxvariance = 0.0;
1414 return ERROR_INT(
"nahisto not defined", procName, 1);
1415 if (!pxmean && !pxmedian && !pxmode && !pxvariance)
1416 return ERROR_INT(
"nothing to compute", procName, 1);
1419 ifirst = L_MAX(0, ifirst);
1420 if (ilast < 0) ilast = n - 1;
1422 return ERROR_INT(
"invalid ifirst", procName, 1);
1424 L_WARNING(
"ilast = %d is beyond max index = %d; adjusting\n",
1425 procName, ilast, n - 1);
1429 return ERROR_INT(
"ifirst > ilast", procName, 1);
1430 for (sum = 0.0, moment = 0.0, var = 0.0, i = ifirst; i <= ilast ; i++) {
1431 x = startx + i * deltax;
1438 L_INFO(
"sum is 0\n", procName);
1443 *pxmean = moment / sum;
1445 *pxvariance = var / sum - moment * moment / (sum * sum);
1448 halfsum = sum / 2.0;
1449 for (sumval = 0.0, i = ifirst; i <= ilast; i++) {
1452 if (sumval >= halfsum) {
1453 *pxmedian = startx + i * deltax;
1462 for (i = ifirst; i <= ilast; i++) {
1469 *pxmode = startx + imax * deltax;
1496 l_float32 sum, fval;
1499 PROCNAME(
"numaMakeRankFromHistogram");
1501 if (pnax) *pnax = NULL;
1503 return ERROR_INT(
"&nay not defined", procName, 1);
1506 return ERROR_INT(
"nasy not defined", procName, 1);
1508 return ERROR_INT(
"no bins in nas", procName, 1);
1516 for (i = 0; i < n; i++) {
1525 startx, startx + n * deltax, npts,
1560 l_int32 i, ibinval, n;
1561 l_float32 startval, binsize, binval, maxval, fractval, total, sum, val;
1563 PROCNAME(
"numaHistogramGetRankFromVal");
1566 return ERROR_INT(
"prank not defined", procName, 1);
1569 return ERROR_INT(
"na not defined", procName, 1);
1572 if (rval < startval)
1574 maxval = startval + n * binsize;
1575 if (rval > maxval) {
1580 binval = (rval - startval) / binsize;
1581 ibinval = (l_int32)binval;
1586 fractval = binval - (l_float32)ibinval;
1589 for (i = 0; i < ibinval; i++) {
1594 sum += fractval * val;
1596 *prank = sum / total;
1632 l_float32 startval, binsize, rankcount, total, sum, fract, val;
1634 PROCNAME(
"numaHistogramGetValFromRank");
1637 return ERROR_INT(
"prval not defined", procName, 1);
1640 return ERROR_INT(
"na not defined", procName, 1);
1642 L_WARNING(
"rank < 0; setting to 0.0\n", procName);
1646 L_WARNING(
"rank > 1.0; setting to 1.0\n", procName);
1653 rankcount = rank * total;
1655 for (i = 0; i < n; i++) {
1657 if (sum + val >= rankcount)
1664 fract = (rankcount - sum) / val;
1668 *prval = startval + binsize * ((l_float32)i + fract);
1718 l_int32 i, j, npts, start, midfound, mcount, rightedge;
1719 l_float32 sum, midrank, endrank, val;
1721 PROCNAME(
"numaDiscretizeRankAndIntensity");
1723 if (pnarbin) *pnarbin = NULL;
1724 if (pnam) *pnam = NULL;
1725 if (pnar) *pnar = NULL;
1726 if (pnabb) *pnabb = NULL;
1727 if (!pnarbin && !pnam && !pnar && !pnabb)
1728 return ERROR_INT(
"no output requested", procName, 1);
1730 return ERROR_INT(
"na not defined", procName, 1);
1732 return ERROR_INT(
"nbins must be > 1", procName, 1);
1740 return ERROR_INT(
"nar not made", procName, 1);
1743 for (i = 0; i < npts; i++) {
1752 if (!nam || !narbin || !nabb) {
1757 return ERROR_INT(
"numa not made", procName, 1);
1767 for (i = 0; i < nbins; i++) {
1768 midrank = (l_float32)(i + 0.5) / (l_float32)(nbins);
1769 endrank = (l_float32)(i + 1.0) / (l_float32)(nbins);
1770 endrank = L_MAX(0.0, L_MIN(endrank - 0.001, 1.0));
1772 for (j = start; j < npts; j++) {
1775 if ((!midfound && val >= midrank) ||
1776 (mcount < nbins && j == npts - 1)) {
1781 if ((val >= endrank) || (j == npts - 1)) {
1794 if (mcount != nbins)
1795 L_WARNING(
"found data for %d bins; should be %d\n",
1796 procName, mcount, nbins);
1800 for (i = 0; i < nbins; i++) {
1802 for (j = start; j < npts; j++) {
1805 if (j > rightedge) {
1809 if (j == npts - 1) {
1861 l_int32 maxbins, discardval;
1862 l_float32 maxval, delx;
1864 PROCNAME(
"numaGetRankBinValues");
1866 if (pnarbin) *pnarbin = NULL;
1867 if (pnam) *pnam = NULL;
1868 if (!pnarbin && !pnam)
1869 return ERROR_INT(
"no output requested", procName, 1);
1871 return ERROR_INT(
"na not defined", procName, 1);
1873 return ERROR_INT(
"na is empty", procName, 1);
1875 return ERROR_INT(
"nbins must be > 1", procName, 1);
1879 maxbins = L_MIN(100002, (l_int32)maxval + 2);
1887 L_WARNING(
"scale change: delx = %6.2f\n", procName, delx);
1951 l_float32 scorefract,
1952 l_int32 *psplitindex,
1959 l_int32 i, n, bestsplit, minrange, maxrange, maxindex;
1960 l_float32 ave1, ave2, ave1prev, ave2prev;
1961 l_float32 num1, num2, num1prev, num2prev;
1962 l_float32 val, minval, sum, fract1;
1963 l_float32 norm, score, minscore, maxscore;
1964 NUMA *nascore, *naave1, *naave2, *nanum1, *nanum2;
1966 PROCNAME(
"numaSplitDistribution");
1968 if (psplitindex) *psplitindex = 0;
1969 if (pave1) *pave1 = 0.0;
1970 if (pave2) *pave2 = 0.0;
1971 if (pnum1) *pnum1 = 0.0;
1972 if (pnum2) *pnum2 = 0.0;
1973 if (pnascore) *pnascore = NULL;
1975 return ERROR_INT(
"na not defined", procName, 1);
1979 return ERROR_INT(
"n = 1 in histogram", procName, 1);
1982 return ERROR_INT(
"sum <= 0.0", procName, 1);
1983 norm = 4.0 / ((l_float32)(n - 1) * (n - 1));
1994 return ERROR_INT(
"nascore not made", procName, 1);
2000 for (i = 0; i < n; i++) {
2002 num1 = num1prev + val;
2006 ave1 = (num1prev * ave1prev + i * val) / num1;
2007 num2 = num2prev - val;
2011 ave2 = (num2prev * ave2prev - i * val) / num2;
2012 fract1 = num1 / sum;
2013 score = norm * (fract1 * (1 - fract1)) * (ave2 - ave1) * (ave2 - ave1);
2019 if (score > maxscore) {
2032 minscore = (1. - scorefract) * maxscore;
2033 for (i = maxindex - 1; i >= 0; i--) {
2039 for (i = maxindex + 1; i < n; i++) {
2046 bestsplit = minrange;
2047 for (i = minrange + 1; i <= maxrange; i++) {
2058 bestsplit = L_MIN(255, bestsplit + 1);
2060 if (psplitindex) *psplitindex = bestsplit;
2067 fprintf(stderr,
"minrange = %d, maxrange = %d\n", minrange, maxrange);
2068 fprintf(stderr,
"minval = %10.0f\n", minval);
2070 "Score for split distribution");
2071 *pnascore = nascore;
2118 NUMA *na1, *na2, *nad;
2120 PROCNAME(
"grayHistogramsToEMD");
2123 return ERROR_INT(
"&nad not defined", procName, 1);
2126 return ERROR_INT(
"na1 and na2 not both defined", procName, 1);
2129 return ERROR_INT(
"naa1 and naa2 numa counts differ", procName, 1);
2132 return ERROR_INT(
"naa1 and naa2 number counts differ", procName, 1);
2134 return ERROR_INT(
"na sizes must be 256", procName, 1);
2138 for (i = 0; i < n; i++) {
2183 l_float32 sum1, sum2, diff, total;
2184 l_float32 *array1, *array3;
2187 PROCNAME(
"numaEarthMoverDistance");
2190 return ERROR_INT(
"&dist not defined", procName, 1);
2193 return ERROR_INT(
"na1 and na2 not both defined", procName, 1);
2196 return ERROR_INT(
"na1 and na2 have different size", procName, 1);
2201 norm = (L_ABS(sum1 - sum2) < 0.00001 * L_ABS(sum1)) ? 1 : 0;
2211 for (i = 1; i < n; i++) {
2212 diff = array1[i - 1] - array3[i - 1];
2214 total += L_ABS(diff);
2216 *pdist = total / sum1;
2276 l_int32 i, j, n, nn;
2278 l_float32 mean, var, rvar;
2279 NUMA *na1, *na2, *na3, *na4;
2281 PROCNAME(
"grayInterHistogramStats");
2283 if (pnam) *pnam = NULL;
2284 if (pnams) *pnams = NULL;
2285 if (pnav) *pnav = NULL;
2286 if (pnarv) *pnarv = NULL;
2287 if (!pnam && !pnams && !pnav && !pnarv)
2288 return ERROR_INT(
"nothing requested", procName, 1);
2290 return ERROR_INT(
"naa not defined", procName, 1);
2292 for (i = 0; i < n; i++) {
2295 L_ERROR(
"%d numbers in numa[%d]\n", procName, nn, i);
2307 arrays = (l_float32 **)LEPT_CALLOC(n,
sizeof(l_float32 *));
2308 for (i = 0; i < n; i++) {
2319 for (j = 0; j < 256; j++) {
2321 for (i = 0; i < n; i++) {
2332 for (i = 0; i < n; i++)
2333 LEPT_FREE(arrays[i]);
2364 l_int32 i, k, n, maxloc, lloc, rloc;
2365 l_float32 fmaxval, sum, total, newtotal, val, lastval;
2366 l_float32 peakfract;
2369 PROCNAME(
"numaFindPeaks");
2372 return (
NUMA *)ERROR_PTR(
"nas not defined", procName, NULL);
2378 return (
NUMA *)ERROR_PTR(
"na not made", procName, NULL);
2379 if ((napeak =
numaCreate(4 * nmax)) == NULL) {
2381 return (
NUMA *)ERROR_PTR(
"napeak not made", procName, NULL);
2384 for (k = 0; k < nmax; k++) {
2386 if (newtotal == 0.0)
2392 for (i = maxloc - 1; i >= 0; --i) {
2398 if (val > fract1 * fmaxval) {
2403 if (lastval - val > fract2 * lastval) {
2413 for (i = maxloc + 1; i < n; ++i) {
2419 if (val > fract1 * fmaxval) {
2424 if (lastval - val > fract2 * lastval) {
2432 peakfract = sum / total;
2438 for (i = lloc; i <= rloc; i++)
2478 l_int32 i, n, found, loc, direction;
2479 l_float32 startval, val, maxval, minval;
2482 PROCNAME(
"numaFindExtrema");
2484 if (pnav) *pnav = NULL;
2486 return (
NUMA *)ERROR_PTR(
"nas not defined", procName, NULL);
2488 return (
NUMA *)ERROR_PTR(
"delta < 0", procName, NULL);
2503 for (i = 1; i < n; i++) {
2505 if (L_ABS(val - startval) >= delta) {
2515 if (val > startval) {
2526 for (i = i + 1; i < n; i++) {
2528 if (direction == 1 && val > maxval ) {
2531 }
else if (direction == -1 && val < minval ) {
2534 }
else if (direction == 1 && (maxval - val >= delta)) {
2540 }
else if (direction == -1 && (val - minval >= delta)) {
2578 l_float32 minreversal,
2582 l_int32 i, n, nr, ival, binvals;
2584 l_float32 fval, delx, len;
2587 PROCNAME(
"numaCountReversals");
2590 if (prd) *prd = 0.0;
2592 return ERROR_INT(
"neither &nr nor &rd are defined", procName, 1);
2594 return ERROR_INT(
"nas not defined", procName, 1);
2596 L_INFO(
"nas is empty\n", procName);
2599 if (minreversal < 0.0)
2600 return ERROR_INT(
"minreversal < 0", procName, 1);
2604 for (i = 0; i < n; i++) {
2606 if (fval != 0.0 && fval != 1.0) {
2614 if (minreversal > 1.0) {
2615 L_WARNING(
"binary values but minreversal > 1\n", procName);
2619 for (i = 1; i < n; i++) {
2620 if (ia[i] != ival) {
2636 *prd = (l_float32)nr / len;
2674 l_float32 estthresh,
2675 l_float32 *pbestthresh)
2677 l_int32 i, inrun, istart, iend, maxstart, maxend, runlen, maxrunlen;
2678 l_int32 val, maxval, nmax, count;
2679 l_float32 thresh, fmaxval, fmodeval;
2682 PROCNAME(
"numaSelectCrossingThreshold");
2685 return ERROR_INT(
"&bestthresh not defined", procName, 1);
2688 return ERROR_INT(
"nay not defined", procName, 1);
2692 for (i = 0; i < 41; i++) {
2693 thresh = estthresh - 80.0 + 4.0 * i;
2702 maxval = (l_int32)fmaxval;
2704 for (i = 0; i < 41; i++) {
2711 if (count > nmax && fmodeval > 0.5 * fmaxval)
2712 maxval = (l_int32)fmodeval;
2717 maxrunlen = 0, maxstart = 0, maxend = 0;
2718 for (i = 0; i < 41; i++) {
2720 if (val == maxval) {
2727 if (inrun && (val != maxval)) {
2729 runlen = iend - istart + 1;
2731 if (runlen > maxrunlen) {
2739 runlen = i - istart;
2740 if (runlen > maxrunlen) {
2747 *pbestthresh = estthresh - 80.0 + 2.0 * (l_float32)(maxstart + maxend);
2750 fprintf(stderr,
"\nCrossings attain a maximum at %d thresholds, between:\n" 2751 " thresh[%d] = %5.1f and thresh[%d] = %5.1f\n",
2752 nmax, maxstart, estthresh - 80.0 + 4.0 * maxstart,
2753 maxend, estthresh - 80.0 + 4.0 * maxend);
2754 fprintf(stderr,
"The best choice: %5.1f\n", *pbestthresh);
2755 fprintf(stderr,
"Number of crossings at the 41 thresholds:");
2784 l_float32 startx, delx;
2785 l_float32 xval1, xval2, yval1, yval2, delta1, delta2, crossval, fract;
2788 PROCNAME(
"numaCrossingsByThreshold");
2791 return (
NUMA *)ERROR_PTR(
"nay not defined", procName, NULL);
2795 return (
NUMA *)ERROR_PTR(
"nax and nay sizes differ", procName, NULL);
2804 for (i = 1; i < n; i++) {
2809 xval2 = startx + i * delx;
2810 delta1 = yval1 - thresh;
2811 delta2 = yval2 - thresh;
2812 if (delta1 == 0.0) {
2814 }
else if (delta2 == 0.0) {
2816 }
else if (delta1 * delta2 < 0.0) {
2817 fract = L_ABS(delta1) / L_ABS(yval1 - yval2);
2818 crossval = xval1 + fract * (xval2 - xval1);
2848 l_int32 i, j, n, np, previndex, curindex;
2849 l_float32 startx, delx;
2850 l_float32 xval1, xval2, yval1, yval2, delta1, delta2;
2851 l_float32 prevval, curval, thresh, crossval, fract;
2854 PROCNAME(
"numaCrossingsByPeaks");
2857 return (
NUMA *)ERROR_PTR(
"nay not defined", procName, NULL);
2861 return (
NUMA *)ERROR_PTR(
"nax and nay sizes differ", procName, NULL);
2869 L_INFO(
"Number of crossings: %d\n", procName, np);
2876 for (i = 0; i < np; i++) {
2879 thresh = (prevval + curval) / 2.0;
2883 xval1 = startx + previndex * delx;
2885 for (j = previndex + 1; j <= curindex; j++) {
2889 xval2 = startx + j * delx;
2891 delta1 = yval1 - thresh;
2892 delta2 = yval2 - thresh;
2893 if (delta1 == 0.0) {
2896 }
else if (delta2 == 0.0) {
2899 }
else if (delta1 * delta2 < 0.0) {
2900 fract = L_ABS(delta1) / L_ABS(yval1 - yval2);
2901 crossval = xval1 + fract * (xval2 - xval1);
2908 previndex = curindex;
2956 l_float32 relweight,
2961 l_float32 *pbestwidth,
2962 l_float32 *pbestshift,
2963 l_float32 *pbestscore)
2966 l_float32 delwidth, delshift, width, shift, score;
2967 l_float32 bestwidth, bestshift, bestscore;
2969 PROCNAME(
"numaEvalBestHaarParameters");
2971 if (pbestscore) *pbestscore = 0.0;
2972 if (pbestwidth) *pbestwidth = 0.0;
2973 if (pbestshift) *pbestshift = 0.0;
2974 if (!pbestwidth || !pbestshift)
2975 return ERROR_INT(
"&bestwidth and &bestshift not defined", procName, 1);
2977 return ERROR_INT(
"nas not defined", procName, 1);
2979 bestscore = bestwidth = bestshift = 0.0;
2980 delwidth = (maxwidth - minwidth) / (nwidth - 1.0);
2981 for (i = 0; i < nwidth; i++) {
2982 width = minwidth + delwidth * i;
2983 delshift = width / (l_float32)(nshift);
2984 for (j = 0; j < nshift; j++) {
2985 shift = j * delshift;
2987 if (score > bestscore) {
2992 fprintf(stderr,
"width = %7.3f, shift = %7.3f, score = %7.3f\n",
2993 width, shift, score);
2999 *pbestwidth = bestwidth;
3000 *pbestshift = bestshift;
3002 *pbestscore = bestscore;
3043 l_float32 relweight,
3046 l_int32 i, n, nsamp, index;
3047 l_float32 score, weight, val;
3049 PROCNAME(
"numaEvalHaarSum");
3052 return ERROR_INT(
"&score not defined", procName, 1);
3055 return ERROR_INT(
"nas not defined", procName, 1);
3057 return ERROR_INT(
"nas size too small", procName, 1);
3060 nsamp = (l_int32)((n - shift) / width);
3061 for (i = 0; i < nsamp; i++) {
3062 index = (l_int32)(shift + i * width);
3063 weight = (i % 2) ? 1.0 : -1.0 * relweight;
3065 score += weight * val;
3068 *pscore = 2.0 * width * score / (l_float32)n;
3102 l_int32 i, nsets, val;
3106 PROCNAME(
"genConstrainedNumaInRange");
3108 first = L_MAX(0, first);
3110 return (
NUMA *)ERROR_PTR(
"last < first!", procName, NULL);
3112 return (
NUMA *)ERROR_PTR(
"nmax < 1!", procName, NULL);
3114 nsets = L_MIN(nmax, last - first + 1);
3118 return (
NUMA *)ERROR_PTR(
"nsets == 0", procName, NULL);
3125 delta = (l_float32)(last - first) / (nsets - 1);
3127 delta = (l_float32)(last - first - 1) / (nsets - 1);
3131 for (i = 0; i < nsets; i++) {
3132 val = (l_int32)(first + i * delta + 0.5);
l_ok numaGetSum(NUMA *na, l_float32 *psum)
numaGetSum()
l_ok numaGetFValue(NUMA *na, l_int32 index, l_float32 *pval)
numaGetFValue()
NUMA * numaFindExtrema(NUMA *nas, l_float32 delta, NUMA **pnav)
numaFindExtrema()
NUMA * numaDilate(NUMA *nas, l_int32 size)
numaDilate()
NUMA * numaCrossingsByPeaks(NUMA *nax, NUMA *nay, l_float32 delta)
numaCrossingsByPeaks()
l_ok numaHasOnlyIntegers(NUMA *na, l_int32 maxsamples, l_int32 *pallints)
numaHasOnlyIntegers()
NUMA * numaConvertToInt(NUMA *nas)
numaConvertToInt()
NUMA * numaMakeHistogram(NUMA *na, l_int32 maxbins, l_int32 *pbinsize, l_int32 *pbinstart)
numaMakeHistogram()
l_ok numaSimpleStats(NUMA *na, l_int32 first, l_int32 last, l_float32 *pmean, l_float32 *pvar, l_float32 *prvar)
numaSimpleStats()
l_ok numaAddNumber(NUMA *na, l_float32 val)
numaAddNumber()
NUMA * numaFindPeaks(NUMA *nas, l_int32 nmax, l_float32 fract1, l_float32 fract2)
numaFindPeaks()
l_int32 numaaGetNumberCount(NUMAA *naa)
numaaGetNumberCount()
NUMA * numaRebinHistogram(NUMA *nas, l_int32 newsize)
numaRebinHistogram()
l_ok numaEarthMoverDistance(NUMA *na1, NUMA *na2, l_float32 *pdist)
numaEarthMoverDistance()
l_ok numaCopyParameters(NUMA *nad, NUMA *nas)
numaCopyParameters()
l_ok numaGetMedian(NUMA *na, l_float32 *pval)
numaGetMedian()
NUMA * numaMakeConstant(l_float32 val, l_int32 size)
numaMakeConstant()
NUMA * numaErode(NUMA *nas, l_int32 size)
numaErode()
NUMA * numaMakeHistogramClipped(NUMA *na, l_float32 binsize, l_float32 maxsize)
numaMakeHistogramClipped()
l_ok numaSplitDistribution(NUMA *na, l_float32 scorefract, l_int32 *psplitindex, l_float32 *pave1, l_float32 *pave2, l_float32 *pnum1, l_float32 *pnum2, NUMA **pnascore)
numaSplitDistribution()
l_ok numaWriteStream(FILE *fp, NUMA *na)
numaWriteStream()
NUMA * numaCreate(l_int32 n)
numaCreate()
l_ok numaSetCount(NUMA *na, l_int32 newcount)
numaSetCount()
NUMA * numaWindowedMedian(NUMA *nas, l_int32 halfwin)
numaWindowedMedian()
NUMA * numaClipToInterval(NUMA *nas, l_int32 first, l_int32 last)
numaClipToInterval()
l_ok numaSetValue(NUMA *na, l_int32 index, l_float32 val)
numaSetValue()
NUMA * numaRemoveBorder(NUMA *nas, l_int32 left, l_int32 right)
numaRemoveBorder()
l_ok numaSelectCrossingThreshold(NUMA *nax, NUMA *nay, l_float32 estthresh, l_float32 *pbestthresh)
numaSelectCrossingThreshold()
l_ok numaGetHistogramStats(NUMA *nahisto, l_float32 startx, l_float32 deltax, l_float32 *pxmean, l_float32 *pxmedian, l_float32 *pxmode, l_float32 *pxvariance)
numaGetHistogramStats()
l_int32 * numaGetIArray(NUMA *na)
numaGetIArray()
l_ok numaCountReversals(NUMA *nas, l_float32 minreversal, l_int32 *pnr, l_float32 *prd)
numaCountReversals()
NUMA * genConstrainedNumaInRange(l_int32 first, l_int32 last, l_int32 nmax, l_int32 use_pairs)
genConstrainedNumaInRange()
NUMA * numaaGetNuma(NUMAA *naa, l_int32 index, l_int32 accessflag)
numaaGetNuma()
NUMA * numaClose(NUMA *nas, l_int32 size)
numaClose()
l_ok numaGetIValue(NUMA *na, l_int32 index, l_int32 *pival)
numaGetIValue()
l_int32 numaGetCount(NUMA *na)
numaGetCount()
l_ok numaDiscretizeRankAndIntensity(NUMA *na, l_int32 nbins, NUMA **pnarbin, NUMA **pnam, NUMA **pnar, NUMA **pnabb)
numaDiscretizeRankAndIntensity()
l_ok numaGetMode(NUMA *na, l_float32 *pval, l_int32 *pcount)
numaGetMode()
l_ok numaInterpolateEqxInterval(l_float32 startx, l_float32 deltax, NUMA *nasy, l_int32 type, l_float32 x0, l_float32 x1, l_int32 npts, NUMA **pnax, NUMA **pnay)
numaInterpolateEqxInterval()
l_ok numaSetParameters(NUMA *na, l_float32 startx, l_float32 delx)
numaSetParameters()
NUMA * numaAddSpecifiedBorder(NUMA *nas, l_int32 left, l_int32 right, l_int32 type)
numaAddSpecifiedBorder()
NUMA * numaWindowedMeanSquare(NUMA *nas, l_int32 wc)
numaWindowedMeanSquare()
NUMA * numaOpen(NUMA *nas, l_int32 size)
numaOpen()
l_ok numaWindowedStats(NUMA *nas, l_int32 wc, NUMA **pnam, NUMA **pnams, NUMA **pnav, NUMA **pnarv)
numaWindowedStats()
l_ok numaGetParameters(NUMA *na, l_float32 *pstartx, l_float32 *pdelx)
numaGetParameters()
NUMA * numaMakeHistogramAuto(NUMA *na, l_int32 maxbins)
numaMakeHistogramAuto()
l_ok numaHistogramGetValFromRank(NUMA *na, l_float32 rank, l_float32 *prval)
numaHistogramGetValFromRank()
NUMA * numaCopy(NUMA *na)
numaCopy()
l_ok numaEvalBestHaarParameters(NUMA *nas, l_float32 relweight, l_int32 nwidth, l_int32 nshift, l_float32 minwidth, l_float32 maxwidth, l_float32 *pbestwidth, l_float32 *pbestshift, l_float32 *pbestscore)
numaEvalBestHaarParameters()
l_ok numaGetHistogramStatsOnInterval(NUMA *nahisto, l_float32 startx, l_float32 deltax, l_int32 ifirst, l_int32 ilast, l_float32 *pxmean, l_float32 *pxmedian, l_float32 *pxmode, l_float32 *pxvariance)
numaGetHistogramStatsOnInterval()
NUMA * numaAddBorder(NUMA *nas, l_int32 left, l_int32 right, l_float32 val)
numaAddBorder()
l_ok numaMakeRankFromHistogram(l_float32 startx, l_float32 deltax, NUMA *nasy, l_int32 npts, NUMA **pnax, NUMA **pnay)
numaMakeRankFromHistogram()
void numaDestroy(NUMA **pna)
numaDestroy()
NUMA * numaCrossingsByThreshold(NUMA *nax, NUMA *nay, l_float32 thresh)
numaCrossingsByThreshold()
l_ok numaGetMin(NUMA *na, l_float32 *pminval, l_int32 *piminloc)
numaGetMin()
NUMA * numaTransform(NUMA *nas, l_float32 shift, l_float32 scale)
numaTransform()
l_ok numaGetRankBinValues(NUMA *na, l_int32 nbins, NUMA **pnarbin, NUMA **pnam)
numaGetRankBinValues()
l_ok numaHistogramGetRankFromVal(NUMA *na, l_float32 rval, l_float32 *prank)
numaHistogramGetRankFromVal()
NUMA * numaWindowedMean(NUMA *nas, l_int32 wc)
numaWindowedMean()
l_float32 * numaGetFArray(NUMA *na, l_int32 copyflag)
numaGetFArray()
l_int32 numaaGetCount(NUMAA *naa)
numaaGetCount()
l_int32 numaaGetNumaCount(NUMAA *naa, l_int32 index)
numaaGetNumaCount()
l_ok grayHistogramsToEMD(NUMAA *naa1, NUMAA *naa2, NUMA **pnad)
grayHistogramsToEMD()
l_ok numaWindowedVariance(NUMA *nam, NUMA *nams, NUMA **pnav, NUMA **pnarv)
numaWindowedVariance()
NUMA * numaNormalizeHistogram(NUMA *nas, l_float32 tsum)
numaNormalizeHistogram()
l_ok numaGetMax(NUMA *na, l_float32 *pmaxval, l_int32 *pimaxloc)
numaGetMax()
l_ok grayInterHistogramStats(NUMAA *naa, l_int32 wc, NUMA **pnam, NUMA **pnams, NUMA **pnav, NUMA **pnarv)
grayInterHistogramStats()
l_ok numaEvalHaarSum(NUMA *nas, l_float32 width, l_float32 shift, l_float32 relweight, l_float32 *pscore)
numaEvalHaarSum()
l_ok gplotSimple1(NUMA *na, l_int32 outformat, const char *outroot, const char *title)
gplotSimple1()
l_ok numaGetStatsUsingHistogram(NUMA *na, l_int32 maxbins, l_float32 *pmin, l_float32 *pmax, l_float32 *pmean, l_float32 *pvariance, l_float32 *pmedian, l_float32 rank, l_float32 *prval, NUMA **phisto)
numaGetStatsUsingHistogram()