प्रोग्राम सिंथेसिस

कंप्यूटर विज्ञान में, कार्यक्रम संश्लेषण एक ऐसा कार्यक्रम बनाने का कार्य है किसी दिए गए उच्च-स्तरीय औपचारिक विनिर्देश को प्रमाणित करता है। कार्यक्रम सत्यापन के विपरीत, कार्यक्रम दिए जाने के बजाय निर्मित किया जाना है; तथापि, दोनों क्षेत्र औपचारिक प्रमाण तकनीकों का उपयोग करते हैं, और दोनों में स्वचालितकरण की विभिन्न डिग्री के दृष्टिकोण सम्मिलित हैं। स्वचालित प्रोग्रामिंग तकनीकों के विपरीत, कार्यक्रम संश्लेषण में विनिर्देश सामान्यतः एक उपयुक्त तार्किक कलन में गैर-एल्गोरिदमिक कथन होते हैं।

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

तब से, विभिन्न अनुसंधान समुदायों ने कार्यक्रम संश्लेषण की समस्या पर विचार किया। उल्लेखनीय कार्यों में बुच्ची और लैंडवेबर द्वारा 1969 ऑटोमेटा-सैद्धांतिक दृष्टिकोण, और मन्ना और वाल्डिंगर (सी। 1980) द्वारा कार्य सम्मिलित हैं। आधुनिक उच्च-स्तरीय प्रोग्रामिंग भाषाओं के विकास को कार्यक्रम संश्लेषण के एक रूप के रूप में भी समझा जा सकता है।

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

मन्ना और वाल्डिंगर की रूपरेखा
1980 में प्रकाशित मन्ना और वाल्डिंगर का ढांचा, उपयोगकर्ता द्वारा दिए गए पहले-क्रम विनिर्देश सूत्र से प्रारंभ होता है। उस सूत्र के लिए, एक प्रमाण का निर्माण किया जाता है, जिससे एक कार्यात्मक कार्यक्रम को एकीकृत प्रतिस्थापन से भी संश्लेषित किया जाता है।

ढांचे को तालिका लेआउट में प्रस्तुत किया गया है, जिसमें कॉलम सम्मिलित हैं: प्रारंभ में, पृष्ठभूमि ज्ञान, पूर्व-शर्तें और पश्च-शर्तें तालिका में दर्ज की जाती हैं। उसके बाद, उपयुक्त प्रमाण नियम मैन्युअल रूप से लागू किए जाते हैं। ढांचे को मध्यवर्ती सूत्रों की मानव पठनीयता को बढ़ाने के लिए डिज़ाइन किया गया है: शास्त्रीयसंकल्प के विपरीत, इसे क्लॉसल सामान्य रूप की आवश्यकता नहीं होती है, लेकिन मनमाना संरचना के सूत्रों के साथ तर्क करने की अनुमति देता है और किसी भी जंक्शनर्स ("गैर-खंड संकल्प") को सम्मिलित करता है। प्रमाण कब पूरा होता है $$\it true$$ लक्ष्य स्तंभ में व्युत्पन्न किया गया है, या, समकक्ष रूप से, $$\it false$$ अभिकथन कॉलम में। इस दृष्टिकोण से प्राप्त कार्यक्रम से प्रारंभ होने वाले विनिर्देश सूत्र को पूरा करने की गारंटी है; इस अर्थ में वे निर्माण द्वारा सही हैं। केवल एक न्यूनतावादी, अभी तक ट्यूरिंग-पूर्ण, विशुद्ध रूप से कार्यात्मक प्रोग्रामिंग भाषा, जिसमें सशर्त, पुनरावर्तन और अंकगणित और अन्य ऑपरेटर सम्मिलित हैं समर्थित है। इस ढांचे के भीतर किए गए मामले के अध्ययन ने गणना करने के लिए एल्गोरिदम को संश्लेषित किया उदाहरण के लिए विभाजन, शेष, वर्गमूल, एकीकरण, संबंधपरक डेटाबेस प्रश्नों के उत्तर और कई छँटाई एल्गोरिदम।
 * संदर्भ उद्देश्यों के लिए एक पंक्ति संख्या ("एनआर")।
 * सूत्र जो पहले से ही स्थापित किए जा चुके हैं, जिनमें स्वयंसिद्ध और पूर्व शर्त सम्मिलित हैं, ("अभिकथन")
 * फॉर्मूले अभी भी सिद्ध होने बाकी हैं, पोस्टकंडिशन (लक्ष्य), सम्मिलित हैं
 * वैध आउटपुट वैल्यू ("प्रोग्राम") को दर्शाने वाली शर्तें
 * वर्तमान पंक्ति के लिए एक औचित्य ("उत्पत्ति")

