WebAssembly - मॉड्यूल

हमने देखा है कि c / c ++ कोड से .wasm फ़ाइल कैसे प्राप्त करें। इस अध्याय में, हम wasm को एक WebAssembly मॉड्यूल में परिवर्तित करेंगे और ब्राउज़र में इसे निष्पादित करेंगे।

नीचे दिखाए अनुसार C ++ फैक्टरल कोड का उपयोग करते हैं -

int fact(int n) {
   if ((n==0)||(n==1))
      return 1;
   else
      return n*fact(n-1);
}

Wasm एक्सप्लोरर खोलें जो यहां उपलब्ध है https://mbebenita.github.io/WasmExplorer/ as shown below −

पहले कॉलम में C ++ factorial फंक्शन है, दूसरे कॉलम में WebAssembly टेक्स्ट फॉर्मेट है और आखिरी कॉलम में x86 असेंबली कोड है।

WebAssembly पाठ प्रारूप -

(module
   (table 0 anyfunc)
   (memory $0 1)
   (export "memory" (memory $0))
   (export "_Z4facti" (func $_Z4facti))
   (func $_Z4facti (; 0 ;) (param $0 i32) (result i32)
      (local $1 i32)
      (set_local $1
         (i32.const 1)
      )
      (block $label$0
         (br_if $label$0
            (i32.eq
               (i32.or
                  (get_local $0)
                  (i32.const 1)
               )
               (i32.const 1)
            )
         )
         (set_local $1
            (i32.const 1)
         )
         (loop $label$1
            (set_local $1
               (i32.mul
                  (get_local $0)
                  (get_local $1)
               )
            )
            (br_if $label$1
               (i32.ne
                  (i32.or
                     (tee_local $0
                        (i32.add
                           (get_local $0)
                           (i32.const -1)
                        )
                     )
                     (i32.const 1)
                  )
                  (i32.const 1)
               )
            )
         )
      )
      (get_local $1)
   )
)

C ++ फ़ंक्शन fact "के रूप में निर्यात किया गया है_Z4factiWebAssembly पाठ प्रारूप में।

Wasm कोड डाउनलोड करने के लिए डाउनलोड बटन पर क्लिक करें और फ़ाइल को factorial.wasm के रूप में सहेजें।

अब .wasm कोड को मॉड्यूल में परिवर्तित करने के लिए हमें निम्नलिखित कार्य करने होंगे -

चरण 1

का उपयोग करके .wasm को arraybuffer में बदलें ArrayBuffer. ArrayBuffer ऑब्जेक्ट आपको निश्चित लंबाई के बाइनरी डेटा बफर लौटाएगा।

चरण 2

ArrayBuffer से बाइट्स का उपयोग करके एक मॉड्यूल में संकलित किया जाना है WebAssembly.compile(buffer) समारोह।

WebAssembly.compile() फ़ंक्शन संकलन करता है और दिए गए बाइट्स से एक WebAssembly.Module देता है।

यहाँ, जावास्क्रिप्ट कोड है, जिस पर चरण 1 और 2 में चर्चा की गई है।

<script type="text/javascript">
   let factorial;
   fetch("factorial.wasm")
      .then(bytes => bytes.arrayBuffer())
      .then(mod => WebAssembly.compile(mod))
      .then(module => {return new WebAssembly.Instance(module) })
      .then(instance => {
      
      factorial = instance.exports._Z4facti;
      console.log('Test the output in Brower Console by using factorial(n)');
   });
</script>

कोड स्पष्टीकरण

  • Javascript ब्राउज़र API fetch का उपयोग factorial.wasm की सामग्री प्राप्त करने के लिए किया जाता है।

  • सामग्री arrayBuffer () का उपयोग करके बाइट में बदल जाती है।

  • मॉड्यूल को WebAssembly.compile (mod) पर कॉल करके बाइट्स से बनाया गया है।

  • एक मॉड्यूल का उदाहरण नए का उपयोग करके बनाया गया है

    WebAssembly.Instance(module)

  • भाज्य फ़ंक्शन निर्यात _Z4facti को WebAssembly.Module.exports () का उपयोग करके चर फैक्टरियल को सौंपा गया है।

उदाहरण

यहाँ जावास्क्रिप्ट कोड के साथ मॉड्यूल.html है -

module.html

<!doctype html>
<html>
   <head>
      <meta charset="utf-8">
      <title>WebAssembly Module</title>
   </head>
   <body>
      <script>
      let factorial;
      fetch("factorial.wasm")
      .then(bytes => bytes.arrayBuffer())
      .then(mod => WebAssembly.compile(mod))
      .then(module => {return new WebAssembly.Instance(module) })
      .then(instance => {
         factorial = instance.exports._Z4facti;
         console.log('Test the output in Browser Console by using factorial(n)');
      });
      </script>
   </body>
</html>

उत्पादन

उत्पादन देखने के लिए ब्राउज़र में मॉड्यूल मॉड्यूल निष्पादित करें -