Q (Kx Systems से प्रोग्रामिंग भाषा): Difference between revisions

From Vigyanwiki
(Created page with "{{Short description|Proprietary array programming language}} {{Distinguish|Q (equational programming language)}} {{Infobox programming language |name = q |logo = |paradigm = [...")
 
No edit summary
Line 1: Line 1:
{{Short description|Proprietary array programming language}}
{{Distinguish|Q (समतुल्य प्रोग्रामिंग भाषा) के साथ भ्रमित न हों।}}
{{Distinguish|Q (equational programming language)}}
{{Infobox programming language
{{Infobox programming language
|name = q
|name = q
Line 24: Line 23:
}}
}}


Q ऐरे डेटा संरचना प्रसंस्करण के लिए एक [[प्रोग्रामिंग भाषा]] है, जिसे [[आर्थर व्हिटनी (कंप्यूटर वैज्ञानिक)]] द्वारा विकसित किया गया है। यह [[मालिकाना सॉफ्टवेयर]] है, जिसका व्यवसायीकरण [[Kx Systems]] द्वारा किया गया है। Q [[kdb+]] के लिए क्वेरी भाषा के रूप में कार्य करता है, जो एक डिस्क आधारित और इन-मेमोरी [[डेटाबेस]]|इन-मेमोरी, कॉलम-ओरिएंटेड DBMS|कॉलम-आधारित डेटाबेस है। Kdb+ भाषा [[k (प्रोग्रामिंग भाषा)]] पर आधारित है, जो भाषा APL (प्रोग्रामिंग भाषा) का संक्षिप्त रूप है। Q, k के चारों ओर एक पतला आवरण है, जो अधिक पठनीय, अंग्रेजी जैसा इंटरफ़ेस प्रदान करता है। उपयोग के मामलों में से एक वित्तीय समय श्रृंखला विश्लेषण है, क्योंकि कोई सटीक समय मिलान नहीं कर सकता है। एक उदाहरण बोली और उससे पहले पूछे जाने वाले प्रश्न का मिलान करना है। दोनों टाइमस्टैम्प थोड़े अलग हैं और वैसे भी मेल खाते हैं।<ref>{{Cite web|url=https://code.kx.com/q/ref/|title=क्यू संदर्भ कार्ड|postscript=|access-date=15 April 2020}}</ref>
Q ऐरे डेटा संरचना प्रसंस्करण के लिए एक [[प्रोग्रामिंग भाषा]] है, जिसे [[आर्थर व्हिटनी (कंप्यूटर वैज्ञानिक)]] द्वारा विकसित किया गया है। यह [[मालिकाना सॉफ्टवेयर]] है, जिसका व्यवसायीकरण [[Kx Systems]] द्वारा किया गया है। Q [[kdb+]] के लिए क्वेरी भाषा के रूप में कार्य करता है, जो एक डिस्क आधारित और इन-मेमोरी [[डेटाबेस]]|इन-मेमोरी, कॉलम-ओरिएंटेड डीबीएमएस |कॉलम-आधारित डेटाबेस है। Kdb+ भाषा [[k (प्रोग्रामिंग भाषा)]] पर आधारित है, जो भाषा एपीएल (प्रोग्रामिंग भाषा) का संक्षिप्त रूप है। Q, k के चारों ओर एक पतला आवरण है, जो अधिक पठनीय, अंग्रेजी जैसा इंटरफ़ेस प्रदान करता है। उपयोग के मामलों में से एक वित्तीय समय श्रृंखला विश्लेषण है, क्योंकि कोई सटीक समय मिलान नहीं कर सकता है। एक उदाहरण बोली और उससे पहले पूछे जाने वाले प्रश्न का मिलान करना है। दोनों टाइमस्टैम्प थोड़े अलग हैं और वैसे भी मेल खाते हैं।<ref>{{Cite web|url=https://code.kx.com/q/ref/|title=क्यू संदर्भ कार्ड|postscript=|access-date=15 April 2020}}</ref>
 
=='''अवलोकन'''==
 
q के मूलभूत निर्माण खंड परमाणु, सूचियाँ और कार्य हैं। परमाणु [[ अदिश (कंप्यूटिंग) ]] हैं और इसमें [[डेटा प्रकार]] संख्यात्मक, वर्ण, दिनांक और समय सम्मिलित हैं। [[सूची (कंप्यूटिंग)]] परमाणुओं (या अन्य सूचियों) का क्रमबद्ध संग्रह है, जिस पर उच्च स्तरीय डेटा संरचनाएं [[सहयोगी सरणी]] और [[तालिका (डेटाबेस)]] आंतरिक रूप से निर्मित होती हैं। शब्दकोश मानों की सूची की कुंजियों की सूची का एक मानचित्र है। एक तालिका प्रतीक कुंजियों और मानों के रूप में समान लंबाई वाली सूचियों (स्तंभों) का एक ट्रांसपोज़्ड शब्दकोश है। एक कुंजीयुक्त तालिका, उस तालिका के समान होती है जिस पर एक अद्वितीय कुंजी रखी होती है, एक शब्दकोश है जहां कुंजी और मान दो तालिकाओं के रूप में व्यवस्थित होते हैं।
==अवलोकन==
q के मूलभूत निर्माण खंड परमाणु, सूचियाँ और कार्य हैं। परमाणु [[ अदिश (कंप्यूटिंग) ]] हैं और इसमें [[डेटा प्रकार]] संख्यात्मक, वर्ण, दिनांक और समय शामिल हैं। [[सूची (कंप्यूटिंग)]] परमाणुओं (या अन्य सूचियों) का क्रमबद्ध संग्रह है, जिस पर उच्च स्तरीय डेटा संरचनाएं [[सहयोगी सरणी]] और [[तालिका (डेटाबेस)]] आंतरिक रूप से निर्मित होती हैं। शब्दकोश मानों की सूची की कुंजियों की सूची का एक मानचित्र है। एक तालिका प्रतीक कुंजियों और मानों के रूप में समान लंबाई वाली सूचियों (स्तंभों) का एक ट्रांसपोज़्ड शब्दकोश है। एक कुंजीयुक्त तालिका, उस तालिका के समान होती है जिस पर एक अद्वितीय कुंजी रखी होती है, एक शब्दकोश है जहां कुंजी और मान दो तालिकाओं के रूप में व्यवस्थित होते हैं।


निम्नलिखित कोड डेटा संरचनाओं के संबंधों को प्रदर्शित करता है। मूल्यांकन करने के लिए अभिव्यक्तियाँ के साथ उपसर्ग दिखाई देती हैं <code>q)</code> शीघ्र, नीचे दिखाए गए मूल्यांकन के आउटपुट के साथ:
निम्नलिखित कोड डेटा संरचनाओं के संबंधों को प्रदर्शित करता है। मूल्यांकन करने के लिए अभिव्यक्तियाँ के साथ उपसर्ग दिखाई देती हैं <code>q)</code> शीघ्र, नीचे दिखाए गए मूल्यांकन के आउटपुट के साथ:
Line 63: Line 60:
jack| 60
jack| 60
</syntaxhighlight>
</syntaxhighlight>
इन संस्थाओं को फ़ंक्शंस के माध्यम से हेरफेर किया जाता है, जिसमें Q के साथ आने वाले अंतर्निहित फ़ंक्शंस (जिन्हें K (प्रोग्रामिंग भाषा) मैक्रोज़ के रूप में परिभाषित किया गया है) और उपयोगकर्ता-परिभाषित फ़ंक्शंस शामिल हैं। फ़ंक्शंस एक डेटा प्रकार हैं, और इन्हें सूचियों, शब्दकोशों और तालिकाओं में रखा जा सकता है, या पैरामीटर के रूप में अन्य फ़ंक्शंस में पास किया जा सकता है।
इन संस्थाओं को फ़ंक्शंस के माध्यम से हेरफेर किया जाता है, जिसमें Q के साथ आने वाले अंतर्निहित फ़ंक्शंस (जिन्हें K (प्रोग्रामिंग भाषा) मैक्रोज़ के रूप में परिभाषित किया गया है) और उपयोगकर्ता-परिभाषित फ़ंक्शंस सम्मिलित हैं। फ़ंक्शंस एक डेटा प्रकार हैं, और इन्हें सूचियों, शब्दकोशों और तालिकाओं में रखा जा सकता है, या पैरामीटर के रूप में अन्य फ़ंक्शंस में पास किया जा सकता है।


==उदाहरण==
==उदाहरण==
Line 134: Line 131:
  60 | 1
  60 | 1
</syntaxhighlight>
</syntaxhighlight>
==संदर्भ==
==संदर्भ==
{{reflist}}
{{reflist}}
==अग्रिम पठन==
==अग्रिम पठन==
*{{cite book|last=Borror|first=Jeffry A|title=Q For Mortals: A Tutorial in Q Programming|isbn=978-1-4348-2901-6}}
*{{cite book|last=उधारकर्ता|first=जेफरी ए|title=क्यू फॉर मॉर्टल्स: क्यू प्रोग्रामिंग में एक ट्यूटोरियल|isbn=978-1-4348-2901-6}}
*{{cite book|last=Psaris|first=Nick|title=Q Tips: Fast, Scalable and Maintainable Kdb+|isbn=978-9-8813-8990-9}}
*{{cite book|last=पसरिस|first=निक|title=क्यू युक्तियाँ: तेज़, स्केलेबल और रखरखाव योग्य केडीबी+|isbn=978-9-8813-8990-9}}
 
 
==बाहरी संबंध==
==बाहरी संबंध==
* {{Official website|kx.com}}, Kx Systems
* {{Official website|kx.com}}, Kx Systems

Revision as of 10:50, 4 August 2023

q
ParadigmArray, functional
द्वारा डिज़ाइन किया गयाArthur Whitney
DeveloperKx Systems
पहली प्रस्तुति2003[1]
Stable release
4.0 / March 17, 2020; 4 years ago (2020-03-17)[2]
टाइपिंग अनुशासनDynamic, strong
वेबसाइटcode.kx.com
Influenced by
A+, APL, Scheme, k

Q ऐरे डेटा संरचना प्रसंस्करण के लिए एक प्रोग्रामिंग भाषा है, जिसे आर्थर व्हिटनी (कंप्यूटर वैज्ञानिक) द्वारा विकसित किया गया है। यह मालिकाना सॉफ्टवेयर है, जिसका व्यवसायीकरण Kx Systems द्वारा किया गया है। Q kdb+ के लिए क्वेरी भाषा के रूप में कार्य करता है, जो एक डिस्क आधारित और इन-मेमोरी डेटाबेस|इन-मेमोरी, कॉलम-ओरिएंटेड डीबीएमएस |कॉलम-आधारित डेटाबेस है। Kdb+ भाषा k (प्रोग्रामिंग भाषा) पर आधारित है, जो भाषा एपीएल (प्रोग्रामिंग भाषा) का संक्षिप्त रूप है। Q, k के चारों ओर एक पतला आवरण है, जो अधिक पठनीय, अंग्रेजी जैसा इंटरफ़ेस प्रदान करता है। उपयोग के मामलों में से एक वित्तीय समय श्रृंखला विश्लेषण है, क्योंकि कोई सटीक समय मिलान नहीं कर सकता है। एक उदाहरण बोली और उससे पहले पूछे जाने वाले प्रश्न का मिलान करना है। दोनों टाइमस्टैम्प थोड़े अलग हैं और वैसे भी मेल खाते हैं।[3]

अवलोकन

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

निम्नलिखित कोड डेटा संरचनाओं के संबंधों को प्रदर्शित करता है। मूल्यांकन करने के लिए अभिव्यक्तियाँ के साथ उपसर्ग दिखाई देती हैं q) शीघ्र, नीचे दिखाए गए मूल्यांकन के आउटपुट के साथ:

q)`john / an atom of type symbol
`john
q)50    / an atom of type integer
50

