میهن بلاکچین
  • اخبار
    • همه
    • رمزارز در ایران
    • اخبار بیت کوین
    • اخبار اتریوم
    • اخبار آلتکوین
    • اخبار بلاکچین
    • اخبار عمومی
    • اطلاعیه صرافی‌های داخلی
  • تحلیل
    • همه
    • تحلیل آنچین
    • تحلیل اقتصادی
    • تحلیل تکنیکال
    • تحلیل فاندامنتال
  • آموزش
    • همه
    • کریپتو پدیا
    • کریپتو کده
    • دیفای
    • سرمایه گذاری
    • آموزش همه صرافی های ارز دیجیتال
    • ترید
    • کیف پول
    • بازی
    • استخراج
    • NFT
    • مقالات عمومی
  • ایردراپ
  • هک و کلاهبرداری
  • قیمت ارزهای دیجیتال
  • ماشین حساب ارزهای دیجیتال
  • مقایسه قیمت در صرافی
No Result
مشاهده همه‌ی نتایج
  • اخبار
    • همه
    • رمزارز در ایران
    • اخبار بیت کوین
    • اخبار اتریوم
    • اخبار آلتکوین
    • اخبار بلاکچین
    • اخبار عمومی
    • اطلاعیه صرافی‌های داخلی
  • تحلیل
    • همه
    • تحلیل آنچین
    • تحلیل اقتصادی
    • تحلیل تکنیکال
    • تحلیل فاندامنتال
  • آموزش
    • همه
    • کریپتو پدیا
    • کریپتو کده
    • دیفای
    • سرمایه گذاری
    • آموزش همه صرافی های ارز دیجیتال
    • ترید
    • کیف پول
    • بازی
    • استخراج
    • NFT
    • مقالات عمومی
  • ایردراپ
  • هک و کلاهبرداری
  • قیمت ارزهای دیجیتال
  • ماشین حساب ارزهای دیجیتال
  • مقایسه قیمت در صرافی
No Result
مشاهده همه‌ی نتایج
میهن بلاکچین
No Result
مشاهده همه‌ی نتایج
میهن بلاکچین آموزش مقالات عمومی

کریپتو با ویتالیک؛ چگونه به کمک چندجمله‌‌ای‌ها گواه ZK-STARK بسازیم؟

نگارش:‌علی شعبانی
28 فروردین 1401 - 22:01
در مقالات عمومی
زمان مطالعه: 4 دقیقه
0
کریپتو با ویتالیک؛ چگونه به کمک چندجمله‌‌ای‌ها گواه STARK بسازیم؟

ویتالیک بوترین، خالق اتریوم و یکی از چهره‌های تاثیرگذار دنیای ارزهای دیجیتال است. بلاگ شخصی او، تاریخچه‌ای از پیشرفت‌های صورت گرفته در دنیای بلاک چین است. از این رو در میهن بلاکچین بر آن شدیم تا با ترجمه مطالب بوترین، خوانندگان محترم را با سیر پیشرفت تئوری این حوزه آشنا کنیم. مطلبی که در ادامه خواهید خواند، در ۹ نوامبر ۲۰۱۷ در وبسایت شخصی بوترین منتشر شده است. ویتالیک در این مطلب، شرحی بر نحوه کار ZK-STARKها که در آن زمان در ابتدای راه خود بودند، ارائه می‌دهد. برای آشنایی با مفاهیم اشاره شده در این مطلب، نوشته‌های زیر می‌تواند راهگشا باشد:

کریپتو با ویتالیک؛ همه‌چیز در مورد برنامه‌ حسابی درجه دوم (QAP)
کریپتو با ویتالیک؛ بررسی زوج‌‌ سازی منحنی بیضوی
کریپتو با ویتالیک؛ zk-SNARK چگونه کار می‌کند؟

آنچه در این مطلب می‌خوانید

Toggle
  • ZK-STARK چیست و چه تفاوتی با ZK-SNARK دارد؟
  • نحوه ساخت گواه ZK-STARK
  • مثالی ساده از اثبات به کمک چندجمله‌ای‌ها
  • گسترش این روش
  • جمع‌بندی

ZK-STARK چیست و چه تفاوتی با ZK-SNARK دارد؟

