स्टेटिक सिंगल-असाइनमेंट फॉर्म

संकलक डिजाइन में, स्थिर एकल असाइनमेंट फॉर्म (अक्सर एसएसए फॉर्म या बस एसएसए के रूप में संक्षिप्त) एक मध्यवर्ती प्रतिनिधित्व (आईआर) की एक संपत्ति है जिसके लिए प्रत्येक वेरिएबल (कंप्यूटर साइंस) को असाइनमेंट (कंप्यूटर साइंस) होने की आवश्यकता होती है और इससे पहले परिभाषित किया जाता है। इस्तेमाल किया गया। मूल आईआर में मौजूदा चर 'संस्करण' में विभाजित हैं, नए चर आमतौर पर पाठ्यपुस्तकों में एक सबस्क्रिप्ट के साथ मूल नाम से संकेतित होते हैं, ताकि हर परिभाषा को अपना संस्करण मिल जाए। एसएसए फॉर्म में, यूज-डिफाइन चेन | यूज-डीफ चेन स्पष्ट हैं और प्रत्येक में एक ही तत्व है।

SSA को बैरी रोसेन (कंप्यूटर वैज्ञानिक) | बैरी के. रोसेन, मार्क एन. वेगमैन, और एफ. केनेथ ज़ेडेक द्वारा 1988 में प्रस्तावित किया गया था। Ron Cytron, Jeanne Ferrante और International Business Machines के पिछले तीन शोधकर्ताओं ने एक एल्गोरिद्म विकसित किया जो SSA फॉर्म की कुशलता से गणना कर सकता है। तो एक के संदर्भ में तैयार किए गए अनुकूलन और परिवर्तन तुरंत दूसरे पर लागू होते हैं।

लाभ
एसएसए की प्राथमिक उपयोगिता इस बात से आती है कि कैसे यह चर के गुणों को सरल बनाकर विभिन्न प्रकार के संकलक अनुकूलन के परिणामों को एक साथ सरल और बेहतर बनाता है। उदाहरण के लिए, कोड के इस टुकड़े पर विचार करें:

यः= 1 य := 2 एक्स := य

मनुष्य देख सकते हैं कि पहला कार्य आवश्यक नहीं है, और यह कि का मूल्य  तीसरी पंक्ति में उपयोग किया जा रहा है के दूसरे असाइनमेंट से आता है. इसे निर्धारित करने के लिए एक प्रोग्राम को परिभाषा तक पहुँचना परफॉर्म करना होगा। लेकिन अगर कार्यक्रम एसएसए फॉर्म में है, तो ये दोनों तत्काल हैं:

वाई1 := 1 और2 := 2 एक्स1 := और2 कंपाइलर ऑप्टिमाइज़ेशन एल्गोरिदम जो एसएसए के उपयोग से या तो सक्षम हैं या दृढ़ता से बढ़ाए गए हैं उनमें शामिल हैं:
 * लगातार प्रसार - संगणनाओं का रनटाइम से संकलन समय में रूपांतरण, उदा। निर्देश का इलाज करें  मानो यह था   * मूल्य सीमा प्रसार - संभावित रेंज की पूर्व-गणना करें जो एक गणना हो सकती है, जिससे अग्रिम में शाखा पूर्वानुमानों के निर्माण की अनुमति मिलती है
 * विरल सशर्त निरंतर प्रसार - कुछ मूल्यों की सीमा-जांच करें, जिससे परीक्षणों को सबसे अधिक संभावित शाखा की भविष्यवाणी करने की अनुमति मिलती है
 * डेड-कोड उन्मूलन - ऐसे कोड को हटा दें जिसका परिणामों पर कोई प्रभाव नहीं पड़ेगा
 * वैश्विक मूल्य अंकन - समान परिणाम उत्पन्न करने वाली डुप्लिकेट गणनाओं को बदलें
 * आंशिक अतिरेक उन्मूलन - कार्यक्रम की कुछ शाखाओं में पहले की गई डुप्लिकेट गणनाओं को हटाना
 * शक्ति में कमी - महंगे संचालन को कम खर्चीले लेकिन समकक्ष कार्यों से बदलना, उदा। पूर्णांक को गुणा करें या 2 की शक्तियों से विभाजित करें, संभावित रूप से कम महंगी शिफ्ट बाएं (गुणा करने के लिए) या दाएं शिफ्ट (विभाजन के लिए)।
 * रजिस्टर आवंटन - गणना के लिए मशीन रजिस्टरों की सीमित संख्या का उपयोग कैसे किया जा सकता है, इसका अनुकूलन करें