सबूत नियम
प्रमाण नियमों में शामिल हैं:
 * नॉन-क्लॉज़ल रेज़ोल्यूशन (तर्क) (तालिका देखें)।
 * उदाहरण के लिए, अभिकथन सूत्रों को हल करके पंक्ति 55 प्राप्त की जाती है $$E$$ 51 से और $$F$$ 52 से जो दोनों कुछ सामान्य उपसूत्र साझा करते हैं $$p$$. विलायक के विघटन के रूप में बनता है $$E$$, साथ $$p$$ द्वारा प्रतिस्थापित $$\it true$$, और $$F$$, साथ $$p$$ द्वारा प्रतिस्थापित $$\it false$$. यह विलायक तार्किक रूप से के संयोजन से अनुसरण करता है $$E$$ और $$F$$. आम तौर पर अधिक, $$E$$ और $$F$$ केवल दो अविवेकी उपसूत्रों की आवश्यकता है $$p_1$$ और $$p_2$$, क्रमश; उनके विलायक तब से बनते हैं $$E \theta$$ और $$F \theta$$ पहले की तरह, कहाँ $$\theta$$ का सबसे सामान्य एकीकरणकर्ता है $$p_1$$ और $$p_2$$. यह नियम पहले क्रम के तर्क में संकल्प (तर्क) #संकल्प का सामान्यीकरण करता है।
 * पैरेंट फ़ार्मुलों की कार्यक्रमशर्तों को संयोजित किया जाता है, जैसा कि पंक्ति 58 में दिखाया गया है ताकि रिज़ॉल्वेंट का आउटपुट तैयार किया जा सके। सामान्य मामले में, $$\theta$$ बाद पर भी लागू होता है। सबफॉर्मूला के बाद से $$p$$ आउटपुट में दिखाई देता है, गणना योग्य गुणों के अनुरूप केवल उप सूत्रों पर हल करने के लिए देखभाल की जानी चाहिए।


 * तार्किक परिवर्तन।
 * उदाहरण के लिए, $$E \land (F \lor G)$$ में परिवर्तित किया जा सकता है $$(E \land F) \lor (E \land G)$$) अभिकथन के साथ-साथ लक्ष्यों में भी, क्योंकि दोनों समतुल्य हैं।


 * संयोजक अभिकथनों और वियोजनात्मक लक्ष्यों का विभाजन।
 * नीचे दिए गए खिलौने के उदाहरण की 11 से 13 पंक्तियों में एक उदाहरण दिखाया गया है।


 * संरचनात्मक प्रेरण।
 * यह नियम पुनरावर्ती कार्य (प्रोग्रामिंग) के संश्लेषण की अनुमति देता है। दी गई पूर्व और पश्‍चात शर्त के लिए $$x$$ ऐसा है कि $$\textit{pre}(x)$$, पाना $$f(x) = y$$ ऐसा है कि $$\textit{post}(x,y)$$, और एक उपयुक्त उपयोगकर्ता द्वारा दिया गया सुव्यवस्थित आदेश $$\prec$$ के डोमेन का $$x$$, एक अभिकथन जोड़ना हमेशा सही होता है$$x' \prec x \land \textit{pre}(x') \implies \textit{post}(x',f(x'))$$. इस अभिकथन के साथ समाधान करने के लिए एक पुनरावर्ती कॉल का परिचय दिया जा सकता है $$f$$ कार्यक्रम अवधि में।
 * मन्ना, वाल्डिंगर (1980), पृष्ठ 108-111 में एक उदाहरण दिया गया है, जहां दो दिए गए पूर्णांकों के भागफल और शेष की गणना करने के लिए एक एल्गोरिथ्म को अच्छी तरह से क्रम का उपयोग करके संश्लेषित किया जाता है। $$(n',d') \prec (n,d)$$ द्वारा परिभाषित $$0 \leq n' < n$$ (पृष्ठ 110)।

मुर्रे ने इन नियमों को प्रथम-क्रम तर्क के लिए पूर्णता (तर्क) के रूप में दिखाया है। 1986 में, मन्ना और वाल्डिंगर ने समानता को संभालने के लिए सामान्यीकृत ई-रिज़ॉल्यूशन और पैरामॉड्यूलेशन नियम जोड़े; बाद में, ये नियम अधूरे निकले (लेकिन फिर भी सुदृढ़ता)।

उदाहरण
एक खिलौना उदाहरण के रूप में, अधिकतम गणना करने के लिए एक कार्यात्मक कार्यक्रम $$M$$ दो नंबर का $$x$$ और $$y$$ निम्नानुसार व्युत्पन्न किया जा सकता है।