امیدوارم که افراد بیشتری حالا با ZK-SNARKها آشنا شده باشند؛ تکنولوژی همه‌منظوره و موجز بی‌نیاز به دانشی که می‌تواند برای انواع و اقسام کاربردها، از محاسبات قابل تایید گرفته تا پرایوسی کوین‌ها به کار رود. چیزی که ممکن است از آن اطلاع نداشته باشید، عموزاده این فناوری است: ZK-STARK. حرف T در این کلمه مخفف کلمه شفاف (Transparent) است. این فانوری یکی از ضعف‌های اساسی اسنارک‌ها را برطرف کرده است. ضعفی که مربوط به «راه‌اندازی اولیه نیازمند اعتماد – Trusted Setup» این تکنولوژی است. همچنین استارک‌ها فروض رمزنگاری بسیار ساده‌تری دارند که نیاز به منحنی‌های بیضوی، زوج‌سازی و فرض دانش توان (Knowledge of Exponent) را برطرف می‌کند و در عوض تنها بر هش‌ها و نظریه اطلاعات استوار است. به طور خلاصه این بدین معنی است که این روش حتی در برابر پردازش کوانتومی نیز مقاوم است.

بررسی دنیای راهکارهای اثبات بی‌نیاز به دانش

اما این مزایا بی‌هزینه نیست: حجم گواه از ۲۸۸ بایت به چندصد کیلوبایت افزایش پیدا می‌کند. برخی اوقات این هزینه مازاد ارزشش را ندارد اما در برخی دیگر از مواقع، به خصوص در مورد بلاک چین‌های عمومی که نیاز به حداقل‌سازی اعتماد بالاست، ارزشش را خواهد داشت. به ویژه اگر زمانی سازوکار منحنی‌های بیضوی روزی بشکند یا کامپیوترهای کوانتومی به حقیقت بپیوندند.

نحوه ساخت گواه ZK-STARK

با بیان این مقدمه، حال بررسی کنیم که این نوع دیگر از گواه بی‌نیاز به دانش چگونه کار می‌کند؛ ابتدا بیایید مرور کنیم که یک گواه بی‌نیاز از دانش همه‌منظوره موجز چگونه کار می‌کند. فرض کنید که تابعی عمومی به نام f، ورودی خصوصی x و ورودی عمومی y را داریم. می‌خواهید ثابت کنید که x را می‌دانید به نحوی که f(x) = y، بی آن که مقدار x را افشا کنید.علاوه بر آن، برای این که گواه شما موجز باشد، باید آن را به نحوی قابل تایید و صحت‌سنجی کنید که انجام این عمل کوتاه‌تر از محاسبه f به طول انجامد.

اصول کار گواه اثبات بی‌نیاز به دانش

بیایید چند مثال را مرور کنیم:

  • f محاسباتی است که انجام در کامپیوتر خانگی حدود دو هفته طول می‌کشد اما می‌توان آن را به کمک دیتا سنترها طی دو ساعت انجام داد. شما محاسبات (کد اجرای f) را برای دیتا سنتر می‌فرستید، دیتا سنتر آن را اجرا می‌کند و نتیجه (y) را به همراه گواه به شما بازمی‌گرداند. شما نتیجه را تنها در عرض چند میلی‌ثانیه صحت‌سنجی می‌کنید و اطمینان حاصل می‌‌کنید که به راستی y جواب درست است.
  • شما تراکنش رمزشده‌ای به فرم «X1 موجودی سابق من، X2 موجودی سابق شما، X3 موجودی جدید من و X4 موجودی جدید شما» دارید. می‌خواهید گواهی ایجاد کنید که این تراکنش صحیح است (به طور مشخص به نحوی که ثابت کند موجودی‌های جدید و قدیم همگی مثبت هستند و کاهش موجودی یک طرف برابر با افزایش موجودی طرف دیگر است). x در اینجا می‌تواند یک زوج کلید رمزنگاری و f تابعی باشد که مقادیر تراکنش را گرفته، تراکنش را رمزگشایی کرده، بررسی را انجام داده و در صورت صحت عدد ۱ و در صورت وجود مشکل عدد صفر را بازگرداند. y در اینجا قاعدتا باید ۱ باشد.
  • بلاک چینی همچون شبکه اتریوم دارید و می‌خواهید واپسین بلوک را دانلود کنید. گواهی نیاز دارید که ثابت کند این بلوک معتبر و آخرین بلوک زنجیره‌ای است که تمام بلوک‌های آن معتبر هستند. از یک فول نود درخواست چنین گواهی می‌کنید. x در اینجا تمامی بلاک چین و f تابعی است که آن را بلوک به بلوک پردازش کرده و اعتبار آن را می‌سنجد و خروجی آن هش آخرین بلوک است. بنابراین در اینجا y باید برابر با هش بلوکی باشد که دانلود کرده‌اید.
«می‌تونی به من اعتماد کنی، این تراکنش معتبره اما دلیلشو بهت نمی‌گم!»

