138#include <config_auto.h>
142#include "allheaders.h"
145static const l_int32 BinSizeArray[] = {2, 5, 10, 20, 50, 100, 200, 500, 1000,\
146 2000, 5000, 10000, 20000, 50000, 100000, 200000,\
147 500000, 1000000, 2000000, 5000000, 10000000,\
148 200000000, 50000000, 100000000};
149static const l_int32 NBinSizes = 24;
154#define DEBUG_CROSSINGS 0
155#define DEBUG_FREQUENCY 0
186l_int32 i, j, n, hsize, len;
188l_float32 *fa, *fas, *fad;
192 return (
NUMA *)ERROR_PTR(
"nas not defined", __func__, NULL);
194 return (
NUMA *)ERROR_PTR(
"size must be > 0", __func__, NULL);
195 if ((size & 1) == 0 ) {
196 L_WARNING(
"sel size must be odd; increasing by 1\n", __func__);
201 return numaCopy(nas);
207 n = numaGetCount(nas);
210 if ((fas = (l_float32 *)LEPT_CALLOC(len,
sizeof(l_float32))) == NULL)
211 return (
NUMA *)ERROR_PTR(
"fas not made", __func__, NULL);
212 for (i = 0; i < hsize; i++)
214 for (i = hsize + n; i < len; i++)
217 for (i = 0; i < n; i++)
218 fas[hsize + i] = fa[i];
220 nad = numaMakeConstant(0, n);
221 numaCopyParameters(nad, nas);
223 for (i = 0; i < n; i++) {
225 for (j = 0; j < size; j++)
226 minval = L_MIN(minval, fas[i + j]);
253l_int32 i, j, n, hsize, len;
255l_float32 *fa, *fas, *fad;
259 return (
NUMA *)ERROR_PTR(
"nas not defined", __func__, NULL);
261 return (
NUMA *)ERROR_PTR(
"size must be > 0", __func__, NULL);
262 if ((size & 1) == 0 ) {
263 L_WARNING(
"sel size must be odd; increasing by 1\n", __func__);
268 return numaCopy(nas);
274 n = numaGetCount(nas);
277 if ((fas = (l_float32 *)LEPT_CALLOC(len,
sizeof(l_float32))) == NULL)
278 return (
NUMA *)ERROR_PTR(
"fas not made", __func__, NULL);
279 for (i = 0; i < hsize; i++)
281 for (i = hsize + n; i < len; i++)
284 for (i = 0; i < n; i++)
285 fas[hsize + i] = fa[i];
287 nad = numaMakeConstant(0, n);
288 numaCopyParameters(nad, nas);
290 for (i = 0; i < n; i++) {
292 for (j = 0; j < size; j++)
293 maxval = L_MAX(maxval, fas[i + j]);
323 return (
NUMA *)ERROR_PTR(
"nas not defined", __func__, NULL);
325 return (
NUMA *)ERROR_PTR(
"size must be > 0", __func__, NULL);
326 if ((size & 1) == 0 ) {
327 L_WARNING(
"sel size must be odd; increasing by 1\n", __func__);
332 return numaCopy(nas);
365NUMA *nab, *nat1, *nat2, *nad;
368 return (
NUMA *)ERROR_PTR(
"nas not defined", __func__, NULL);
370 return (
NUMA *)ERROR_PTR(
"size must be > 0", __func__, NULL);
371 if ((size & 1) == 0 ) {
372 L_WARNING(
"sel size must be odd; increasing by 1\n", __func__);
377 return numaCopy(nas);
379 nab = numaAddBorder(nas, size, size, 0);
382 nad = numaRemoveBorder(nat2, size, size);
416 return (
NUMA *)ERROR_PTR(
"nas not defined", __func__, NULL);
417 n = numaGetCount(nas);
418 if ((nad = numaCreate(n)) == NULL)
419 return (
NUMA *)ERROR_PTR(
"nad not made", __func__, NULL);
420 numaCopyParameters(nad, nas);
421 for (i = 0; i < n; i++) {
422 numaGetFValue(nas, i, &val);
423 val = scale * (val + shift);
424 numaAddNumber(nad, val);
450l_float32 sum, sumsq, val, mean, var;
452 if (pmean) *pmean = 0.0;
453 if (pvar) *pvar = 0.0;
454 if (prvar) *prvar = 0.0;
455 if (!pmean && !pvar && !prvar)
456 return ERROR_INT(
"nothing requested", __func__, 1);
458 return ERROR_INT(
"na not defined", __func__, 1);
459 if ((n = numaGetCount(na)) == 0)
460 return ERROR_INT(
"na is empty", __func__, 1);
461 first = L_MAX(0, first);
462 if (last < 0) last = n - 1;
464 return ERROR_INT(
"invalid first", __func__, 1);
466 L_WARNING(
"last = %d is beyond max index = %d; adjusting\n",
467 __func__, last, n - 1);
471 return ERROR_INT(
"first > last\n", __func__, 1);
472 ni = last - first + 1;
474 for (i = first; i <= last; i++) {
475 numaGetFValue(na, i, &val);
484 var = sumsq / ni - mean * mean;
485 if (pvar) *pvar = var;
486 if (prvar) *prvar = sqrtf(var);
535 return ERROR_INT(
"nas not defined", __func__, 1);
536 if (2 * wc + 1 > numaGetCount(nas))
537 L_WARNING(
"filter wider than input array!\n", __func__);
539 if (!pnav && !pnarv) {
577l_int32 i, n, n1, width;
579l_float32 *fa1, *fad, *suma;
583 return (
NUMA *)ERROR_PTR(
"nas not defined", __func__, NULL);
584 n = numaGetCount(nas);
587 L_WARNING(
"filter wider than input array!\n", __func__);
592 nad = numaMakeConstant(0, n);
596 if ((suma = (l_float32 *)LEPT_CALLOC(n1 + 1,
sizeof(l_float32))) == NULL) {
599 return (
NUMA *)ERROR_PTR(
"suma not made", __func__, NULL);
603 for (i = 0; i < n1; i++) {
608 norm = 1. / (2 * wc + 1);
609 for (i = 0; i < n; i++)
610 fad[i] = norm * (suma[width + i] - suma[i]);
635l_int32 i, n, n1, width;
637l_float32 *fa1, *fad, *suma;
641 return (
NUMA *)ERROR_PTR(
"nas not defined", __func__, NULL);
642 n = numaGetCount(nas);
645 L_WARNING(
"filter wider than input array!\n", __func__);
650 nad = numaMakeConstant(0, n);
654 if ((suma = (l_float32 *)LEPT_CALLOC(n1 + 1,
sizeof(l_float32))) == NULL) {
657 return (
NUMA *)ERROR_PTR(
"suma not made", __func__, NULL);
661 for (i = 0; i < n1; i++) {
662 sum += fa1[i] * fa1[i];
666 norm = 1. / (2 * wc + 1);
667 for (i = 0; i < n; i++)
668 fad[i] = norm * (suma[width + i] - suma[i]);
705l_float32 *fam, *fams, *fav, *farv;
708 if (pnav) *pnav = NULL;
709 if (pnarv) *pnarv = NULL;
711 return ERROR_INT(
"neither &nav nor &narv are defined", __func__, 1);
713 return ERROR_INT(
"nam not defined", __func__, 1);
715 return ERROR_INT(
"nams not defined", __func__, 1);
716 nm = numaGetCount(nam);
717 nms = numaGetCount(nams);
719 return ERROR_INT(
"sizes of nam and nams differ", __func__, 1);
722 nav = numaMakeConstant(0, nm);
727 narv = numaMakeConstant(0, nm);
729 farv = numaGetFArray(narv,
L_NOCOPY);
732 fams = numaGetFArray(nams,
L_NOCOPY);
734 for (i = 0; i < nm; i++) {
735 var = fams[i] - fam[i] * fam[i];
739 farv[i] = sqrtf(var);
769NUMA *na1, *na2, *nad;
772 return (
NUMA *)ERROR_PTR(
"nas not defined", __func__, NULL);
773 if ((n = numaGetCount(nas)) < 3)
774 return numaCopy(nas);
776 L_ERROR(
"filter too small; returning a copy\n", __func__);
777 return numaCopy(nas);
780 if (halfwin > (n - 1) / 2) {
781 halfwin = (n - 1) / 2;
782 L_INFO(
"reducing filter to halfwin = %d\n", __func__, halfwin);
791 for (i = 0; i < n; i++) {
792 na2 = numaClipToInterval(na1, i, i + 2 * halfwin);
793 numaGetMedian(na2, &medval);
794 numaAddNumber(nad, medval);
817 return (
NUMA *)ERROR_PTR(
"nas not defined", __func__, NULL);
819 n = numaGetCount(nas);
820 if ((nad = numaCreate(n)) == NULL)
821 return (
NUMA *)ERROR_PTR(
"nad not made", __func__, NULL);
822 numaCopyParameters(nad, nas);
823 for (i = 0; i < n; i++) {
824 numaGetIValue(nas, i, &ival);
825 numaAddNumber(nad, ival);
866l_int32 i, n, ival, hval;
867l_int32 iminval, imaxval, range, binsize, nbins, ibin;
871 if (pbinsize) *pbinsize = 0;
872 if (pbinstart) *pbinstart = 0;
874 return (
NUMA *)ERROR_PTR(
"na not defined", __func__, NULL);
876 return (
NUMA *)ERROR_PTR(
"maxbins < 1", __func__, NULL);
879 numaGetMin(na, &val, NULL);
880 iminval = (l_int32)(val + 0.5);
881 numaGetMax(na, &val, NULL);
882 imaxval = (l_int32)(val + 0.5);
883 if (pbinstart == NULL) {
886 return (
NUMA *)ERROR_PTR(
"all values < 0", __func__, NULL);
890 range = imaxval - iminval + 1;
891 if (range > maxbins - 1) {
892 ratio = (l_float64)range / (l_float64)maxbins;
894 for (i = 0; i < NBinSizes; i++) {
895 if (ratio < BinSizeArray[i]) {
896 binsize = BinSizeArray[i];
901 return (
NUMA *)ERROR_PTR(
"numbers too large", __func__, NULL);
905 if (pbinsize) *pbinsize = binsize;
906 nbins = 1 + range / binsize;
909 if (pbinstart && binsize > 1) {
911 iminval = binsize * (iminval / binsize);
913 iminval = binsize * ((iminval - binsize + 1) / binsize);
915 if (pbinstart) *pbinstart = iminval;
918 lept_stderr(
" imaxval = %d, range = %d, nbins = %d\n",
919 imaxval, range, nbins);
924 return (
NUMA *)ERROR_PTR(
"nai not made", __func__, NULL);
925 n = numaGetCount(nai);
929 if ((nahist = numaCreate(nbins)) == NULL) {
931 return (
NUMA *)ERROR_PTR(
"nahist not made", __func__, NULL);
933 numaSetCount(nahist, nbins);
934 numaSetParameters(nahist, iminval, binsize);
935 for (i = 0; i < n; i++) {
936 numaGetIValue(nai, i, &ival);
937 ibin = (ival - iminval) / binsize;
938 if (ibin >= 0 && ibin < nbins) {
939 numaGetIValue(nahist, ibin, &hval);
940 numaSetValue(nahist, ibin, hval + 1.0);
975l_int32 i, n, imin, imax, irange, ibin, ival, allints;
976l_float32 minval, maxval, range, binsize, fval;
980 return (
NUMA *)ERROR_PTR(
"na not defined", __func__, NULL);
981 maxbins = L_MAX(1, maxbins);
984 numaGetMin(na, &minval, NULL);
985 numaGetMax(na, &maxval, NULL);
988 n = numaGetCount(na);
989 numaHasOnlyIntegers(na, &allints);
992 if (allints && (maxval - minval < maxbins)) {
993 imin = (l_int32)minval;
994 imax = (l_int32)maxval;
995 irange = imax - imin + 1;
996 nah = numaCreate(irange);
997 numaSetCount(nah, irange);
998 numaSetParameters(nah, minval, 1.0);
999 for (i = 0; i < n; i++) {
1000 numaGetIValue(na, i, &ival);
1002 numaGetIValue(nah, ibin, &ival);
1003 numaSetValue(nah, ibin, ival + 1.0);
1010 range = maxval - minval;
1011 binsize = range / (l_float32)maxbins;
1013 nah = numaCreate(1);
1014 numaSetParameters(nah, minval, binsize);
1015 numaAddNumber(nah, n);
1018 nah = numaCreate(maxbins);
1019 numaSetCount(nah, maxbins);
1020 numaSetParameters(nah, minval, binsize);
1021 for (i = 0; i < n; i++) {
1022 numaGetFValue(na, i, &fval);
1023 ibin = (l_int32)((fval - minval) / binsize);
1024 ibin = L_MIN(ibin, maxbins - 1);
1025 numaGetIValue(nah, ibin, &ival);
1026 numaSetValue(nah, ibin, ival + 1.0);
1058l_int32 i, n, nbins, ival, ibin;
1059l_float32 val, maxval;
1063 return (
NUMA *)ERROR_PTR(
"na not defined", __func__, NULL);
1065 return (
NUMA *)ERROR_PTR(
"binsize must be > 0.0", __func__, NULL);
1066 if (binsize > maxsize)
1069 numaGetMax(na, &maxval, NULL);
1070 n = numaGetCount(na);
1071 maxsize = L_MIN(maxsize, maxval);
1072 nbins = (l_int32)(maxsize / binsize) + 1;
1076 if ((nad = numaCreate(nbins)) == NULL)
1077 return (
NUMA *)ERROR_PTR(
"nad not made", __func__, NULL);
1078 numaSetParameters(nad, 0.0, binsize);
1079 numaSetCount(nad, nbins);
1080 for (i = 0; i < n; i++) {
1081 numaGetFValue(na, i, &val);
1082 ibin = (l_int32)(val / binsize);
1083 if (ibin >= 0 && ibin < nbins) {
1084 numaGetIValue(nad, ibin, &ival);
1085 numaSetValue(nad, ibin, ival + 1.0);
1104l_int32 i, j, ns, nd, index, count, val;
1105l_float32 start, oldsize;
1109 return (
NUMA *)ERROR_PTR(
"nas not defined", __func__, NULL);
1111 return (
NUMA *)ERROR_PTR(
"newsize must be > 1", __func__, NULL);
1112 if ((ns = numaGetCount(nas)) == 0)
1113 return (
NUMA *)ERROR_PTR(
"no bins in nas", __func__, NULL);
1115 nd = (ns + newsize - 1) / newsize;
1116 if ((nad = numaCreate(nd)) == NULL)
1117 return (
NUMA *)ERROR_PTR(
"nad not made", __func__, NULL);
1118 numaGetParameters(nad, &start, &oldsize);
1119 numaSetParameters(nad, start, oldsize * newsize);
1121 for (i = 0; i < nd; i++) {
1123 index = i * newsize;
1124 for (j = 0; j < newsize; j++) {
1126 numaGetIValue(nas, index, &val);
1131 numaAddNumber(nad, count);
1151l_float32 sum, factor, fval;
1155 return (
NUMA *)ERROR_PTR(
"nas not defined", __func__, NULL);
1157 return (
NUMA *)ERROR_PTR(
"tsum must be > 0.0", __func__, NULL);
1158 if ((ns = numaGetCount(nas)) == 0)
1159 return (
NUMA *)ERROR_PTR(
"no bins in nas", __func__, NULL);
1161 numaGetSum(nas, &sum);
1162 factor = tsum / sum;
1164 if ((nad = numaCreate(ns)) == NULL)
1165 return (
NUMA *)ERROR_PTR(
"nad not made", __func__, NULL);
1166 numaCopyParameters(nad, nas);
1168 for (i = 0; i < ns; i++) {
1169 numaGetFValue(nas, i, &fval);
1171 numaAddNumber(nad, fval);
1232 l_float32 *pvariance,
1239l_float32 minval, maxval, fval, mean, sum;
1242 if (pmin) *pmin = 0.0;
1243 if (pmax) *pmax = 0.0;
1244 if (pmean) *pmean = 0.0;
1245 if (pvariance) *pvariance = 0.0;
1246 if (pmedian) *pmedian = 0.0;
1247 if (prval) *prval = 0.0;
1248 if (phisto) *phisto = NULL;
1250 return ERROR_INT(
"na not defined", __func__, 1);
1251 if ((n = numaGetCount(na)) == 0)
1252 return ERROR_INT(
"numa is empty", __func__, 1);
1254 numaGetMin(na, &minval, NULL);
1255 numaGetMax(na, &maxval, NULL);
1256 if (pmin) *pmin = minval;
1257 if (pmax) *pmax = maxval;
1258 if (pmean || pvariance) {
1260 for (i = 0; i < n; i++) {
1261 numaGetFValue(na, i, &fval);
1264 mean = sum / (l_float32)n;
1265 if (pmean) *pmean = mean;
1269 for (i = 0; i < n; i++) {
1270 numaGetFValue(na, i, &fval);
1273 *pvariance = sum / (l_float32)n - mean * mean;
1276 if (!pmedian && !prval && !phisto)
1320 l_float32 *pxmedian,
1322 l_float32 *pxvariance)
1324 if (pxmean) *pxmean = 0.0;
1325 if (pxmedian) *pxmedian = 0.0;
1326 if (pxmode) *pxmode = 0.0;
1327 if (pxvariance) *pxvariance = 0.0;
1329 return ERROR_INT(
"nahisto not defined", __func__, 1);
1332 pxmean, pxmedian, pxmode,
1369 l_float32 *pxmedian,
1371 l_float32 *pxvariance)
1374l_float32 sum, sumval, halfsum, moment, var, x, y, ymax;
1376 if (pxmean) *pxmean = 0.0;
1377 if (pxmedian) *pxmedian = 0.0;
1378 if (pxmode) *pxmode = 0.0;
1379 if (pxvariance) *pxvariance = 0.0;
1381 return ERROR_INT(
"nahisto not defined", __func__, 1);
1382 if (!pxmean && !pxmedian && !pxmode && !pxvariance)
1383 return ERROR_INT(
"nothing to compute", __func__, 1);
1385 n = numaGetCount(nahisto);
1386 ifirst = L_MAX(0, ifirst);
1387 if (ilast < 0) ilast = n - 1;
1389 return ERROR_INT(
"invalid ifirst", __func__, 1);
1391 L_WARNING(
"ilast = %d is beyond max index = %d; adjusting\n",
1392 __func__, ilast, n - 1);
1396 return ERROR_INT(
"ifirst > ilast", __func__, 1);
1397 for (sum = 0.0, moment = 0.0, var = 0.0, i = ifirst; i <= ilast ; i++) {
1398 x = startx + i * deltax;
1399 numaGetFValue(nahisto, i, &y);
1405 L_INFO(
"sum is 0\n", __func__);
1410 *pxmean = moment / sum;
1412 *pxvariance = var / sum - moment * moment / (sum * sum);
1415 halfsum = sum / 2.0;
1416 for (sumval = 0.0, i = ifirst; i <= ilast; i++) {
1417 numaGetFValue(nahisto, i, &y);
1419 if (sumval >= halfsum) {
1420 *pxmedian = startx + i * deltax;
1429 for (i = ifirst; i <= ilast; i++) {
1430 numaGetFValue(nahisto, i, &y);
1436 *pxmode = startx + imax * deltax;
1466 if (pnax) *pnax = NULL;
1468 return ERROR_INT(
"&nay not defined", __func__, 1);
1471 return ERROR_INT(
"nasy not defined", __func__, 1);
1472 if ((n = numaGetCount(nasy)) == 0)
1473 return ERROR_INT(
"no bins in nas", __func__, 1);
1478 nar = numaCreate(n + 1);
1480 numaAddNumber(nar, sum);
1481 for (i = 0; i < n; i++) {
1482 numaGetFValue(nan, i, &fval);
1484 numaAddNumber(nar, sum);
1490 startx, startx + n * deltax, npts,
1525l_int32 i, ibinval, n;
1526l_float32 startval, binsize, binval, maxval, fractval, total, sum, val;
1529 return ERROR_INT(
"prank not defined", __func__, 1);
1532 return ERROR_INT(
"na not defined", __func__, 1);
1533 numaGetParameters(na, &startval, &binsize);
1534 n = numaGetCount(na);
1535 if (rval < startval)
1537 maxval = startval + n * binsize;
1538 if (rval > maxval) {
1543 binval = (rval - startval) / binsize;
1544 ibinval = (l_int32)binval;
1549 fractval = binval - (l_float32)ibinval;
1552 for (i = 0; i < ibinval; i++) {
1553 numaGetFValue(na, i, &val);
1556 numaGetFValue(na, ibinval, &val);
1557 sum += fractval * val;
1558 numaGetSum(na, &total);
1559 *prank = sum / total;
1595l_float32 startval, binsize, rankcount, total, sum, fract, val;
1598 return ERROR_INT(
"prval not defined", __func__, 1);
1601 return ERROR_INT(
"na not defined", __func__, 1);
1603 L_WARNING(
"rank < 0; setting to 0.0\n", __func__);
1607 L_WARNING(
"rank > 1.0; setting to 1.0\n", __func__);
1611 n = numaGetCount(na);
1612 numaGetParameters(na, &startval, &binsize);
1613 numaGetSum(na, &total);
1614 rankcount = rank * total;
1616 for (i = 0; i < n; i++) {
1617 numaGetFValue(na, i, &val);
1618 if (sum + val >= rankcount)
1625 fract = (rankcount - sum) / val;
1629 *prval = startval + binsize * ((l_float32)i + fract);
1666l_int32 i, ntot, bincount, binindex, binsize;
1667l_float32 sum, val, ave;
1670 return ERROR_INT(
"&nabinval not defined", __func__, 1);
1673 return ERROR_INT(
"na not defined", __func__, 1);
1675 return ERROR_INT(
"nbins must be > 1", __func__, 1);
1678 ntot = numaGetCount(na);
1680 return ERROR_INT(
"naeach not made", __func__, 1);
1686 numaGetIValue(naeach, 0, &binsize);
1687 nabinval = numaCreate(nbins);
1688 for (i = 0; i < ntot; i++) {
1689 numaGetFValue(na, i, &val);
1692 if (bincount == binsize) {
1693 ave = sum / binsize;
1694 numaAddNumber(nabinval, ave);
1698 if (binindex == nbins)
break;
1699 numaGetIValue(naeach, binindex, &binsize);
1702 *pnabinval = nabinval;
1704 numaDestroy(&naeach);
1742l_int32 i, j, nxvals, occup, count, bincount, binindex, binsize;
1743l_float32 sum, ave, ntot;
1745 if (pnarank) *pnarank = NULL;
1747 return ERROR_INT(
"&nabinval not defined", __func__, 1);
1750 return ERROR_INT(
"na not defined", __func__, 1);
1752 return ERROR_INT(
"nbins must be > 1", __func__, 1);
1754 nxvals = numaGetCount(na);
1755 numaGetSum(na, &ntot);
1756 occup = ntot / nxvals;
1757 if (occup < 1) L_INFO(
"average occupancy %d < 1\n", __func__, occup);
1761 return ERROR_INT(
"naeach not made", __func__, 1);
1767 numaGetIValue(naeach, 0, &binsize);
1768 nabinval = numaCreate(nbins);
1769 for (i = 0; i < nxvals; i++) {
1770 numaGetIValue(na, i, &count);
1771 for (j = 0; j < count; j++) {
1774 if (bincount == binsize) {
1775 ave = sum / binsize;
1776 numaAddNumber(nabinval, ave);
1780 if (binindex == nbins)
break;
1781 numaGetIValue(naeach, binindex, &binsize);
1784 if (binindex == nbins)
break;
1786 *pnabinval = nabinval;
1787 if (binindex != nbins)
1788 L_ERROR(
"binindex = %d != nbins = %d\n", __func__, binindex, nbins);
1794 *pnarank = numaGetPartialSums(nan);
1797 numaDestroy(&naeach);
1826l_int32 maxbins, type;
1827l_float32 maxval, delx;
1830 return ERROR_INT(
"&pnam not defined", __func__, 1);
1833 return ERROR_INT(
"na not defined", __func__, 1);
1834 if (numaGetCount(na) == 0)
1835 return ERROR_INT(
"na is empty", __func__, 1);
1837 return ERROR_INT(
"nbins must be > 1", __func__, 1);
1845 type = numaChooseSortType(na);
1847 L_INFO(
"sort the array: input size = %d\n", __func__, numaGetCount(na));
1858 L_INFO(
"use a histogram: input size = %d\n", __func__, numaGetCount(na));
1859 numaGetMax(na, &maxval, NULL);
1860 maxbins = L_MIN(100002, (l_int32)maxval + 2);
1865 numaGetParameters(na1, NULL, &delx);
1867 L_WARNING(
"scale change: delx = %6.2f\n", __func__, delx);
1893l_int32 i, start, end;
1897 return (
NUMA *)ERROR_PTR(
"ntotal <= 0", __func__, NULL);
1899 return (
NUMA *)ERROR_PTR(
"nbins <= 0", __func__, NULL);
1901 if ((naeach = numaCreate(nbins)) == NULL)
1902 return (
NUMA *)ERROR_PTR(
"naeach not made", __func__, NULL);
1904 for (i = 0; i < nbins; i++) {
1905 end = ntotal * (i + 1) / nbins;
1906 numaAddNumber(naeach, end - start);
1967 l_float32 scorefract,
1968 l_int32 *psplitindex,
1975l_int32 i, n, bestsplit, minrange, maxrange, maxindex;
1976l_float32 ave1, ave2, ave1prev, ave2prev;
1977l_float32 num1, num2, num1prev, num2prev;
1978l_float32 val, minval, sum, fract1;
1979l_float32 norm, score, minscore, maxscore;
1980NUMA *nascore, *naave1, *naave2, *nanum1, *nanum2;
1982 if (psplitindex) *psplitindex = 0;
1983 if (pave1) *pave1 = 0.0;
1984 if (pave2) *pave2 = 0.0;
1985 if (pnum1) *pnum1 = 0.0;
1986 if (pnum2) *pnum2 = 0.0;
1987 if (pnascore) *pnascore = NULL;
1989 return ERROR_INT(
"na not defined", __func__, 1);
1991 n = numaGetCount(na);
1993 return ERROR_INT(
"n = 1 in histogram", __func__, 1);
1994 numaGetSum(na, &sum);
1996 return ERROR_INT(
"sum <= 0.0", __func__, 1);
1997 norm = 4.0 / ((l_float32)(n - 1) * (n - 1));
2007 if ((nascore = numaCreate(n)) == NULL)
2008 return ERROR_INT(
"nascore not made", __func__, 1);
2009 naave1 = (pave1) ? numaCreate(n) : NULL;
2010 naave2 = (pave2) ? numaCreate(n) : NULL;
2011 nanum1 = (pnum1) ? numaCreate(n) : NULL;
2012 nanum2 = (pnum2) ? numaCreate(n) : NULL;
2014 for (i = 0; i < n; i++) {
2015 numaGetFValue(na, i, &val);
2016 num1 = num1prev + val;
2020 ave1 = (num1prev * ave1prev + i * val) / num1;
2021 num2 = num2prev - val;
2025 ave2 = (num2prev * ave2prev - i * val) / num2;
2026 fract1 = num1 / sum;
2027 score = norm * (fract1 * (1 - fract1)) * (ave2 - ave1) * (ave2 - ave1);
2028 numaAddNumber(nascore, score);
2029 if (pave1) numaAddNumber(naave1, ave1);
2030 if (pave2) numaAddNumber(naave2, ave2);
2031 if (pnum1) numaAddNumber(nanum1, num1);
2032 if (pnum2) numaAddNumber(nanum2, num2);
2033 if (score > maxscore) {
2046 minscore = (1. - scorefract) * maxscore;
2047 for (i = maxindex - 1; i >= 0; i--) {
2048 numaGetFValue(nascore, i, &val);
2053 for (i = maxindex + 1; i < n; i++) {
2054 numaGetFValue(nascore, i, &val);
2059 numaGetFValue(na, minrange, &minval);
2060 bestsplit = minrange;
2061 for (i = minrange + 1; i <= maxrange; i++) {
2062 numaGetFValue(na, i, &val);
2072 bestsplit = L_MIN(255, bestsplit + 1);
2074 if (psplitindex) *psplitindex = bestsplit;
2075 if (pave1) numaGetFValue(naave1, bestsplit, pave1);
2076 if (pave2) numaGetFValue(naave2, bestsplit, pave2);
2077 if (pnum1) numaGetFValue(nanum1, bestsplit, pnum1);
2078 if (pnum2) numaGetFValue(nanum2, bestsplit, pnum2);
2081 lept_stderr(
"minrange = %d, maxrange = %d\n", minrange, maxrange);
2082 lept_stderr(
"minval = %10.0f\n", minval);
2083 gplotSimple1(nascore, GPLOT_PNG,
"/tmp/lept/nascore",
2084 "Score for split distribution");
2085 *pnascore = nascore;
2087 numaDestroy(&nascore);
2090 if (pave1) numaDestroy(&naave1);
2091 if (pave2) numaDestroy(&naave2);
2092 if (pnum1) numaDestroy(&nanum1);
2093 if (pnum2) numaDestroy(&nanum2);
2132NUMA *na1, *na2, *nad;
2135 return ERROR_INT(
"&nad not defined", __func__, 1);
2138 return ERROR_INT(
"na1 and na2 not both defined", __func__, 1);
2139 n = numaaGetCount(naa1);
2140 if (n != numaaGetCount(naa2))
2141 return ERROR_INT(
"naa1 and naa2 numa counts differ", __func__, 1);
2142 nt = numaaGetNumberCount(naa1);
2143 if (nt != numaaGetNumberCount(naa2))
2144 return ERROR_INT(
"naa1 and naa2 number counts differ", __func__, 1);
2146 return ERROR_INT(
"na sizes must be 256", __func__, 1);
2148 nad = numaCreate(n);
2150 for (i = 0; i < n; i++) {
2151 na1 = numaaGetNuma(naa1, i,
L_CLONE);
2152 na2 = numaaGetNuma(naa2, i,
L_CLONE);
2154 numaAddNumber(nad, dist / 255.);
2195l_float32 sum1, sum2, diff, total;
2196l_float32 *array1, *array3;
2200 return ERROR_INT(
"&dist not defined", __func__, 1);
2203 return ERROR_INT(
"na1 and na2 not both defined", __func__, 1);
2204 n = numaGetCount(na1);
2205 if (n != numaGetCount(na2))
2206 return ERROR_INT(
"na1 and na2 have different size", __func__, 1);
2209 numaGetSum(na1, &sum1);
2210 numaGetSum(na2, &sum2);
2211 norm = (L_ABS(sum1 - sum2) < 0.00001 * L_ABS(sum1)) ? 1 : 0;
2215 na3 = numaCopy(na2);
2216 array1 = numaGetFArray(na1,
L_NOCOPY);
2217 array3 = numaGetFArray(na3,
L_NOCOPY);
2221 for (i = 1; i < n; i++) {
2222 diff = array1[i - 1] - array3[i - 1];
2224 total += L_ABS(diff);
2226 *pdist = total / sum1;
2288l_float32 mean, var, rvar;
2289NUMA *na1, *na2, *na3, *na4;
2291 if (pnam) *pnam = NULL;
2292 if (pnams) *pnams = NULL;
2293 if (pnav) *pnav = NULL;
2294 if (pnarv) *pnarv = NULL;
2295 if (!pnam && !pnams && !pnav && !pnarv)
2296 return ERROR_INT(
"nothing requested", __func__, 1);
2298 return ERROR_INT(
"naa not defined", __func__, 1);
2299 n = numaaGetCount(naa);
2300 for (i = 0; i < n; i++) {
2301 nn = numaaGetNumaCount(naa, i);
2303 L_ERROR(
"%d numbers in numa[%d]\n", __func__, nn, i);
2308 if (pnam) *pnam = numaCreate(256);
2309 if (pnams) *pnams = numaCreate(256);
2310 if (pnav) *pnav = numaCreate(256);
2311 if (pnarv) *pnarv = numaCreate(256);
2315 arrays = (l_float32 **)LEPT_CALLOC(n,
sizeof(l_float32 *));
2316 for (i = 0; i < n; i++) {
2317 na1 = numaaGetNuma(naa, i,
L_CLONE);
2320 arrays[i] = numaGetFArray(na3,
L_COPY);
2327 for (j = 0; j < 256; j++) {
2328 na4 = numaCreate(n);
2329 for (i = 0; i < n; i++) {
2330 numaAddNumber(na4, arrays[i][j]);
2333 if (pnam) numaAddNumber(*pnam, mean);
2334 if (pnams) numaAddNumber(*pnams, mean * mean);
2335 if (pnav) numaAddNumber(*pnav, var);
2336 if (pnarv) numaAddNumber(*pnarv, rvar);
2340 for (i = 0; i < n; i++)
2341 LEPT_FREE(arrays[i]);
2372l_int32 i, k, n, maxloc, lloc, rloc;
2373l_float32 fmaxval, sum, total, newtotal, val, lastval;
2378 return (
NUMA *)ERROR_PTR(
"nas not defined", __func__, NULL);
2379 n = numaGetCount(nas);
2380 numaGetSum(nas, &total);
2383 if ((na = numaCopy(nas)) == NULL)
2384 return (
NUMA *)ERROR_PTR(
"na not made", __func__, NULL);
2385 if ((napeak = numaCreate(4 * nmax)) == NULL) {
2387 return (
NUMA *)ERROR_PTR(
"napeak not made", __func__, NULL);
2390 for (k = 0; k < nmax; k++) {
2391 numaGetSum(na, &newtotal);
2392 if (newtotal == 0.0)
2394 numaGetMax(na, &fmaxval, &maxloc);
2398 for (i = maxloc - 1; i >= 0; --i) {
2399 numaGetFValue(na, i, &val);
2404 if (val > fract1 * fmaxval) {
2409 if (lastval - val > fract2 * lastval) {
2419 for (i = maxloc + 1; i < n; ++i) {
2420 numaGetFValue(na, i, &val);
2425 if (val > fract1 * fmaxval) {
2430 if (lastval - val > fract2 * lastval) {
2438 peakfract = sum / total;
2439 numaAddNumber(napeak, lloc);
2440 numaAddNumber(napeak, maxloc);
2441 numaAddNumber(napeak, rloc);
2442 numaAddNumber(napeak, peakfract);
2444 for (i = lloc; i <= rloc; i++)
2445 numaSetValue(na, i, 0.0);
2487l_int32 i, n, found, loc, direction;
2488l_float32 startval, val, maxval, minval;
2491 if (pnav) *pnav = NULL;
2493 return (
NUMA *)ERROR_PTR(
"nas not defined", __func__, NULL);
2495 return (
NUMA *)ERROR_PTR(
"delta < 0", __func__, NULL);
2497 n = numaGetCount(nas);
2498 nad = numaCreate(0);
2501 nav = numaCreate(0);
2508 numaGetFValue(nas, 0, &startval);
2510 for (i = 1; i < n; i++) {
2511 numaGetFValue(nas, i, &val);
2512 if (L_ABS(val - startval) >= delta) {
2522 if (val > startval) {
2533 for (i = i + 1; i < n; i++) {
2534 numaGetFValue(nas, i, &val);
2535 if (direction == 1 && val > maxval ) {
2538 }
else if (direction == -1 && val < minval ) {
2541 }
else if (direction == 1 && (maxval - val >= delta)) {
2542 numaAddNumber(nad, loc);
2543 if (nav) numaAddNumber(nav, maxval);
2547 }
else if (direction == -1 && (val - minval >= delta)) {
2548 numaAddNumber(nad, loc);
2549 if (nav) numaAddNumber(nav, minval);
2594l_int32 i, n, start, index, minloc, found;
2595l_float32 val, pval, jval, minval, maxval, sum, partsum;
2598 if (pfract) *pfract = 0.0;
2600 return ERROR_INT(
"&thresh not defined", __func__, 1);
2603 return ERROR_INT(
"na not defined", __func__, 1);
2604 if (skip <= 0) skip = 20;
2607 numaGetMin(na, &minval, NULL);
2608 numaGetMax(na, &maxval, NULL);
2609 if (minval == maxval)
2610 return ERROR_INT(
"all array values are the same", __func__, 1);
2613 n = numaGetCount(na);
2615 L_WARNING(
"array size %d < 256\n", __func__, n);
2618 for (i = 1; i < n; i++) {
2620 index = L_MIN(i + skip, n - 1);
2622 if (val < pval && jval < pval)
2628 return ERROR_INT(
"top of first peak not found", __func__, 1);
2634 for (i = start + 1; i < n; i++) {
2639 index = L_MIN(i + skip, n - 1);
2651 return ERROR_INT(
"no minimum found", __func__, 1);
2656 for (i = index - 1; i > index - skip; i--) {
2657 if (fa[i] < minval) {
2664 if (minloc > n - 10)
2665 return ERROR_INT(
"minimum at end of array; invalid", __func__, 1);
2670 numaGetSumOnInterval(na, 0, minloc, &partsum);
2671 numaGetSum(na, &sum);
2673 *pfract = partsum / sum;
2702 l_float32 minreversal,
2706l_int32 i, n, nr, ival, binvals;
2708l_float32 fval, delx, len;
2712 if (prd) *prd = 0.0;
2714 return ERROR_INT(
"neither &nr nor &rd are defined", __func__, 1);
2716 return ERROR_INT(
"nas not defined", __func__, 1);
2717 if ((n = numaGetCount(nas)) == 0) {
2718 L_INFO(
"nas is empty\n", __func__);
2721 if (minreversal < 0.0)
2722 return ERROR_INT(
"minreversal < 0", __func__, 1);
2726 for (i = 0; i < n; i++) {
2727 numaGetFValue(nas, i, &fval);
2728 if (fval != 0.0 && fval != 1.0) {
2736 if (minreversal > 1.0) {
2737 L_WARNING(
"binary values but minreversal > 1\n", __func__);
2739 ia = numaGetIArray(nas);
2741 for (i = 1; i < n; i++) {
2742 if (ia[i] != ival) {
2751 nr = numaGetCount(nat);
2756 numaGetParameters(nas, NULL, &delx);
2758 *prd = (l_float32)nr / len;
2797 l_float32 estthresh,
2798 l_float32 *pbestthresh)
2800l_int32 i, inrun, istart, iend, maxstart, maxend, runlen, maxrunlen;
2801l_int32 val, maxval, nmax, count;
2802l_float32 thresh, fmaxval, fmodeval;
2806 return ERROR_INT(
"&bestthresh not defined", __func__, 1);
2809 return ERROR_INT(
"nay not defined", __func__, 1);
2810 if (numaGetCount(nay) < 2) {
2811 L_WARNING(
"nay count < 2; no threshold crossing\n", __func__);
2816 nat = numaCreate(41);
2817 for (i = 0; i < 41; i++) {
2818 thresh = estthresh - 80.0 + 4.0 * i;
2820 numaAddNumber(nat, numaGetCount(nac));
2826 numaGetMax(nat, &fmaxval, NULL);
2827 maxval = (l_int32)fmaxval;
2829 for (i = 0; i < 41; i++) {
2830 numaGetIValue(nat, i, &val);
2835 numaGetMode(nat, &fmodeval, &count);
2836 if (count > nmax && fmodeval > 0.5 * fmaxval)
2837 maxval = (l_int32)fmodeval;
2842 maxrunlen = 0, maxstart = 0, maxend = 0;
2843 for (i = 0; i < 41; i++) {
2844 numaGetIValue(nat, i, &val);
2845 if (val == maxval) {
2852 if (inrun && (val != maxval)) {
2854 runlen = iend - istart + 1;
2856 if (runlen > maxrunlen) {
2864 runlen = i - istart;
2865 if (runlen > maxrunlen) {
2872 *pbestthresh = estthresh - 80.0 + 2.0 * (l_float32)(maxstart + maxend);
2875 lept_stderr(
"\nCrossings attain a maximum at %d thresholds, between:\n"
2876 " thresh[%d] = %5.1f and thresh[%d] = %5.1f\n",
2877 nmax, maxstart, estthresh - 80.0 + 4.0 * maxstart,
2878 maxend, estthresh - 80.0 + 4.0 * maxend);
2879 lept_stderr(
"The best choice: %5.1f\n", *pbestthresh);
2880 lept_stderr(
"Number of crossings at the 41 thresholds:");
2881 numaWriteStderr(nat);
2909l_float32 startx, delx;
2910l_float32 xval1, xval2, yval1, yval2, delta1, delta2, crossval, fract;
2914 return (
NUMA *)ERROR_PTR(
"nay not defined", __func__, NULL);
2915 n = numaGetCount(nay);
2917 if (nax && (numaGetCount(nax) != n))
2918 return (
NUMA *)ERROR_PTR(
"nax and nay sizes differ", __func__, NULL);
2920 nad = numaCreate(0);
2921 if (n < 2)
return nad;
2922 numaGetFValue(nay, 0, &yval1);
2923 numaGetParameters(nay, &startx, &delx);
2925 numaGetFValue(nax, 0, &xval1);
2928 for (i = 1; i < n; i++) {
2929 numaGetFValue(nay, i, &yval2);
2931 numaGetFValue(nax, i, &xval2);
2933 xval2 = startx + i * delx;
2934 delta1 = yval1 - thresh;
2935 delta2 = yval2 - thresh;
2936 if (delta1 == 0.0) {
2937 numaAddNumber(nad, xval1);
2938 }
else if (delta2 == 0.0) {
2939 numaAddNumber(nad, xval2);
2940 }
else if (delta1 * delta2 < 0.0) {
2941 fract = L_ABS(delta1) / L_ABS(yval1 - yval2);
2942 crossval = xval1 + fract * (xval2 - xval1);
2943 numaAddNumber(nad, crossval);
2972l_int32 i, j, n, np, previndex, curindex;
2973l_float32 startx, delx;
2974l_float32 xval1, xval2, yval1, yval2, delta1, delta2;
2975l_float32 prevval, curval, thresh, crossval, fract;
2979 return (
NUMA *)ERROR_PTR(
"nay not defined", __func__, NULL);
2981 n = numaGetCount(nay);
2982 if (nax && (numaGetCount(nax) != n))
2983 return (
NUMA *)ERROR_PTR(
"nax and nay sizes differ", __func__, NULL);
2989 numaAddNumber(nap, n - 1);
2990 np = numaGetCount(nap);
2991 L_INFO(
"Number of crossings: %d\n", __func__, np);
2994 nad = numaCreate(np);
2996 numaGetFValue(nay, 0, &prevval);
2997 numaGetParameters(nay, &startx, &delx);
2998 for (i = 0; i < np; i++) {
2999 numaGetIValue(nap, i, &curindex);
3000 numaGetFValue(nay, curindex, &curval);
3001 thresh = (prevval + curval) / 2.0;
3003 numaGetFValue(nax, previndex, &xval1);
3005 xval1 = startx + previndex * delx;
3006 numaGetFValue(nay, previndex, &yval1);
3007 for (j = previndex + 1; j <= curindex; j++) {
3009 numaGetFValue(nax, j, &xval2);
3011 xval2 = startx + j * delx;
3012 numaGetFValue(nay, j, &yval2);
3013 delta1 = yval1 - thresh;
3014 delta2 = yval2 - thresh;
3015 if (delta1 == 0.0) {
3016 numaAddNumber(nad, xval1);
3018 }
else if (delta2 == 0.0) {
3019 numaAddNumber(nad, xval2);
3021 }
else if (delta1 * delta2 < 0.0) {
3022 fract = L_ABS(delta1) / L_ABS(yval1 - yval2);
3023 crossval = xval1 + fract * (xval2 - xval1);
3024 numaAddNumber(nad, crossval);
3030 previndex = curindex;
3078 l_float32 relweight,
3083 l_float32 *pbestwidth,
3084 l_float32 *pbestshift,
3085 l_float32 *pbestscore)
3088l_float32 delwidth, delshift, width, shift, score;
3089l_float32 bestwidth, bestshift, bestscore;
3091 if (pbestscore) *pbestscore = 0.0;
3092 if (pbestwidth) *pbestwidth = 0.0;
3093 if (pbestshift) *pbestshift = 0.0;
3094 if (!pbestwidth || !pbestshift)
3095 return ERROR_INT(
"&bestwidth and &bestshift not defined", __func__, 1);
3097 return ERROR_INT(
"nas not defined", __func__, 1);
3099 bestscore = bestwidth = bestshift = 0.0;
3100 delwidth = (maxwidth - minwidth) / (nwidth - 1.0);
3101 for (i = 0; i < nwidth; i++) {
3102 width = minwidth + delwidth * i;
3103 delshift = width / (l_float32)(nshift);
3104 for (j = 0; j < nshift; j++) {
3105 shift = j * delshift;
3107 if (score > bestscore) {
3112 lept_stderr(
"width = %7.3f, shift = %7.3f, score = %7.3f\n",
3113 width, shift, score);
3119 *pbestwidth = bestwidth;
3120 *pbestshift = bestshift;
3122 *pbestscore = bestscore;
3163 l_float32 relweight,
3166l_int32 i, n, nsamp, index;
3167l_float32 score, weight, val;
3170 return ERROR_INT(
"&score not defined", __func__, 1);
3173 return ERROR_INT(
"nas not defined", __func__, 1);
3174 if ((n = numaGetCount(nas)) < 2 * width)
3175 return ERROR_INT(
"nas size too small", __func__, 1);
3178 nsamp = (l_int32)((n - shift) / width);
3179 for (i = 0; i < nsamp; i++) {
3180 index = (l_int32)(shift + i * width);
3181 weight = (i % 2) ? 1.0 : -1.0 * relweight;
3182 numaGetFValue(nas, index, &val);
3183 score += weight * val;
3186 *pscore = 2.0 * width * score / (l_float32)n;
3220l_int32 i, nsets, val;
3224 first = L_MAX(0, first);
3226 return (
NUMA *)ERROR_PTR(
"last < first!", __func__, NULL);
3228 return (
NUMA *)ERROR_PTR(
"nmax < 1!", __func__, NULL);
3230 nsets = L_MIN(nmax, last - first + 1);
3234 return (
NUMA *)ERROR_PTR(
"nsets == 0", __func__, NULL);
3241 delta = (l_float32)(last - first) / (nsets - 1);
3243 delta = (l_float32)(last - first - 1) / (nsets - 1);
3246 na = numaCreate(nsets);
3247 for (i = 0; i < nsets; i++) {
3248 val = (l_int32)(first + i * delta + 0.5);
3249 numaAddNumber(na, val);
3251 numaAddNumber(na, val + 1);
NUMA * numaErode(NUMA *nas, l_int32 size)
numaErode()
l_ok numaGetRankBinValues(NUMA *na, l_int32 nbins, NUMA **pnam)
numaGetRankBinValues()
NUMA * genConstrainedNumaInRange(l_int32 first, l_int32 last, l_int32 nmax, l_int32 use_pairs)
genConstrainedNumaInRange()
l_ok numaCountReversals(NUMA *nas, l_float32 minreversal, l_int32 *pnr, l_float32 *prd)
numaCountReversals()
NUMA * numaWindowedMeanSquare(NUMA *nas, l_int32 wc)
numaWindowedMeanSquare()
NUMA * numaClose(NUMA *nas, l_int32 size)
numaClose()
NUMA * numaNormalizeHistogram(NUMA *nas, l_float32 tsum)
numaNormalizeHistogram()
NUMA * numaWindowedMedian(NUMA *nas, l_int32 halfwin)
numaWindowedMedian()
l_ok numaEvalHaarSum(NUMA *nas, l_float32 width, l_float32 shift, l_float32 relweight, l_float32 *pscore)
numaEvalHaarSum()
NUMA * numaDilate(NUMA *nas, l_int32 size)
numaDilate()
l_ok numaEarthMoverDistance(NUMA *na1, NUMA *na2, l_float32 *pdist)
numaEarthMoverDistance()
l_ok numaSelectCrossingThreshold(NUMA *nax, NUMA *nay, l_float32 estthresh, l_float32 *pbestthresh)
numaSelectCrossingThreshold()
NUMA * numaTransform(NUMA *nas, l_float32 shift, l_float32 scale)
numaTransform()
l_ok numaWindowedStats(NUMA *nas, l_int32 wc, NUMA **pnam, NUMA **pnams, NUMA **pnav, NUMA **pnarv)
numaWindowedStats()
NUMA * numaGetUniformBinSizes(l_int32 ntotal, l_int32 nbins)
numaGetUniformBinSizes()
l_ok numaWindowedVariance(NUMA *nam, NUMA *nams, NUMA **pnav, NUMA **pnarv)
numaWindowedVariance()
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 numaDiscretizeHistoInBins(NUMA *na, l_int32 nbins, NUMA **pnabinval, NUMA **pnarank)
numaDiscretizeHistoInBins()
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 * numaWindowedMean(NUMA *nas, l_int32 wc)
numaWindowedMean()
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_ok grayHistogramsToEMD(NUMAA *naa1, NUMAA *naa2, NUMA **pnad)
grayHistogramsToEMD()
NUMA * numaCrossingsByPeaks(NUMA *nax, NUMA *nay, l_float32 delta)
numaCrossingsByPeaks()
NUMA * numaOpen(NUMA *nas, l_int32 size)
numaOpen()
NUMA * numaCrossingsByThreshold(NUMA *nax, NUMA *nay, l_float32 thresh)
numaCrossingsByThreshold()
l_ok numaMakeRankFromHistogram(l_float32 startx, l_float32 deltax, NUMA *nasy, l_int32 npts, NUMA **pnax, NUMA **pnay)
numaMakeRankFromHistogram()
NUMA * numaMakeHistogramAuto(NUMA *na, l_int32 maxbins)
numaMakeHistogramAuto()
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 numaHistogramGetRankFromVal(NUMA *na, l_float32 rval, l_float32 *prank)
numaHistogramGetRankFromVal()
NUMA * numaRebinHistogram(NUMA *nas, l_int32 newsize)
numaRebinHistogram()
l_ok numaHistogramGetValFromRank(NUMA *na, l_float32 rank, l_float32 *prval)
numaHistogramGetValFromRank()
NUMA * numaConvertToInt(NUMA *nas)
numaConvertToInt()
NUMA * numaFindExtrema(NUMA *nas, l_float32 delta, NUMA **pnav)
numaFindExtrema()
l_ok numaFindLocForThreshold(NUMA *na, l_int32 skip, l_int32 *pthresh, l_float32 *pfract)
numaFindLocForThreshold()
l_ok grayInterHistogramStats(NUMAA *naa, l_int32 wc, NUMA **pnam, NUMA **pnams, NUMA **pnav, NUMA **pnarv)
grayInterHistogramStats()
NUMA * numaFindPeaks(NUMA *nas, l_int32 nmax, l_float32 fract1, l_float32 fract2)
numaFindPeaks()
l_ok numaSimpleStats(NUMA *na, l_int32 first, l_int32 last, l_float32 *pmean, l_float32 *pvar, l_float32 *prvar)
numaSimpleStats()
NUMA * numaMakeHistogramClipped(NUMA *na, l_float32 binsize, l_float32 maxsize)
numaMakeHistogramClipped()
NUMA * numaMakeHistogram(NUMA *na, l_int32 maxbins, l_int32 *pbinsize, l_int32 *pbinstart)
numaMakeHistogram()
l_ok numaDiscretizeSortedInBins(NUMA *na, l_int32 nbins, NUMA **pnabinval)
numaDiscretizeSortedInBins()
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()