Commit Graph

100 Commits

Author SHA1 Message Date
Sean Barrett 99f3b78bbd Merge branch 'resample' of http://github.com/bsvino/stb into resample 2014-09-12 03:54:17 -07:00
Sean Barrett df128b7995 update STBIR__UNUSED_PARAM to match stb_image.h version 2014-09-12 03:53:36 -07:00
Jorge Rodriguez ca88b6fba6 Calculate and store vertical contributors first so that they can be normalized and optimized. 2014-09-11 12:45:18 -07:00
Jorge Rodriguez a25c1d2bbd Merge remote-tracking branch 'remotes/nothings/resample' into resample 2014-09-11 10:00:57 -07:00
Jorge Rodriguez 36b417f6b4 Optimizations: Skip zero-coefficient contributions. Reduce the size of the coefficients array when downsampling. 2014-09-11 09:53:14 -07:00
Sean Barrett 27f26f8337 Documentation;
rename STBIR_FLAG_PREMULTIPLED_ALPHA to STBIR_FLAG_ALPHA_PREMULTIPLIED so that both flags have "ALPHA" first
2014-09-11 03:02:20 -07:00
Sean Barrett 16d68d14f8 fix stbir__linear_to_srgb_uchar:
1. table stored threshhold of transition from i to i+1, but wants to be i-1 to i
    2. table was computed by dividing uchar by 256.0 instead of 255.0, causing it to be 100% wrong
