mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-15 03:46:28 +03:00
simpler coefficients calculation in ImagingResampleHorizontal_8bpc
This commit is contained in:
parent
d3749ccc7c
commit
7722d00daf
|
@ -103,11 +103,11 @@ ImagingPrecompute(int inSize, int outSize, struct filter *filterp,
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/* coefficient buffer */
|
/* coefficient buffer */
|
||||||
kk = malloc(outSize * kmax * sizeof(double));
|
kk = calloc(outSize * kmax, sizeof(double));
|
||||||
if ( ! kk)
|
if ( ! kk)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
xbounds = malloc(outSize * 2 * sizeof(int));
|
xbounds = calloc(outSize * 2, sizeof(int));
|
||||||
if ( ! xbounds) {
|
if ( ! xbounds) {
|
||||||
free(kk);
|
free(kk);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -159,20 +159,15 @@ ImagingResampleHorizontal_8bpc(Imaging imIn, int xsize, struct filter *filterp)
|
||||||
return (Imaging) ImagingError_MemoryError();
|
return (Imaging) ImagingError_MemoryError();
|
||||||
}
|
}
|
||||||
|
|
||||||
kk = malloc(xsize * kmax * sizeof(int));
|
kk = calloc(xsize * kmax, sizeof(int));
|
||||||
if ( ! kk) {
|
if ( ! kk) {
|
||||||
free(xbounds);
|
free(xbounds);
|
||||||
free(prekk);
|
free(prekk);
|
||||||
return (Imaging) ImagingError_MemoryError();
|
return (Imaging) ImagingError_MemoryError();
|
||||||
}
|
}
|
||||||
|
|
||||||
for (xx = 0; xx < xsize; xx++) {
|
for (x = 0; x < xsize * kmax; x++) {
|
||||||
xmin = xbounds[xx * 2 + 0];
|
kk[x] = (int) (0.5 + prekk[x] * (1 << PRECISION_BITS));
|
||||||
xmax = xbounds[xx * 2 + 1];
|
|
||||||
k = &kk[xx * kmax];
|
|
||||||
for (x = 0; x < xmax - xmin; x++) {
|
|
||||||
k[x] = (int) floor(0.5 + prekk[xx * kmax + x] * (1 << PRECISION_BITS));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
free(prekk);
|
free(prekk);
|
||||||
|
|
Loading…
Reference in New Issue
Block a user