Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
-
- Posts: 1944
- Joined: 2010-08-28T11:16:00-07:00
- Authentication code: 8675308
- Location: Montreal, Canada
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
Your set up definitely has a very particular "look".
Are you sure that all you do is use linear filtering with your modified weights?
Are you sure that all you do is use linear filtering with your modified weights?
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
Sorry, I forgot to mention I use some anti-ringing code internally.NicolasRobidoux wrote:Your set up definitely has a very particular "look".
Are you sure that all you do is use linear filtering with your modified weights?
-
- Posts: 1944
- Joined: 2010-08-28T11:16:00-07:00
- Authentication code: 8675308
- Location: Montreal, Canada
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
I find the "texturelessness" unnatural. I personally would tone down the anti-ringing (not eliminate it: just turn it down).
Otherwise, it's an interesting approach. Good job!
(My apologies for a very cursory evaluation. No time for more.)
Otherwise, it's an interesting approach. Good job!
(My apologies for a very cursory evaluation. No time for more.)
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
The anti-ringing works more or less like this:
It gets the four nearest neighbors from the point I'm sampling and choose the max and the min, per color channel. Then, the jinc2 output is clamped to that range (min,max).
By toning down, do you mean enlarging that range? Something like a new range (min - d, max + d)?
It gets the four nearest neighbors from the point I'm sampling and choose the max and the min, per color channel. Then, the jinc2 output is clamped to that range (min,max).
By toning down, do you mean enlarging that range? Something like a new range (min - d, max + d)?
-
- Posts: 1944
- Joined: 2010-08-28T11:16:00-07:00
- Authentication code: 8675308
- Location: Montreal, Canada
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
This approach is reasonable and a bit reminiscent of what is done in the LBB component of the nohalo sampler (in the GEGL and VIPS FLOSS libraries; just google nohalo image sampler).
-----
Instead of (min-d,max+d), what I would do is blend (lerp) the unclamped result with the clamped result.
I would also apply it to a different color space than (I imagine) sRGB and blend the result of clamping in this space with the one you have already. I'd start with L*a*b*.
So, you'd be blending three results to get the final result.
The reason for using a second color space is that this way you are more likely to clamp "approximately isotropically": Nothing says that the clamping is better done with the primaries: you may be dealing with blended colors. L*a*b* is sufficiently different to mix things up a little.
-----
Instead of (min-d,max+d), what I would do is blend (lerp) the unclamped result with the clamped result.
I would also apply it to a different color space than (I imagine) sRGB and blend the result of clamping in this space with the one you have already. I'd start with L*a*b*.
So, you'd be blending three results to get the final result.
The reason for using a second color space is that this way you are more likely to clamp "approximately isotropically": Nothing says that the clamping is better done with the primaries: you may be dealing with blended colors. L*a*b* is sufficiently different to mix things up a little.
-
- Posts: 1944
- Joined: 2010-08-28T11:16:00-07:00
- Authentication code: 8675308
- Location: Montreal, Canada
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
One thing I am curious about but have had no time to experiment with is whether such "clamping" is better done in linear light or in perceptual spaces.
Generally, upsampling (enlarging) through a perceptual space is better than linear light, at least when the filter has negative lobes. When the filter does not produce over or undershoots, however, it has been my hunch that the advantage of perceptual vs linear light when upsampling vanishes.
With an AR filter of some sort we are kind of in the latter situation. So, it could be that using, say, RGB and XYZ as color spaces in which the resampling and clamping is done would be better than using sRGB and L*a*b* with your filter.
Am I being too terse?
Generally, upsampling (enlarging) through a perceptual space is better than linear light, at least when the filter has negative lobes. When the filter does not produce over or undershoots, however, it has been my hunch that the advantage of perceptual vs linear light when upsampling vanishes.
With an AR filter of some sort we are kind of in the latter situation. So, it could be that using, say, RGB and XYZ as color spaces in which the resampling and clamping is done would be better than using sRGB and L*a*b* with your filter.
Am I being too terse?
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
Thanks, Nicolas, for the suggestions.
I've implemented the blend suggestion and it indeed worked better for natural images. Though for Pixel Art (my primary need) it isn't so good, because it let escape some ringing.
Here's the images using the blend AR:
data:image/s3,"s3://crabby-images/c7cf6/c7cf6722573ad21d9d69052cb3cc8e952d30957c" alt="Image"
data:image/s3,"s3://crabby-images/5fe07/5fe0723a09442c89eae88481cc25e6e0a8d8b63f" alt="Image"
data:image/s3,"s3://crabby-images/2190c/2190c8a083b2840757dedb8531beb1e1dbb3fe82" alt="Image"
Sorry if I can't respond fast some messages. I access the forum from time to time as I constantly have to go out and can't keep a regular conversation.
I've implemented the blend suggestion and it indeed worked better for natural images. Though for Pixel Art (my primary need) it isn't so good, because it let escape some ringing.
Here's the images using the blend AR:
data:image/s3,"s3://crabby-images/0b67e/0b67ee0dcedbcb4f2ac6b7776d7ddb49819bb981" alt="Image"
data:image/s3,"s3://crabby-images/5a749/5a7495779750e7ad9b72ee31740d852ef635cdac" alt="Image"
data:image/s3,"s3://crabby-images/c7cf6/c7cf6722573ad21d9d69052cb3cc8e952d30957c" alt="Image"
data:image/s3,"s3://crabby-images/71ed1/71ed1c12cc8fdde8172a54336cfa5d672ec35811" alt="Image"
data:image/s3,"s3://crabby-images/4f560/4f5609291f754f25ce99bb3da873a49d9573cbf2" alt="Image"
data:image/s3,"s3://crabby-images/5fe07/5fe0723a09442c89eae88481cc25e6e0a8d8b63f" alt="Image"
data:image/s3,"s3://crabby-images/0110a/0110ad90a6467e70e9e6dc976a112b675a783fe8" alt="Image"
data:image/s3,"s3://crabby-images/ba872/ba8721e5f39ffa385843d0e4a7387d81d419c296" alt="Image"
data:image/s3,"s3://crabby-images/2190c/2190c8a083b2840757dedb8531beb1e1dbb3fe82" alt="Image"
Sorry if I can't respond fast some messages. I access the forum from time to time as I constantly have to go out and can't keep a regular conversation.
- fmw42
- Posts: 25562
- Joined: 2007-07-02T17:14:51-07:00
- Authentication code: 1152
- Location: Sunnyvale, California, USA
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
Art-like images have not been studied/discussed too much on this forum. Here is the last topic of discussion. Perhaps you would like to make the study and report back.
see viewtopic.php?f=1&t=25629
see viewtopic.php?f=1&t=25629
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
Ok, I was just making an observation about pixel art. I've already developed an algorithm for that kind of image.
In this thread I'm more interested in extract the most of a Jinc2 algorithm, because for realtime applications as games, Jinc3 is a bit prohibitive yet. Actually, this Jinc2 implementation I made already works in shader format and is used in some emulators.
With the new AR (blend based thanks to Nicolas) I've found a sharp config (WA=0.9 and WB=0.4). Using the old AR, this config flattened to much the textures. Now they seem almost accetable to me:
data:image/s3,"s3://crabby-images/1e015/1e01596c4a3dd705e1f65caaab1dafe2fd810882" alt="Image"
data:image/s3,"s3://crabby-images/57ba8/57ba853e6a5790d75ab859dc1a88d75be8cc8498" alt="Image"
data:image/s3,"s3://crabby-images/cc013/cc0138af8b7bc0f921e25693fea1e82aee98e69b" alt="Image"
In this thread I'm more interested in extract the most of a Jinc2 algorithm, because for realtime applications as games, Jinc3 is a bit prohibitive yet. Actually, this Jinc2 implementation I made already works in shader format and is used in some emulators.
With the new AR (blend based thanks to Nicolas) I've found a sharp config (WA=0.9 and WB=0.4). Using the old AR, this config flattened to much the textures. Now they seem almost accetable to me:
data:image/s3,"s3://crabby-images/031a8/031a892b8de4f3810fec872f7d87592f97e73036" alt="Image"
data:image/s3,"s3://crabby-images/46659/466596633d37e420f489598992ed7283c12c8cb7" alt="Image"
data:image/s3,"s3://crabby-images/d2ef7/d2ef79a3a8016c8ca3fe37c76673f80076f06fbf" alt="Image"
data:image/s3,"s3://crabby-images/1e015/1e01596c4a3dd705e1f65caaab1dafe2fd810882" alt="Image"
data:image/s3,"s3://crabby-images/f0b3a/f0b3a897acc1066b93cdaca70ec34f6c00024570" alt="Image"
data:image/s3,"s3://crabby-images/56f22/56f228481aab79d28d5fc2f168e571becf9b26f0" alt="Image"
data:image/s3,"s3://crabby-images/ffaf4/ffaf4ca4e31b5b2a7070ff3df50490a932ecb964" alt="Image"
data:image/s3,"s3://crabby-images/57ba8/57ba853e6a5790d75ab859dc1a88d75be8cc8498" alt="Image"
data:image/s3,"s3://crabby-images/99cec/99cec3a5a63ffb20c82bc38dfb4fb763961f14c1" alt="Image"
data:image/s3,"s3://crabby-images/a4b78/a4b78e04ab7861c0e1813beacf4cc8110fbffe80" alt="Image"
data:image/s3,"s3://crabby-images/cc013/cc0138af8b7bc0f921e25693fea1e82aee98e69b" alt="Image"
-
- Posts: 1944
- Joined: 2010-08-28T11:16:00-07:00
- Authentication code: 8675308
- Location: Montreal, Canada
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
If it is truly pixel art (as opposed to line art) see https://plus.google.com/+SevensheavenNL ... nXFi6BHJ1N.
If you really want to develop your own method from what you have already, I suggest the following:
Instead of blending with your scheme untouched by your AR method, blend with the result of a different scheme that has no, or little, halo.
Something like VSQBS = Vertex Split Quadratic B-Spline interpolation (FLOSS code in the libvips library) or, if you want to stick to something available in IM, EWA Quadratic or EWA QuadraticJinc, discussed in http://www.imagemagick.org/Usage/filter/nicolas/.
Also, my guess is that EWA LanczosSharpest 4-lobe (google: it's not a built-in method, at least not yet) would be a good candidate to use with your AR and may work well with pixel art.
If you really want to develop your own method from what you have already, I suggest the following:
Instead of blending with your scheme untouched by your AR method, blend with the result of a different scheme that has no, or little, halo.
Something like VSQBS = Vertex Split Quadratic B-Spline interpolation (FLOSS code in the libvips library) or, if you want to stick to something available in IM, EWA Quadratic or EWA QuadraticJinc, discussed in http://www.imagemagick.org/Usage/filter/nicolas/.
Also, my guess is that EWA LanczosSharpest 4-lobe (google: it's not a built-in method, at least not yet) would be a good candidate to use with your AR and may work well with pixel art.
-
- Posts: 1944
- Joined: 2010-08-28T11:16:00-07:00
- Authentication code: 8675308
- Location: Montreal, Canada
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
Our posts crossed.
-----
Now that I understand more what you want to do, I really suggest that you try EWA with Keys cubics. This is a one parameter family of schemes which only grab data from a disc of diameter 4, the weights are cheap to compute (there is code that computes some of them efficiently in libvips and GEGL; I don't remember if or where I've put the most general/efficient code; IM can compute all BC-splines, so the code is not as optimal for Keys).
At one end you have EWA B-spline smoothing, at the other you have EWA Catmull-Rom, which is very very sharp.
Blend one used with your AR together with one, closer to B-spline smoothing (or maybe EWA Quadratic) without AR.
The special thing about EWA done with Keys cubic weights is that they almost interpolate "perfect" linear gradients exactly.
-----
Now that I understand more what you want to do, I really suggest that you try EWA with Keys cubics. This is a one parameter family of schemes which only grab data from a disc of diameter 4, the weights are cheap to compute (there is code that computes some of them efficiently in libvips and GEGL; I don't remember if or where I've put the most general/efficient code; IM can compute all BC-splines, so the code is not as optimal for Keys).
At one end you have EWA B-spline smoothing, at the other you have EWA Catmull-Rom, which is very very sharp.
Blend one used with your AR together with one, closer to B-spline smoothing (or maybe EWA Quadratic) without AR.
The special thing about EWA done with Keys cubic weights is that they almost interpolate "perfect" linear gradients exactly.
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
Thanks for the tips, Nicolas. I'll look into it later.
If I have news, I'll post here.
If I have news, I'll post here.
-
- Posts: 1944
- Joined: 2010-08-28T11:16:00-07:00
- Authentication code: 8675308
- Location: Montreal, Canada
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
Hyllian: Apologies for telling you, of all people, about the existence of specialized pixel art shaders. (Foot in mouth disease strikes again.)
Last edited by NicolasRobidoux on 2014-06-06T15:53:56-07:00, edited 1 time in total.
-
- Posts: 1944
- Joined: 2010-08-28T11:16:00-07:00
- Authentication code: 8675308
- Location: Montreal, Canada
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
And indeed your latest scheme looks very good.
- fmw42
- Posts: 25562
- Joined: 2007-07-02T17:14:51-07:00
- Authentication code: 1152
- Location: Sunnyvale, California, USA
Re: Sigmoidized Ginseng (pronounced "Jinc-Sinc") resampling
I do not know if this is relevant or beneficial, but IM -fx has j0, j1 and jinc (bessel functions). See http://www.imagemagick.org/script/fx.php
My understanding is that Catrom is the same as keys cubic convolution. I generally like its sharpness over other artifacts, but I do not have such a critical "eye" as others, especially Nicholas. But it is even obvious to me that your second set of images is clearly sharper/better than the first set of images.
My understanding is that Catrom is the same as keys cubic convolution. I generally like its sharpness over other artifacts, but I do not have such a critical "eye" as others, especially Nicholas. But it is even obvious to me that your second set of images is clearly sharper/better than the first set of images.