एसएसए
में कनवर्ट करना सामान्य कोड को एसएसए फॉर्म में परिवर्तित करना मुख्य रूप से प्रत्येक असाइनमेंट के लक्ष्य को एक नए चर के साथ बदलने का मामला है, और चर के प्रत्येक उपयोग को उस बिंदु तक पहुंचने वाले चर के संस्करण के साथ बदलना है। उदाहरण के लिए, निम्नलिखित नियंत्रण-प्रवाह ग्राफ़ पर विचार करें:

x के बाईं ओर नाम बदलना $$\leftarrow$$ x - 3 और x के निम्नलिखित उपयोगों को उस नए नाम में बदलने से कार्यक्रम में कोई बदलाव नहीं होगा। SSA में दो नए वेरिएबल बनाकर इसका फायदा उठाया जा सकता है: x 1 और x 2, जिनमें से प्रत्येक को केवल एक बार सौंपा गया है। इसी तरह, अन्य सभी चरों को अलग-अलग सबस्क्रिप्ट देने से पैदावार होती है:

यह स्पष्ट है कि प्रत्येक उपयोग किस परिभाषा का संदर्भ दे रहा है, एक मामले को छोड़कर: नीचे के ब्लॉक में y के दोनों उपयोग या तो y का संदर्भ दे सकते हैं1 या y 2, नियंत्रण प्रवाह किस पथ पर निर्भर करता है।

इसे हल करने के लिए, अंतिम ब्लॉक में एक विशेष कथन डाला जाता है, जिसे Φ (Phi) फ़ंक्शन कहा जाता है। यह कथन y की एक नई परिभाषा उत्पन्न करेगा जिसे y कहा जाता है3 या तो y चुनकर1 या y 2अतीत में नियंत्रण प्रवाह के आधार पर।

अब, अंतिम ब्लॉक केवल y का उपयोग कर सकता है3, और सही मान किसी भी तरह से प्राप्त किया जाएगा। x के लिए Φ फ़ंक्शन की आवश्यकता नहीं है: x का केवल एक संस्करण, अर्थात् x 2 इस स्थान पर पहुँच रहा है, इसलिए कोई समस्या नहीं है (दूसरे शब्दों में, Φ( x 2, x 2)= x 2).

एक मनमाना नियंत्रण-प्रवाह ग्राफ दिया गया है, यह बताना मुश्किल हो सकता है कि Φ फ़ंक्शंस कहाँ सम्मिलित करें, और किन चरों के लिए। इस सामान्य प्रश्न का एक कुशल समाधान है जिसे प्रभुत्व सीमा (नीचे देखें) नामक अवधारणा का उपयोग करके गणना की जा सकती है।