आवश्यकता विवरण से शुरू करते हुए अधिकतम किसी भी संख्या से बड़ा या उसके बराबर है, और दी गई संख्याओं में से एक है, प्रथम-क्रम सूत्र $$\forall X \forall Y \exists M: X \leq M \land Y \leq M \land (X=M \lor Y=M)$$ इसके औपचारिक अनुवाद के रूप में प्राप्त किया जाता है। इस सूत्र को सिद्ध करना है। रिवर्स विद्वता  द्वारा, पंक्ति 10 में विनिर्देश प्राप्त किया गया है, क्रमशः एक चर और एक स्कोलेम स्थिरांक को दर्शाने वाला एक अपर- और लोअर-केस अक्षर।

पंक्ति 11 में वितरण नियम के लिए रूपांतरण नियम लागू करने के बाद, प्रमाण लक्ष्य एक संयोजन है, और इसलिए इसे दो मामलों में विभाजित किया जा सकता है, अर्थात। लाइन 12 और 13।

पहले मामले की ओर मुड़ते हुए, पंक्ति 12 को पंक्ति 1 में स्वयंसिद्ध के साथ हल करने से प्रतिस्थापन (तर्क) होता है # कार्यक्रम चर का पहला-क्रम तर्क $$M$$ पंक्ति 14 में। सहज रूप से, पंक्ति 12 का अंतिम संयोजन मूल्य निर्धारित करता है $$M$$ इस मामले में लेना चाहिए। औपचारिक रूप से, उपरोक्त पंक्ति 57 में दिखाया गया गैर-खंड संकल्प नियम 12 और 1 पंक्तियों पर लागू होता है उपज $$\lnot ($$$p$$x=x$$A=A$$x=M$$F[$$$)$$, जो सरल करता है $$x \leq x \land y \leq x$$.
 * $p$ सामान्य उदाहरण होने के नाते $]$ का $true ∧$ और $x=x$, वाक्य-विन्यास एकीकरण (कंप्यूटर विज्ञान) द्वारा प्राप्त # पहले-क्रम की शर्तों के बाद के सूत्रों का वाक्य-विन्यास एकीकरण,
 * $F[⋅]$$p$$G[$ प्राणी $p$$]$, प्रतिस्थापन (तर्क) से प्राप्त # प्रथम-क्रम तर्क पंक्ति 1 (संदर्भ बनाने के लिए उचित रूप से गद्देदार $x ≤ x ∧ y ≤ x ∧$ आस-पास $x = x$ दृश्यमान), और
 * $true ∧$$false$$) ∧ ($ प्राणी $x ≤ x ∧ y ≤ x ∧$$true$, तात्कालिक रेखा 12 से प्राप्त,

इसी तरह, लाइन 14 से लाइन 15 और फिर लाइन 16 रेजोल्यूशन से मिलती है। साथ ही, दूसरा मामला, $$x \leq M \land y \leq M \land y = M$$ लाइन 13 में, इसी तरह से संभाला जाता है, अंत में लाइन 18 की उपज होती है।

अंतिम चरण में, दोनों स्थितियाँ (यानी पंक्तियाँ 16 और 18) जुड़ जाती हैं, पंक्ति 58 से संकल्प नियम का उपयोग करते हुए; उस नियम को लागू करने के लिए प्रारंभिक चरण 15→16 की आवश्यकता थी। सहज रूप से, लाइन 18 को मामले की तरह पढ़ा जा सकता है $$x \leq y$$, उत्पादन $$y$$ मान्य है (मूल विनिर्देशन के संबंध में), जबकि पंक्ति 15 कहती है case $$y \leq x$$, उत्पादन $$x$$ यह सही है; चरण 15→16 ने स्थापित किया कि दोनों मामले 16 और 18 पूरक हैं। चूँकि 16 और 18 दोनों पंक्तियाँ एक कार्यक्रमटर्म के साथ आती हैं, a ?: कार्यक्रमकॉलम में परिणाम देता है। लक्ष्य सूत्र के बाद से $$\textit{true}$$ व्युत्पन्न किया गया है, प्रमाण किया गया है, और का कार्यक्रम स्तंभ$$\textit{true}$$लाइन में कार्यक्रम शामिल है।

यह भी देखें

 * आगमनात्मक प्रोग्रामिंग
 * मेटाप्रोग्रामिंग
 * कार्यक्रम व्युत्पत्ति
 * प्राकृतिक भाषा प्रोग्रामिंग
 * प्रतिक्रियाशील संश्लेषण