پس قسمت مشکل این ماجرا در کجاست؟ به نظر می‌رسد که اطمینان بخشی از طریق ارائه گواه اثبات بی‌نیاز به دانش چندان مشکل نیست؛ راه‌های مختلفی برای تبدیل هر نوع محاسباتی به شکلی همچون مساله گراف سه رنگ وجود دارد، به نحوی که رنگ‌آمیزی گراف با سه رنگ مترادف با جواب مساله اصلی باشد. سپس از پروتکل سنتی گواه بی‌نیاز به دانش برای اثبات اینکه رنگ‌آمیزی صحیحی داریم – بدون افشای آن – استفاده خواهیم کرد. این مطلب عالی از متیو گرین (Matthew Green) که در سال ۲۰۱۴ نوشته شده است، این مطلب را با جزییات تشریح می‌کند.

قسمت پیچیده‌تر ماجرا، ارائه گواهی موجز و مختصر است. اگر بخواهیم شهودی بگوییم، اثبات چیزی در خصوص اختصار محاسبات مشکل است چرا که محاسبات مفهومی به شدت شکننده است. اگر محاسبه سخت و طلانی داشته باشید که تنها با تغییر یک بیت، نتیجه کلی عوض شود، ایجاد نمونه رد محاسباتی تصادفی که بتوان اعتبار آن را ثابت کرد، بسیار مشکل می‌شود. اما خوشبختانه به کمک ریاضیات پیشرفته، می‌توان این کار را انجام داد.

تفسیر عمومی و سطح بالای این مساله این است که پروتکل‌ها به کمک ریاضیاتی مشابه آن چه در کدگذاری پاک کردن (Erasure Coding – EC) استفاده می‌شود، این کار را انجام می‌دهند. EC برای تحمل‌پذیری خطا در داده‌ها به کار می‌رود. اگر مقداری داده در اختیار داشته باشید و آن را به شکل یک خط کد کنید، آن گاه می‌توانید چهار نقطه بر روی خط برگزینید. هر دو نقطه از آن چهار نقطه برای بازسازی مجدد خط کافی است (به کمک معادله خط) و در نتیجه می‌تواند به شما مختصات آن دو نقطه دیگر را بدهد. اگر کوچکترین تغییری در داده‌ ایجاد نمایید، آن گاه حداقل سه نقطه از آن چهار نقطه تضمین شده است. همچنین می‌توانید داده را به شکل یک چندجمله‌ای درجه ۱۰۰۰۰۰۰ کدگذاری کنید و دو میلیون نقطه بر روی چندجمله‌ای برگزینید؛ در این صورت هر ۱۰۰۰۰۰۱ نقاط از آن نقطه‌ها می‌تواند داده‌های اصلی (و در نتیجه دیگر نقاط) را بازسازی کند و هر تغییری در داده‌ اصلی سبب تغییر حداقل ۱۰۰۰۰۰۰ نقطه می‌شود. الگوریتم‌هایی که در اینجا به نمایش درخواهند آمد، از چندجمله‌ای‌ها برای تقویت خطا (Error Amplification) استفاده گسترده‌ای می‌نمایند.

تغییر جزیی در داده‌های اصلی سبب تغییرات گسترده در شیب چندجمله‌ای می‌شود
تغییر جزیی در داده‌های اصلی سبب تغییرات گسترده در شیب چندجمله‌ای می‌شود

مثالی ساده از اثبات به کمک چندجمله‌ای‌ها

فرض کنید که می‌خواهید اثبات کنید که چندجمله‌ای P را دارید به نحوی که P(x) دارای جوابی به فرم عدد صحیح بین ۰ تا ۹ برای xهای بین ۱ تا ۱ میلیون است. این نمونه‌ای نسبتا ساده از فرایندی به نام بررسی برد (Range Checking) است؛ می‌توانید یکی از کاربردهای چنین فرایندی را برای صحت‌سنجی و تایید مثبت بودن موجودی حساب‌ها پس از انجام تراکنش در نظر بگیرید. اگر بررسی برای جواب‌های ۱ تا ۹ باشد، می‌توان آن را بررسی جواب‌های صحیح یک جدول سودوکو در نظر گرفت.

راه سنتی این اثبات این است که تمامی یک میلیون نقطه را رسم کنیم و با بررسی مقادیر برد، ثابت کنیم که در محدوده قرار دارد. اما هدف ما ایجاد گواهی است که بتوانیم اعتبار آن را در کمتر از یک میلیون گام بررسی کنیم. بررسی تصادفی مقادیر P فایده‌ای نخواهد داشت: جرا که همواره احتمال این وجود دارد که یک اثبات‌کننده متخاصم یک جواب برای P ارائه کند که در ۹۹۹۹۹۹ حالت، شرط را به درستی ارضا کند اما در یک مورد نادرست باشد. نمونه‌برداری تصادفی چند مقدار، تقریبا همیشه این یک مقدار نادرست را شناسایی نخواهد کرد. حال چه باید کنیم؟

برد تابع ما باید در این محدوده باشد
برد تابع ما باید در این محدوده باشد

