एसवाईसीएल: Difference between revisions

From Vigyanwiki
(Created page with "{{short description|Higher-level programming standard for heterogeneous computing}} {{Distinguish|Cilk}} {{third-party|date=January 2019}} {{Infobox software | name = SYCL | l...")
 
No edit summary
Line 1: Line 1:
{{short description|Higher-level programming standard for heterogeneous computing}}
{{short description|Higher-level programming standard for heterogeneous computing}}SYCL विभिन्न हार्डवेयर त्वरण पर प्रोग्रामिंग उत्पादकता में सुधार करने के लिए एक उच्च स्तरीय प्रोग्रामिंग मॉडल है। यह शुद्ध [[C++17]] पर आधारित एकल-स्रोत एम्बेडेड डोमेन-विशिष्ट भाषा ([[eDSL]]) है। यह [[क्रोनोस समूह]] द्वारा विकसित एक मानक है, जिसकी घोषणा मार्च 2014 में की गई थी।
{{Distinguish|Cilk}}
{{third-party|date=January 2019}}
{{Infobox software
| name = SYCL
| logo = [[Image:SYCL logo.svg|SYCL logo|220px]]
| author = [[Khronos Group]]
| developer = [[Khronos Group]]
| released = {{Start date and age|2014|03}}
| latest release version = 2020 revision 8 (1.2.1)
| latest release date = {{Start date and age|2023|10|19|df=yes}}<ref name=releases>{{cite web|url=https://registry.khronos.org/SYCL/}}</ref>
| operating_system = [[Cross-platform]]
| platform = Cross-platform
| genre = [[High-level programming language]]
| website = {{URL|https://www.khronos.org/sycl/}} {{URL|https://sycl.tech}}
}}
 
SYCL विभिन्न हार्डवेयर त्वरण पर प्रोग्रामिंग उत्पादकता में सुधार करने के लिए एक उच्च स्तरीय प्रोग्रामिंग मॉडल है। यह शुद्ध [[C++17]] पर आधारित एकल-स्रोत एम्बेडेड डोमेन-विशिष्ट भाषा ([[eDSL]]) है। यह [[क्रोनोस समूह]] द्वारा विकसित एक मानक है, जिसकी घोषणा मार्च 2014 में की गई थी।


==नाम की उत्पत्ति==
==नाम की उत्पत्ति==
SYCL (उच्चारण 'सिकल') मूल रूप से सिस्टम-वाइड कंप्यूट लैंग्वेज के लिए है,<ref>{{cite web |last1=Keryell |first1=Ronan |title=SYCL: A Single-Source C++ Standard for Heterogeneous Computing |url=https://www.khronos.org/assets/uploads/developers/presentations/SC19-H2RC-keynote-SYCL_Nov19.pdf |website=Khronos.org |date=17 November 2019| access-date=26 September 2023}}</ref> लेकिन 2020 से SYCL डेवलपर्स ने कहा है कि SYCL एक नाम है और उन्होंने स्पष्ट कर दिया है कि यह अब एक संक्षिप्त नाम नहीं है और इसमें [[OpenCL]] का कोई संदर्भ नहीं है।<ref>{{cite web |last1=Keryell |first1=Ronan |title=SYCL का मतलब|url=https://github.com/KhronosGroup/SYCL-Docs/issues/112 |website=GitHub |access-date=5 February 2021}}</ref>
SYCL (उच्चारण 'सिकल') मूल रूप से सिस्टम-वाइड कंप्यूट लैंग्वेज के लिए है,<ref>{{cite web |last1=Keryell |first1=Ronan |title=SYCL: A Single-Source C++ Standard for Heterogeneous Computing |url=https://www.khronos.org/assets/uploads/developers/presentations/SC19-H2RC-keynote-SYCL_Nov19.pdf |website=Khronos.org |date=17 November 2019| access-date=26 September 2023}}</ref> लेकिन 2020 से SYCL डेवलपर्स ने कहा है कि SYCL एक नाम है और उन्होंने स्पष्ट कर दिया है कि यह अब एक संक्षिप्त नाम नहीं है और इसमें [[OpenCL]] का कोई संदर्भ नहीं है।<ref>{{cite web |last1=Keryell |first1=Ronan |title=SYCL का मतलब|url=https://github.com/KhronosGroup/SYCL-Docs/issues/112 |website=GitHub |access-date=5 February 2021}}</ref>


 
== उद्देश्य ==
==उद्देश्य==
एसवाईसीएल एक रॉयल्टी-मुक्त, क्रॉस-प्लेटफ़ॉर्म एब्स्ट्रैक्शन परत है जो ओपनसीएल से प्रेरित अंतर्निहित अवधारणाओं, पोर्टेबिलिटी और दक्षता पर आधारित है जो पूरी तरह से मानक सी ++ का उपयोग करके विषम प्रोसेसर के लिए कोड को "एकल-स्रोत" शैली में लिखने में सक्षम बनाता है। एसवाईसीएल एकल-स्रोत विकास को सक्षम बनाता है जहां [[टेम्पलेट ([[सी++]])]]|सी++ टेम्पलेट फ़ंक्शंस में जटिल एल्गोरिदम बनाने के लिए होस्ट और डिवाइस कोड दोनों शामिल हो सकते हैं जो हार्डवेयर त्वरण का उपयोग करते हैं, और फिर विभिन्न प्रकार के डेटा पर अपने स्रोत कोड में उनका पुन: उपयोग करते हैं।
एसवाईसीएल एक रॉयल्टी-मुक्त, क्रॉस-प्लेटफ़ॉर्म एब्स्ट्रैक्शन परत है जो ओपनसीएल से प्रेरित अंतर्निहित अवधारणाओं, पोर्टेबिलिटी और दक्षता पर आधारित है जो पूरी तरह से मानक सी ++ का उपयोग करके विषम प्रोसेसर के लिए कोड को "एकल-स्रोत" शैली में लिखने में सक्षम बनाता है। एसवाईसीएल एकल-स्रोत विकास को सक्षम बनाता है जहां [[टेम्पलेट ([[सी++]])]]|सी++ टेम्पलेट फ़ंक्शंस में जटिल एल्गोरिदम बनाने के लिए होस्ट और डिवाइस कोड दोनों शामिल हो सकते हैं जो हार्डवेयर त्वरण का उपयोग करते हैं, और फिर विभिन्न प्रकार के डेटा पर अपने स्रोत कोड में उनका पुन: उपयोग करते हैं।


Line 39: Line 21:


IWOCL 2021 में एक रोडमैप प्रस्तुत किया गया। DPC++, ComputeCpp, Open SYCL, triSYCL और neoSYCL SYCL के मुख्य कार्यान्वयन हैं। विकास में अगला लक्ष्य भविष्य के SYCL 202x में C++20 का समर्थन है।<ref>https://www.iwocl.org/wp-content/uploads/k04-iwocl-syclcon-2021-wong-slides.pdf {{Bare URL PDF|date=March 2022}}</ref>
IWOCL 2021 में एक रोडमैप प्रस्तुत किया गया। DPC++, ComputeCpp, Open SYCL, triSYCL और neoSYCL SYCL के मुख्य कार्यान्वयन हैं। विकास में अगला लक्ष्य भविष्य के SYCL 202x में C++20 का समर्थन है।<ref>https://www.iwocl.org/wp-content/uploads/k04-iwocl-syclcon-2021-wong-slides.pdf {{Bare URL PDF|date=March 2022}}</ref>


== कार्यान्वयन ==
== कार्यान्वयन ==
Line 51: Line 32:
* पॉलीजिस्ट के पास एमएलआईआर के माध्यम से एसवाईसीएल को संकलित करने वाला एक कांटा है<ref>{{Cite web|url=https://github.com/InteonCo/बहुपत्नीवादी|title = बहुपत्नीवादी|website = [[GitHub]]|date = 25 February 2022}}</ref> जो Inteon कंपनी द्वारा समर्थित है।<ref>{{Cite web|url=https://inteon.co|title = इंटोन|date = 25 February 2022}}</ref>
* पॉलीजिस्ट के पास एमएलआईआर के माध्यम से एसवाईसीएल को संकलित करने वाला एक कांटा है<ref>{{Cite web|url=https://github.com/InteonCo/बहुपत्नीवादी|title = बहुपत्नीवादी|website = [[GitHub]]|date = 25 February 2022}}</ref> जो Inteon कंपनी द्वारा समर्थित है।<ref>{{Cite web|url=https://inteon.co|title = इंटोन|date = 25 February 2022}}</ref>


 
== सॉफ़्टवेयर ==
==सॉफ़्टवेयर==
* [[ग्रोमैक]]: एसवाईसीएल 2020 ग्रोमैक संस्करण 2021 का हिस्सा है।<ref>https://www.iwocl.org/wp-content/uploads/k03-iwocl-syclcon-2021-trevett-updated.mp4.pdf {{Bare URL PDF|date=March 2022}}</ref>
* [[ग्रोमैक]]: एसवाईसीएल 2020 ग्रोमैक संस्करण 2021 का हिस्सा है।<ref>https://www.iwocl.org/wp-content/uploads/k03-iwocl-syclcon-2021-trevett-updated.mp4.pdf {{Bare URL PDF|date=March 2022}}</ref>
* [[ISO 26262]] के समर्थन के साथ स्वायत्त ड्राइविंग के लिए ऑटोमोटिव उद्योग में उपयोग।<ref>https://www.iwocl.org/wp-content/uploads/20-iwocl-syclcon-2021-rudkin-slides.pdf {{Bare URL PDF|date=March 2022}}</ref>
* [[ISO 26262]] के समर्थन के साथ स्वायत्त ड्राइविंग के लिए ऑटोमोटिव उद्योग में उपयोग।<ref>https://www.iwocl.org/wp-content/uploads/20-iwocl-syclcon-2021-rudkin-slides.pdf {{Bare URL PDF|date=March 2022}}</ref>


 
== संसाधन ==
==संसाधन==
ख्रोनोस ग्रुप एसवाईसीएल संसाधनों की एक सूची बनाए रखता है।<ref>{{cite web |title=एसवाईसीएल संसाधन|url=https://www.khronos.org/sycl/resources |website=khronos.org |publisher=Khronos group}}</ref> [[कोडप्ले]] एसवाईसीएल पारिस्थितिकी तंत्र पर अन्य जानकारी और समाचारों के साथ वेबसाइट [https://sycl.tech/learn sycl.tech] पर ट्यूटोरियल भी प्रदान करता है।
ख्रोनोस ग्रुप एसवाईसीएल संसाधनों की एक सूची बनाए रखता है।<ref>{{cite web |title=एसवाईसीएल संसाधन|url=https://www.khronos.org/sycl/resources |website=khronos.org |publisher=Khronos group}}</ref> [[कोडप्ले]] एसवाईसीएल पारिस्थितिकी तंत्र पर अन्य जानकारी और समाचारों के साथ वेबसाइट [https://sycl.tech/learn sycl.tech] पर ट्यूटोरियल भी प्रदान करता है।


Line 83: Line 62:


===आरओसीएम हिप===
===आरओसीएम हिप===
{{Section_expand|small=no|date=February 2022}}
ROCm HIP को Nvidia GPU, AMD GPU और x86 CPU को लक्षित करने वाले CUDA के क्लोन के रूप में देखा जा सकता है। इस प्रकार आरओसीएम एचआईपी एसवाईसीएल की तुलना में एक निम्न-स्तरीय एपीआई है और सीयूडीए के साथ तुलना में उल्लिखित अधिकांश टिप्पणियाँ लागू होती हैं।
ROCm HIP को Nvidia GPU, AMD GPU और x86 CPU को लक्षित करने वाले CUDA के क्लोन के रूप में देखा जा सकता है। इस प्रकार आरओसीएम एचआईपी एसवाईसीएल की तुलना में एक निम्न-स्तरीय एपीआई है और सीयूडीए के साथ तुलना में उल्लिखित अधिकांश टिप्पणियाँ लागू होती हैं।


Line 109: Line 87:
{{Reflist}}
{{Reflist}}


==बाहरी संबंध==
*[https://www.khronos.org/sycl/ Khronos SYCL webpage]
* [https://www.khronos.org/registry/SYCL/ The SYCL specifications in Khronos registry]
* [https://github.com/KhronosGroup/SyclParallelSTL C++17 ParallelSTL in SYCL]
* [http://sycl.tech/ SYCL tech resources]
* [https://www.codeplay.com/products/computesuite/computecpp Codeplay ComputeCpp SYCL implementation]
* [https://github.com/intel/llvm/tree/sycl Implementation of SYCL started by Intel with the goal of Clang/LLVM up-streaming]
* [https://github.com/illuhad/hipSYCL hipSYCL: implementation of SYCL 1.2.1 over AMD HIP/NVIDIA CUDA]
* [https://github.com/triSYCL/triSYCL triSYCL open-source SYCL implementation]
* [https://www.iwocl.org/sycl-conference/ SYCL Conference @ IWOCL]
* [https://www.hpcwire.com/2021/02/09/sycl-2020-launches-new-name-new-features/ "SYCL 2020 Launches with New Name, New Features, and High Ambition", HPCWire article (2021 Feb. 9th)]
* [https://link.springer.com/book/10.1007/978-1-4842-5574-2 James Reinders, Ben Ashbaugh, James Brodman, Michael Kinsner, John Pennycook, Xinmin Tian:  "Data Parallel C++: Mastering DPC++ for Programming of Heterogeneous Systems using C++ and SYCL", Apress (2021), OpenAccess.]
{{Khronos Group standards}}
{{Parallel computing}}
[[Category: एप्लिकेशन प्रोग्रामिंग इंटरफ़ेस]] [[Category: सी++]] [[Category: क्रॉस-प्लेटफ़ॉर्म सॉफ़्टवेयर]] [[Category: डोमेन-विशिष्ट प्रोग्रामिंग भाषाएँ]] [[Category: जीपीजीपीयू]] [[Category: जीपीजीपीयू पुस्तकालय|ओपनसीएल]] [[Category: विषम कंप्यूटिंग]] [[Category: समानांतर कंप्यूटिंग]]  
[[Category: एप्लिकेशन प्रोग्रामिंग इंटरफ़ेस]] [[Category: सी++]] [[Category: क्रॉस-प्लेटफ़ॉर्म सॉफ़्टवेयर]] [[Category: डोमेन-विशिष्ट प्रोग्रामिंग भाषाएँ]] [[Category: जीपीजीपीयू]] [[Category: जीपीजीपीयू पुस्तकालय|ओपनसीएल]] [[Category: विषम कंप्यूटिंग]] [[Category: समानांतर कंप्यूटिंग]]  



Revision as of 19:38, 1 December 2023

SYCL विभिन्न हार्डवेयर त्वरण पर प्रोग्रामिंग उत्पादकता में सुधार करने के लिए एक उच्च स्तरीय प्रोग्रामिंग मॉडल है। यह शुद्ध C++17 पर आधारित एकल-स्रोत एम्बेडेड डोमेन-विशिष्ट भाषा (eDSL) है। यह क्रोनोस समूह द्वारा विकसित एक मानक है, जिसकी घोषणा मार्च 2014 में की गई थी।

नाम की उत्पत्ति

SYCL (उच्चारण 'सिकल') मूल रूप से सिस्टम-वाइड कंप्यूट लैंग्वेज के लिए है,[1] लेकिन 2020 से SYCL डेवलपर्स ने कहा है कि SYCL एक नाम है और उन्होंने स्पष्ट कर दिया है कि यह अब एक संक्षिप्त नाम नहीं है और इसमें OpenCL का कोई संदर्भ नहीं है।[2]

उद्देश्य

एसवाईसीएल एक रॉयल्टी-मुक्त, क्रॉस-प्लेटफ़ॉर्म एब्स्ट्रैक्शन परत है जो ओपनसीएल से प्रेरित अंतर्निहित अवधारणाओं, पोर्टेबिलिटी और दक्षता पर आधारित है जो पूरी तरह से मानक सी ++ का उपयोग करके विषम प्रोसेसर के लिए कोड को "एकल-स्रोत" शैली में लिखने में सक्षम बनाता है। एसवाईसीएल एकल-स्रोत विकास को सक्षम बनाता है जहां [[टेम्पलेट (सी++)]]|सी++ टेम्पलेट फ़ंक्शंस में जटिल एल्गोरिदम बनाने के लिए होस्ट और डिवाइस कोड दोनों शामिल हो सकते हैं जो हार्डवेयर त्वरण का उपयोग करते हैं, और फिर विभिन्न प्रकार के डेटा पर अपने स्रोत कोड में उनका पुन: उपयोग करते हैं।

जबकि SYCL मानक OpenCL कार्य समूह के उच्च-स्तरीय प्रोग्रामिंग मॉडल उप-समूह के रूप में शुरू हुआ था और मूल रूप से OpenCL और मानक पोर्टेबल इंटरमीडिएट प्रतिनिधित्व के साथ उपयोग के लिए विकसित किया गया था, SYCL 20 सितंबर से OpenCL कार्य समूह से स्वतंत्र एक ख्रोनोस समूह कार्य समूह है। 2019 और SYCL 2020 से शुरू होकर, SYCL को अन्य प्रणालियों को लक्षित करने में सक्षम एक अधिक सामान्य विषम ढांचे के रूप में सामान्यीकृत किया गया है। किसी भी त्वरण अप्लिकेशन प्रोग्रामिंग अंतरफलक को लक्षित करने के लिए जेनेरिक बैकएंड (कंप्यूटिंग) की अवधारणा के साथ यह अब संभव है, जबकि लक्ष्य एप्लिकेशन प्रोग्रामिंग इंटरफ़ेस के साथ पूर्ण इंटरऑपरेबिलिटी को सक्षम करना, जैसे प्रोग्रामिंग प्रयास को सरल बनाने के साथ-साथ अधिकतम प्रदर्शन तक पहुंचने के लिए मौजूदा देशी पुस्तकालयों का उपयोग करना। उदाहरण के लिए, ओपन एसवाईसीएल कार्यान्वयन पोर्टेबिलिटी के लिए उन्नत लघु उपकरण ेज के क्रॉस-वेंडर हेटेरोजेनियस-कंप्यूट इंटरफेस के माध्यम से आरओसीएम और सीयूडीए को लक्षित करता है।

संस्करण

SYCL को मार्च 2014 में गेम डेवलपर्स सम्मेलन में पेश किया गया था अनंतिम संस्करण 1.2,[3] तब SYCL 1.2 अंतिम संस्करण था मई 2015 में IWOCL 2015 में पेश किया गया।[4] पिछली SYCL 1.2.1 श्रृंखला का नवीनतम संस्करण SYCL 1.2.1 संशोधन 7 है जो 27 अप्रैल, 2020 को प्रकाशित हुआ था (पहला संस्करण 6 दिसंबर, 2017 को प्रकाशित हुआ था)[5]).

SYCL 2.2 अनंतिम को मई 2016 में IWOCL 2016 में पेश किया गया था[6] C++14 और OpenCL 2.2 को लक्षित करना। लेकिन एसवाईसीएल समिति ने इस संस्करण को अंतिम रूप नहीं देने और कृत्रिम बुद्धिमत्ता इंजनों सहित वर्तमान हार्डवेयर त्वरण की बढ़ती विविधता को संबोधित करने के लिए अधिक लचीले एसवाईसीएल विनिर्देश की ओर बढ़ने को प्राथमिकता दी, जिसके कारण एसवाईसीएल 2020 हुआ।

नवीनतम संस्करण SYCL 2020 संशोधन 6 है जिसे 13 नवंबर, 2022 को प्रकाशित किया गया था, यह संशोधन 2 की पहली रिलीज से एक विकास है जो 9 फरवरी, 2021 को प्रकाशित हुआ था।[7] पर प्रकाशित SYCL 2020 अनंतिम विशिष्टता संशोधन 1 पर उपयोगकर्ताओं और कार्यान्वयनकर्ताओं की प्रतिक्रिया को ध्यान में रखते हुए 30 जून 2020.[8] C++17 और OpenCL 3.0 समर्थन इस रिलीज़ के मुख्य लक्ष्य हैं। ओपनसीएल और सीयूडीए समर्थन वाले जीपीयू के लिए एकीकृत साझा मेमोरी (यूएसएम) एक मुख्य विशेषता है।

IWOCL 2021 में एक रोडमैप प्रस्तुत किया गया। DPC++, ComputeCpp, Open SYCL, triSYCL और neoSYCL SYCL के मुख्य कार्यान्वयन हैं। विकास में अगला लक्ष्य भविष्य के SYCL 202x में C++20 का समर्थन है।[9]

कार्यान्वयन

  • डीपीसी++: (डेटा पैरेलल सी++) एलएलवीएम और वनएपीआई के लिए एसवाईसीएल पेश करने के लिए इंटेल का एक ओपन सोर्स प्रोजेक्ट है। C++17 और SYCL 2020 के साथ C++20 के भाग इस कंपाइलर फ्रेमवर्क का आधार हैं।[10][11]
  • ComputeCpp: सामुदायिक संस्करण के साथ फर्म कोडप्ले का SYCL 1.2.1 अनुरूप ढांचा[12][13]
  • एडेप्टिवसीपीपी (पूर्व में हिपएसवाईसीएल और ओपन एसवाईसीएल): इमेज या ओपनसीएल इंटरऑप के बिना अधूरा 1.2.1 समर्थन, आंशिक रूप से एसवाईसीएल 2020, आरओसीएम (एएमडी), सीयूडीए (एनवीडिया), ओपनएमपी (सीपीयू) और लेवल जीरो (इंटेल) का समर्थन करता है।[14][15]
  • triSYCL: C++20, OpenMP और OpenCL पर आधारित, धीमा विकास, अधूरा, DPC++ के शीर्ष पर आधारित संस्करण के साथ[16]
  • neoSYCL: SYCL 1.2.1 लगभग पूर्ण, hpc SX-Aurora Tsubasa के लिए, छवि समर्थन जैसी कोई OpenCL विशिष्ट सुविधाएँ नहीं[17][18]
  • एसवाईसीएल-जीटीएक्स: सी++11 समर्थन, ओपनसीएल 1.2+ के लिए, पूर्ण से बहुत दूर, कोई वास्तविक विकास नहीं[19]
  • सिल्कन प्रायोगिक अवस्था में वल्कन उपकरणों के लिए एसवाईसीएल का कार्यान्वयन है।[20]
  • पॉलीजिस्ट के पास एमएलआईआर के माध्यम से एसवाईसीएल को संकलित करने वाला एक कांटा है[21] जो Inteon कंपनी द्वारा समर्थित है।[22]

सॉफ़्टवेयर

  • ग्रोमैक: एसवाईसीएल 2020 ग्रोमैक संस्करण 2021 का हिस्सा है।[23]
  • ISO 26262 के समर्थन के साथ स्वायत्त ड्राइविंग के लिए ऑटोमोटिव उद्योग में उपयोग।[24]

संसाधन

ख्रोनोस ग्रुप एसवाईसीएल संसाधनों की एक सूची बनाए रखता है।[25] कोडप्ले एसवाईसीएल पारिस्थितिकी तंत्र पर अन्य जानकारी और समाचारों के साथ वेबसाइट sycl.tech पर ट्यूटोरियल भी प्रदान करता है।

लाइसेंस

विनिर्देशन के निर्माण के लिए स्रोत फ़ाइलें, जैसे मेकफ़ाइल्स और कुछ स्क्रिप्ट, एसवाईसीएल हेडर और एसवाईसीएल कोड नमूने अपाचे 2.0 लाइसेंस के अंतर्गत हैं।[26] लाइसेंस का विवरण यहां है: https://www.apache.org/licenses/LICENSE-2.0.html

अन्य एपीआई के साथ तुलना

खुले मानक SYCL और OpenCL, Nvidia के मालिकाना स्टैक CUDA के प्रोग्रामिंग मॉडल और ओपन-सोर्स स्टैक ROCm से ROCm#HIP प्रोग्रामिंग के समान हैं, जो एडवांस्ड माइक्रो डिवाइसेस द्वारा समर्थित हैं।

ख्रोनोस ग्रुप क्षेत्र में, ओपनसीएल और वल्कन (एपीआई) निम्न-स्तरीय गैर-एकल स्रोत एप्लिकेशन प्रोग्रामिंग इंटरफ़ेस हैं और एसवाईसीएल उच्च-स्तरीय एकल-स्रोत सी++ ईडीएसएल|एम्बेडेड डोमेन-विशिष्ट भाषा (ईडीएसएल) है।

सीयूडीए

तुलनात्मक रूप से, CUDA का एकल-स्रोत C++ eDSL|एम्बेडेड डोमेन-विशिष्ट भाषा संस्करण, जिसे वास्तव में CUDA रनटाइम एप्लिकेशन प्रोग्रामिंग इंटरफ़ेस नाम दिया गया है, कुछ हद तक SYCL के समान है। लेकिन वास्तव में CUDA का एक कम ज्ञात गैर एकल-स्रोत संस्करण है जिसे CUDA ड्राइवर एप्लिकेशन प्रोग्रामिंग इंटरफ़ेस कहा जाता है, जो OpenCL के समान है, और उदाहरण के लिए CUDA रनटाइम एप्लिकेशन प्रोग्रामिंग इंटरफ़ेस कार्यान्वयन द्वारा उपयोग किया जाता है।

SYCL C++ AMP सुविधाओं का विस्तार करता है, जिससे प्रोग्रामर को CUDA के विरोध में (CUDA 6 में यूनिफाइड मेमोरी की शुरूआत से पहले) बफ़र्स और एक्सेसर्स का उपयोग करके होस्ट और डिवाइस के बीच डेटा को स्पष्ट रूप से स्थानांतरित करने से राहत मिलती है। लेकिन SYCL 2020 से शुरू करके, CUDA में यूनिफाइड मेमोरी के समान निचले स्तर के प्रोग्रामिंग मॉडल का उपयोग करने के लिए बफ़र्स और एक्सेसर्स के बजाय यूएसएम का उपयोग करना भी संभव है।

SYCL C++ AMP और CUDA से उच्च स्तरीय है क्योंकि आपको सभी कर्नेल के बीच एक स्पष्ट निर्भरता ग्राफ बनाने की आवश्यकता नहीं है, और आपको संचार और गणना ओवरलैप के साथ कर्नेल की स्वचालित अतुल्यकालिक शेड्यूलिंग प्रदान करता है। यह है यह सब किसी कंपाइलर समर्थन की आवश्यकता के बिना, एक्सेसर्स की अवधारणा का उपयोग करके किया गया।

C++ AMP और CUDA के विपरीत, SYCL बिना किसी C++ एक्सटेंशन के एक शुद्ध C++ eDSL है, जो बिना किसी विशिष्ट कंपाइलर के शुद्ध रनटाइम पर निर्भर बुनियादी CPU कार्यान्वयन की अनुमति देता है। यह किसी एप्लिकेशन को डीबग करने या किसी नए आर्किटेक्चर के लिए प्रोटोटाइपिंग के लिए बहुत उपयोगी है, बिना आर्किटेक्चर और कंपाइलर अभी तक उपलब्ध नहीं है।

CUDA बैकएंड को लक्षित करने वाले कम से कम 3 ज्ञात SYCL कार्यान्वयन हैं।

आरओसीएम हिप

ROCm HIP को Nvidia GPU, AMD GPU और x86 CPU को लक्षित करने वाले CUDA के क्लोन के रूप में देखा जा सकता है। इस प्रकार आरओसीएम एचआईपी एसवाईसीएल की तुलना में एक निम्न-स्तरीय एपीआई है और सीयूडीए के साथ तुलना में उल्लिखित अधिकांश टिप्पणियाँ लागू होती हैं।

ROCm HIP में SYCL से कुछ समानताएँ हैं, इस अर्थ में कि यह विभिन्न विक्रेताओं (AMD और Nvidia) और त्वरक प्रकारों (GPU और CPU) को लक्षित कर सकता है। लेकिन एसवाईसीएल बैकएंड की अवधारणा के साथ एक ही एप्लिकेशन में संभावित रूप से एक ही समय में किसी भी प्रकार के त्वरक और किसी भी विक्रेता को कार्यान्वयन के अनुसार लक्षित कर सकता है। SYCL भी शुद्ध C++ है जबकि HIP CUDA से विरासत में मिले कुछ एक्सटेंशन का उपयोग करता है, जो किसी भी CPU को लक्षित करने के लिए सामान्य C++ कंपाइलर का उपयोग करने से रोकता है।

एचआईपी बैकएंड को लक्षित करने वाले एसवाईसीएल के कम से कम 2 ज्ञात कार्यान्वयन हैं, वनएपीआई डीपीसी++ और ओपन एसवाईसीएल। ओपन SYCL कार्यान्वयन, HIP पर, SYCL प्रोग्रामिंग को CUDA और HIP में जोड़ता है।

अन्य प्रोग्रामिंग मॉडल

एसवाईसीएल में ट्रिलिनोस प्रोग्रामिंग मॉडल से कई समानताएं हैं,[27] जिसमें अपारदर्शी बहु-आयामी सरणी ऑब्जेक्ट (एसवाईसीएल बफ़र्स और कोक्कोस एरेज़), समानांतर निष्पादन के लिए बहु-आयामी श्रेणियां और कटौती (एसवाईसीएल 2020 में जोड़ा गया) का उपयोग शामिल है। कोक्कोस समुदाय की प्रतिक्रिया के जवाब में एसवाईसीएल 2020 में कई सुविधाएँ जोड़ी गईं।

यह भी देखें

संदर्भ

  1. Keryell, Ronan (17 November 2019). "SYCL: A Single-Source C++ Standard for Heterogeneous Computing" (PDF). Khronos.org. Retrieved 26 September 2023.
  2. Keryell, Ronan. "SYCL का मतलब". GitHub. Retrieved 5 February 2021.
  3. Khronos Group (19 March 2014). "Khronos Releases SYCL 1.2 Provisional Specification". Khronos. Retrieved 20 August 2017.
  4. Khronos Group (11 May 2015). "Khronos Releases SYCL 1.2 Final Specification". Khronos. Retrieved 20 August 2017.
  5. Khronos Group (6 December 2017). "The Khronos Group Releases Finalized SYCL 1.2.1". Khronos. Retrieved 12 December 2017.
  6. Khronos Group (18 April 2016). "Khronos Releases OpenCL 2.2 Provisional Specification with OpenCL C++ Kernel Language". Khronos. Retrieved 18 September 2017.
  7. Khronos Group (9 February 2021). "Khronos Releases SYCL 2020 Specification". Khronos. Retrieved 22 February 2021.
  8. Khronos Group (30 June 2020). "Khronos Steps Towards Widespread Deployment of SYCL with Release of SYCL 2020 Provisional Specification". Khronos. Retrieved 4 December 2020.
  9. https://www.iwocl.org/wp-content/uploads/k04-iwocl-syclcon-2021-wong-slides.pdf[bare URL PDF]
  10. https://www.iwocl.org/wp-content/uploads/k01-iwocl-syclcon-2021-reinders-slides.pdf[bare URL PDF]
  11. "Compile Cross-Architecture: Intel® oneAPI DPC++/C++ Compiler".
  12. "Home - ComputeCpp CE - Products - Codeplay Developer".
  13. "Guides - ComputeCpp CE - Products - Codeplay Developer".
  14. "AdaptiveCpp (formerly known as hipSYCL / Open SYCL)". GitHub. 4 July 2023.
  15. "हिपएसवाईसीएल सुविधा समर्थन". GitHub. 4 July 2023.
  16. "ट्राईएसवाईसीएल". GitHub. 6 January 2022.
  17. Ke, Yinan; Agung, Mulya; Takizawa, Hiroyuki (2021). "NeoSYCL: A SYCL implementation for SX-Aurora TSUBASA". एशिया-प्रशांत क्षेत्र में उच्च प्रदर्शन कंप्यूटिंग पर अंतर्राष्ट्रीय सम्मेलन. pp. 50–57. doi:10.1145/3432261.3432268. ISBN 9781450388429. S2CID 231597238.
  18. Ke, Yinan; Agung, Mulya; Takizawa, Hiroyuki (2021). "NeoSYCL: A SYCL implementation for SX-Aurora TSUBASA". एशिया-प्रशांत क्षेत्र में उच्च प्रदर्शन कंप्यूटिंग पर अंतर्राष्ट्रीय सम्मेलन. pp. 50–57. doi:10.1145/3432261.3432268. ISBN 9781450388429. S2CID 231597238.
  19. "Sycl-GTX". GitHub. 10 April 2021.
  20. https://www.iwocl.org/wp-content/uploads/14-iwocl-syclcon-2021-thoman-slides.pdf[bare URL PDF]
  21. "बहुपत्नीवादी". GitHub. 25 February 2022.
  22. "इंटोन". 25 February 2022.
  23. https://www.iwocl.org/wp-content/uploads/k03-iwocl-syclcon-2021-trevett-updated.mp4.pdf[bare URL PDF]
  24. https://www.iwocl.org/wp-content/uploads/20-iwocl-syclcon-2021-rudkin-slides.pdf[bare URL PDF]
  25. "एसवाईसीएल संसाधन". khronos.org. Khronos group.
  26. "एसवाईसीएल ओपन सोर्स विशिष्टता". GitHub. 10 January 2022.
  27. Hammond, Jeff R.; Kinsner, Michael; Brodman, James (2019). "A comparative analysis of Kokkos and SYCL as heterogeneous, parallel programming models for C++ applications". ओपनसीएल पर अंतर्राष्ट्रीय कार्यशाला की कार्यवाही. pp. 1–2. doi:10.1145/3318170.3318193. ISBN 9781450362306. S2CID 195777149.{{cite book}}: CS1 maint: date and year (link)