अधिकांश मशीनों पर मशीन संचालन के रूप में Φ कार्यों को लागू नहीं किया जाता है। एक कंपाइलर प्रत्येक पूर्ववर्ती ब्लॉक के अंत में मूव ऑपरेशंस डालने से Φ फ़ंक्शन कार्यान्वित कर सकता है। उपरोक्त उदाहरण में, कंपाइलर y से एक चाल सम्मिलित कर सकता है1 को य 3 मध्य-बाएँ ब्लॉक के अंत में और y से एक चाल2 को य 3 मध्य-दाएँ ब्लॉक के अंत में। कंपाइलर की रजिस्टर आवंटन प्रक्रिया के आधार पर ये मूव ऑपरेशंस अंतिम कोड में समाप्त नहीं हो सकते हैं। हालांकि, यह दृष्टिकोण तब काम नहीं कर सकता है जब एक साथ संचालन अनुमानित रूप से Φ फ़ंक्शन के लिए इनपुट का उत्पादन कर रहे हों, जैसा कि व्यापक मुद्दा मशीनों पर हो सकता है। आमतौर पर, एक वाइड-इश्यू मशीन में Φ फ़ंक्शन को लागू करने के लिए कंपाइलर द्वारा ऐसी स्थितियों में चयन निर्देश का उपयोग किया जाता है।

केनी ज़ेडेक के अनुसार, Φ कार्यों को मूल रूप से नकली कार्यों के रूप में जाना जाता था, जबकि एसएसए को 1980 के दशक में आईबीएम रिसर्च में विकसित किया जा रहा था। एक Φ समारोह का औपचारिक नाम केवल तभी अपनाया गया था जब काम पहली बार अकादमिक पेपर में प्रकाशित हुआ था।

प्रभुत्व सीमाओं का उपयोग करते हुए न्यूनतम एसएसए की गणना
एक नियंत्रण-प्रवाह ग्राफ में, एक नोड ए कहा जाता हैएक अलग नोड बी अगर पहले ए से गुजरे बिना बी तक पहुंचना असंभव है। दूसरे शब्दों में, यदि नोड B तक पहुँच जाता है, तो यह माना जा सकता है कि A चल चुका है। A को B पर हावी होना कहा जाता है (या B को A द्वारा हावी होना कहा जाता है) यदि A सख्ती से B या A = B पर हावी होता है।

एक नोड जो एक नोड A को नियंत्रण स्थानांतरित करता है, कहलाता हैए का

नोड ए का नोड बी का सेट है जहां ए कड़ाई से बी पर हावी है, लेकिन बी के कुछ तत्काल पूर्ववर्ती पर हावी है। ये ऐसे बिंदु हैं जिन पर कई नियंत्रण पथ एक साथ एक ही पथ में विलीन हो जाते हैं।

उदाहरण के लिए, निम्नलिखित कोड में:

 [1] एक्स = यादृच्छिक अगर एक्स <0.5 [2] परिणाम = सिर अन्य [3] परिणाम = पूंछ अंत [4] प्रिंट (परिणाम) 

नोड 1 कड़ाई से 2, 3 और 4 पर हावी है, और नोड 4 के तत्काल पूर्ववर्ती नोड 2 और 3 हैं।

प्रभुत्व सीमाएं उन बिंदुओं को परिभाषित करती हैं जिन पर Φ कार्यों की आवश्यकता होती है। उपरोक्त उदाहरण में, जब नियंत्रण को नोड 4 पर पारित किया जाता है, की परिभाषा  प्रयुक्त इस बात पर निर्भर करता है कि क्या नियंत्रण नोड 2 या 3 से पारित किया गया था। डोमिनेटर में परिभाषित चर के लिए Φ कार्यों की आवश्यकता नहीं है, क्योंकि केवल एक संभावित परिभाषा है जो लागू हो सकती है।

प्रत्येक नोड के प्रभुत्व सीमाओं को खोजने के लिए एक कुशल एल्गोरिदम है। इस एल्गोरिथ्म को मूल रूप से 1991 में रॉन साइट्रॉन, जीन फेरेंटे, एट अल द्वारा "कुशलतापूर्वक कम्प्यूटिंग स्टेटिक सिंगल असाइनमेंट फॉर्म और कंट्रोल ग्राफ" में वर्णित किया गया था। कीथ डी. कूपर, टिमोथी जे. हार्वे, और राइस विश्वविद्यालय के केन कैनेडी ने अपने पेपर में एक सरल, तेज प्रभुत्व एल्गोरिथम नामक एक एल्गोरिद्म का वर्णन किया है:

प्रत्येक नोड के लिए बी प्रभुत्व_फ्रंटियर (बी) := {} प्रत्येक नोड के लिए बी यदि बी ≥ 2 के तत्काल पूर्ववर्तियों की संख्या बी के तत्काल पूर्ववर्तियों में प्रत्येक पी के लिए धावक := प जबकि धावक ≠ मुहावरा (बी) प्रभुत्व_फ्रंटियर (धावक) := प्रभुत्व_फ्रंटियर (धावक) ∪ { बी } धावक := इडोम (धावक)

उपरोक्त कोड में,  हैb का, अद्वितीय नोड जो सख्ती से b पर हावी होता है लेकिन किसी अन्य नोड पर कड़ाई से हावी नहीं होता है जो सख्ती से b पर हावी होता है।

वेरिएशंस जो Φ फंक्शन्स की संख्या को कम करते हैं
न्यूनतम एसएसए यह सुनिश्चित करने के लिए आवश्यक Φ कार्यों की न्यूनतम संख्या सम्मिलित करता है कि प्रत्येक नाम को एक बार एक मान निर्दिष्ट किया गया है और मूल कार्यक्रम में एक नाम का प्रत्येक संदर्भ (उपयोग) अभी भी एक अद्वितीय नाम का उल्लेख कर सकता है। (बाद की आवश्यकता यह सुनिश्चित करने के लिए आवश्यक है कि संकलक प्रत्येक ऑपरेशन में प्रत्येक ऑपरेंड के लिए एक नाम लिख सके।)

हालाँकि, इनमें से कुछ Φ फ़ंक्शंस मृत कोड उन्मूलन हो सकते हैं। इस कारण से, न्यूनतम एसएसए आवश्यक रूप से सबसे कम Φ कार्यों का उत्पादन नहीं करता है जो एक विशिष्ट प्रक्रिया के लिए आवश्यक हैं। कुछ प्रकार के विश्लेषणों के लिए, ये Φ कार्य अनावश्यक हैं और विश्लेषण को कम कुशलता से चलाने का कारण बन सकते हैं।

छंटनी एसएसए
प्रून्ड एसएसए फॉर्म एक साधारण अवलोकन पर आधारित है: Φ फ़ंक्शन केवल वेरिएबल्स के लिए आवश्यक हैं जो Φ फ़ंक्शन के बाद लाइव हैं। (यहां, लाइव का अर्थ है कि मान का उपयोग किसी ऐसे पथ के साथ किया जाता है जो प्रश्न में Φ फ़ंक्शन से शुरू होता है।) यदि कोई चर लाइव नहीं है, तो Φ फ़ंक्शन का परिणाम उपयोग नहीं किया जा सकता है और Φ फ़ंक्शन द्वारा असाइनमेंट समाप्त हो गया है।

छंटे हुए एसएसए फॉर्म का निर्माण लाइव-वैरिएबल विश्लेषण का उपयोग करता है। यह तय करने के लिए Φ फ़ंक्शन सम्मिलन चरण में लाइव-वैरिएबल जानकारी दी गई है कि किसी दिए गए Φ फ़ंक्शन की आवश्यकता है या नहीं। यदि मूल चर नाम Φ फ़ंक्शन सम्मिलन बिंदु पर लाइव नहीं है, तो Φ फ़ंक्शन सम्मिलित नहीं किया गया है।

एक अन्य संभावना यह है कि छंटाई को डेड-कोड एलिमिनेशन समस्या के रूप में देखा जाए। फिर, एक Φ फ़ंक्शन केवल तभी लाइव होता है जब इनपुट प्रोग्राम में कोई उपयोग इसे फिर से लिखा जाएगा, या यदि इसे किसी अन्य Φ फ़ंक्शन में तर्क के रूप में उपयोग किया जाएगा। एसएसए फॉर्म में प्रवेश करते समय, प्रत्येक उपयोग को उस पर हावी होने वाली निकटतम परिभाषा में फिर से लिखा जाता है। एक Φ फ़ंक्शन को तब तक लाइव माना जाएगा जब तक कि यह निकटतम परिभाषा है जो कम से कम एक उपयोग पर हावी है, या लाइव Φ का कम से कम एक तर्क है।

