Jyrki Alakuijala، Ph.D., Google, Inc.
وینسنت راباود، دکترای گوگل، شرکت
آخرین به روز رسانی: 2017-08-01
چکیده - ما استفاده از منبع رمزگذار/رمزگشا WebP را با PNG در هر دو حالت بدون اتلاف و اتلاف مقایسه می کنیم. ما از مجموعه ای از 12000 تصویر شفاف PNG به طور تصادفی انتخاب شده از وب و اندازه گیری های ساده تر برای نشان دادن تغییرات در عملکرد استفاده می کنیم. ما PNG های موجود در مجموعه خود را مجددا فشرده کرده ایم تا تصاویر WebP را با PNG های بهینه شده با اندازه مقایسه کنیم. در نتایج ما نشان میدهیم که WebP جایگزین خوبی برای PNG برای استفاده در وب از نظر اندازه و سرعت پردازش است.
معرفی
WebP از تصاویر بدون اتلاف و شفاف پشتیبانی می کند و آن را جایگزین فرمت PNG می کند. بسیاری از تکنیک های اساسی مورد استفاده در فشرده سازی PNG، مانند کدگذاری فرهنگ لغت، کدگذاری هافمن و تبدیل نمایه سازی رنگ در WebP نیز پشتیبانی می شوند که در بدترین حالت منجر به سرعت و تراکم فشرده سازی مشابه می شود. در عین حال، تعدادی از ویژگیهای جدید - مانند کدهای آنتروپی مجزا برای کانالهای رنگی مختلف، محل دوبعدی فاصلههای مرجع معکوس، و حافظه پنهان رنگی از رنگهای اخیراً استفاده شده - باعث افزایش تراکم فشردهسازی در بیشتر تصاویر میشود.
در این کار، ما عملکرد WebP را با PNG هایی که با استفاده از pngcrush و ZopfliPNG بسیار فشرده شده اند مقایسه می کنیم. ما مجموعه مرجع تصاویر وب خود را با استفاده از بهترین شیوهها مجدداً فشرده کردیم و فشردهسازی WebP بدون اتلاف و اتلاف را با این مجموعه مقایسه کردیم. علاوه بر پیکره مرجع، ما دو تصویر بزرگتر، یکی عکاسی و دیگری گرافیکی را برای محک زدن سرعت و استفاده از حافظه انتخاب کردیم.
سرعت رمزگشایی سریعتر از PNG نشان داده شده است و همچنین فشرده سازی 23٪ متراکم تر از آنچه می توان با استفاده از فرمت PNG امروزی بدست آورد. نتیجه می گیریم که WebP جایگزین کارآمدتری برای فرمت تصویر PNG امروزی است. علاوه بر این، فشرده سازی تصویر با اتلاف با پشتیبانی آلفای بدون اتلاف، امکانات بیشتری را در سرعت بخشیدن به وب سایت ها می دهد.
مواد و روش ها
ابزارهای خط فرمان
ما از ابزارهای خط فرمان زیر برای اندازه گیری عملکرد استفاده می کنیم:
cwebp و dwebp. این ابزارها که بخشی از کتابخانه libwebp هستند (کامپایل شده از head).
تبدیل. این یک ابزار خط فرمان بخشی از نرم افزار ImageMagick است (6.7.7-10 2017-07-21).
pngcrush 1.8.12 (30 ژوئیه 2017)
ZopfliPNG (17 ژوئیه 2017)
ما از ابزارهای خط فرمان با پرچم های کنترل مربوطه استفاده می کنیم. به عنوان مثال، اگر به cwebp -q 1 -m 0 اشاره کنیم، به این معنی است که ابزار cwebp با پرچم -q 1 و -m 0 برانگیخته شده است.
م��موعه تصویر
سه مجموعه انتخاب شدند:
یک تصویر عکاسی واحد (شکل 1)،
یک تصویر گرافیکی واحد با شفافیت (شکل 2)، و
یک مجموعه وب: 12000 تصویر PNG به طور تصادفی انتخاب شده با شفافیت یا غیر شفاف، از اینترنت خزیده شده است. این تصاویر PNG از طریق تبدیل، pngcrush، ZopfliPNG بهینه شده اند و کوچکترین نسخه هر تصویر برای مطالعه در نظر گرفته شده است.
شکل 1. تصویر عکاسی، 1024 x 752 پیکسل. Fire breathing "Jaipur Maharaja Brass Band" Chassepierre Belgium, نویسنده: Luc Viatour, Photo دارای مجوز Creative Commons Attribution-Share Alike 3.0 Unported. وب سایت نویسنده اینجاست .
شکل 2. تصویر گرافیکی، 1024 x 752 پیکسل. تصاویر کلاژ از ابزار نمودار گوگل
برای اندازه گیری توانایی کامل فرمت موجود، PNG، همه این تصاویر اصلی PNG را با استفاده از چندین روش فشرده سازی کرده ایم:
گیره به 8 بیت در هر جزء: تبدیل input.png -depth 8 output.png
ImageMagick(1) بدون پیش بینی: تبدیل input.png -کیفیت 90 output-candidate.png
ImageMagick با پیش بینی کننده های تطبیقی: تبدیل input.png -کیفیت 95 output-candidate.png
Pngcrush(2): pngcrush -brute -rem tEXt -rem tIME -rem iTXt -rem zTXt -rem gAMA -rem cHRM -rem iCCP -rem sRGB -rem alla -rem text input.png output-candidate.png
ZopfliPNG(3): zopflipng --lossy_transparent input.png output-candidate.png
ZopfliPNG با همه فیلترها: zopflipng --iterations=500 --filters=01234mepb --lossy_8bit --lossy_transparent input.png output-candidate.png
نتایج
ما چگالی فشردهسازی را برای هر یک از تصاویر موجود در پیکره وب، نسبت به اندازههای تصویر PNG بهینهشده برای سه روش محاسبه کردیم:
WebPlessless (تنظیمات پیش فرض)
WebP بدون اتلاف با کوچکترین اندازه (-m 6 -q 100)
بهترین WebP بی ضرر و WebP با اتلاف با آلفا (تنظیمات پیش فرض).
ما این فاکتورهای فشرده سازی را مرتب کردیم و آنها را در شکل 3 ترسیم کردیم.
شکل 3. چگالی فشرده سازی PNG به عنوان مرجع، در 1.0 استفاده می شود. همین تصاویر با استفاده از دو روش بدون اتلاف و اتلاف فشرده می شوند. برای هر تصویر، نسبت اندازه به PNG فشرده محاسبه میشود و نسبتهای اندازه مرتب میشوند و برای فشردهسازی بدون تلفات و فشردهسازی با اتلاف نشان داده میشوند. برای منحنی فشرده سازی با اتلاف، فشرده سازی بدون تلفات در مواردی انتخاب می شود که تصویر WebP کوچکتری تولید می کند.
WebP از تراکم فشرده سازی PNG برای هر دو libpng در حداکثر کیفیت (تبدیل) و همچنین ZopfliPNG (جدول 1) فراتر می رود، با سرعت های رمزگذاری (جدول 2) و رمزگشایی (جدول 3) تقریباً با سرعت های PNG قابل مقایسه است.
جدول 1. میانگین بیت در هر پیکسل برای سه مجموعه با استفاده از روش های مختلف فشرده سازی.
مجموعه تصویر | تبدیل با کیفیت 95 | ZopfliPNG | WebP بدون اتلاف -q 0 -m 1 | WebPlessless (تنظیمات پیش فرض) | WebP بدون ضرر -m 6 -q 100 | WebP از دست رفته با آلفا |
---|---|---|---|---|---|---|
عکس | 12.3 | 12.2 | 10.5 | 10.1 | 9.83 | 0.81 |
گرافیکی | 1.36 | 1.05 | 0.88 | 0.71 | 0.70 | 0.51 |
وب | 6.85 | 5.05 | 4.42 | 4.04 | 3.96 | 1.92 |
جدول 2. میانگین زمان رمزگذاری برای پیکره های فشرده سازی و برای روش های مختلف فشرده سازی.
مجموعه تصویر | تبدیل با کیفیت 95 | ZopfliPNG | WebP بدون اتلاف -q 0 -m 1 | WebPlessless (تنظیمات پیش فرض) | WebP بدون ضرر -m 6 -q 100 | WebP از دست رفته با آلفا |
---|---|---|---|---|---|---|
عکس | 0.500 ثانیه | 8.7 ثانیه | 0.293 ثانیه | 0.780 ثانیه | 8.440 ثانیه | 0.111 ثانیه |
گرافیکی | 0.179 ثانیه | 14.0 ثانیه | 0.065 ثانیه | 0.140 ثانیه | 3.510 ثانیه | 0.184 ثانیه |
وب | 0.040 ثانیه | 1.55 ثانیه | 0.017 ثانیه | 0.072 ثانیه | 2.454 ثانیه | 0.020 ثانیه |
جدول 3. میانگین زمان رمزگشایی برای سه مجموعه برای فایل های تصویری که با روش ها و تنظیمات مختلف فشرده شده اند.
مجموعه تصویر | تبدیل با کیفیت 95 | ZopfliPNG | WebP بدون اتلاف -q 0 -m 1 | WebPlessless (تنظیمات پیش فرض) | WebP بدون ضرر -m 6 -q 100 | WebP از دست رفته با آلفا |
---|---|---|---|---|---|---|
عکس | 0.027 ثانیه | 0.026 ثانیه | 0.027 ثانیه | 0.026 ثانیه | 0.027 | 0.012 ثانیه |
گرافیک | 0.049 ثانیه | 0.015 ثانیه | 0.005 ثانیه | 0.005 ثانیه | 0.003 | 0.010 ثانیه |
وب | 0.007 ثانیه | 0.005 ثانیه | 0.003 ثانیه | 0.003 ثانیه | 0.003 | 0.003 ثانیه |
پروفایل سازی حافظه
برای پروفایل حافظه، ما حداکثر اندازه مجموعه مقیم را که توسط /usr/bin/time -v گزارش شده است، ثبت کردیم.
برای پیکره وب، اندازه بزرگترین تصویر به تنهایی حداکثر استفاده از حافظه را مشخص می کند. برای اینکه اندازه گیری حافظه را بهتر تعریف کنیم، از یک تصویر عکاسی منفرد (شکل 1) برای ارائه یک نمای کلی از استفاده از حافظه استفاده می کنیم. تصویر گرافیکی نتایج مشابهی به دست می دهد.
ما 10 تا 19 مگابایت برای libpng و ZopfliPNG، و 25 مگابایت و 32 مگابایت برای رمزگذاری بدون اتلاف WebP در تنظیمات -q 0 -m 1 و -q 95 (با مقدار پیشفرض -m) به ترتیب اندازهگیری کردیم.
در آزمایش رمزگشایی، convert -resize 1x1 از 10 مگابایت برای فایلهای PNG تولید شده توسط libpng و ZopfliPNG استفاده میکند. با استفاده از cwebp، رمزگشایی بدون تلفات WebP از 7 مگابایت و رمزگشایی با اتلاف 3 مگابایت استفاده می کند.
نتیجه گیری
ما نشان دادهایم که هر دو سرعت رمزگذاری و رمزگشایی در همان دامنه سرعت PNG هستند. افزایش استفاده از حافظه در طول مرحله رمزگذاری وجود دارد، اما مرحله رمزگشایی کاه�� سالمی را نشان میدهد، حداقل زمانی که رفتار cwebp را با تبدیل ImageMagick مقایسه میکنیم.
تراکم فشرده سازی برای بیش از 99 درصد از تصاویر وب بهتر است، که نشان می دهد می توان نسبتاً به راحتی از PNG به WebP تغییر کرد.
وقتی WebP با تنظیمات پیشفرض اجرا میشود، 42 درصد بهتر از libpng و 23 درصد بهتر از ZopfliPNG فشرده میشود. این نشان می دهد که WebP برای سرعت بخشیدن به وب سایت های سنگین تصویر امیدوار کننده است.
منابع
لینک های خارجی
موارد زیر مطالعات مستقلی هستند که توسط Google حمایت نمیشوند و گوگل لزوماً پشت صحت همه محتویات آنها نمیایستد.