
Hi, all,
Today I finally got an initial (very rough) ability to scan an image multiple times, and produce multiple paths.
The trace option I added today does:
1) Quantizes a bitmap into a reduced number of colors or shades of gray 2) Separates out each color, and traces it (much like taking four-color art to your local print shop). 3) Scans each one, applies the color to it. 4) Assembles them as a <g>roup.
It seems to do fairly well with simple images, but complex ones have a "Potrace problem". What I mean is that since Potrace traced an estimate around each region, the reassembled curves do not exactly tile together again. You might need a background shade or something to keep the white background from peeking through.
But give it a try. It should be a bit of fun.
If anyone can think of a good general algorithm for stitching together two adjacent curves, give it a try.
There will be more stuff later, of course. The 'differing levels of brightness' thing will be added soon.
Bob

Here is a typical photo, quantized to 16 colors:
http://troi.hous.es3.titan.com/~rjamison/inkscape/files/multiscan.png
Bob
Bob Jamison wrote:
Hi, all,
Today I finally got an initial (very rough) ability to scan an image multiple times, and produce multiple paths.
The trace option I added today does:
- Quantizes a bitmap into a reduced number of colors or shades of gray
- Separates out each color, and traces it (much like taking
four-color art to your local print shop). 3) Scans each one, applies the color to it. 4) Assembles them as a <g>roup.
It seems to do fairly well with simple images, but complex ones have a "Potrace problem". What I mean is that since Potrace traced an estimate around each region, the reassembled curves do not exactly tile together again. You might need a background shade or something to keep the white background from peeking through.
But give it a try. It should be a bit of fun.
If anyone can think of a good general algorithm for stitching together two adjacent curves, give it a try.
There will be more stuff later, of course. The 'differing levels of brightness' thing will be added soon.

Bob Jamison wrote:
Here is a typical photo, quantized to 16 colors:
http://troi.hous.es3.titan.com/~rjamison/inkscape/files/multiscan.png
Same thing, but with a dark background. Where the background peeks through, it looks like strokes on the paths, so it is not unpleasant.
http://troi.hous.es3.titan.com/~rjamison/inkscape/files/multiscan_bkg.png
Bob

Bob Jamison wrote:
Bob Jamison wrote:
Here is a typical photo, quantized to 16 colors:
http://troi.hous.es3.titan.com/~rjamison/inkscape/files/multiscan.png
Same thing, but with a dark background. Where the background peeks through, it looks like strokes on the paths, so it is not unpleasant.
http://troi.hous.es3.titan.com/~rjamison/inkscape/files/multiscan_bkg.png
And, finally, here is the same thing, but instead of quantizing, this does 8 levels of brightness threshold scanning, superimposing the results from light-to-dark. Wasteful in the nodecount, but makes a very nice vector rendition of the original:
http://troi.hous.es3.titan.com/~rjamison/inkscape/files/brightness_multi.png
Bob

Hi, all.
Ok.. once more. After talking to Mental, I changed the Color and Monochrome quantized multiscans a bit. In addition to the tiling of color regions side-by-side, they now can stack color regions atop each other, the same way the Brightness Multiscan works. It makes for a fairly good vector rendition of an original:
http://troi.hous.es3.titan.com/~rjamison/inkscape/files/multiscan_stack.png
I think both ways of rendering the color regions are good effects, so they will both be available from the dialog.
I could probably expand this further, but this is basically good enough for this release cycle, I think, with a tweak or two.
Bob
Bob Jamison wrote:
Here is a typical photo, quantized to 16 colors:
http://troi.hous.es3.titan.com/~rjamison/inkscape/files/multiscan.png
Same thing, but with a dark background. Where the background peeks through, it looks like strokes on the paths, so it is not unpleasant.
http://troi.hous.es3.titan.com/~rjamison/inkscape/files/multiscan_bkg.png
And, finally, here is the same thing, but instead of quantizing, this does 8 levels of brightness threshold scanning, superimposing the results from light-to-dark. Wasteful in the nodecount, but makes a very nice vector rendition of the original:
http://troi.hous.es3.titan.com/~rjamison/inkscape/files/brightness_multi.png