بیایید مساله را با تبدیل ریاضی تغییر دهیم. فرض کنید C(x) چندجمله‌ای بررسی قیود باشد؛ این چندجمله‌ای اگر x بین صفر تا ۹ باشد جواب صفر و در غیراین صورت غیرصفر خواهد بود. راه ساده‌ای برای ساخت این چندجمله‌ای وجود دارد. فرض می‌کنیم که تمامی چندجمله‌ای‌های ما و دیگر مقادیر، اعداد صحیح هستند و نیازی نیست که در خصوص اعداد مابین نگران باشیم. خواهیم داشت:

C(x):x.(x-1)(x-2)…(x-9)
نمودار چندجمله‌ای محدودیتی که ساخته‌ایم
نمودار چندجمله‌ای محدودیتی که ساخته‌ایم

حال مساله بدل به این می‌شود: ثابت کنید که P را می‌دانید بدین ترتیب که برای همه xهای بین ۱ تا ۱۰۰۰۰۰۰، C(P(x)) = 0. حال Z(x) = (x-1)(x-2)…(x-1000000) تعریف می‌کنیم. اصل شناخته‌شده ریاضی‌ای وجود دارد که هر چندجمله‌ای که در تمامی xهای بین ۱ تا ۱۰۰۰۰۰۰ صفر باشد، باید مضربی از Z(x) باشد. بنابراین می‌توانیم دوباره مساله را تبدیل کنیم: ثابت کنید که از مقدار P و D اطلاع دارید با این شرط که C(P(x)) = Z(x).D(x) باشد (برای تمامی مقادیر x). توجه داشته باشید که اگر شما C(P(x)) مناسبی بشناسید، تقسیم آن بر Z(x) برای محاسبه D(x) چندان مشکل نیست؛ برای این کار می‌توانید از تقسیم چندجمله‌ای بلند یا از الگوریتمی بهتر همچون تبدیل فوریه سریع استفاده کنید. این گونه ما ادعای اولیه خود را به چیزی که از لحاظ ریاضی مرتب و اثبات آن نسبتا آسان است تبدیل کردیم.

حال چگونه می‌توان این ادعا را اثبات کرد؟ می‌توانیم فرایند اثبات را یک پروسه ارتباط سه مرحله‌ای بین اثبات‌کننده (Prover) و اعتبارسنج (Verifier) ببینیم: اثبات‌کننده مقداری اطلاعات می‌فرستد، سپس اعتبارسنج چند درخواست بازمی‌گرداند، در نهایت اثبات‌کننده اطلاعات بیشتری می‌فرستد. ابتدا اثبات‌کننده یک درخت مرکل از ارزیابی مقادیر P(x) و D(x) برای xهای بین ۱ تا ۱ میلیارد (بله، میلیارد و نه میلیون) و هش ریشه آن می‌سازد و برای اعتبارسنج می‌فرستد. این جواب‌‌ها شامل یک میلیون نقطه‌ای که P(x) بین صفر تا ۹ است به علاوه ۹۹۹ میلیون نقطه دیگر که احتمالا در این شرط نمی‌گنجند است.

یک میلیون نقطه مدنظر در کنار ۹۹۹ میلیون نقطه دیگر در درخت مرکل
یک میلیون نقطه مدنظر در کنار ۹۹۹ میلیون نقطه دیگر در درخت مرکل

فرض می‌کنیم که اعتبارسنج جواب تمامی بررسی Z(x) در تمامی این نقاط را می‌داند؛ تابع Z(x) همانند کلید عمومی اعتبارسنجی برای این روش است که تمامی افراد باید از قبل بدانند (کلاینت‌هایی که توان ذخیره‌ئازی تمامی Z(x) را ندارند می‌توانند ریشه مرکل Z(x) را ذخیره کنند و از اثبات‌کننده بخواهند تا شاخه Z(x) مدنظر اعتبارسنج را فراهم آورد؛ همچنین به روشی متفاوت، چندین میدان عددی بر Z(x) وجود دارد که xای مشخص را می‌توان به راحتی محاسبه کرد). پس از دریافت تعهد (=ریشه مرکل)، اعتبارسنج سپس ۱۶ مقدار تصادفی x بین ۱ تا ۱ میلیارد را انتخاب می‌کند و از اثبات‌کننده می‌خواهد تا شاخه مرکل P(x) و D(x) را فراهم آورد. اثبات‌کننده این مقادیر را تهیه می‌‌کند. اعتبارسنج سپس بررسی می‌کند که الف) این شاخه‌ها با هش ریشه که پیش‌تر ارائه شده بود مطابقت داشته باشد و ب) C(P(x)) برابر با Z(x).D(x) در تمامی ۱۶ نقطه باشد.