q)`john`jack / a list of symbols
`john`jack
q)50 60 / a list of integers
50 60

q)`john`jack!50 60 / a list of symbols and a list of integers combined to form a dictionary
john| 50
jack| 60

q)`name`age!(`john`jack;50 60) / an arrangement termed a column dictionary
name| john jack
age | 50   60

q)flip `name`age!(`john`jack;50 60) / when transposed via the function "flip", the column dictionary becomes a table
name age
--------
john 50
jack 60

q)(flip (enlist `name)!enlist `john`jack)!flip (enlist `age)!enlist 50 60  / two equal length tables combined as a dictionary become a keyed table
name| age
----| ---
john| 50
jack| 60

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

उदाहरण

K की तरह, Q की व्याख्या की जाती है और किसी अभिव्यक्ति के मूल्यांकन का परिणाम तुरंत प्रदर्शित किया जाता है, जब तक कि अर्ध-विराम के साथ समाप्त न किया जाए। हैलो वर्ल्ड कार्यक्रम इस प्रकार तुच्छ है:

q)"Hello world!"
"Hello world!"

निम्नलिखित अभिव्यक्ति वेरिएबल x में संग्रहीत स्ट्रिंग्स की सूची को उनकी लंबाई के आधार पर क्रमबद्ध करती है:

x@idesc count each x

अभिव्यक्ति का मूल्यांकन दाएं से बाएं इस प्रकार किया जाता है:

  1. प्रत्येक x की गणना करें, सूची x में प्रत्येक शब्द की लंबाई लौटाएं।
  2. idesc सूचकांक लौटाता है जो मानों की सूची को घटते क्रम में क्रमबद्ध करेगा।
  3. @ स्ट्रिंग्स की मूल सूची में अनुक्रमणिका के दाईं ओर पूर्णांक मानों का उपयोग करें।

फैक्टोरियल फ़ंक्शन को सीधे Q रूप में कार्यान्वित किया जा सकता है

{prd 1+til x}

या पुनरावर्ती रूप में

{$[x=0;1;x*.z.s[x-1]]}

ध्यान दें कि दोनों ही मामलों में फ़ंक्शन अंतर्निहित रूप से x नामक एक एकल तर्क लेता है - सामान्य तौर पर x, y और z नामक तीन अंतर्निहित तर्कों का उपयोग करना संभव है, या स्थानीय चर बाइंडिंग को स्पष्ट रूप से तर्क देना संभव है।

प्रत्यक्ष कार्यान्वयन में, अभिव्यक्ति til x 0 से x-1 तक पूर्णांकों की गणना करता है, 1+ सूची के प्रत्येक तत्व में 1 जोड़ता है और prd सूची का उत्पाद लौटाता है।