2014-09-11 02:05:53 -07:00
Sean Barrett 30c7a981ec compile as C;
fix some unsigned/signed comparisons;
avoid round() since it's not in pre-C99 C;
remove MAX_CHANNELS since I never ended up needing it;
rename STBIR_EPSILON to STBIR_ALPHA_EPSILON;
don't use STBIR_ALPHA_EPSILON on float input (can't remove it properly due to numeric precision, and they can do it themselves);
optimize subtraction of STBIR_ALPHA_EPSILON;
sorry i forgot to commit these separately!;
2014-09-11 01:47:50 -07:00
Jorge Rodriguez 793818d1af Skip zero-coefficient contributors, a fairly decent speedup. 2014-09-10 20:26:14 -07:00
Jorge Rodriguez 46dc8f84fb Use vertical pixel width for the ring buffer. 2014-09-10 20:12:38 -07:00
Jorge Rodriguez 953a637841 Use a carefully shaped trapezoid instead of a box filter to avoid jumps between pixel values. 2014-09-10 19:08:11 -07:00
Jorge Rodriguez 6922628106 Use an even smaller epsilon. Allow the user to avoid the epsilon business if they want to preserve their alpha values. 2014-09-10 15:03:55 -07:00
Jorge Rodriguez c9d67446d2 Reverse allocation routines parameter order so that the context is at the back. 2014-09-09 22:57:15 -07:00
Jorge Rodriguez 17b931047c Add the epsilon value into the alpha instead of using an if statement. It's a tiny bit faster and it can be removed afterwards. 2014-09-09 22:47:53 -07:00
Jorge Rodriguez 1d5c902e2e These minor optimizations were probably already done by the compiler but they can't hurt. 2014-09-09 22:07:40 -07:00
Jorge Rodriguez 41e6aad693 Avoid repeated adds and ensure correct round-trip result. 2014-09-09 21:57:46 -07:00
Jorge Rodriguez f2102d906f Use the info structure to keep track of our memory block sizes to reduce duplicated code and cut down on errors. 2014-09-09 20:58:19 -07:00
Jorge Rodriguez 969ff7c850 Make sure calculate_memory matches with the allocations. Fix some errant asserts. 2014-09-09 20:51:29 -07:00
Jorge Rodriguez 8355ea1184 Use height, not width, for correct progress report. 2014-09-09 18:41:28 -07:00
Jorge Rodriguez 4b69c0637e If alpha is zero then sneakily replace it with a very small nonzero so that the color data is preserved.
Pre-process n1 so that we don't have to do it later on. Can't do n0 since it's used to find the coefficient index.
2014-09-09 18:38:05 -07:00
Jorge Rodriguez d510d70b6a Report downsample progress by when we empty the ring buffer, it's more accurate that way. 2014-09-09 16:35:00 -07:00
Jorge Rodriguez 497eab8339 Normalize downsample coefficients. 2014-09-09 15:22:29 -07:00
Jorge Rodriguez 43fbc1d5e3 Rearrange the algebra on two of the filters to avoid repeating decimals which cause precision loss. Use int32 to test filters because it's more accurate. 2014-09-09 14:10:14 -07:00
Jorge Rodriguez ca241daefa Use rounding to try to preserve the original value. Fix test case. 2014-09-09 12:16:23 -07:00
Jorge Rodriguez 145690788c Use input_h + pixel_margin * 2 to prevent progress report from ever going above 1. Always report a 0 before and a 1 at the end of each resize. 2014-09-09 10:58:01 -07:00
Jorge Rodriguez e6c47ec657 Fix kernel lookup for downsampling. 2014-09-07 12:57:53 -07:00
Sean Barrett 7da729bfce restore correct definition of box 2014-09-07 04:07:07 -07:00
Sean Barrett 08ca345839 Merge branch 'resample2' into resample 2014-09-07 03:36:16 -07:00
Sean Barrett cd1fbacbb6 rename NEAREST to BOX
write test for BOX
2014-09-07 03:19:18 -07:00
Jorge Rodriguez 38ce5494bc Clarify some comments. Make stbir__resize_arbitrary an internal function. Update test cases to use actual API functions. 2014-09-06 20:17:19 -07:00
Sean Barrett 41555b5d53 update test cases to work on things other than barbara.png 2014-09-06 14:58:32 -07:00
Jorge Rodriguez fb059fcece Progress report. 2014-09-06 10:57:21 -07:00
Jorge Rodriguez 75bdd2da83 Fix malloc context and whitespace. 2014-09-06 08:48:46 -07:00
Sean Barrett 952c26e626 inline stbir__encode_pixel into stbir__encode_scanline 2014-09-01 19:29:28 -07:00
Sean Barrett aee30095c7 refactor internal interfaces to avoid passing things multiple times;
finish prepping 'stbir__info' even before calculate_memory;
get rid of 'noinfo' functions since now calculate_memory doesn't need 'em;
add new binary-searched sRGB function (untested)
2014-09-01 16:52:04 -07:00
Sean Barrett 24c540e1b0 rename alpha gamma flag 2014-08-31 10:00:54 -07:00
Sean Barrett 07c35180f7 tweak new API 2014-08-31 09:45:29 -07:00
Sean Barrett 84520de6c4 finish STBI_EDGE_ZERO, untested 2014-08-31 09:32:17 -07:00
Sean Barrett 9a1d34843e STBIR_EDGE_ZERO 2014-08-31 09:10:49 -07:00
Sean Barrett 732fec68ee tweak new API, get it partly working 2014-08-31 08:55:41 -07:00
Sean Barrett 664d8961f5 new API partially in-use 2014-08-31 08:34:05 -07:00
Sean Barrett bbd4e2ee9a new API "finished" but untested 2014-08-31 07:32:10 -07:00
Sean Barrett 034674c142 Merge branch 'resample2' into resample
Conflicts:
	stb_image_resize.h
2014-08-31 07:23:22 -07:00
Sean Barrett 1bd9770e75 separate filter for horizontal and vertical 2014-08-31 06:47:45 -07:00
Sean Barrett c1b876768e in progress new API 2014-08-31 06:31:50 -07:00
Sean Barrett 5dfa79fb31 stride doesn't have to be multiples of pixels 2014-08-18 10:18:59 -07:00
Sean Barrett 32b626859d remove most per-pixel switches, beginnings of removing encode_pixel switch 2014-08-18 10:02:00 -07:00
Sean Barrett 5eb0236d9d reverse default behavior of linear/gamma for alpha 2014-08-18 09:33:01 -07:00
Sean Barrett b9bb05b81c minor cleanups 2014-08-18 09:14:11 -07:00
Sean Barrett 6ef563d089 rename to stb_image_resize.h 2014-08-18 09:12:59 -07:00