می‌دانیم که این گواه از نظر ریاضی کامل (Perfect Completeness) است – بدین معنی که اگر شما P(x) مناسبی سراغ داشته باشید،‌آن گاه می‌توانید با محاسبه D(x) و ساخت گواه به شکل صحیح، از بررسی ۱۶ نقطه سربلند بیرون آیید. اما صحت یا استواری (Soundness) جواب چه؟ – بدین معنی که اگر یک اثبات‌کننده متخاصم تابع P(x) نادرستی ارائه کند، حداقل احتمالی که شناسایی خواهد شد چقدر است؟ می‌توانیم این گونه بررسی کنیم. از آن جا که C(P(x)) یک چندجمله‌ای درجه دهم است که با چندجمله‌ای درجه ۱۰۰۰۰۰۰ ساخته شده است، حداقل درجه آن ده میلیون خواهد بود.به صورت کلی می‌دانیم که دو چندجمله‌ای متفاوت با درجه N یکسان، حداکثر در N نقطه با یکدیگر یکسان هستند: بنابراین بنابراین یک چندجمله‌ای درجه ده میلیون که با هیچ چندجمله‌ای که برابر با Z(x).D(x) برای برخی از xها باشد، برابر نباشد در حداقل ۹۹۰ میلیون نقطه با آن‌ها اختلاف خواهد داشت. بنابراین احتمال اینکه یک P(x) نادرست تنها در یک بار آزمون رد شود ۹۹٪ است؛ با ۱۶ آزمون، احتمال شناسایی یک پاسخ نادرست به «یک منهای ۱۰ به توان منفی ۳۲» افزایش پیدا می‌کند. بنابراین احتمال شکست چنین روشی به اندازه احتمال شکست تابع هش خواهد بود.

در عمل چه کردیم؟ از چندجمله‌ای‌ها برای افزایش خطا در هر راه‌حل نادرستی بهره جستیم تا هر پاسخ نادرست برای مساله اصلی به جای آن که به یک میلیون بار بررسی برای کشف احتیاج داشته باشد، در همان آزمون اول به احتمال ۹۹ درصد بتواند پاسخ نادرست را شناسایی کند.

می‌توانیم سه گام شرح داده شده را به گواه غیرتعاملی (non-interactive proof) تبدیل کنیم؛ گواهی که می‌تواند توسط یک اثبات‌کننده تک ارسال شده و توسط همه صحت‌سنجی شود. برای این کار می‌توان از میان‌بر فیات-شمیر استفاده کرد. اثبات‌کننده در ابتدا درخت مرکلی از مقادیر P(x) و D(x) می‌سازد و سپس هش ریشه آن را محاسبه می‌کند. از این ریشه سپس به عنوان عامل آنتروپی استفاده می‌شود تا شاخه‌هایی از درخت که باید توسط اثبات‌کننده فراهم شود، تعیین شوند. اثبات‌کننده سپس ریشه مرکل و شاخه‌ها را همراه با گواه ارائه میدهد. تمامی محاسبات در سمت اثبیات‌کننده صورت می‌پذیرد: فرایند محاسبه ریشه مرکل از داده و سپس استفاده از آن برای انتخاب شاخه‌هایی که قرار است مورد وارسی قرار گیرند. از این رو نیاز به تعامل بین اثبات‌کننده و اعتبارسنج از بین می‌رود.

تنها کاری که یک عامل متخاصم بدون در اختیار داشتن P(x) صحیح می‌تواند انجام دهد، ساخت گواه به شکل پشت سرهم است تا بالاخره شانس به او رو کند. اما با احتمال صحت گفته شده، میلیاردها سال طول خواهد کشید تا بتواند گواهی نامعتبر ارائه دهد و قسر در رود.

مراحل انجام و ارائه گواه اثبات بی‌نیاز از دانش غیرتعاملی | نحوه ساخت گواه ZK-STARK
مراحل انجام و ارائه گواه اثبات بی‌نیاز از دانش غیرتعاملی

گسترش این روش

برای نمایش قدرت این تکنیک، بیایید از آن برای انجام کاری کمتر متداول استفاده کنیم: اثبات اینکه شما عدد یک میلیونیوم دنباله فیبوناچی را می‌دانید. برای نیل به این هدف، ثابت خواهیم کرد که از چندجمله‌ای P(x) که دربرگیرنده عدد xام دنباله فیبوناچی است، اطلاع داریم. در این مثال، دنباله چک‌کننده محدودیت ما در سه مختصات x در گذر خواهد بود:

C(x_1,x_2,x_3 )=x_3- x_2- x_1

توجه داشته باشید که اگر برای تمام xها، C(P(x), P(x+1), P(x+2)) = 0 باشد، آن‌گاه P(x) نماینده دنباله فیبوناچی است.