On Tue, 04 Jan 2005 07:23:47 -0600, Bob Jamison <rjamison@...357...> wrote:
Ok.. once more. After talking to Mental, I changed the Color and Monochrome quantized multiscans a bit. In addition to the tiling of color regions side-by-side, they now can stack color regions atop each other, the same way the Brightness Multiscan works. It makes for a fairly good vector rendition of an original:
http://troi.hous.es3.titan.com/~rjamison/inkscape/files/multiscan_stack.png
Thanks! Now this is a very powerful tool. I'm really impressed. This is something you cannot easily do with plain potrace.
Questions:
- Within "multiple scanning", what's the difference between "brightness" and "monochrome"? They give different previews but very similar results. Besides "brightness" is confusing with the brightness method. I think we should leave only one.
- Import this image (b/w jpeg):
http://www.livejournal.com/userpic/569297/360079
and trace it: multiscan, monochrome, 8 colors. Results are quite good. Now do it again at 9 colors - the result becomes much worse and flatter, as if you reduced the number of colors, not increased it. Then try 10, 11, etc colors: the color resolution does not improve, but the trace becomes darker and darker. After 12 it brightens up again and later starts behaving unpredictably. At 16 colors, each click on Preview gives a different preview image (does not happen at 8 colors). Doing the same in color is similar: the best result is at 8 colors, then starts darkening and degradation, then some wild colors appear. I think this is some bug in the algorithm.
Things to do:
- Since "color" and "monochrome" are in the same radio button group as all the other scanning methods, they should be stacked vertically to align with them.
- Please add tooltips to all widgets in the dialog.
- Please fill in the release note on this feature (http://inkscape.org/cgi-bin/wiki.pl?ReleaseNotes)
- Please prepare a large detailed screenshot with comments, to be added to the site.
Thanks for the beautiful work!

bulia byak wrote:
Questions:
- Within "multiple scanning", what's the difference between
"brightness" and "monochrome"? They give different previews but very similar results. Besides "brightness" is confusing with the brightness method. I think we should leave only one.
These are quite different, actually. Brightness has the same algorithm as the Brightness Threshold above, but instead of merely diving the image into 2 light and dark regions, it partitions the brightness space into however many pieces the user wants. It merely adds r,g,and b to get the brightness, and throws color information away. It is good for areas of different brightness, but fails for areas of similar brightness but different color.
Color does a color quantization, and scans for each color.
Mono does the same as color, and merely removes the hue from the indexed palette after quantization. It is like a convenience tool, so that a user who wants a grayscale set of paths does not need to use 'Color' then the Fill-stroke tool to remove the colors. It is quite different from brightness, actually. They do look similar from a distance, but very different up close. It is like the difference between an old b&w movie, and a color movie showing a scene in b&w. You can tell the difference.
- Import this image (b/w jpeg):
http://www.livejournal.com/userpic/569297/360079
and trace it: multiscan, monochrome, 8 colors. Results are quite good. Now do it again at 9 colors - the result becomes much worse and flatter, as if you reduced the number of colors, not increased it. Then try 10, 11, etc colors: the color resolution does not improve, but the trace becomes darker and darker. After 12 it brightens up again and later starts behaving unpredictably. At 16 colors, each click on Preview gives a different preview image (does not happen at 8 colors). Doing the same in color is similar: the best result is at 8 colors, then starts darkening and degradation, then some wild colors appear. I think this is some bug in the algorithm.
I think that the darkness is caused by the default transparency of 75%, making the deeper multi-traces darker. I'll try "fill-opacity:1.0", as suggested by mental.
I'll look for any bugs you mentioned. It should be threadsafe. There is no static data. Intermediate data is all thrown away.
Also, keep in mind that octree reductions might not have satisfactory solutions for some color subsets. To get the number of colors desired, a complete octree reduction is performed, and then it is pruned to the best N colors. Then the pixels in the image are each adusted to the closest color in the palette. So each N set of colors can have a very different result.
Things to do:
- Since "color" and "monochrome" are in the same radio button group as
all the other scanning methods, they should be stacked vertically to align with them.
I'd like to not waste too much space, and I wanted to make it clear that they are all similar. But how about this? Instead of: ()Brightness (o)Color ()Mono Colors:[8.0] [x]Smooth [x]Stack
... how about this?
()Brightness [x]Smooth (o)Color [x]Stack ()Mono Colors:[8.0]
- Please add tooltips to all widgets in the dialog.
Okay. Any easter eggs? ;-)
- Please fill in the release note on this feature
- Please prepare a large detailed screenshot with comments, to be
added to the site.
I'll try tomorrow, when I can get to a monitor as large as the ones you guys apparently have. ^^
Bob

bulia byak wrote:
Things to do:
- Since "color" and "monochrome" are in the same radio button group as
all the other scanning methods, they should be stacked vertically to align with them.
Done.
- Please add tooltips to all widgets in the dialog.
Done.
- Please fill in the release note on this feature
Done. I also noticed 'scripting'. I will add info there now that I am ready to resume working on it.
- Please prepare a large detailed screenshot with comments, to be
added to the site.
Working on it, but my favorite pr0n site is busy right now. ;-)
Bob

It seems to do fairly well with simple images, but complex ones have a "Potrace problem". What I mean is that since Potrace traced an estimate around each region, the reassembled curves do not exactly tile together again. You might need a background shade or something to keep the white background from peeking through.
But give it a try. It should be a bit of fun.
If anyone can think of a good general algorithm for stitching together two adjacent curves, give it a try.
Is it possible to "average" the path edges together? (using the result to create edge paths for both objects to get a seamless look)
Or to just use an duplicate edge from a neighbor path? Which if done right, could theoretically cut down on tracing time since it would just use existing paths to create new objects vs tracing new ones.
My guess is that it's probably not possible due to how potrace works, but hey... I figured I throw it out there anyway.
Just a thought...
-Josh

Bob Jamison <rjamison@...357...> writes:
Today I finally got an initial (very rough) ability to scan an image multiple times, and produce multiple paths.
These examples look very cool.
I think this could be very useful for creating vector maps from data like http://www.demis.nl/mapserver/mapper.asp (this data is free enough (http://de.wikipedia.org/wiki/Bild:Demis_Best%C3%A4tigung.gif) to be used in e.g. Wikipedia).
Would you mind trying this one some map?
Cheers, Colin
participants (4)
-
Bob Jamison
-
bulia byak
-
Colin Marquardt
-
Joshua A. Andler