Quantization algorithm currently used by ImageMagick posterizes images unnecessarily, doesn't support alpha transparency, and is slower than quantizers of comparable quality (like the 15-bit mediancut from libjpeg).
Comparison with pngquant based on this image:
ImageMagick:
data:image/s3,"s3://crabby-images/54ace/54ace5b146cb8ef2bcf559a8acb85aac2b2aa2db" alt="Image"
data:image/s3,"s3://crabby-images/9f16b/9f16bb9d9adc7e30408c479d3aef3bd74a364c79" alt="Image"
Both have essentially the same file size, took about the same time to generate (0.6/0.7s), but pngquant version is visibly less posterized and even had lots colors to spare for semitransparencies of the shadow.
Images above are without dithering, because in this particular case ImageMagick produces malformed image when dithering is on. Another comparison:
ImageMagick:
data:image/s3,"s3://crabby-images/61b67/61b67bc14a3cd5b1108f2b127b212640a50b77cb" alt="Image"
data:image/s3,"s3://crabby-images/b553b/b553b84c19cb3e9c925f4d8f4cbca22d7aab5b4f" alt="Image"
Note that the first image is quite noisy (especially in dark areas) and brightest points on the yellow ball are remapped incorrectly.
So overall I think switch to pngquant's quantization and remapping would be a significant quality improvement without loss of speed or file sizes. pngquant also has fast-and-rough speed setting that is 2.5 to 6 times faster than ImageMagick's current algorithm while still mostly winning in quality.
Would you be interested in adopting the library?
It's written in C99, doesn't have any dependencies, less than 60KB compiled. Optionally supports OpenMP and SSE optimizations. It's successfully integrated with LibGD already.
More info/documentation: http://pngquant.org/lib/ and source.
From what I've gathered by looking at ImageMagick's source code is that currently ImageMagick supports generating palette from arbitrary number of images. The library can do that too, but I haven't added public API for it yet. I will if you're interested.