اثبات مقدار اندیس xام دنباله فیبوناچی
اثبات مقدار اندیس xام دنباله فیبوناچی

مساله را به شکل زیر می‌توان ترجمه کرد: ثابت کنید که P و D را می‌دانید به نحوی که C(P(x), P(x+1), P(x+2)) = Z(x).D(x) باشد. برای تمامی ۱۶ اندیسی که اعتبارسنج خواهد سنجید، اثبات‌کننده باید شاخه‌های مرکل را برای P(x)، P(x+1)، P(x+2) و D(x) فراهم آورد.اثبات‌کننده همچنین باید به شکلی مجزا، شاخه‌های مرکلی که نشان می‌دهد P(0) = P(1) = 0 را ارائه کند. جز این، باقی فرایند مشابه قبل است.

برای اینکه در دنیای واقعی از این روش استفاده کنیم دو مشکل وجود دارد که باید حل شوند. مشکل اول این است که اگر بخواهیم از اعداد حقیقی برای راه‌حل استفاده کنیم، پاسخ چندان بهینه نخواهد شد چرا که اعداد به سرعت بسیار بزرگ خواهند شد. برای مثال، عدد یک میلیونیوم دنباله فیبوناچی، ۲۰۸۹۸۸ رقم دارد. اگر بخواهیم در عمل به موجز بودن برسیم، به جای استفاده از چندجمله‌ای‌ها با اعداد حقیقی، باید از میادین متناهی – سیستمی عددی که از قوانین حسابی یکسانی که می‌شناسیم و دوست داریم همچون a ⋅ ( b + c ) = ( a ⋅ b ) + ( a ⋅ c ) و ( a 2 − b 2 ) = ( a − b ) ⋅ ( a + b ) تبعیت می‌کند اما هر عدد میزان مشخصی از فضا را اشغال میکند – استفاده کنیم. بدین شکل، اثبات ادعاییی در خصوص عدد یک میلیونیوم دنبال فیبوناچی نیازمند طراحی پیچیده‌تری است که از «حساب اعداد بزرگ» (Big Number Arithmetic) بر روی میادین متناهی سود می‌برد.

ساده‌ترین میدان متناهی ممکن، حساب پیمانه‌ای است. در این روش، هر نمونه‌ای از a + b را با مود (mod) a + b بر عدد اول N جایگزین می‌کنیم. همین کار را برای تفریق و ضرب نیز انجام می‌دهیم و برای تقسیم از وارون ضربی سود می‌جوییم. برای مثال اگر N هفت باشد، حاصل 3 + 4 برابر صفر، 2 + 6 = 1، 3 . 4 = 5، 4/2 = 2 و حاصل تقسیم ۵ بر ۲ برابر با ۶ خواهد شد.

ممکن است در اثبات «صحت» فوق، توجه کرده باشید که من یک از انواع حملات ممکن را پوشش ندادم: چه می‌شود اگر به جای P(x) درجه یک میلیون و D(x) درجه ۹ میلیون، عامل متخاصم مقادیری ارائه دهد که بر روی هیچ یک از این چندجمله‌ای‌های نسبتا درجه پایین نباشد؟ در این صورت، این استدلال که C(P(x)) نادرست باید متفاوت از هر C(P(x)) معتبر بر روی حداقل ۹۹۰ میلیون نقطه باشد، دیگر اعتباری نخواهد داشت. بنابراین حملات متفاوت و موثرتری قابل اجرا است. برای مثال، عامل متخاصم می‌تواند یک مقدار تصادفی p برای هر x تولید کند و سپس d = C(p)/Z(x) را محاسبه کند و این مقادیر را به جای P(x) و D(x) ارائه کند. این مقادیر بر روی هیچ‌کدام از چندجمله‌ای‌های درجه پایین نیست، اما همچنان از آزمون موفق بیرون خواهند آمد.

از این احتمال می‌توان به شکل موثر دفاع کرد، اما ابزار لازم برای چنین کاری پیچیده هستند و می‌توان گفت اکثر نوآوری ریاضی STARKها مربوط به این حوزه است. افزون بر این، راه‌حل محدودیتی پیدا خواهد کرد: می‌توانید پاسخ‌هایی که بسیار از هر چندجمله‌ای درجه یک میلیون، دور هستند را پاکسازی کنید (برای مثال، نیاز به تغییر ۲۰ درصد از کل مقادیر برای تبدیل آن به چندجمله‌ای درجه یک میلیون دارید)، اما نمی‌توانید پاسخ‌هایی را که از یک چندجمله‌ای تنها در یک یا دو مختصات متفاوت هستند، شناسایی کنید. بنابراین چیزی که این ابزارها مهیا می‌کنند گواه نزدیکی (Proof of Proximity) است – گواهی که اکثر نقاط P و D، متناظر با چندجمله‌ای صحیحی هستند.