सेमी-प्रूनेड एसएसए
सेमी-प्रून एसएसए फॉर्म लाइव-वैरिएबल जानकारी कंप्यूटिंग की अपेक्षाकृत उच्च लागत के बिना Φ कार्यों की संख्या को कम करने का प्रयास है। यह निम्नलिखित अवलोकन पर आधारित है: यदि एक मूल ब्लॉक में प्रवेश पर एक चर कभी भी जीवित नहीं होता है, तो उसे कभी भी Φ फ़ंक्शन की आवश्यकता नहीं होती है। एसएसए निर्माण के दौरान, किसी भी ब्लॉक-स्थानीय चर के लिए Φ फ़ंक्शन छोड़े जाते हैं।

ब्लॉक-लोकल वेरिएबल्स के सेट की गणना पूर्ण लाइव-वैरिएबल विश्लेषण की तुलना में एक सरल और तेज प्रक्रिया है, जो सेमी-प्रून किए गए एसएसए फॉर्म को कम एसएसए फॉर्म की तुलना में गणना करने के लिए अधिक कुशल बनाता है। दूसरी ओर, सेमी-प्रून्ड SSA फॉर्म में अधिक Φ फंक्शन होंगे।

ब्लॉक तर्क
ब्लॉक तर्क Φ कार्यों का एक विकल्प है जो प्रतिनिधित्वात्मक रूप से समान है लेकिन व्यवहार में अनुकूलन के दौरान अधिक सुविधाजनक हो सकता है। ब्लॉक का नाम दिया गया है और फ़ंक्शन पैरामीटर के रूप में नोट किए गए ब्लॉक तर्कों की एक सूची लें। ब्लॉक को कॉल करते समय ब्लॉक तर्क निर्दिष्ट मानों से बंधे होते हैं। स्विफ्ट (प्रोग्रामिंग भाषा) और एलएलवीएम का बहु-स्तरीय मध्यवर्ती प्रतिनिधित्व ब्लॉक तर्कों का उपयोग करता है।

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

SSA फॉर्म पर अनुकूलन करने से आमतौर पर SSA-वेब उलझ जाते हैं, जिसका अर्थ है कि ऐसे Φ निर्देश हैं जिनके ऑपरेंड में सभी समान रूट ऑपरेंड नहीं होते हैं। ऐसे मामलों में एसएसए से बाहर आने के लिए ग्राफ रंग | कलर-आउट एल्गोरिदम का उपयोग किया जाता है। Naive एल्गोरिदम प्रत्येक पूर्ववर्ती पथ के साथ एक प्रति प्रस्तुत करता है जिसके कारण Φ के गंतव्य की तुलना में भिन्न रूट प्रतीक का स्रोत Φ में रखा जाता है। एसएसए से कम प्रतियों के साथ बाहर आने के लिए कई एल्गोरिदम हैं, अधिकांश इंटरफेरेंस ग्राफ का उपयोग करते हैं या कॉपी कोलेसिंग करने के लिए इसके कुछ सन्निकटन का उपयोग करते हैं।

एक्सटेंशन
एसएसए फॉर्म के विस्तार को दो श्रेणियों में विभाजित किया जा सकता है।

नाम बदलने की योजना के विस्तार से नाम बदलने की कसौटी बदल जाती है। याद रखें कि एसएसए फॉर्म प्रत्येक वेरिएबल का नाम बदल देता है जब इसे मान निर्दिष्ट किया जाता है। वैकल्पिक योजनाओं में स्थैतिक एकल उपयोग प्रपत्र (जो प्रत्येक चर का उपयोग किए जाने पर प्रत्येक चर का नाम बदलता है) और स्थिर एकल सूचना प्रपत्र (जो प्रत्येक चर का नाम बदलता है जब इसे मान निर्दिष्ट किया जाता है, और प्रभुत्व के बाद की सीमा पर) शामिल होता है।

