গণনাগত জটিলতা হ্রাস করা সর্বদা ব্লকচেইন প্রযুক্তির প্রাথমিক লক্ষ্যগুলির মধ্যে একটি। এটি অর্জনের একটি কার্যকর পদ্ধতি হল গণনা ক্ষেত্রের বিট প্রস্থ হ্রাস করা। উদাহরণস্বরূপ, উপবৃত্তাকার বক্ররেখার উপর ভিত্তি করে SNARKগুলি 256 বা তার বেশি বিট প্রস্থের ক্ষেত্রে গাণিতিক ক্রিয়াকলাপ সম্পাদন করে, যখন STARKগুলি 64-বিট গোল্ডিলক্স ক্ষেত্র ব্যবহার করে 31-বিট মার্সেন 31 এবং বেবিবিয়ার ক্ষেত্রগুলিতে বিবর্তিত হয়েছে। মডুলার ক্রিয়াকলাপের সময় মৌলিক সংখ্যার দক্ষতার বাইরে, বিট প্রস্থে উল্লেখযোগ্য হ্রাস প্লনকি2 এর পূর্বসূরি প্লঙ্কির চেয়ে শতগুণ দ্রুততর হয়েছে। এই ট্র্যাজেক্টোরি অনুসরণ করে, কেউ ভাবতে পারে: ক্ষেত্রের প্রস্থ 1 এ সেট করা কি সম্ভব, বিশেষ করে ${\mathbb{F}}_{2}$? উলভেটান্না (অপ্রত্যাশিত) দলটি তাদের গবেষণামূলক প্রবন্ধে এই প্রশ্নটি সম্বোধন করেছে যার শিরোনাম ছিল বাইনারি ফিল্ডের টাওয়ারের উপর সংক্ষিপ্ত আর্গুমেন্টস।
মুক্তির পর থেকে, বিনিয়াস জেডকে (জিরো-নলেজ) সম্প্রদায়ে উল্লেখযোগ্য মনোযোগ অর্জন করেছে। LambdaClass টিম বেশ কিছু প্রযুক্তিগত বিশ্লেষণ প্রদান করেছে [4][5][6], এবং Vitalik Buterin একটি আরো সহজলভ্য ব্যাখ্যা প্রদান করেছেন
বিনিয়াসের বাস্তবায়ন বাইনারি ফিল্ডের উপর ভিত্তি করে। বিনিয়াসে, বাইনারি ক্ষেত্রগুলি ফিল্ড এক্সটেনশনের টাওয়ার ব্যবহার করে তৈরি করা হয়।
সবচেয়ে সহজ বাইনারি ক্ষেত্র হল ${{\mathbb{F}}{2}}$
, যেটিতে মাত্র দুটি উপাদান রয়েছে ${0,1}$
, ক্রিয়াকলাপ সম্পাদিত মডুলো 2 সহ: সংযোজন বিটওয়াইজ XOR এর সাথে মিলে যায়, এবং গুণন বিটওয়াইজের সাথে মিলে যায় এবং $m(x) = x^{2} + x + 1$ over ${{\mathbb{F}}{2}}$
বেছে নিয়ে, আমরা ${{\mathbb{F}}_{{2^{2}}}}$
ক্ষেত্রটি গঠন করতে পারি। ${{\mathbb{F}}_{{2^{2}}}}$
, যেখানে উপাদানগুলি সর্বাধিক 1 ডিগ্রির বহুপদীর অবশিষ্টাংশ, $r(x) = ax + b$ (with $a, b \in {0, 1}$
)।
ক্ষেত্র প্রসারিত করার একটি পদ্ধতির মধ্যে অপরিবর্তনীয় বহুপদ ব্যবহার করে অবশিষ্টাংশ নেওয়া জড়িত, বিনিয়াস আরও দক্ষ পদ্ধতি ব্যবহার করে: টাওয়ার এক্সটেনশনের ভিত্তি হিসাবে মাল্টিলিনিয়ার ল্যাগ্রেঞ্জ বহুপদীর ব্যবহার। এই পদ্ধতিটি পুনরাবৃত্ত ক্ষেত্র এক্সটেনশনের জন্য অনুমতি দেয়, যেখানে প্রতিটি এক্সটেনশন ক্ষেত্র পূর্ববর্তীটির মধ্যে নেস্ট করা হয়।
টাওয়ার এক্সটেনশনের সুনির্দিষ্ট বাস্তবায়ন নিম্নরূপ: প্রথম, ${{\tau }{0}} = {{\mathbb{F}}{2}}$
; তারপর, ${{\tau }{1}} = \frac{{{\mathbb{F}}{2}}[{{x}{0}}]}{(x{0}^{2} + {{x}_{0}} + 1)}$
; এরপরে, ${{\tau }{k}} = \frac{{{\mathbb{F}}{2}}[{{x}{k-1}}]}{(x{k-1}^{2} + {{x}{k-1}}{{x}{k-2}} + 1)}$.
ফিল্ড এক্সটেনশনগুলির নির্মাণ প্রক্রিয়া থেকে, এটা স্পষ্ট যে এক্সটেনশনগুলি নিম্নলিখিত সম্পর্কগুলিকে সন্তুষ্ট করে: ${{\tau }{0}} \subset {{\tau }{1}} \subset {{\tau }{2}} \subset \cdots \subset {{\tau }{m}}$
$k \ge 0$
এর জন্য, ক্ষেত্রের এক্সটেনশনটিকে একটি রিংয়ের সরাসরি আকারেও প্রকাশ করা যেতে পারে: ${{\tau }{k}}={{{\mathbb{F}}{2}}[{{x}{0,}}\ldots ,{{x}{k-1}}]}/{\left( x_{0}^{2}+{{x}{0}}+1,\ldots ,x{k-1}^{2}+{{x}{k-2}}{{x}{k-1}}+1 \right)}$.
এই বাস্তবায়নের উপর ভিত্তি করে, নিম্নরূপ বিভিন্ন এক্সটেনশন প্রাপ্ত করা যেতে পারে:
${{\tau }_{0}}=\left{ 0,1 \right}$
${{\tau }{1}}=\left{ 0+0{{x}{0}},1+0{{x}{0}},0+1{{x}{0}},1+1{{x}{0}} \right}$, or ${{\tau }{1}}=\left{ {{\tau }{0}},0+1{{x}{0}},1+1{{x}_{0}} \right}$
$${{\tau }{2}}=\left{ \begin{align} & 0+0{{x}{0}}+0{{x}{1}}+0{{x}{0}}{{x}{1}},1+0{{x}{0}}+0{{x}{1}}+0{{x}{0}}{{x}{1}},0+1{{x}{0}}+0{{x}{1}}+0{{x}{0}}{{x}{1}}, \ & 1+1{{x}{0}}+0{{x}{1}}+0{{x}{0}}{{x}{1}},\ldots ,1+1{{x}{0}}+1{{x}{1}}+1{{x}{0}}x \ \end{align} \right}$$, Or ${{\tau }{2}}=\left{ {{\tau }{1}},0+0{{x}{0}}+1{{x}{1}}+0{{x}{0}}{{x}{1}},\ldots ,1+1{{x}{0}}+1{{x}{1}}+1{{x}{0}}{{x}{1}} \right}$
বর্ধিত ক্ষেত্রের মধ্যে থাকা উপাদানগুলি থেকে এটি স্পষ্ট যে একটি উপাদান ${{b}{0}}{{b}{1}}{{b}{2}}\ldots {{b}{{{2}^{k}}-1}}$
${{\tau }{k}}$
থেকে প্রাপ্ত, এটি দুটি অংশের সমষ্টিতে পচে যেতে পারে: ${{b}{lo}} + {{x}{k-1}}{{b}{hi}}$ (where ${{b}{lo}}, {{b}{hi}} \in {{\tau }{k-1}}$)
. উদাহরণস্বরূপ, $01111 = 11001010 + 1000111 \times {{x}{3}}$, where $11001010, 10001111 \in {{\tau }{2}}$
।
পুনরাবৃত্তিমূলকভাবে পচন ধরে, আমরা অবশেষে প্রকাশ করতে পারি: $$01111=1+{{x}{0}}+{{x}{2}}+{{x}{2}}{{x}{1}}+{{x}{3}}+{{x}{2}}{{x}{3}}+{{x}{0}}{{x}{2}}{{x}{3}}+{{x}{1}}{{x}{2}}{{x}{3}}+{{x}{0}}{{x}{1}}{{x}{2}}{{x}{3}}$$
উপরন্তু, $k > 0$
-এর জন্য, যেহেতু $x_{k}^{2} = {{x}{k}}{{x}{k-1}} + 1$
, যোগ এবং গুণন দক্ষতার সাথে প্রয়োগ করা যেতে পারে বাইনারি বর্ধিত ক্ষেত্র।
ইরিডুসিবল বিনিয়াসের ওপেন সোর্স রাস্ট বাস্তবায়ন প্রদান করে [3]। সোর্স কোডে টাওয়ার অফ বাইনারি ফিল্ডস [8,9,10] এর জন্য সম্পূর্ণ বাস্তবায়ন এবং ক্রিয়াকলাপ অন্তর্ভুক্ত রয়েছে।
[৮], চিত্র 1-এ দেখানো হিসাবে, বাস্তবায়নে বাইনারি ক্ষেত্রগুলির জন্য ক্রিয়াকলাপের সম্পূর্ণ সংজ্ঞা এবং বাইনারি ক্ষেত্রগুলির টাওয়ার নির্মাণ অন্তর্ভুক্ত রয়েছে। বাইনারি ক্ষেত্রগুলির টাওয়ার, একটি 128-বিট বাইনারি ক্ষেত্র পর্যন্ত সমর্থন করে, নিম্নরূপ সংজ্ঞায়িত করা হয়েছে:
অতিরিক্তভাবে, [৮] টাওয়ার অফ বাইনারি ফিল্ড এবং সম্পর্কিত ক্রিয়াকলাপগুলির জন্য পরীক্ষা এবং যাচাইকরণ কোড সরবরাহ করে।
[১]
[২]
[৩]
[৪] বাইনারি ক্ষেত্রগুলিতে SNARK: বিনিয়াস - পার্ট 1 (lambdaclass.com)
[৫] বাইনারি ক্ষেত্রগুলিতে SNARK: বিনিয়াস - পার্ট 2 (lambdaclass.com)
[৬] বিনিয়াস কীভাবে ZK শিল্পকে এগিয়ে নিয়ে যেতে সাহায্য করছে (lambdaclass.com)
[৭]
[৮] binius/crates/field/src/binary_field.rs প্রধান এ · IrreducibleOSS/binius · GitHub
[৯] binius/crates/field/src/binary_field_arithmetic.rs এ প্রধান · IrreducibleOSS/binius · GitHub
[১০] binius/crates/field/src/extension.rs প্রধান · IrreducibleOSS/binius · GitHub এ