می‌توان دزیافت که با وجود این مسائل، همچنان امنیتی کافی برای ارائه گواه وجود دارد، گرچه دو تغییر باید به وجود آید: ابتدا، در این حالت اعتبارسنج باید اندیس‌های بیشتری را وارسی کند تا خطایی که این محدودیت ایجاب می‌کند، را خنثی سازد. مورد دوم این است که اگر مقدار مرزی در مساله داریم و آن را مورد بررسی قرار می‌دهیم (برای مثال، P(0) = P(1) = 1 در مساله بالا)، آن گاه نه تنها باید ثابت کنیم که اکثر نقاط بر روی یک چندجمله‌ای هستند، بلکه باید مشخصا ثابت کنیم که آن دو نقطه خاص (یا به هر تعداد محدودیت مقدار مرزی که داشته باشیم) بر روی آن چندجمله‌ای هستند.

جمع‌بندی

ویتالیک بوترین در این مطلب مبانی گواه اثبات بی‌نیاز از دانش (ZK-STARK) را شرح می‌دهد و ما را با نحوه عمل این فناوری آشنا می‌کند. در این پروسه، به کمک چندجمله‌ای‌ها، میادین متناهی، مسائل بهینه‌سازی چندمتغیره و رمزنگاری، بی نیاز از افشای اطلاعات، می‌توانیم وجود/دانایی خود نسبت به آن را ثابت کنیم. این مطلب شماره نخست، از مقالات سه بخشی ویتالیک بوترین در این خصوص است. در هفته‌های آتی، با دو شماره دیگر با شما خواهیم بود.

آیا تاکنون از ZK‌ها در زندگی عادی خود استفاده کرده‌اید؟ آیا با رواج این فناوری، صحته ارزهای دیجیتال و زندگی عادی دستخوش تغییر خواهد شد؟

تگ: اتریومتکنولوژی بلاک چین
اشتراک‌گذاریتوئیت

نوشته‌های مشابه

فیچر رویدادهای کریپتویی هفته
تحلیل فاندامنتال

مهم‌ترین رویدادهای کریپتویی هفته آتی؛ هفته‌ای سرنوشت‌ساز برای ارزهای دیجیتال

28 اردیبهشت 1404 - 18:00
86
کمیسیون بورس و اوراق بهادار آمریکا ۱۱ نفر از بنیان‌گذاران شرکت فورسیج را به کلاهبرداری پانزی ۳۰۰ میلیون دلاری متهم کرد
تحلیل فاندامنتال

افشای تماس محرمانه دادستان‌ها با FinCEN؛ برگ برنده‌ای برای دفاع سامورایی ولت و تورنادوکش؟

28 اردیبهشت 1404 - 17:30
22
توکن آنلاک
تحلیل فاندامنتال

بررسی برنامه آزادسازی توکن پروژه‌های رمزارزی در هفته آینده؛ ۲۸ اردیبهشت ۱۴۰۴

28 اردیبهشت 1404 - 15:00
49
اخبار بلاکچین

حمله ۵۱ درصد به بیت‌ کوین ارزان‌تر از اتریوم است؛ مقایسه عملکرد امنیتی این دو شبکه

28 اردیبهشت 1404 - 13:00
78
فیچر تحلیل اتر و بیت
تحلیل تکنیکال

تحلیل تکنیکال قیمت بیت کوین (BTC) و اتریوم (ETH)؛ ۲۸ اردیبهشت ۱۴۰۴

28 اردیبهشت 1404 - 09:00
150
فیچر اتریوم
تحلیل بازار

سیگنال نادر اتریوم؛ رشد اتریوم و شروع آلت سیزن نزدیک است؟

27 اردیبهشت 1404 - 21:00
1447
اشتراک
اطلاع از
0 دیدگاه
جدید ترین
قدیمی ترین محبوب ترین
Inline Feedbacks
View all comments

آموزش

حمله سایبری به deBridge
صرافی متمرکز

حمله سازمان‌یافته به صرافی‌های بزرگ کریپتو؛ امنیت داخلی بایننس و کراکن مانع نفوذ مجرمین شد

27 اردیبهشت 1404 - 17:00
79
ربات های ترید ارز دیجیتال
ترید

راهنمای جامع ربات‌های ترید ارز دیجیتال؛ مقایسه عملکرد ربات‌های تلگرامی، ربات‌های مبتنی بر وب و ایجنت‌های AI

27 اردیبهشت 1404 - 08:01
201
بیت کوین لیب bitcoinlib
کریپتو پدیا

بیت‌کوین‌لیب (Bitcoinlib) چیست و چگونه مورد حمله هکرها قرار گرفت؟