फ़ीचर-विशिष्ट एक्सटेंशन चर के लिए एकल असाइनमेंट प्रॉपर्टी को बनाए रखते हैं, लेकिन अतिरिक्त सुविधाओं को मॉडल करने के लिए नए सिमेंटिक्स को शामिल करते हैं। कुछ फीचर-विशिष्ट एक्सटेंशन मॉडल उच्च-स्तरीय प्रोग्रामिंग लैंग्वेज फीचर्स जैसे सरणियाँ, ऑब्जेक्ट और अलियास पॉइंटर्स। अन्य फीचर-विशिष्ट एक्सटेंशन मॉडल निम्न-स्तरीय आर्किटेक्चरल फीचर्स जैसे अटकलें और पूर्वानुमान।

एसएसए फॉर्म का उपयोग करने वाले कंपाइलर्स
एसएसए फॉर्म कंपाइलर समुदाय में एक अपेक्षाकृत हालिया विकास है। जैसे, कई पुराने संकलक केवल संकलन या अनुकूलन प्रक्रिया के कुछ भाग के लिए SSA फॉर्म का उपयोग करते हैं, लेकिन अधिकांश इस पर भरोसा नहीं करते हैं। एसएसए फॉर्म पर भारी निर्भर करने वाले कंपाइलर्स के उदाहरणों में शामिल हैं:


 * ईटीएच ओबेरोन -2 कंपाइलर एसएसए के एक संस्करण जीएसए को शामिल करने वाली पहली सार्वजनिक परियोजनाओं में से एक था।
 * एलएलवीएम कंपाइलर इन्फ्रास्ट्रक्चर अपने प्राथमिक कोड प्रतिनिधित्व में सभी स्केलर रजिस्टर वैल्यू (मेमोरी को छोड़कर सब कुछ) के लिए एसएसए फॉर्म का उपयोग करता है। एसएसए फॉर्म केवल एक बार रजिस्टर आवंटन होने के बाद समाप्त हो जाता है, संकलन प्रक्रिया में देर से (अक्सर लिंक समय पर)।
 * Open64 कंपाइलर अपने वैश्विक स्केलर ऑप्टिमाइज़र में SSA फॉर्म का उपयोग करता है, हालाँकि कोड को पहले SSA फॉर्म में लाया जाता है और बाद में SSA फॉर्म से बाहर कर दिया जाता है। Open64 एसएसए फॉर्म में एक्सटेंशन का उपयोग एसएसए फॉर्म के साथ-साथ स्केलर वैल्यू में मेमोरी का प्रतिनिधित्व करने के लिए करता है।
 * संस्करण 4 (अप्रैल 2005 में जारी) जीसीसी, जीएनयू कंपाइलर संग्रह, एसएसए का व्यापक उपयोग करता है। आगे और पीछे के सिरे GIMPLE#GENERIC और GIMPLE कोड जनरेट करते हैं जिसे बाद में GIMPLE#GENERIC और GIMPLE कोड में बदल दिया जाता है। इसके बाद GIMPLE के SSA फॉर्म पर उच्च-स्तरीय अनुकूलन लागू किए जाते हैं। परिणामी अनुकूलित इंटरमीडिएट कोड को तब स्थानांतरण भाषा पंजीकृत करें में अनुवादित किया जाता है, जिस पर निम्न-स्तरीय अनुकूलन लागू होते हैं। आर्किटेक्चर-विशिष्ट आगे और पीछे समाप्त होता है अंत में RTL को सभा की भाषा में बदल देते हैं।
 * आईबीएम का ओपन सोर्स एडेप्टिव जावा वर्चुअल मशीन, जैक्स आरवीएम, विस्तारित एरे एसएसए का उपयोग करता है, जो एसएसए का एक विस्तार है जो एक एकीकृत ढांचे में स्केलर, एरे और ऑब्जेक्ट फील्ड के विश्लेषण की अनुमति देता है। विस्तारित ऐरे एसएसए विश्लेषण केवल अधिकतम अनुकूलन स्तर पर सक्षम है, जो कोड के सबसे अधिक बार निष्पादित भागों पर लागू होता है।
 * 2002 में, शोधकर्ताओं ने संशोधित IBM के JaikesRVM (उस समय Jalapeno नाम) को मानक जावा बाईटकोड और एक प्रकार सुरक्षित SSA (SafeTSA) बाइटकोड क्लास फ़ाइलों, और दोनों को चलाने के लिए एसएसए बायटेकोड का उपयोग करने के लिए महत्वपूर्ण प्रदर्शन लाभों का प्रदर्शन किया।
 * Oracle Corporation का HotSpot (वर्चुअल मशीन) अपने JIT कंपाइलर में SSA-आधारित इंटरमीडिएट भाषा का उपयोग करता है।
 * माइक्रोसॉफ्ट विजुअल स्टूडियो 2015 अपडेट 3 में उपलब्ध माइक्रोसॉफ्ट विजुअल सी ++ कंपाइलर बैकएंड एसएसए का उपयोग करता है
 * मोनो (सॉफ्टवेयर) मिनी नामक अपने जेआईटी कंपाइलर में एसएसए का उपयोग करता है।
 * jackcc अकादमिक निर्देश सेट जैकल 3.0 के लिए एक ओपन-सोर्स कंपाइलर है। यह अपने मध्यवर्ती प्रतिनिधित्व के लिए एसएसए के साथ एक साधारण 3-ऑपरेंड कोड का उपयोग करता है। एक दिलचस्प संस्करण के रूप में, यह Φ कार्यों को एक तथाकथित समान निर्देश के साथ बदल देता है, जो रजिस्टर एलोकेटर को दो लाइव रेंज को एक ही भौतिक रजिस्टर में रखने का निर्देश देता है।
 * हालांकि एक कंपाइलर नहीं है, डीकंपाइलर अपने आंतरिक प्रतिनिधित्व में एसएसए फॉर्म का उपयोग करता है। SSA का उपयोग अभिव्यक्ति प्रसार को सरल बनाने, मापदंडों और रिटर्न की पहचान करने, संरक्षण विश्लेषण और बहुत कुछ करने के लिए किया जाता है।
 * पोर्टेबल.नेट अपने जेआईटी कंपाइलर में एसएसए का उपयोग करता है।
 * libFirm कंपाइलर्स के लिए पूरी तरह से ग्राफ आधारित एसएसए इंटरमीडिएट प्रतिनिधित्व। libFirm एसएसए-जागरूक रजिस्टर आवंटक के उपयोग से कोड जनरेशन तक सभी स्केलर रजिस्टर मानों के लिए एसएसए फॉर्म का उपयोग करता है।
 * इलिनोइस संगीत कार्यक्रम संकलक लगभग 1994 एसएसए (स्टेटिक सिंगल यूज) नामक एसएसए के एक संस्करण का उपयोग किया जाता है जो प्रत्येक चर का नाम बदल देता है जब इसे मान निर्दिष्ट किया जाता है, और प्रत्येक सशर्त संदर्भ में जिसमें उस चर का उपयोग किया जाता है; अनिवार्य रूप से ऊपर वर्णित स्थैतिक एकल सूचना प्रपत्र। SSU प्रपत्र जॉन Plevyak की Ph.D थीसिस में प्रलेखित है।
 * COINS कंपाइलर SSA फॉर्म ऑप्टिमाइज़ेशन का उपयोग करता है जैसा कि समझाया गया है यहाँ।
 * mozilla फ़ायरफ़ॉक्स मकड़ी बंदर जावास्क्रिप्ट इंजन एसएसए-आधारित आईआर का उपयोग करता है।
 * क्रोमियम (वेब ​​​​ब्राउज़र) V8 जावास्क्रिप्ट इंजन एसएसए को अपने क्रैंकशाफ्ट कंपाइलर इन्फ्रास्ट्रक्चर में लागू करता है दिसंबर 2010 में घोषित
 * PyPy अपने JIT संकलक में निशान के लिए एक रेखीय SSA प्रतिनिधित्व का उपयोग करता है।
 * Android (ऑपरेटिंग सिस्टम) की Dalvik (सॉफ्टवेयर) वर्चुअल मशीन अपने JIT कंपाइलर में SSA का उपयोग करती है।
 * Android रनटाइम के लिए Android (ऑपरेटिंग सिस्टम) का नया ऑप्टिमाइज़िंग कंपाइलर अपने IR के लिए SSA का उपयोग करता है।
 * मानक एमएल संकलक एमएलटन अपनी मध्यवर्ती भाषाओं में से एक में एसएसए का उपयोग करता है।
 * PlayAdvanced एसएसए-आधारित अनुकूलन का भारी उपयोग करता है।
 * PHP और हैक (प्रोग्रामिंग भाषा) कंपाइलर HHVM अपने IR में SSA का उपयोग करता है।
 * जलाशय लैब्स का आर-स्ट्रीम कंपाइलर गैर-एसएसए (क्वाड लिस्ट), एसएसए और एसएसआई (स्टेटिक सिंगल इंफॉर्मेशन) का समर्थन करता है ) रूप।
 * जाओ (प्रोग्रामिंग भाषा) (1.7: केवल x86-64 आर्किटेक्चर के लिए; 1.8: सभी समर्थित आर्किटेक्चर के लिए)।
 * एसपीआईआर-वी, वल्कन (एपीआई) के लिए छायांकन भाषा मानक और ओपनसीएल कंप्यूट एपीआई के लिए कर्नेल की गणना करें, एक एसएसए प्रतिनिधित्व है।
 * एनआईआर के माध्यम से विभिन्न मेसा (कंप्यूटर ग्राफिक्स) ड्राइवर, छायांकन भाषाओं के लिए एक एसएसए प्रतिनिधित्व।
 * वेबकिट अपने जेआईटी कंपाइलर्स में एसएसए का उपयोग करता है।
 * स्विफ्ट (प्रोग्रामिंग लैंग्वेज) एलएलवीएम आईआर के ऊपर अपने स्वयं के एसएसए फॉर्म को परिभाषित करती है, जिसे एसआईएल (स्विफ्ट इंटरमीडिएट लैंग्वेज) कहा जाता है।
 * एरलांग (प्रोग्रामिंग भाषा) ने स्टेटिक सिंगल असाइनमेंट (एसएसए) पर आधारित एक मध्यवर्ती प्रतिनिधित्व का आंतरिक रूप से उपयोग करने के लिए ओटीपी 22.0 में अपने कंपाइलर को फिर से लिखा। भविष्य के रिलीज में एसएसए के शीर्ष पर निर्मित और अनुकूलन की योजना के साथ।

सामान्य संदर्भ

 * जावा (प्रोग्रामिंग भाषा) में भी उपलब्ध (ISBN 0-521-82060-X, 2002) और सी (प्रोग्रामिंग भाषा) (ISBN 0-521-60765-5, 1998) संस्करण।

बाहरी संबंध

 * Bosscher, Steven; and Novillo, Diego. GCC gets a new Optimizer Framework. An article about GCC's use of SSA and how it improves over older IRs.
 * The SSA Bibliography. Extensive catalogue of SSA research papers.
 * Zadeck, F. Kenneth. "The Development of Static Single Assignment Form", December 2007 talk on the origins of SSA.
 * VV.AA. "SSA-based Compiler Design" (2014)