सिम्पी - क्विक गाइड
प्रतीकात्मक गणना करने के लिए सिम्पी एक पायथन लाइब्रेरी है। यह है एकcomputer algebra system(कैस) जिसका उपयोग या तो स्टैंडअलोन एप्लिकेशन के रूप में किया जा सकता है, अन्य अनुप्रयोगों के लिए एक पुस्तकालय के रूप में। इसका लाइव सत्र भी उपलब्ध हैhttps://live.sympy.org/। चूंकि यह एक शुद्ध पायथन लाइब्रेरी है, इसलिए इसे इंटरएक्टिव मोड के रूप में और प्रोग्रामेटिक एप्लिकेशन के रूप में उपयोग किया जा सकता है। SymPy अब वैज्ञानिक पायथन पारिस्थितिकी तंत्र के लिए एक लोकप्रिय प्रतीकात्मक पुस्तकालय बन गया है।
SymPy में मूलभूत प्रतीकात्मक अंकगणित, कलन, बीजगणित, असतत गणित, क्वांटम भौतिकी, आदि के क्षेत्र में कई तरह की सुविधाएँ लागू हैं। SymPy, LaTeX, MathML, आदि सहित विभिन्न प्रकार के स्वरूपों में परिणाम स्वरूपित करने में सक्षम है। नया बीएसडी लाइसेंस। के नेतृत्व में डेवलपर्स की एक टीमOndřej Čertík तथा Aaron Meurer 2007 में SymPy का पहला संस्करण प्रकाशित हुआ। इसका वर्तमान संस्करण 1.5.1 है।
सिम्पी के अनुप्रयोगों के कुछ क्षेत्र हैं -
- Polynomials
- Calculus
- असतत गणित
- Matrices
- Geometry
- Plotting
- Physics
- Statistics
- Combinatorics
SymPy में एक महत्वपूर्ण पूर्वापेक्षित पुस्तकालय है mpmath। यह मनमाना परिशुद्धता के साथ वास्तविक और जटिल फ्लोटिंग-पॉइंट अंकगणित के लिए एक पायथन लाइब्रेरी है। हालाँकि, जब सिम्पी को निम्नानुसार स्थापित किया जाता है, तो पायथन का पैकेज इंस्टॉलर पीआईपी इसे स्वचालित रूप से स्थापित करता है -
pip install sympy
अन्य पायथन वितरण जैसे कि एनाकोंडा, सेंसिटिव कैनोपी इत्यादि में सिम्पी पहले से ही बंडल हो सकती है। सत्यापित करने के लिए, आप पायथन प्रॉम्प्ट में निम्नलिखित लिख सकते हैं -
>>> import sympy
>>> sympy.__version__
और आपको सहानुभूति के वर्तमान संस्करण के रूप में नीचे का आउटपुट मिलता है -
'1.5.1'
SymPy पैकेज का सोर्स कोड उपलब्ध है https://github.com/sympy/sympy।
प्रतीकात्मक गणना गणितीय अभिव्यक्तियों और अन्य गणितीय वस्तुओं में हेरफेर के लिए एल्गोरिदम के विकास को संदर्भित करता है। प्रतीकात्मक अभिकलन गणितीय प्रतीकों का उपयोग करके गणितीय अभिव्यक्तियों को हल करने के लिए कंप्यूटर विज्ञान के साथ गणित को एकीकृत करता है। एक कंप्यूटर बीजगणित प्रणाली (CAS) जैसे कि SymPy बीजीय अभिव्यक्तियों का मूल्यांकन करता है (लगभग नहीं) उन्हीं प्रतीकों का उपयोग करके जो पारंपरिक मैनुअल विधि में उपयोग किए जाते हैं। उदाहरण के लिए, हम पायथन के गणित मॉड्यूल का उपयोग करके एक संख्या के वर्गमूल की गणना करते हैं, जैसा कि नीचे दिया गया है -
>>> import math
>>> print (math.sqrt(25), math.sqrt(7))
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
5.0 2.6457513110645907
जैसा कि आप देख सकते हैं, 7 के वर्गमूल की गणना लगभग की जाती है। लेकिन संख्याओं की SymPy वर्गाकार जड़ों में, जो कि पूर्ण वर्ग नहीं हैं, डिफ़ॉल्ट रूप से नीचे दिए गए के रूप में बिना बचे हुए हैं -
>>> import sympy
>>> print (sympy.sqrt(7))
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
sqrt(7)
नीचे कोड स्निपेट के साथ प्रतीकात्मक रूप से अभिव्यक्ति के परिणाम को सरल और दिखाना संभव है -
>>> import math
>>> print (math.sqrt(12))
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
3.4641016151377544
आपको सिम्पी का उपयोग करके उसी कोड को निष्पादित करने के लिए नीचे दिए गए कोड स्निपेट का उपयोग करने की आवश्यकता है -
##sympy output
>>> print (sympy.sqrt(12))
और उसके लिए आउटपुट निम्नानुसार है -
2*sqrt(3)
सिम्पी कोड, जब ज्यूपिटर नोटबुक में चलाया जाता है, गणित के प्रतीकों को लैटेक्स के रूप में प्रस्तुत करने के लिए MathJax लाइब्रेरी का उपयोग करता है। इसे नीचे दिए गए कोड स्निपेट में दिखाया गया है -
>>> from sympy import *
>>> x=Symbol ('x')
>>> expr = integrate(x**x, x)
>>> expr
अजगर शेल में उपरोक्त कमांड निष्पादित करने पर, निम्नलिखित आउटपुट उत्पन्न होंगे -
Integral(x**x, x)
के बराबर है
$\int \mathrm{x}^{x}\,\mathrm{d}x$
एक गैर-पूर्ण वर्ग का वर्गमूल पारंपरिक प्रतीक का उपयोग करते हुए लेटेक्स द्वारा दर्शाया जा सकता है -
>>> from sympy import *
>>> x=7
>>> sqrt(x)
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
$\sqrt7$
प्रतीकात्मक गणना प्रणाली जैसे कि SymPy प्रतीकात्मक रूप से सभी प्रकार की संगणनाएँ (जैसे कि व्युत्पन्न, अभिन्न और सीमाएँ, समीकरणों को हल करना, कार्य करना) करती है। सिम्पी पैकेज में अलग-अलग मॉड्यूल होते हैं जो प्लॉटिंग, प्रिंटिंग (जैसे LATEX), फिजिक्स, स्टैटिस्टिक्स, कॉम्बिनेटरिक्स, नंबर थ्योरी, ज्योमेट्री, लॉजिक आदि को सपोर्ट करते हैं।
SymPy पैकेज में मुख्य मॉड्यूल में संख्या वर्ग होता है जो परमाणु संख्याओं का प्रतिनिधित्व करता है। इस वर्ग में दो उपवर्ग हैं: फ्लोट और तर्कसंगत वर्ग। इंटेगर क्लास द्वारा रैशनल क्लास को आगे बढ़ाया जाता है।
फ्लोट वर्ग मनमानी परिशुद्धता के एक अस्थायी बिंदु संख्या का प्रतिनिधित्व करता है।
>>> from sympy import Float
>>> Float(6.32)
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
6.32
SymPy एक पूर्णांक या एक स्ट्रिंग को फ्लोट में बदल सकता है।
>>> Float(10)
10.0
Float('1.33E5')# scientific notation
133000.0
फ्लोट में परिवर्तित करते समय, नीचे दिए गए अनुसार सटीक के लिए अंकों की संख्या निर्दिष्ट करना भी संभव है -
>>> Float(1.33333,2)
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
1.3
संख्या का एक प्रतिनिधित्व (p / q) गैर-शून्य संख्या के साथ q के साथ परिमेय वर्ग के ऑब्जेक्ट के रूप में दर्शाया गया है।
>>> Rational(3/4)
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
$\frac{3}{4}$
यदि एक फ़्लोटिंग पॉइंट नंबर तर्कसंगत () निर्माता को पास किया जाता है, तो यह उसके बाइनरी प्रतिनिधित्व के अंतर्निहित मूल्य को वापस करता है
>>> Rational(0.2)
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
$\frac{3602879701896397}{18014398509481984}$
सरल प्रतिनिधित्व के लिए, हर सीमा को निर्दिष्ट करें।
>>> Rational(0.2).limit_denominator(100)
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
$\frac{1}{5}$
जब एक स्ट्रिंग को तर्कसंगत () निर्माता को पास किया जाता है, तो मनमाना परिशुद्धता की एक तर्कसंगत संख्या वापस आ जाती है।
>>> Rational("3.65")
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
$\frac{73}{20}$
यदि दो नंबर तर्क पारित किए जाते हैं तो तर्कसंगत वस्तु भी प्राप्त की जा सकती है। गुणक और हर के हिस्से गुण के रूप में उपलब्ध हैं।
>>> a=Rational(3,5)
>>> print (a)
>>> print ("numerator:{}, denominator:{}".format(a.p, a.q))
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
3/5
numerator:3, denominator:5
>>> a
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
$\frac{3}{5}$
सिम्पी में इंटेगर वर्ग किसी भी आकार के पूर्णांक संख्या का प्रतिनिधित्व करता है। कंस्ट्रक्टर एक फ्लोट या परिमेय संख्या को स्वीकार कर सकता है, लेकिन आंशिक भाग को छोड़ दिया जाता है
>>> Integer(10)
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
10
>>> Integer(3.4)
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
3
>>> Integer(2/7)
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
0
सिम्पी ने ए RealNumberवह वर्ग जो फ्लोट के लिए उपनाम के रूप में कार्य करता है। सिम्पी ने शून्य और वन को एकल वर्ग के रूप में भी परिभाषित किया है, जो क्रमशः एस.जेरो और एस.वन के साथ सुलभ है जैसा कि नीचे दिखाया गया है -
>>> S.Zero
आउटपुट इस प्रकार है -
0
>>> S.One
आउटपुट इस प्रकार है -
1
अन्य पूर्वनिर्धारित सिंगलटन नंबर ऑब्जेक्ट्स हाफ, नाएन, इन्फिनिटी और इमेजिनरी यूनीट हैं
>>> from sympy import S
>>> print (S.Half)
आउटपुट इस प्रकार है -
½
>>> print (S.NaN)
आउटपुट इस प्रकार है -
nan
इन्फिनिटी oo प्रतीक वस्तु या S.Infinity के रूप में उपलब्ध है
>>> from sympy import oo
>>> oo
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
$\infty$
>>> S.Infinity
उपरोक्त कोड स्निपेट के लिए आउटपुट निम्नानुसार है -
$\infty$
इमेजिनरी यूनेट नंबर को I प्रतीक के रूप में आयात किया जा सकता है या S.ImaginaryUnit के रूप में एक्सेस किया जा सकता है और -1 का वर्गमूल का प्रतिनिधित्व करता है
>>> from sympy import I
>>> I
जब आप उपरोक्त कोड स्निपेट निष्पादित करते हैं, तो आपको निम्न आउटपुट मिलते हैं -
i
>>> S.ImaginaryUnit
उपरोक्त स्निपेट का आउटपुट निम्नानुसार है -
i
>>> from sympy import sqrt
>>> i=sqrt(-1)
>>> i*i
जब आप उपरोक्त कोड स्निपेट निष्पादित करते हैं, तो आपको निम्न आउटपुट मिलते हैं -
-1
Symbolसहानुभूति पुस्तकालय में सबसे महत्वपूर्ण वर्ग है। जैसा कि पहले उल्लेख किया गया है, प्रतीकों के साथ प्रतीकात्मक गणना की जाती है। SymPy वैरिएबल Symbols क्लास की वस्तुएं हैं।
प्रतीक () फ़ंक्शन का तर्क एक स्ट्रिंग है जिसमें प्रतीक होता है जिसे एक चर को सौंपा जा सकता है।
>>> from sympy import Symbol
>>> x=Symbol('x')
>>> y=Symbol('y')
>>> expr=x**2+y**2
>>> expr
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$x^2 + y^2$
एक प्रतीक एक से अधिक वर्णों का हो सकता है।
>>> s=Symbol('side')
>>> s**3
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$side^3$
सिम्पी ने भी ए Symbols()फ़ंक्शन जो एक साथ कई प्रतीकों को परिभाषित कर सकता है। स्ट्रिंग में अल्पविराम या स्थान द्वारा अलग किए गए चर के नाम हैं।
>>> from sympy import symbols
>>> x,y,z=symbols("x,y,z")
सिम्पी के एबीसी मॉड्यूल में, सभी लैटिन और ग्रीक वर्णमाला को प्रतीकों के रूप में परिभाषित किया गया है। इसलिए, सिंबल ऑब्जेक्ट को इंस्टेंट करने के बजाय, यह विधि सुविधाजनक है।
>>> from sympy.abc import x,y,z
हालांकि, नाम C, O, S, I, N, E तथा Qपूर्वनिर्धारित प्रतीक हैं। इसके अलावा, एक से अधिक अक्षर वाले प्रतीकों को एबीसी मॉड्यूल में परिभाषित नहीं किया जाता है, जिसके लिए आपको ऊपर के रूप में प्रतीक वस्तु का उपयोग करना चाहिए। एबीसी मॉड्यूल विशेष नामों को परिभाषित करता है जो डिफ़ॉल्ट सिम्पी नामस्थान में परिभाषा का पता लगा सकते हैं। clash1 में एकल अक्षर हैं और clash2 में बहु अक्षर क्लैशिंग प्रतीक हैं
>>> from sympy.abc import _clash1, _clash2
>>> _clash1
उपरोक्त स्निपेट का आउटपुट निम्नानुसार है -
{'C': C, 'O': O, 'Q': Q, 'N': N, 'I': I, 'E': E, 'S': S}
>>> _clash2
उपरोक्त स्निपेट का आउटपुट निम्नानुसार है -
{'beta': beta, 'zeta': zeta, 'gamma': gamma, 'pi': pi}
अनुक्रमित प्रतीकों को सीमा () फ़ंक्शन के समान सिंटैक्स का उपयोग करके परिभाषित किया जा सकता है। रंग एक बृहदान्त्र द्वारा इंगित किए जाते हैं। प्रकार की सीमा बृहदान्त्र के दाईं ओर चरित्र द्वारा निर्धारित की जाती है। यदि itr एक अंक है, तो बाईं ओर के सभी सन्निहित अंकों को नॉनगेटिव प्रारंभिक मूल्य के रूप में लिया जाता है। दाईं ओर सभी सन्निहित अंकों को समाप्ति मूल्य से 1 से अधिक लिया जाता है।
>>> from sympy import symbols
>>> symbols('a:5')
उपरोक्त स्निपेट का आउटपुट निम्नानुसार है -
(a0, a1, a2, a3, a4)
>>> symbols('mark(1:4)')
उपरोक्त स्निपेट का आउटपुट निम्नानुसार है -
(mark1, mark2, mark3)
गणितीय अभिव्यक्ति पर किए जाने वाले सबसे बुनियादी कार्यों में से एक प्रतिस्थापन है। सिम्पी में उप () फ़ंक्शन पहले पैरामीटर की सभी घटनाओं को दूसरे के साथ बदल देता है।
>>> from sympy.abc import x,a
>>> expr=sin(x)*sin(x)+cos(x)*cos(x)
>>> expr
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\sin^2(x)+\cos^2(x)$
>>> expr.subs(x,a)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\sin^2(a)+\cos^2(a)$
यह फ़ंक्शन उपयोगी है अगर हम एक निश्चित अभिव्यक्ति का मूल्यांकन करना चाहते हैं। उदाहरण के लिए, हम 5 के साथ प्रतिस्थापित करके निम्नलिखित अभिव्यक्ति के मूल्यों की गणना करना चाहते हैं।
>>> expr=a*a+2*a+5
>>> expr
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$a^2 + 2a + 5$
expr.subs(a,5)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
40
>>> from sympy.abc import x
>>> from sympy import sin, pi
>>> expr=sin(x)
>>> expr1=expr.subs(x,pi)
>>> expr1
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
0
इस फ़ंक्शन का उपयोग किसी सबफ़ेक्सेशन को किसी अन्य सबफ़्रेप्रेशन के साथ बदलने के लिए भी किया जाता है। निम्नलिखित उदाहरण में, b को + b से बदल दिया गया है।
>>> from sympy.abc import a,b
>>> expr=(a+b)**2
>>> expr1=expr.subs(b,a+b)
>>> expr1
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$(2a + b)^2$
सहानुभूति () फ़ंक्शन का उपयोग किसी भी मनमानी अभिव्यक्ति को परिवर्तित करने के लिए किया जाता है जैसे कि इसे SymPy अभिव्यक्ति के रूप में उपयोग किया जा सकता है। सामान्य अजगर वस्तुओं जैसे पूर्णांक वस्तुओं को SymPy में परिवर्तित किया जाता है। पूर्णांक, आदि .., तार भी SymPy अभिव्यक्तियों में परिवर्तित होते हैं।
>>> expr="x**2+3*x+2"
>>> expr1=sympify(expr)
>>> expr1
>>> expr1.subs(x,2)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
12
किसी भी पायथन ऑब्जेक्ट को SymPy ऑब्जेक्ट में परिवर्तित किया जा सकता है। हालाँकि, चूंकि रूपांतरण आंतरिक रूप से eval () फ़ंक्शन का उपयोग करता है, इसलिए असमान अभिव्यक्ति का उपयोग नहीं किया जाना चाहिए, अन्यथा SympifyError को उठाया जाता है।
>>> sympify("x***2")
---------------------------------------------------------------------------
SympifyError: Sympify of अभिव्यक्ति 'अपवाद के कारण' x *** 2 'को पार्स नहीं कर सका, क्योंकि अपवाद को उठाया गया था।
सहानुभूति () फ़ंक्शन निम्न तर्कों को लेता है: * सख्त: डिफ़ॉल्ट गलत है। यदि इसे True पर सेट किया जाता है, तो केवल वे प्रकार जिनके लिए एक स्पष्ट रूपांतरण परिभाषित किया गया है, परिवर्तित किए जाते हैं। अन्यथा, SympifyError को उठाया जाता है। * मूल्यांकन: यदि गलत पर सेट किया गया है, तो अंकगणित और ऑपरेटरों को अभिव्यक्ति का मूल्यांकन किए बिना उनके सिम्पी समकक्षों में परिवर्तित किया जाएगा।
>>> sympify("10/5+4/2")
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
4
>>> sympify("10/5+4/2", evaluate=False)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
$\frac{10}{5}+\frac{4}{2}$
यह फ़ंक्शन दिए गए संख्यात्मक बिंदु का मूल्यांकन 100 अंकों तक एक दिए गए फ्लोटिंग पॉइंट सटीक तक करता है। यह फ़ंक्शन उप पैरामीटर को प्रतीकों के लिए संख्यात्मक मानों की एक शब्दकोश वस्तु लेता है। निम्नलिखित अभिव्यक्ति पर विचार करें
>>> from sympy.abc import r
>>> expr=pi*r**2
>>> expr
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\Pi{r^2}$
5 के साथ आर प्रतिस्थापित करके evalf () फ़ंक्शन का उपयोग करके उपरोक्त अभिव्यक्ति का मूल्यांकन करने के लिए
>>> expr.evalf(subs={r:5})
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
78.5398163397448
डिफ़ॉल्ट रूप से, फ्लोटिंग पॉइंट सटीक 15 अंकों तक होता है जिसे किसी भी संख्या में 100 तक ओवरराइड किया जा सकता है। सटीक का मूल्यांकन 20 अंकों तक किया जाता है।
>>> expr=a/b
>>> expr.evalf(20, subs={a:100, b:3})
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
33.333333333333333333
मेमने का कार्य पायथन कार्यों में सिम्पी के भावों का अनुवाद करता है। यदि एक अभिव्यक्ति का मूल्यांकन मूल्यों की एक बड़ी श्रृंखला पर किया जाना है, तो evalf () फ़ंक्शन कुशल नहीं है। lambdify एक लैम्ब्डा फ़ंक्शन की तरह कार्य करता है, सिवाय इसके कि सिम्पी के नामों को दिए गए संख्यात्मक लाइब्रेरी के नामों में परिवर्तित किया जाता है, आमतौर पर न्यूमपी। डिफ़ॉल्ट रूप से, गणित मानक पुस्तकालय में कार्यान्वयन पर लंबित करें।
>>> expr=1/sin(x)
>>> f=lambdify(x, expr)
>>> f(3.14)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
627.8831939138764
अभिव्यक्ति में एक से अधिक चर हो सकते हैं। उस स्थिति में, लैम्ब्डाइज़ () फ़ंक्शन का पहला तर्क चर की एक सूची है, जिसके बाद अभिव्यक्ति का मूल्यांकन किया जाना है।
>>> expr=a**2+b**2
>>> f=lambdify([a,b],expr)
>>> f(2,3)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
13
हालाँकि, संख्यात्मक पुस्तकालय को संख्यात्मक बैकएंड के रूप में उत्तोलन करने के लिए, हमें लैम्बडीज़ () फ़ंक्शन के तर्क के रूप में परिभाषित करना होगा।
>>> f=lambdify([a,b],expr, "numpy")
हम उपरोक्त फ़ंक्शन में दो तर्क ए और बी के लिए दो सुन्न सरणियों का उपयोग करते हैं। सुन्न सरणियों के मामले में निष्पादन का समय काफी तेज है।
>>> import numpy
>>> l1=numpy.arange(1,6)
>>> l2=numpy.arange(6,11)
>>> f(l1,l2)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
array([ 37, 53, 73, 97, 125], dtype=int32)
बूलियन कार्यों को परिभाषित किया गया है sympy.basic.booleanarg module। मानक अजगर ऑपरेटरों और (और) के साथ बूलियन अभिव्यक्ति का निर्माण संभव है, (|) | (या), ~ (Not) के साथ ही >> और << सिम्पी के मुख्य मॉड्यूल में परिभाषित मूल वर्ग से बूलियन अभिव्यक्तियां होती हैं।
बूलियनट्रू फ़ंक्शन
यह फ़ंक्शन ट्रू के बराबर है जैसा कि कोर पायथन में है। यह एक सिंगलटन देता है जिसे S.true द्वारा पुनः प्राप्त किया जा सकता है।
>>> from sympy import *
>>> x=sympify(true)
>>> x, S.true
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
(सच सच)
बूलियनफाल्स फ़ंक्शन
इसी तरह, यह फ़ंक्शन पायथन में बूलियन फाल्स के बराबर है और एसफाल्से द्वारा पहुँचा जा सकता है
>>> from sympy import *
>>> x=sympify(false)
>>> x, S.false
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
(असत्य, असत्य)
और कार्य करते हैं
एक तार्किक और फ़ंक्शन इसके दो तर्कों का मूल्यांकन करता है और यदि उनमें से कोई भी गलत है तो गलत रिटर्न देता है। फ़ंक्शन का अनुकरण और ऑपरेटर करता है।
>>> from sympy import *
>>> from sympy.logic.boolalg import And
>>> x,y=symbols('x y')
>>> x=True
>>> y=True
>>> And(x,y), x"&"y
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
(सच सच)
>>> y=False
>>> And(x,y), x"&"y
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
(असत्य, असत्य)
या कार्य करते हैं
यह फ़ंक्शन दो बूलियन तर्कों का मूल्यांकन करता है और यदि उनमें से कोई भी सत्य है तो यह सही है। | ऑपरेटर आसानी से अपने व्यवहार का अनुकरण करता है।
>>> from sympy import *
>>> from sympy.logic.boolalg import Or
>>> x,y=symbols('x y')
>>> x=True
>>> y=False
>>> Or(x,y), x|y
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
(सच सच)
>>> x=False
>>> y=False
>>> Or(x,y), x|y
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
(असत्य, असत्य)
काम नहीं कर करता
बूलियन तर्क की उपेक्षा में एक तार्किक कार्य नहीं होता है। यह सही है अगर इसका तर्क गलत है और यदि सही है तो गलत लौटाता है। ~ ऑपरेटर नहीं फ़ंक्शन के समान ऑपरेशन करता है। यह नीचे दिए गए उदाहरण में दिखाया गया है -
>>> from sympy import *
>>> from sympy.logic.boolalg import Or, And, Not
>>> x,y=symbols('x y')
>>> x=True
>>> y=False
>>> Not(x), Not(y)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
(सच्चा झूठा)
>>> Not(And(x,y)), Not(Or(x,y))
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
(सही गलत)
Xor फ़ंक्शन
तार्किक XOR (अनन्य OR) फ़ंक्शन सही देता है यदि विषम संख्या में तर्क सत्य हैं और शेष गलत हैं और यदि गलत संख्या के तर्क सत्य हैं और शेष गलत हैं तो वापस लौटता है। इसी तरह का ऑपरेशन ^ ऑपरेटर द्वारा किया जाता है।
>>> from sympy import *
>>> from sympy.logic.boolalg import Xor
>>> x,y=symbols('x y')
>>> x=True
>>> y=False
>>> Xor(x,y), x^y
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
(सच सच)
>>> a,b,c,d,e=symbols('a b c d e')
>>> a,b,c,d,e=(True, False, True, True, False)
>>> Xor(a,b,c,d,e)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
सच
उपरोक्त मामले में, तीन (विषम संख्या) तर्क सत्य हैं, इसलिए Xor सही है। हालाँकि, यदि सच्चे तर्कों की संख्या सम है, तो इसका परिणाम गलत है, जैसा कि नीचे दिखाया गया है -
>>> a,b,c,d,e=(True, False, False, True, False)
>>> Xor(a,b,c,d,e)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
असत्य
नंद समारोह
यह फ़ंक्शन लॉजिकल नंद ऑपरेशन करता है। यह उसके तर्कों का मूल्यांकन करता है और यदि उनमें से कोई भी गलत है, और यदि वे सभी सच्चे हैं तो गलत होने पर वापस लौटाता है।
>>> from sympy import *
>>> from sympy.logic.boolalg import Nand
>>> a,b,c=symbols('a b c')
>>> a,b,c=(True, False, True)
>>> Nand(a,b,c), Nand(a,c)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
(सही गलत)
न ही समारोह
यह फ़ंक्शन लॉजिकल NOR ऑपरेशन करता है। यह अपने तर्कों का मूल्यांकन करता है और यदि उनमें से कोई भी सत्य है, और यदि वे सभी गलत हैं, तो गलत रिटर्न देता है।
>>> from sympy import *
>>> from sympy.logic.boolalg import Nor
>>> a,b,c=symbols('a b c')
>>> a,b,c=(True, False, True)
>>> Nor(a,b,c), Nor(a,c)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
(असत्य, असत्य)
ध्यान दें कि भले ही SymPy एक्स के लिए ^ ऑपरेटर प्रदान करता है, ~ के लिए नहीं, | सुविधा के रूप में और / या के लिए कार्य करता है, पायथन में उनका सामान्य उपयोग बिटवाइज़ ऑपरेटरों के रूप में है। इसलिए, यदि ऑपरेंड पूर्णांक हैं, तो परिणाम भिन्न होंगे।
समतुल्य कार्य
यह फ़ंक्शन तुल्यता संबंध देता है। समतुल्य (ए, बी) सत्य है यदि और केवल ए और बी दोनों सत्य हैं या दोनों गलत हैं। यदि सभी तर्क तार्किक रूप से समतुल्य हैं, तो फ़ंक्शन सही है। झूठा लौटाता है।
>>> from sympy import *
>>> from sympy.logic.boolalg import Equivalent
>>> a,b,c=symbols('a b c')
>>> a,b,c=(True, False, True)
>>> Equivalent(a,b), Equivalent(a,c)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
(सच्चा झूठा)
ITE फ़ंक्शन
यह फ़ंक्शन तब कार्य करता है जब कोई अन्य प्रोग्रामिंग भाषा में क्लॉज़ करता है। A (A, B, C) मूल्यांकन करता है और B का परिणाम देता है यदि A सत्य है तो यह C का परिणाम देता है। सभी args का बूलियन होना आवश्यक है।
>>> from sympy import * >>> from sympy.logic.boolalg import ITE >>> a,b,c=symbols('a b c') >>> a,b,c=(True, False, True)
>>> ITE(a,b,c), ITE(a,c,b)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
(सच्चा झूठा)
SymPy पैकेज में मान्यताओं के मॉड्यूल में भावों के बारे में जानकारी निकालने के लिए उपकरण हैं। मॉड्यूल इस उद्देश्य के लिए पूछना () फ़ंक्शन को परिभाषित करता है।
sympy.assumptions.ask(property)
निम्नलिखित गुण एक अभिव्यक्ति के बारे में उपयोगी जानकारी प्रदान करते हैं -
algebraic(x)
बीजगणितीय होने के लिए, एक संख्या को तर्कसंगत गुणांक वाले गैर-शून्य बहुपद समीकरण का मूल होना चाहिए। √2 क्योंकि is2 x2 - 2 = 0 का हल है, इसलिए यह बीजीय है।
complex(x)
जटिल संख्या विधेय। यह सच है अगर और केवल अगर x जटिल संख्याओं के सेट के अंतर्गत आता है।
composite(x)
समग्र संख्या विधेय (Q.composite (x)) द्वारा लौटाया गया है और यदि x केवल धनात्मक पूर्णांक है और केवल 1 और संख्या के अलावा कम से कम एक धनात्मक विभाजक है तो यह सही है।
even, odd
X का सच () रिटर्न क्रमशः संख्याओं और विषम संख्याओं के सेट में है।
imaginary
यह संपत्ति काल्पनिक संख्या का प्रतिनिधित्व करती है। यह सच है अगर x को काल्पनिक इकाई I द्वारा गुणा वास्तविक संख्या के रूप में लिखा जा सकता है।
integer
Q.integer (x) द्वारा लौटाया गया यह गुण x का सही रिटर्न सम संख्याओं के सेट से संबंधित है।
rational, irrational
Q.irrational (x) सही है और यदि केवल x ही कोई वास्तविक संख्या है जिसे पूर्णांक के अनुपात के रूप में व्यक्त नहीं किया जा सकता है। उदाहरण के लिए, पी एक अपरिमेय संख्या है।
positive, negative
यह जांचने के लिए कि क्या नंबर पॉजिटिव है या नेगेटिव है
zero, nonzero
यदि संख्या शून्य है या नहीं, तो बिल्ली को समर्पित है
>>> from sympy import *
>>> x=Symbol('x')
>>> x=10
>>> ask(Q.algebraic(pi))
False
>>> ask(Q.complex(5-4*I)), ask( Q.complex(100))
(True, True)
>>> x,y=symbols("x y")
>>> x,y=5,10
>>> ask(Q.composite(x)), ask(Q.composite(y))
(False, True)
>>> ask(Q.even(x)), ask(Q.even(y))
(False, True)
>>> x,y= 2*I, 4+5*I
>>> ask(Q.imaginary(x)), ask(Q.imaginary(y))
(True, False)
>>> x,y=5,10
>>> ask(Q.even(x)), ask(Q.even(y)), ask(Q.odd(x)), ask(Q.odd(y))
(False, True, True, False)
>>> x,y=5,-5
>>> ask(Q.positive(x)), ask(Q.negative(y)), ask(Q.positive(x)), ask(Q.negative(y))
(True, True, True, True)
>>> ask(Q.rational(pi)), ask(Q.irrational(S(2)/3))
(False, False)
>>> ask(Q.zero(oo)), ask(Q.nonzero(I))
(False, False)
सिम्पी में गणितीय अभिव्यक्तियों को सरल बनाने की शक्तिशाली क्षमता है। सिम्पी में कई प्रकार के सरलीकरण करने के लिए कई कार्य हैं। एक सामान्य फ़ंक्शन जिसे सरलीकरण कहा जाता है () वहाँ है जो एक अभिव्यक्ति के सबसे सरल रूप में आने का प्रयास करता है।
सरल
यह फ़ंक्शन sympy.simplify मॉड्यूल में परिभाषित किया गया है। सरलीकृत () इनपुट अभिव्यक्ति "सरल" बनाने के लिए बुद्धिमान heuristics लागू करने की कोशिश करता है। निम्नलिखित कोड शो अभिव्यक्ति को सरल करता है$sin^2(x)+cos^2(x)$।
>>> from sympy import *
>>> x=Symbol('x')
>>> expr=sin(x)**2 + cos(x)**2
>>> simplify(expr)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
1
विस्तार
विस्तार () सिम्पी में सबसे सामान्य सरलीकरण कार्यों में से एक है, जिसका उपयोग बहुपद अभिव्यक्ति का विस्तार करने में किया जाता है। उदाहरण के लिए -
>>> a,b=symbols('a b')
>>> expand((a+b)**2)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$a^2 + 2ab + b^2$
>>> expand((a+b)*(a-b))
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$a^2 - b^2$
विस्तार () फ़ंक्शन अभिव्यक्तियों को बड़ा बनाता है, छोटा नहीं। आमतौर पर यह मामला है, लेकिन अक्सर कॉलिंग एक्सपेंशन () पर एक अभिव्यक्ति छोटी हो जाएगी।
>>> expand((x + 1)*(x - 2) - (x - 1)*x)
उपरोक्त कोड स्निपेट निम्नलिखित आउटपुट देता है -
-2
फ़ैक्टर
यह फ़ंक्शन एक बहुपद लेता है और इसे तर्कसंगत संख्याओं से अधिक अप्रासंगिक कारकों में शामिल करता है।
>>> x,y,z=symbols('x y z')
>>> expr=(x**2*z + 4*x*y*z + 4*y**2*z)
>>> factor(expr)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$z(x + 2y)^2$
>>> factor(x**2+2*x+1)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$(x + 1)^2$
कारक () फ़ंक्शन का विस्तार () के विपरीत है। कारक () द्वारा लौटाए गए कारकों में से प्रत्येक को अप्रासंगिक होने की गारंटी है। फैक्टर_लिस्ट () फ़ंक्शन अधिक संरचित आउटपुट देता है।
>>> expr=(x**2*z + 4*x*y*z + 4*y**2*z)
>>> factor_list(expr)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
(1, [(z, 1), (x + 2*y, 2)])
कलेक्ट
यह फ़ंक्शन तर्कसंगत अभिव्यक्ति के साथ शक्तियों तक अभिव्यक्ति की सूची के संबंध में एक अभिव्यक्ति के additve शब्द एकत्र करता है।
>>> expr=x*y + x - 3 + 2*x**2 - z*x**2 + x**3
>>> expr
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$x^3 + x^2z + 2x^2 + xy + x - 3$
इस अभिव्यक्ति पर एकत्रित () फ़ंक्शन निम्नानुसार है -
>>> collect(expr,x)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$x^3 + x^2(2 - z) + x(y + 1) - 3$
>>> expr=y**2*x + 4*x*y*z + 4*y**2*z+y**3+2*x*y
>>> collect(expr,y)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$Y^3+Y^2(x+4z)+y(4xz+2x)$
रद्द करना
रद्द () फ़ंक्शन किसी भी तर्कसंगत फ़ंक्शन को ले जाएगा और इसे मानक विहित रूप, पी / क्यू में डाल देगा, जहां पी और क्यू बिना किसी सामान्य कारकों के साथ बहुपद का विस्तार किया जाता है। P और q के प्रमुख गुणांकों में भाजक नहीं हैं अर्थात, वे पूर्णांक हैं।
>>> expr1=x**2+2*x+1
>>> expr2=x+1
>>> cancel(expr1/expr2)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$x+1$
>>> expr = 1/x + (3*x/2 - 2)/(x - 4)
>>> expr
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\frac{\frac{3x}{2} - 2}{x - 4} + \frac{1}{x}$
>>> cancel(expr)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\frac{3x^2 - 2x - 8}{2x^2 - 8}$
>>> expr=1/sin(x)**2
>>> expr1=sin(x)
>>> cancel(expr1*expr)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\frac{1}{\sin(x)}$
trigsimp
इस फ़ंक्शन का उपयोग त्रिकोणमितीय पहचान को सरल बनाने के लिए किया जाता है। यह ध्यान दिया जा सकता है कि व्युत्क्रम त्रिकोणमितीय कार्यों के लिए नामकरण सम्मेलनों को फ़ंक्शन के नाम के सामने एक संलग्न करना है। उदाहरण के लिए, व्युत्क्रम कोसाइन या आर्क कोसाइन को एकोस () कहा जाता है।
>>> from sympy import trigsimp, sin, cos
>>> from sympy.abc import x, y
>>> expr = 2*sin(x)**2 + 2*cos(x)**2
>>> trigsimp(expr)
2
Trigsimp फ़ंक्शन सबसे उपयुक्त उपयुक्त त्रिकोणमितीय पहचान को लागू करने के लिए heuristics का उपयोग करता है।
powersimp
यह फ़ंक्शन समान आधारों और घातांक के साथ शक्तियों को जोड़कर दी गई अभिव्यक्ति को कम करता है।
>>> expr=x**y*x**z*y**z
>>> expr
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$x^y x^z y^z$
>>> powsimp(expr)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$x^{y+z} y^z$
आप powsimp बना सकते हैं () केवल आधारों को जोड़ सकते हैं या केवल संयोजन = 'आधार' या गठबंधन = 'exp' को बदलकर संयोजन जोड़ सकते हैं। डिफ़ॉल्ट रूप से, गठबंधन = 'सभी', जो दोनों करता है। यदि बल सत्य है तो मान्यताओं की जांच किए बिना आधारों को जोड़ दिया जाएगा।
>>> powsimp(expr, combine='base', force=True)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$x^y(xy)^z$
combsimp
कंबाइनोरियल एक्सप्रेशंस में फैक्टरियल ए बिनोमाइल्स को कॉम्बीम्पिंप () फ़ंक्शन का उपयोग करके सरल बनाया जा सकता है। SymPy एक भाज्य () फ़ंक्शन प्रदान करता है
>>> expr=factorial(x)/factorial(x - 3)
>>> expr
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\frac{x!}{(x - 3)!}$
कॉम्बिनेटरियल एक्सप्रेशन को सरल बनाने के लिए हम कॉम्बीम्पिंप () फ़ंक्शन का उपयोग करते हैं -
>>> combsimp(expr)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$x(x-2)(x-1)$
द्विपद (x, y) x अलग-अलग मदों के सेट से y आइटम चुनने के तरीकों की संख्या है। इसे अक्सर xCy के रूप में भी लिखा जाता है।
>>> binomial(x,y)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$(\frac{x}{y})$
>>> combsimp(binomial(x+1, y+1)/binomial(x, y))
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\frac{x + 1}{y + 1}$
logcombine
यह फ़ंक्शन लघुगणक लेता है और उन्हें निम्नलिखित नियमों का उपयोग करके जोड़ती है -
- log (x) + log (y) == लॉग (x * y) यदि दोनों सकारात्मक हैं
- यदि x धनात्मक है और वास्तविक है, तो एक * लॉग (x) == लॉग (x ** a)
>>> logcombine(a*log(x) + log(y) - log(z))
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$a\log(x) + \log(y) - \log(z)$
यदि इस फ़ंक्शन के बल पैरामीटर को True पर सेट किया गया है, तो उपरोक्त मान्यताओं को धारण करने के लिए माना जाएगा यदि मात्रा पर पहले से ही कोई धारणा नहीं है।
>>> logcombine(a*log(x) + log(y) - log(z), force=True)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\log\frac{x^a y}{z}$
किसी फ़ंक्शन का व्युत्पन्न उसके एक चर के संबंध में परिवर्तन की तात्कालिक दर है। यह एक बिंदु पर कार्य के लिए स्पर्शरेखा रेखा के ढलान को खोजने के बराबर है। हम सिम्पी पैकेज में भिन्न () फ़ंक्शन का उपयोग करके चर के रूप में गणितीय अभिव्यक्तियों के अंतर को पा सकते हैं।
diff(expr, variable)
>>> from sympy import diff, sin, exp
>>> from sympy.abc import x,y
>>> expr=x*sin(x*x)+1 >>> expr
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$x\sin(x^2) + 1$
>>> diff(expr,x)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$2x^2\cos(x^2) + \sin(x^2)$
>>> diff(exp(x**2),x)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
2xex2
एकाधिक व्युत्पन्न लेने के लिए, चर को जितनी बार आप अंतर करना चाहते हैं उतने बार पास करें, या चर के बाद एक संख्या पास करें।
>>> diff(x**4,x,3)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$24x$
>>> for i in range(1,4): print (diff(x**4,x,i))
उपरोक्त कोड स्निपेट निम्न अभिव्यक्ति देता है -
4*x**3
12*x**2
24*x
एक अभिव्यक्ति के अंतर () विधि को कॉल करना भी संभव है। यह समान रूप से भिन्न () फ़ंक्शन के रूप में काम करता है।
>>> expr=x*sin(x*x)+1
>>> expr.diff(x)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$2x^2\cos(x^2) + \sin(x^2)$
एक व्युत्पन्न व्युत्पन्न व्युत्पन्न वर्ग का उपयोग करके बनाया गया है। इसमें अलग-अलग () फ़ंक्शन के समान सिंटैक्स होता है। एक निर्विवाद व्युत्पन्न का मूल्यांकन करने के लिए, doit पद्धति का उपयोग करें।
>>> from sympy import Derivative
>>> d=Derivative(expr)
>>> d
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\frac{d}{dx}(x\sin(x^2)+1)$
>>> d.doit()
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$2x^2\cos(x^2) + \sin(x^2)$
SymPy पैकेज में इंटीग्रल मॉड्यूल शामिल हैं। यह अभिव्यक्ति की निश्चित और अनिश्चित समरूपताओं की गणना करने के तरीकों को लागू करता है। एकीकृत () विधि का उपयोग निश्चित और अनिश्चित दोनों अभिन्नों की गणना करने के लिए किया जाता है। एक अनिश्चित या आदिम अभिन्न की गणना करने के लिए, बस अभिव्यक्ति के बाद चर पास करें।
उदाहरण के लिए -
integrate(f, x)
एक निश्चित अभिन्न गणना करने के लिए, इस प्रकार से तर्क पास करें -
(integration_variable, lower_limit, upper_limit)
>>> from sympy import *
>>> x,y = symbols('x y')
>>> expr=x**2 + x + 1
>>> integrate(expr, x)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\frac{x^3}{3} + \frac{x^2}{2} + x$
>>> expr=sin(x)*tan(x)
>>> expr
>>> integrate(expr,x)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$-\frac{\log(\sin(x) - 1)}{2} + \frac{\log(\sin(x) + 1)}{2} - \sin(x)$
निश्चित अभिन्न का उदाहरण नीचे दिया गया है -
>>> expr=exp(-x**2)
>>> integrate(expr,(x,0,oo) )
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\frac{\sqrt\pi}{2}$
एक से अधिक अभिन्न प्रदर्शन करने के लिए आप कई सीमाएँ पास कर सकते हैं। एक उदाहरण नीचे दिया गया है -
>>> expr=exp(-x**2 - y**2)
>>> integrate(expr,(x,0,oo),(y,0,oo))
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\frac{\pi}{4}$
इंटीग्रल ऑब्जेक्ट का उपयोग करके आप अनवैलिडेटेड इंटीग्रल बना सकते हैं, जिसका मूल्यांकन डिट (कॉलिंग) विधि से किया जा सकता है।
>>> expr = Integral(log(x)**2, x)
>>> expr
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\int \mathrm\log(x)^2 \mathrm{d}x$
>>> expr.doit()
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$x\log(x)^2 - 2xlog(x) + 2x$
इंटीग्रल ट्रांसफ़ॉर्म
SymPy विभिन्न प्रकार के अभिन्न परिवर्तनों का समर्थन करता है -
- laplace_transform
- fourier_transform
- sine_transform
- cosine_transform
- hankel_transform
ये फ़ंक्शन sympy.integrals.transforms मॉड्यूल में परिभाषित किए गए हैं। निम्नलिखित उदाहरण क्रमशः फूरियर रूपांतरण और लाप्लास रूपांतरण की गणना करते हैं।
Example 1
>>> from sympy import fourier_transform, exp
>>> from sympy.abc import x, k
>>> expr=exp(-x**2)
>>> fourier_transform(expr, x, k)
अजगर शेल में उपरोक्त कमांड निष्पादित करने पर, निम्नलिखित आउटपुट उत्पन्न होंगे -
sqrt(pi)*exp(-pi**2*k**2)
जिसके समतुल्य है -
$\sqrt\pi * e^{\pi^2k^2}$
Example 2
>>> from sympy.integrals import laplace_transform
>>> from sympy.abc import t, s, a
>>> laplace_transform(t**a, t, s)
अजगर शेल में उपरोक्त कमांड निष्पादित करने पर, निम्नलिखित आउटपुट उत्पन्न होंगे -
(s**(-a)*gamma(a + 1)/s, 0, re(a) > -1)
गणित में, एक मैट्रिक्स संख्याओं, प्रतीकों या अभिव्यक्तियों का एक दो आयामी सरणी है। मैट्रिक्स हेरफेर का सिद्धांत मैट्रिक्स ऑब्जेक्ट्स पर अंकगणितीय संचालन करने से संबंधित है, कुछ नियमों के अधीन।
रैखिक परिवर्तन मैट्रिस के महत्वपूर्ण अनुप्रयोगों में से एक है। कई वैज्ञानिक क्षेत्र, विशेष रूप से भौतिकी से संबंधित मैट्रिक्स संबंधित अनुप्रयोगों का उपयोग करते हैं।
SymPy पैकेज में मैट्रिक्स मॉड्यूल है जो मैट्रिक्स हैंडलिंग से संबंधित है। इसमें मैट्रिक्स क्लास शामिल है जिसका ऑब्जेक्ट मैट्रिक्स का प्रतिनिधित्व करता है।
Note: If you want to execute all the snippets in this chapter individually, you need to import the matrix module as shown below −
>>> from sympy.matrices import Matrix
Example
>>> from sympy.matrices import Matrix
>>> m=Matrix([[1,2,3],[2,3,1]])
>>> m
$\displaystyle \left[\begin{matrix}1 & 2 & 3\\2 & 3 & 1\end{matrix}\right]$
अजगर शेल में उपरोक्त कमांड निष्पादित करने पर, निम्नलिखित आउटपुट उत्पन्न होंगे -
[1 2 3 2 3 1]
मैट्रिक्स को उचित रूप से आकार की वस्तुओं से बनाया गया है। आप निर्दिष्ट संख्या में पंक्तियों और स्तंभों में सूची आइटम वितरित करके एक मैट्रिक्स भी प्राप्त कर सकते हैं।
>>> M=Matrix(2,3,[10,40,30,2,6,9])
>>> M
$\displaystyle \left[\begin{matrix}10 & 40 & 30\\2 & 6 & 9\end{matrix}\right]$
अजगर शेल में उपरोक्त कमांड निष्पादित करने पर, निम्नलिखित आउटपुट उत्पन्न होंगे -
[10 40 30 2 6 9]
मैट्रिक्स एक उत्परिवर्तित वस्तु है। मैट्रिक्स मॉड्यूल अपरिवर्तनीय मैट्रिक्स प्राप्त करने के लिए ImmutableMatrix वर्ग भी प्रदान करता है।
बेसिक हेरफेर
shape मैट्रिक्स ऑब्जेक्ट की संपत्ति इसका आकार लौटाती है।
>>> M.shape
उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -
(2,3)
पंक्ति () और कॉल () विधि क्रमशः निर्दिष्ट संख्या की पंक्ति या स्तंभ लौटाती है।
>>> M.row(0)
$\displaystyle \left[\begin{matrix}10 & 40 & 30\end{matrix}\right]$
उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -
[10 40 30]
>>> M.col(1)
$\displaystyle \left[\begin{matrix}40\\6\end{matrix}\right]$
उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -
[40 6]
पंक्ति या स्तंभ से संबंधित एक या अधिक आइटम लाने के लिए पायथन के स्लाइस ऑपरेटर का उपयोग करें।
>>> M.row(1)[1:3]
[6, 9]
मैट्रिक्स वर्ग में row_del () और col_del () विधियाँ हैं जो दी गई मैट्रिक्स से निर्दिष्ट पंक्ति / स्तंभ को हटाती हैं -
>>> M=Matrix(2,3,[10,40,30,2,6,9])
>>> M.col_del(1)
>>> M
अजगर शेल में उपरोक्त कमांड निष्पादित करने पर, निम्नलिखित आउटपुट उत्पन्न होंगे -
Matrix([[10, 30],[ 2, 9]])
आप निम्न कमांड का उपयोग करके आउटपुट पर स्टाइल लागू कर सकते हैं -
$\displaystyle \left[\begin{matrix}10 & 30\\2 & 9\end{matrix}\right]$
उपरोक्त कोड स्निपेट को निष्पादित करने के बाद आपको निम्न आउटपुट मिलते हैं -
[10 30 2 9]
>>> M.row_del(0)
>>> M
$\displaystyle \left[\begin{matrix}2 & 9\end{matrix}\right]$
उपरोक्त कोड स्निपेट को निष्पादित करने के बाद आपको निम्न आउटपुट मिलते हैं -
[2 9]
इसी प्रकार, row_insert () और col_insert () विधियाँ निर्दिष्ट पंक्ति या स्तंभ अनुक्रमणिका में पंक्तियों या स्तंभों को जोड़ती हैं
>>> M1=Matrix([[10,30]])
>>> M=M.row_insert(0,M1)
>>> M
$\displaystyle \left[\begin{matrix}10 & 30\\2 & 9\end{matrix}\right]$
उपरोक्त कोड स्निपेट को निष्पादित करने के बाद आपको निम्न आउटपुट मिलते हैं -
[10 40 30 2 9]
>>> M2=Matrix([40,6])
>>> M=M.col_insert(1,M2)
>>> M
$\displaystyle \left[\begin{matrix}10 & 40 & 30\\2 & 6 & 9\end{matrix}\right]$
उपरोक्त कोड स्निपेट को निष्पादित करने के बाद आपको निम्न आउटपुट मिलते हैं -
[10 40 30 6 9]
अंकगणितीय आपरेशनस
सामान्य ऑपरेटर +, - और * इसके अलावा, घटाव और गुणा करने के लिए परिभाषित किए गए हैं।
>>> M1=Matrix([[1,2,3],[3,2,1]])
>>> M2=Matrix([[4,5,6],[6,5,4]])
>>> M1+M2
$\displaystyle \left[\begin{matrix}5 & 7 & 9\\9 & 7 & 5\end{matrix}\right]$
उपरोक्त कोड स्निपेट को निष्पादित करने के बाद आपको निम्न आउटपुट मिलते हैं -
[5 7 9 9 7 5]
>>> M1-M2
$\displaystyle \left[\begin{matrix}-3 & -3 & -3\\-3 & -3 & -3\end{matrix}\right]$
उपरोक्त कोड स्निपेट को निष्पादित करने के बाद आपको निम्न आउटपुट मिलते हैं -
[- 3 -3 -3 -3 -3 -3]
मैट्रिक्स गुणन केवल तभी संभव है जब - 1 मैट्रिक्स के कॉलम की संख्या 2 मैट्रिक्स की पंक्तियों की संख्या के बराबर होनी चाहिए। - और परिणाम में 1 मैट्रिक्स के समान पंक्तियां होंगी, और 2 मैट्रिक्स के समान संख्या में कॉलम होंगे।
>>> M1=Matrix([[1,2,3],[3,2,1]])
>>> M2=Matrix([[4,5],[6,6],[5,4]])
>>> M1*M2
$\displaystyle \left[\begin{matrix}31 & 29\\29 & 31\end{matrix}\right]$
उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -
[31 29 29 31]
>>> M1.T
$\displaystyle \left[\begin{matrix}1 & 3\\2 & 2\\3 & 1\end{matrix}\right]$
कोड निष्पादित करने के बाद निम्न आउटपुट प्राप्त होता है -
[1 3 2 2 3 1]
मैट्रिक्स के निर्धारक की गणना करने के लिए, det () विधि का उपयोग करें। एक निर्धारक एक अदिश मान होता है जिसे एक वर्ग मैट्रिक्स 0 के तत्वों से गणना की जा सकती है
>>> M=Matrix(3,3,[10,20,30,5,8,12,9,6,15])
>>> M
$\displaystyle \left[\begin{matrix}10 & 20 & 30\\5 & 8 & 12\\9 & 6 & 15\end{matrix}\right]$
उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -
[10 20 30 5 8 12 9 6 15]
>>> M.det()
उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -
-120
मैट्रिक्स कंस्ट्रक्टर्स
SymPy कई विशेष प्रकार की मैट्रिक्स कक्षाएं प्रदान करता है। उदाहरण के लिए, पहचान मैट्रिक्स, सभी शून्य और लोगों के मैट्रिक्स, आदि। इन वर्गों को क्रमशः आंख, शून्य और वाले के रूप में नामित किया गया है। पहचान मैट्रिक्स एक वर्ग मैट्रिक्स है जिसमें विकर्ण पर गिरने वाले तत्वों को 1 पर सेट किया जाता है, बाकी तत्व 0 हैं।
Example
from sympy.matrices import eye eye(3)
Output
Matrix([[1, 0, 0], [0, 1, 0], [0, 0, 1]])
$\displaystyle \left[\begin{matrix}1 & 0 & 0\\0 & 1 & 0\\0 & 0 & 1\end{matrix}\right]$
उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -
[1 0 0 0 1 0 0 0 1]
डायग मैट्रिक्स में, विकर्ण पर तत्वों को प्रदान किए गए तर्कों के अनुसार प्रारंभ किया जाता है।
>>> from sympy.matrices import diag
>>> diag(1,2,3)
$\displaystyle \left[\begin{matrix}1 & 0 & 0\\0 & 2 & 0\\0 & 0 & 3\end{matrix}\right]$
उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -
[1 0 0 0 2 0 0 0 3]
शून्य मैट्रिक्स में सभी तत्व 0 से प्रारंभ होते हैं।
>>> from sympy.matrices import zeros
>>> zeros(2,3)
$\displaystyle \left[\begin{matrix}0 & 0 & 0\\0 & 0 & 0\end{matrix}\right]$
उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -
[0 0 0 0 0 0]
इसी तरह, सभी 1 में सेट सभी तत्वों के साथ मैट्रिक्स हैं।
>>> from sympy.matrices import ones
>>> ones(2,3)
$\displaystyle \left[\begin{matrix}1 & 1 & 1\\1 & 1 & 1\end{matrix}\right]$
उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -
[1 1 1 1 1 1]
Sympy पैकेज में फंक्शन क्लास है, जिसे sympy.core.function मॉड्यूल में परिभाषित किया गया है। यह सभी लागू गणितीय कार्यों के लिए एक आधार वर्ग है, साथ ही अपरिभाषित फ़ंक्शन कक्षाओं के लिए एक निर्माता भी है।
फंक्शन क्लास से विरासत में मिले कार्यों की निम्नलिखित श्रेणियां हैं -
- जटिल संख्या के लिए कार्य
- त्रिकोणमितीय फलन
- पूर्णांक संख्या के लिए कार्य
- संयुक्त कार्य करता है
- अन्य विविध कार्य
जटिल संख्या के लिए कार्य
कार्यों के इस सेट में परिभाषित किया गया है sympy.functions.elementary.complexes मापांक।
re
यह फ़ंक्शन एक अभिव्यक्ति का वास्तविक हिस्सा देता है -
>>> from sympy import *
>>> re(5+3*I)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
5
>>> re(I)
उपरोक्त कोड स्निपेट के लिए आउटपुट है -
0
Im
यह फ़ंक्शन एक अभिव्यक्ति का काल्पनिक हिस्सा देता है -
>>> im(5+3*I)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
3
>>> im(I)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
1
sign
यह फ़ंक्शन किसी अभिव्यक्ति का जटिल संकेत देता है।
वास्तविक अभिव्यक्ति के लिए, संकेत होगा -
- 1 यदि अभिव्यक्ति सकारात्मक है
- 0 यदि अभिव्यक्ति शून्य के बराबर है
- -1 यदि अभिव्यक्ति नकारात्मक है
यदि अभिव्यक्ति काल्पनिक है तो हस्ताक्षर किया गया है -
- मैं अगर im (अभिव्यक्ति) सकारात्मक है
- यदि मैं im (अभिव्यक्ति) नकारात्मक है
>>> sign(1.55), sign(-1), sign(S.Zero)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
(1, -1, 0)
>>> sign (-3*I), sign(I*2)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
(-I, I)
Abs
यह फ़ंक्शन किसी जटिल संख्या का निरपेक्ष मान लौटाता है। इसे जटिल विमान में उत्पत्ति (0,0) और बिंदु (ए, बी) के बीच की दूरी के रूप में परिभाषित किया गया है। यह फ़ंक्शन प्रतीकात्मक मूल्यों को स्वीकार करने के लिए अंतर्निहित फ़ंक्शन एब्स () का एक विस्तार है।
>>> Abs(2+3*I)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
$\sqrt13$
conjugate
यह फ़ंक्शन किसी जटिल संख्या का संयुग्म देता है। जटिल संयुग्म को खोजने के लिए हम काल्पनिक भाग के संकेत को बदलते हैं।
>>> conjugate(4+7*I)
उपरोक्त कोड स्निपेट को निष्पादित करने के बाद आपको निम्न आउटपुट मिलते हैं -
4 - 7i
त्रिकोणमितीय फलन
SymPy में सभी त्रिकोणमितीय अनुपात - पाप कॉस, टैन इत्यादि के साथ-साथ इसके उलटे समकक्ष जैसे कि एसिन, एकॉस, एटैन आदि के लिए भी परिभाषाएँ हैं। ये कार्य रेडियन में व्यक्त कोण के लिए संबंधित मान की गणना करते हैं।
>>> sin(pi/2), cos(pi/4), tan(pi/6)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
(1, sqrt(2)/2, sqrt(3)/3)
>>> asin(1), acos(sqrt(2)/2), atan(sqrt(3)/3)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
(pi/2, pi/4, pi/6)
पूर्णांक संख्या पर कार्य
यह पूर्णांक संख्या पर विभिन्न संचालन करने के लिए कार्यों का एक समूह है।
ceiling
यह एक अविभाज्य फ़ंक्शन है जो सबसे छोटे पूर्णांक मान को उसके तर्क से कम नहीं लौटाता है। जटिल संख्या के मामले में, वास्तविक और काल्पनिक भागों की अलग-अलग छत।
>>> ceiling(pi), ceiling(Rational(20,3)), ceiling(2.6+3.3*I)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
(4, 7, 3 + 4*I)
floor
यह फ़ंक्शन सबसे बड़ा पूर्णांक मान देता है जो इसके तर्क से अधिक नहीं है। जटिल संख्याओं के मामले में, यह कार्य भी वास्तविक और काल्पनिक भागों के तल को अलग-अलग करता है।
>>> floor(pi), floor(Rational(100,6)), floor(6.3-5.9*I)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
(3, 16, 6 - 6*I)
frac
यह फ़ंक्शन x के आंशिक भाग का प्रतिनिधित्व करता है।
>>> frac(3.99), frac(Rational(10,3)), frac(10)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
(0.990000000000000, 1/3, 0)
संयुक्त कार्य करता है
संयोजक गणित का एक क्षेत्र है जो एक परिमित या असतत प्रणाली के भीतर चयन, व्यवस्था और संचालन की समस्याओं से संबंधित है।
factorial
कॉम्बीनेटरिक्स में फैक्टरियल बहुत महत्वपूर्ण है जहां यह उन तरीकों की संख्या देता है जिसमें एन ऑब्जेक्ट्स को अनुमति दी जा सकती है। इसे प्रतीकात्मक रूप से '??' symbol के रूप में दर्शाया गया है! यह फ़ंक्शन nonnegative पूर्णांक पर फैक्टरियल फ़ंक्शन का कार्यान्वयन है, एक नकारात्मक पूर्णांक के factorial जटिल अनन्तता है।
>>> x=Symbol('x')
>>> factorial(x)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
x!
>>> factorial(5)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
120
>>> factorial(-1)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
$\infty\backsim$
द्विपद
यह उन तरीकों की संख्या को काम करता है जिन्हें हम n तत्वों के एक सेट से k तत्व चुन सकते हैं।
>>> x,y=symbols('x y')
>>> binomial(x,y)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
$(\frac{x}{y})$
>>> binomial(4,2)
उपरोक्त कोड स्निपेट के लिए आउटपुट नीचे दिया गया है -
6
पास्कल के त्रिकोण की पंक्तियों को द्विपद फ़ंक्शन के साथ उत्पन्न किया जा सकता है।
>>> for i in range(5): print ([binomial(i,j) for j in range(i+1)])
उपरोक्त कोड स्निपेट को निष्पादित करने के बाद आपको निम्न आउटपुट मिलते हैं -
[1]
[1, 1]
[1, 2, 1]
[1, 3, 3, 1]
[1, 4, 6, 4, 1]
fibonacci
फाइबोनैचि संख्याएं पूर्णांक प्रारंभिक क्रम F0 = 0, F1 = 1 और दो-अवधि के पुनरावृत्ति संबंध Fn = Fnâˆ1 + Fnâˆ'2 द्वारा परिभाषित होती हैं।
>>> [fibonacci(x) for x in range(10)]
उपरोक्त कोड स्निपेट निष्पादित करने के बाद निम्न आउटपुट प्राप्त होता है -
[0, 1, 1, 2, 3, 5, 8, 13, 21, 34]
tribonacci
ट्रिबोनैचि संख्याएं पूर्णांक अनुक्रम हैं जिन्हें प्रारंभिक शर्तों F0 = 0, F1 = 1, F2 = 1 और तीन-अवधि पुनरावृत्ति संबंध Fn = Fn-1 + Fn-2 + Fn-3 द्वारा परिभाषित किया गया है।
>>> tribonacci(5, Symbol('x'))
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$x^8 + 3x^5 + 3x^2$
>>> [tribonacci(x) for x in range(10)]
उपरोक्त कोड स्निपेट निष्पादित करने के बाद निम्न आउटपुट प्राप्त होता है -
[0, 1, 1, 2, 4, 7, 13, 24, 44, 81]
विविध कार्य
निम्नलिखित कुछ अक्सर उपयोग किए जाने वाले कार्यों की एक सूची है -
Min- सूची का न्यूनतम मूल्य लौटाता है। इसे बिल्ट-इन फ़ंक्शन मिन के साथ टकराव से बचने के लिए मिन का नाम दिया गया है।
Max- सूची का अधिकतम मूल्य लौटाता है। बिल्ट-इन फंक्शन मैक्स के साथ टकराव से बचने के लिए इसे मैक्स नाम दिया गया है।
root - x का nth रूट लौटाता है।
sqrt - x का मूल वर्ग मूल लौटाता है।
cbrt - यह फ़ंक्शन x के प्रिंसिपल क्यूब रूट, (x ++ रेशनल के लिए शॉर्टकट (1,3)) की गणना करता है।
उपरोक्त विविध कार्यों और उनके संबंधित आउटपुट के उदाहरण निम्नलिखित हैं -
>>> Min(pi,E)
e
>>> Max(5, Rational(11,2))
$\frac{11}{2}$
>>> root(7,Rational(1,2))
49
>>> sqrt(2)
$\sqrt2$
>>> cbrt(1000)
10
गणित में, क्वाटरनियन नंबर सिस्टम जटिल संख्याओं का विस्तार है। प्रत्येक Quaternion ऑब्जेक्ट में चार स्केलर चर और चार आयाम, एक वास्तविक आयाम और तीन काल्पनिक आयाम होते हैं।
निम्नलिखित अभिव्यक्ति द्वारा उद्धरण का प्रतिनिधित्व किया जाता है -
q = एक + द्वि + CJ + dk
कहाँ पे a, b, c और डी वास्तविक संख्या हैं और i, j, k चतुष्कोणीय इकाइयाँ ऐसी हैं, i2 == j2 == k2 == ijk
sympy.algebras.quaternion मॉड्यूल में Quaternion वर्ग है।
>>> from sympy.algebras.quaternion import Quaternion
>>> q=Quaternion(2,3,1,4)
>>> q
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$2 + 3i + 1j + 4k$
क्वाटरन्यूज़ का उपयोग शुद्ध गणित के साथ-साथ अनुप्रयुक्त गणित, कंप्यूटर ग्राफिक्स, कंप्यूटर विज़न इत्यादि में किया जाता है।
>>> from sympy import *
>>> x=Symbol('x')
>>> q1=Quaternion(x**2, x**3, x) >>> q1
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$x^2 + x^3i + xj + 0k$
क्वाटरनियन ऑब्जेक्ट में काल्पनिक सह-प्रभावकारक भी हो सकते हैं
>>> q2=Quaternion(2,(3+2*I), x**2, 3.5*I)
>>> q2
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$2 + (3 + 2i)i + x2j + 3.5ik$
(जोड़ें)
क्वाटरनियन क्लास में उपलब्ध यह विधि दो क्वाटरनियन वस्तुओं के अलावा काम करती है।
>>> q1=Quaternion(1,2,3,4)
>>> q2=Quaternion(4,3,2,1)
>>> q1.add(q2)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$5 + 5i + 5j + 5k$
एक चतुर्भुज वस्तु में संख्या या प्रतीक जोड़ना संभव है।
>>> q1+2
उपरोक्त कोड स्निपेट निष्पादित करने के बाद निम्न आउटपुट प्राप्त होता है -
$3 + 2i + 3j + 4k$
>>> q1+x
उपरोक्त कोड स्निपेट निष्पादित करने के बाद निम्न आउटपुट प्राप्त होता है -
$(x + 1) + 2i + 3j + 4k$
mul ()
यह विधि दो चतुष्कोणीय वस्तुओं का गुणन करती है।
>>> q1=Quaternion(1,2,1,2)
>>> q2=Quaternion(2,4,3,1)
>>> q1.mul(q2)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$(-11) + 3i + 11j + 7k$
श्लोक में()
यह विधि एक चतुर्धातुक वस्तु का प्रतिलोम देती है।
>>> q1.inverse()
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\frac{1}{10} + (-\frac{1}{5})i + (-\frac{1}{10})j + (-\frac{1}{5})k$
पॉव ()
यह विधि एक चतुर्भुज वस्तु की शक्ति लौटाती है।
>>> q1.pow(2)
उपरोक्त कोड स्निपेट निष्पादित करने के बाद निम्न आउटपुट प्राप्त होता है -
$(-8) + 4i + 2j + 4k$
exp ()
यह विधि एक क्वाटरनियन ऑब्जेक्ट अर्थात eq के घातांक की गणना करती है
>>> q=Quaternion(1,2,4,3)
>>> q.exp()
उपरोक्त कोड स्निपेट निष्पादित करने के बाद निम्न आउटपुट प्राप्त होता है -
$e\cos(\sqrt29) + \frac{2\sqrt29e\sin(\sqrt29)}{29}i + \frac{4\sqrt29e\sin(\sqrt29)}{29}j + \frac{3\sqrt29e\sin}{29}k$
चूंकि प्रतीक = और == को पायथन में असाइनमेंट और समानता ऑपरेटरों के रूप में परिभाषित किया गया है, उनका उपयोग प्रतीकात्मक समीकरणों को बनाने के लिए नहीं किया जा सकता है। SymPy एक समीकरण सेट करने के लिए Eq () फ़ंक्शन प्रदान करता है।
>>> from sympy import *
>>> x,y=symbols('x y')
>>> Eq(x,y)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
x = y
चूंकि x = y संभव है यदि और केवल अगर xy = 0, तो उपरोक्त समीकरण के रूप में लिखा जा सकता है -
>>> Eq(x-y,0)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
x − y = 0
SymPy में सॉल्वर मॉड्यूल सॉसेट () फ़ंक्शन प्रदान करता है जिसका प्रोटोटाइप निम्नानुसार है -
solveset(equation, variable, domain)
डोमेन डिफ़ॉल्ट S.Complexes द्वारा है। सोल्सेट () फ़ंक्शन का उपयोग करके, हम एक बीजीय समीकरण को निम्नानुसार हल कर सकते हैं -
>>> solveset(Eq(x**2-9,0), x)
निम्नलिखित उत्पादन प्राप्त किया जाता है -
{−3, 3}
>>> solveset(Eq(x**2-3*x, -2),x)
उपरोक्त कोड स्निपेट निष्पादित करने के बाद निम्न आउटपुट प्राप्त होता है -
{1,2}
सॉल्वेट का आउटपुट समाधानों का एक FiniteSet है। यदि कोई समाधान नहीं है, तो एक EmptySet लौटाया जाता है
>>> solveset(exp(x),x)
उपरोक्त कोड स्निपेट निष्पादित करने के बाद निम्न आउटपुट प्राप्त होता है -
$\varnothing$
रेखीय समीकरण
हमें रैखिक समीकरणों को हल करने के लिए linsolve () फ़ंक्शन का उपयोग करना होगा।
उदाहरण के लिए, समीकरण इस प्रकार हैं -
xy = 4
x + y = 1
>>> from sympy import *
>>> x,y=symbols('x y')
>>> linsolve([Eq(x-y,4),Eq( x + y ,1) ], (x, y))
उपरोक्त कोड स्निपेट निष्पादित करने के बाद निम्न आउटपुट प्राप्त होता है -
$\lbrace(\frac{5}{2},-\frac{3}{2})\rbrace$
Linsolve () फ़ंक्शन मैट्रिक्स रूप में व्यक्त रैखिक समीकरणों को भी हल कर सकता है।
>>> a,b=symbols('a b')
>>> a=Matrix([[1,-1],[1,1]])
>>> b=Matrix([4,1])
>>> linsolve([a,b], (x,y))
यदि हम उपरोक्त कोड स्निपेट निष्पादित करते हैं तो हमें निम्न आउटपुट मिलते हैं -
$\lbrace(\frac{5}{2},-\frac{3}{2})\rbrace$
गैर-रेखीय समीकरण
इस उद्देश्य के लिए, हम नॉनलिंसोल्यूशन () फ़ंक्शन का उपयोग करते हैं। इस उदाहरण के लिए समीकरण -
a 2 + a = 0 ab = 0
>>> a,b=symbols('a b')
>>> nonlinsolve([a**2 + a, a - b], [a, b])
यदि हम उपरोक्त कोड स्निपेट निष्पादित करते हैं तो हमें निम्न आउटपुट मिलते हैं -
$\lbrace(-1, -1),(0,0)\rbrace$
अंतर समीकरण
सबसे पहले, cls = फंक्शन को सिंबल फ़ंक्शन को पास करके एक अपरिभाषित फ़ंक्शन बनाएं। विभेदक समीकरणों को हल करने के लिए, dsolve का उपयोग करें।
>>> x=Symbol('x')
>>> f=symbols('f', cls=Function)
>>> f(x)
उपरोक्त कोड स्निपेट निष्पादित करने के बाद निम्न आउटपुट प्राप्त होता है -
f(x)
यहाँ f (x) एक अनवैलिडेटेड फंक्शन है। इसका व्युत्पन्न इस प्रकार है -
>>> f(x).diff(x)
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$\frac{d}{dx}f(x)$
हम पहले अंतर समीकरण का अनुसरण करते हुए Eq ऑब्जेक्ट बनाते हैं
>>> eqn=Eq(f(x).diff(x)-f(x), sin(x))
>>> eqn
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$-f(x) + \frac{d}{dx}f(x)= \sin(x)$
>>> dsolve(eqn, f(x))
उपरोक्त कोड स्निपेट नीचे दी गई अभिव्यक्ति के बराबर आउटपुट देता है -
$f(x)=(c^1-\frac{e^-xsin(x)}{2}-\frac{e^-xcos(x)}{2})e^x$
SymPy गणितीय कार्यों के 2-डी और 3-डी भूखंडों को रेंडर करने के बैकएंड के रूप में मेटप्लोटिब लाइब्रेरी का उपयोग करता है। सुनिश्चित करें कि Matplotlib वर्तमान पायथन इंस्टॉलेशन में उपलब्ध है। यदि नहीं, तो निम्नलिखित कमांड का उपयोग करके इसे स्थापित करें -
pip install matplotlib
प्लॉटिंग समर्थन sympy.plotting मॉड्यूल में परिभाषित किया गया है। निम्नलिखित कार्य प्लॉटिंग मॉड्यूल में मौजूद हैं -
plot - 2 डी लाइन भूखंड
plot3d - 3 डी लाइन प्लॉट
plot_parametric - 2 डी पैरामीट्रिक भूखंड
plot3d_parametric - 3 डी पैरामीट्रिक भूखंड
प्लॉट () फ़ंक्शन प्लॉट वर्ग का एक उदाहरण देता है। एक प्लॉट आकृति में एक या एक से अधिक सिम्पी भाव हो सकते हैं। हालांकि यह बैकप्लेंट के रूप में मैटलपोटलिब का उपयोग करने में सक्षम है, अन्य बैकएंड जैसे टेक्सप्लॉट, पीगलेट या Google चार्ट एपीआई का भी उपयोग किया जा सकता है।
plot(expr, range, kwargs)
जहां expr किसी भी वैध सहानुभूति अभिव्यक्ति है। यदि उल्लेख नहीं किया गया है, तो सीमा (-10, 10) के रूप में डिफ़ॉल्ट का उपयोग करती है।
श्रेणी (-10,10) में प्रत्येक मान के लिए x2 के उदाहरण प्लॉट मानों का अनुसरण करना -
>>> from sympy.plotting import plot
>>> from sympy import *
>>> x=Symbol('x')
>>> plot(x**2, line_color='red')
एक ही श्रेणी के लिए कई भूखंडों को आकर्षित करने के लिए, रेंज टपल से पहले कई भाव दें।
>>> plot( sin(x),cos(x), (x, -pi, pi))
आप प्रत्येक अभिव्यक्ति के लिए अलग-अलग सीमा भी निर्दिष्ट कर सकते हैं।
plot((expr1, range1), (expr2, range2))
विभिन्न श्रेणियों में फिगर प्लॉट सिन (x) और कॉस (x) के बाद।
>>> plot( (sin(x),(x, -2*pi, 2*pi)),(cos(x), (x, -pi, pi)))
वैकल्पिक कीवर्ड तर्कों को प्लॉट () फ़ंक्शन में निर्दिष्ट किया जा सकता है।
line_color - प्लॉट लाइन का रंग निर्दिष्ट करता है।
title - शीर्षक के रूप में प्रदर्शित होने वाली एक स्ट्रिंग
xlabel - एक्स अक्ष के लिए लेबल के रूप में प्रदर्शित होने वाली एक स्ट्रिंग
ylabel - y अक्ष के लेबल के रूप में प्रदर्शित होने वाली एक स्ट्रिंग
>>> plot( (sin(x),(x, -2*pi, 2*pi)),(cos(x), (x, -pi, pi)), line_color='red', title='SymPy plot example')
प्लॉट 3 डी () फ़ंक्शन एक तीन आयामी भूखंड का प्रतिपादन करता है।
plot3d(expr, xrange, yrange, kwargs)
निम्नलिखित उदाहरण एक 3 डी सतह भूखंड खींचता है -
>>> from sympy.plotting import plot3d
>>> x,y=symbols('x y')
>>> plot3d(x*y, (x, -10,10), (y, -10,10))
जैसे कि 2 डी प्लॉट में, तीन आयामी प्लॉट में अलग-अलग रेंज के साथ कई प्लॉट हो सकते हैं।
>>> plot3d(x*y, x/y, (x, -5, 5), (y, -5, 5))
प्लॉट 3d_parametric_line () फ़ंक्शन 3 आयामी पैरामीट्रिक लाइन प्लॉट प्रदान करता है।
>>> from sympy.plotting import plot3d_parametric_line
>>> plot3d_parametric_line(cos(x), sin(x), x, (x, -5, 5))
एक पैरामीट्रिक सतह भूखंड खींचने के लिए, प्लॉट 3 डी_परमेट्रिक_सर्फ़ () फ़ंक्शन का उपयोग करें।
plot3d_parametric_surface(xexpr, yexpr, zexpr, rangex, rangey, kwargs)
>>> from sympy.plotting import plot3d_parametric_surface
>>> plot3d_parametric_surface(cos(x+y), sin(x-y), x-y, (x, -5, 5), (y, -5, 5))
SymPy में ज्योमेट्री मॉड्यूल दो आयामी संस्थाओं जैसे लाइन, सर्कल आदि के निर्माण की अनुमति देता है। हम बाद में उनके बारे में जानकारी प्राप्त कर सकते हैं जैसे कि कॉलिनियरिटी की जांच करना या चौराहा ढूंढना।
बिंदु
बिंदु वर्ग यूक्लिडियन अंतरिक्ष में एक बिंदु का प्रतिनिधित्व करता है। बिंदुओं की कोलिनैरिटी के लिए उदाहरण जाँच के बाद -
>>> from sympy.geometry import Point
>>> from sympy import *
>>> x=Point(0,0)
>>> y=Point(2,2)
>>> z=Point(4,4)
>>> Point.is_collinear(x,y,z)
Output
True
>>> a=Point(2,3)
>>> Point.is_collinear(x,y,a)
Output
False
बिंदु वर्ग की दूरी () विधि दो बिंदुओं के बीच की दूरी की गणना करती है
>>> x.distance(y)
Output
$2\sqrt2$
दूरी को प्रतीकों के संदर्भ में भी दर्शाया जा सकता है।
लाइन
लाइन इकाई दो बिंदु वस्तुओं से प्राप्त की जाती है। चौराहा () विधि प्रतिच्छेदन बिंदु को लौटाती है यदि दो रेखाएं एक दूसरे को काटती हैं।
>>> from sympy.geometry import Point, Line
>>> p1, p2=Point(0,5), Point(5,0)
>>> l1=Line(p1,p2)
>>> l2=Line(Point(0,0), Point(5,5))
>>> l1.intersection(l2)
Output
[Point2D(5/2, 5/2)]
>>> l1.intersection(Line(Point(0,0), Point(2,2)))
Output
[Point2D(5/2, 5/2)]
>>> x,y=symbols('x y')
>>> p=Point(x,y)
>>> p.distance(Point(0,0))
Output
$\sqrt{x^2 + y^2}$
त्रिकोण
यह फ़ंक्शन तीन बिंदु ऑब्जेक्ट से एक त्रिकोण इकाई बनाता है।
Triangle(a,b,c)
>>> t=Triangle(Point(0,0),Point(0,5), Point(5,0))
>>> t.area
Output
$-\frac{25}{2}$
अंडाकार
एक अण्डाकार ज्यामिति इकाई का निर्माण केंद्र के अनुरूप एक पॉइंट ऑब्जेक्ट और क्षैतिज और ऊर्ध्वाधर त्रिज्या के लिए प्रत्येक दो संख्याओं को पास करके किया जाता है।
ellipse(center, hradius, vradius)
>>> from sympy.geometry import Ellipse, Line
>>> e=Ellipse(Point(0,0),8,3)
>>> e.area
Output
$24\pi$
सनकी परोक्ष पैरामीटर का उपयोग करके परोक्ष रूप से प्रदान किया जा सकता है।
>>> e1=Ellipse(Point(2,2), hradius=5, eccentricity=Rational(3,4))
>>> e1.vradius
Output
$\frac{5\sqrt7}{4}$
apoapsis दीर्घवृत्त फोकस और समोच्च के बीच सबसे बड़ी दूरी है।
>>> e1.apoapsis
Output
$\frac{35}{4}$
निम्नलिखित कथन दीर्घवृत्त की परिधि की गणना करता है -
>>> e1.circumference
Output
$20E(\frac{9}{16})$
equation दीर्घवृत्त की विधि दीर्घवृत्त का समीकरण लौटाती है।
>>> e1.equation(x,y)
Output
$(\frac{x}{5}-\frac{2}{5})^2 + \frac{16(y-2)2}{175} - 1$
गणित में, एक सेट अलग-अलग वस्तुओं का एक अच्छी तरह से परिभाषित संग्रह है जो संख्या, लोग, वर्णमाला के अक्षर या अन्य सेट भी हो सकते हैं। सेट भी पायथन में अंतर्निहित प्रकारों में से एक है। SymPy सेट मॉड्यूल प्रदान करता है। इसमें विभिन्न प्रकार के सेट की परिभाषाएँ हैं और सेट ऑपरेशन जैसे चौराहे, यूनियन आदि करने के लिए कार्यक्षमता है।
सेट SymPy में किसी अन्य प्रकार के सेट के लिए एक बेस क्लास है। ध्यान दें कि यह अंतर्निहित डेटा प्रकार के पायथन से अलग है। अंतराल वर्ग वास्तविक अंतराल का प्रतिनिधित्व करता है और इसकी सीमा संपत्ति एक रिटर्न देती हैFiniteSet वस्तु।
>>> from sympy import Interval
>>> s=Interval(1,10).boundary
>>> type(s)
sympy.sets.sets.FiniteSet
FiniteSet असतत संख्याओं का एक संग्रह है। इसे किसी भी अनुक्रम ऑब्जेक्ट से प्राप्त किया जा सकता है जैसे कि सूची या स्ट्रिंग।
>>> from sympy import FiniteSet
>>> FiniteSet(range(5))
Output
$\lbrace\lbrace0,1,...,4\rbrace\rbrace$
>>> numbers=[1,3,5,2,8]
>>> FiniteSet(*numbers)
Output
$\lbrace1,2,3,5,8\rbrace$
>>> s="HelloWorld"
>>> FiniteSet(*s)
Output
{H,W,d,e,l,o,r}
ध्यान दें कि, बिल्ट-इन सेट की तरह, सिम्पी का सेट भी अलग-अलग वस्तुओं का एक संग्रह है।
ConditionSet तत्वों का एक समूह है जो किसी दिए गए शर्त को पूरा करता है
>>> from sympy import ConditionSet, Eq, Symbol
>>> x=Symbol('x')
>>> s=ConditionSet(x, Eq(x**2-2*x,0), Interval(1,10)) >>> s
Output
$\lbrace x\mid x\in[1,10]∧x^2 - 2x =0\rbrace$
Unionएक यौगिक सेट है। इसमें दो सेटों में सभी तत्व शामिल हैं। ध्यान दें कि दोनों में पाए जाने वाले तत्व संघ में केवल एक बार दिखाई देंगे।
>>> from sympy import Union
>>> l1=[3,1,5,7]
>>> l2=[9,7,2,1]
>>> a=FiniteSet(*l1)
>>> b=FiniteSet(*l2)
>>> Union(a,b)
Intersection दूसरी ओर केवल वही तत्व होते हैं जो दोनों में मौजूद होते हैं।
>>> from sympy import Intersection
>>> Intersection(a,b)
ProductSet ऑब्जेक्ट दोनों सेटों में तत्वों के कार्टेशियन उत्पाद का प्रतिनिधित्व करता है।
>>> from sympy import ProductSet
>>> l1=[1,2]
>>> l2=[2,3]
>>> a=FiniteSet(*l1)
>>> b=FiniteSet(*l2)
>>> set(ProductSet(a,b))
Complement(a,b) बी सेट के साथ सामान्य होने वाले तत्वों को छोड़कर तत्वों को बनाए रखता है।
>>> from sympy import Complement
>>> l1=[3,1,5,7]
>>> l2=[9,7,2,1]
>>> a=FiniteSet(*l1)
>>> b=FiniteSet(*l2)
>>> Complement(a,b), Complement(b,a)
SymmetricDifference सेट में दोनों सेट में केवल असामान्य तत्व होते हैं।
>>> from sympy import SymmetricDifference
>>> l1=[3,1,5,7]
>>> l2=[9,7,2,1]
>>> a=FiniteSet(*l1)
>>> b=FiniteSet(*l2)
>>> SymmetricDifference(a,b)
Output
{2,3,5,9}
SymPy में कई प्रिंटर उपलब्ध हैं। निम्नलिखित एक आंशिक सूची है -
- str
- srepr
- ASCII सुंदर प्रिंटर
- यूनिकोड सुंदर प्रिंटर
- LaTeX
- MathML
- Dot
SymPy ऑब्जेक्ट्स को विभिन्न भाषाओं के कोड के आउटपुट के रूप में भी भेजा जा सकता है, जैसे C, फोरट्रान, जावास्क्रिप्ट, थीनो और पायथन।
SymPy सुंदर प्रिंट के रूप में आउटपुट रेंडर करने के लिए यूनिकोड वर्णों का उपयोग करता है। यदि आप SymPy सत्र को निष्पादित करने के लिए पायथन कंसोल का उपयोग कर रहे हैं, तो init_session () फ़ंक्शन को कॉल करके सबसे अच्छा मुद्रण वातावरण सक्रिय होता है।
>>> from sympy import init_session
>>> init_session()
सिम्पी 1.5.1 (पायथन 3.7.4-64-बिट) के लिए आईपीथॉन कंसोल (जमीन के प्रकार: अजगर)।
इन आदेशों पर अमल किया गया -
>>> from __future__ import division
>>> from sympy import *
>>> x, y, z, t = symbols('x y z t')
>>> k, m, n = symbols('k m n', integer=True)
>>> f, g, h = symbols('f g h', cls=Function)
>>> init_printing()
प्रलेखन पर पाया जा सकता है https://docs.sympy.org/1.5.1/.
>>> Integral(sqrt(1/x),x)
$\int \sqrt\frac{1}{x} dx$
यदि LATEX स्थापित नहीं है, लेकिन Matplotlib स्थापित है, तो यह Matplotlib रेंडरिंग इंजन का उपयोग करेगा। यदि Matplotlib स्थापित नहीं है, तो यह यूनिकोड सुंदर प्रिंटर का उपयोग करता है। हालाँकि, Jupyter नोटबुक LATEX को प्रस्तुत करने के लिए MathJax का उपयोग करता है।
एक टर्मिनल में जो यूनिकोड का समर्थन नहीं करता है, ASCII सुंदर प्रिंटर का उपयोग किया जाता है।
ASCII प्रिंटर का उपयोग करने के लिए pprint () function_unicode प्रॉपर्टी के साथ फाल्स पर सेट करें
>>> pprint(Integral(sqrt(1/x),x),use_unicode=False)
यूनिकोड सुंदर प्रिंटर को भी प्रिंट () और सुंदर () से एक्सेस किया जाता है। यदि टर्मिनल यूनिकोड का समर्थन करता है, तो इसका उपयोग स्वचालित रूप से किया जाता है। यदि pprint () यह पता लगाने में सक्षम नहीं है कि टर्मिनल यूनिकोड का समर्थन करता है, तो आप यूनिकोड का उपयोग करने के लिए मजबूर करने के लिए use_unicode = True को पास कर सकते हैं।
किसी अभिव्यक्ति के LATEX रूप को प्राप्त करने के लिए, लेटेक्स () फ़ंक्शन का उपयोग करें।
>>> print(latex(Integral(sqrt(1/x),x)))
\int \sqrt{\frac{1}{x}}\, dx
आप mathml प्रिंटर का भी उपयोग कर सकते हैं। उस उद्देश्य के लिए, print_mathml फ़ंक्शन आयात करें। एक स्ट्रिंग संस्करण mathml () फ़ंक्शन द्वारा प्राप्त किया गया है।
>>> from sympy.printing.mathml import print_mathml
>>> print_mathml(Integral(sqrt(1/x),x))
<apply>
<int/>
<bvar>
<ci>x</ci>
</bvar>
<apply>
<root/>
<apply>
<power/>
<ci>x</ci>
<cn>-1</cn>
</apply>
</apply>
</apply>
>>>mathml(Integral(sqrt(1/x),x))
'<apply><int/><bvar><ci>x</ci></bvar><apply><root/><apply><power/><ci>x</ci><cn>-1</cn></apply></apply></apply>'