26 اردیبهشت 1404 - 20:00
59
دپ های بی ان بی اسمارت چین
مقالات عمومی

بهترین پروژه‌های زنجیره‌ هوشمند BNB در سال ۲۰۲۵ که نباید از دست بدهید!

26 اردیبهشت 1404 - 16:00
297
استیکینگ سولانا
آموزش

آموزش استیک سولانا در سال ۲۰۲۵؛ راهنمای گام‌به‌گام استیکینگ SOL در کیف پول فانتوم

27 اردیبهشت 1404 - 08:02
194
بیت کوین به عنوان پوشش تورم
مقالات عمومی

آیا بیت کوین به‌عنوان پوشش تورم در سال ۲۰۲۵ مناسب است؟

25 اردیبهشت 1404 - 22:00
92

پیشنهاد سردبیر

استیکینگ سولانا

آموزش استیک سولانا در سال ۲۰۲۵؛ راهنمای گام‌به‌گام استیکینگ SOL در کیف پول فانتوم

27 اردیبهشت 1404 - 08:02
194

راهنمای جامع ربات‌های ترید ارز دیجیتال؛ مقایسه عملکرد ربات‌های تلگرامی، ربات‌های مبتنی بر وب و ایجنت‌های AI

ترید کریپتو در دوران رکود اقتصادی؛ هنر بقا در روزهای سخت

نرخ بهره فدرال رزرو چیست؟

معرفی بایننس آلفا (Binance Alpha)؛ پلتفرم کشف توکن‌های آینده‌دار پیش از لیست شدن در صرافی

آینده میکروپرداخت‌ها (Micro Payments)؛ بررسی چالش‌های قدیمی و راه‌حل‌ها

  • خانه
  • قیمت ارز
  • صرافی ها
  • ماشین حساب
No Result
مشاهده همه‌ی نتایج
  • اخبار
    • همه
    • رمزارز در ایران
    • اخبار بیت کوین
    • اخبار اتریوم
    • اخبار آلتکوین
    • اخبار بلاکچین
    • اخبار عمومی
    • اطلاعیه صرافی‌های داخلی
  • تحلیل
    • همه
    • تحلیل آنچین
    • تحلیل اقتصادی
    • تحلیل تکنیکال
    • تحلیل فاندامنتال
  • آموزش
    • همه
    • کریپتو پدیا
    • کریپتو کده
    • دیفای
    • سرمایه گذاری
    • آموزش همه صرافی های ارز دیجیتال
    • ترید
    • کیف پول
    • بازی
    • استخراج
    • NFT
    • مقالات عمومی
  • ایردراپ
  • هک و کلاهبرداری
  • قیمت ارزهای دیجیتال
  • ماشین حساب ارزهای دیجیتال
  • مقایسه قیمت در صرافی

© 2025 - تمامی حقوق مادی و معنوی این وبسایت نزد میهن بلاکچین محفوظ است

سرویس‌ها
لیست قیمت ارزهای دیجیتال مقایسه قیمت صرافی‌ها مقایسه ویژگی صرافی‌ها ماشین حساب ارزهای دیجیتال مقایسه رمزارز‌ها
خبر و آموزش
اخبار آموزش ویدیو پیشنهاد سردبیر
میهن بلاکچین
درباره ما ارتباط با ما تبلیغات و همکاری تجاری قوانین و مقررات سیاست های حریم خصوصی فرصت های شغلی
تگ‌های پربازدید
قانون گذاری سرمایه‌ گذاری افراد معروف صرافی ارز دیجیتال دوج‌کوین بیت‌کوین استیبل کوین رمزارز در ایران پیش بینی بازار تکنولوژی بلاک چین اتریوم ‌کاردانو شیبا هک و کلاهبرداری
سرویس‌ها
لیست قیمت ارزهای دیجیتال مقایسه قیمت صرافی‌ها مقایسه ویژگی صرافی‌ها ماشین حساب ارزهای دیجیتال مقایسه رمزارز‌ها
خبر و آموزش
اخبار آموزش ویدیو پیشنهاد سردبیر
میهن بلاکچین
درباره ما ارتباط با ما تبلیغات و همکاری تجاری قوانین و مقررات سیاست های حریم خصوصی فرصت های شغلی
تگ‌های پربازدید
قانون گذاری سرمایه‌ گذاری افراد معروف صرافی ارز دیجیتال دوج‌کوین بیت‌کوین استیبل کوین رمزارز در ایران پیش بینی بازار تکنولوژی بلاک چین اتریوم ‌کاردانو شیبا هک و کلاهبرداری
میهن بلاکچین دست در دست، بی‌نهایت برای میهن

© 2025 - تمامی حقوق مادی و معنوی این وبسایت نزد میهن بلاکچین محفوظ است.