पुनरावर्ती कार्यान्वयन में, सिंटैक्स $[condition; expr1; expr2] एक टर्नरी सशर्त है - यदि शर्त सत्य है तो expr1 वापस कर दिया जाता है; अन्यथा expr2 लौटा दिया जाता है। अभिव्यक्ति .z.s जावा में 'यह' या पायथन में 'स्वयं' के बराबर है - यह युक्त वस्तु का एक संदर्भ है, और q में फ़ंक्शन को स्वयं को कॉल करने में सक्षम बनाता है।

जब x 2 से बड़ा पूर्णांक है, तो निम्न फ़ंक्शन 1 लौटाएगा यदि यह अभाज्य है, अन्यथा 0:

{min x mod 2_til x}

फ़ंक्शन का मूल्यांकन दाएं से बाएं ओर किया जाता है:

  1. x तक x से कम गैर-नकारात्मक पूर्णांकों की गणना करें।
  2. 2_ गणना के पहले दो तत्वों (0 और 1) को हटा देता है।
  3. x मॉड मूल पूर्णांक और काटी गई सूची में प्रत्येक मान के बीच मॉड्यूलो विभाजन करता है।
  4. न्यूनतम मॉड्यूलो परिणाम की सूची का न्यूनतम मान ज्ञात करें।

क्यू प्रोग्रामिंग भाषा में अपना स्वयं का टेबल क्वेरी सिंटैक्स होता है जिसे qSQL कहा जाता है, जो पारंपरिक एसक्यूएल जैसा दिखता है लेकिन इसमें महत्वपूर्ण अंतर हैं, मुख्य रूप से इस तथ्य के कारण कि अंतर्निहित टेबल पंक्ति के बजाय कॉलम द्वारा उन्मुख होते हैं।

q)show t:([] name:`john`jack`jill`jane; age: 50 60 50 20) / define a simple table and assign to "t"
name age
--------
john 50
jack 60
jill 50
jane 20
 q)select from t where name like "ja*",age>50
 name age
 --------
 jack 60
 
 q)select rows:count i by age from t
 age| rows
 ---| ----
 20 | 1
 50 | 2
 60 | 1

संदर्भ

  1. "Q Language Widening the Appeal of Vectors". Archived from the original on January 1, 2007. Retrieved June 1, 2016.{{cite web}}: CS1 maint: unfit URL (link)
  2. "Changes in 4.0" (Press release). Palo Alto: Kx Systems. Mar 17, 2020. Retrieved Apr 15, 2020.
  3. "क्यू संदर्भ कार्ड". Retrieved 15 April 2020.

अग्रिम पठन

  • उधारकर्ता, जेफरी ए. क्यू फॉर मॉर्टल्स: क्यू प्रोग्रामिंग में एक ट्यूटोरियल. ISBN 978-1-4348-2901-6.
  • पसरिस, निक. क्यू युक्तियाँ: तेज़, स्केलेबल और रखरखाव योग्य केडीबी+. ISBN 978-9-8813-8990-9.

बाहरी संबंध