LISP - संख्या
आम लिस्प कई प्रकार की संख्याओं को परिभाषित करता है। number डेटा प्रकार में LISP द्वारा समर्थित विभिन्न प्रकार की संख्याएँ शामिल हैं।
LISP द्वारा समर्थित संख्या प्रकार हैं -
- Integers
- Ratios
- दशमलव संख्याएं
- जटिल आंकड़े
निम्नलिखित चित्र संख्या पदानुक्रम और LISP में उपलब्ध विभिन्न संख्यात्मक डेटा प्रकारों को दर्शाता है -
LISP में विभिन्न संख्यात्मक प्रकार
निम्न तालिका LISP में उपलब्ध विभिन्न प्रकार के डेटा का वर्णन करती है -
अनु क्रमांक। | डेटा प्रकार और विवरण |
---|---|
1 | fixnum यह डेटा प्रकार पूर्णांक का प्रतिनिधित्व करता है जो बहुत बड़ा नहीं है और अधिकतर -215 से 215-1 की सीमा में है (यह मशीन पर निर्भर है) |
2 | bignum ये एलआईएसपी के लिए आवंटित स्मृति की मात्रा द्वारा सीमित आकार के साथ बहुत बड़ी संख्या हैं, वे फ़िक्नम संख्या नहीं हैं। |
3 | ratio अंश / हर में दो संख्याओं के अनुपात का प्रतिनिधित्व करता है। / फ़ंक्शन हमेशा अनुपात में परिणाम उत्पन्न करता है, जब इसके तर्क पूर्णांक होते हैं। |
4 | float यह गैर-पूर्णांक संख्याओं का प्रतिनिधित्व करता है। बढ़ती सटीकता के साथ चार फ्लोट डेटा प्रकार हैं। |
5 | complex यह जटिल संख्याओं का प्रतिनिधित्व करता है, जिन्हें #c द्वारा दर्शाया जाता है। वास्तविक और काल्पनिक दोनों भाग तर्कसंगत या फ्लोटिंग पॉइंट संख्या हो सकते हैं। |
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (/ 1 2))
(terpri)
(write ( + (/ 1 2) (/ 3 4)))
(terpri)
(write ( + #c( 1 2) #c( 3 -4)))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
1/2
5/4
#C(4 -2)
संख्या कार्य
निम्न तालिका कुछ सामान्य रूप से उपयोग किए जाने वाले संख्यात्मक कार्यों का वर्णन करती है -
अनु क्रमांक। | समारोह विवरण |
---|---|
1 | +, -, *, / प्रतिक्रियाशील अंकगणित संचालन |
2 | sin, cos, tan, acos, asin, atan प्रतिक्रियाशील त्रिकोणमितीय कार्य। |
3 | sinh, cosh, tanh, acosh, asinh, atanh प्रतिक्रियाशील अतिशयोक्तिपूर्ण कार्य। |
4 | exp घातांक कार्य करते हैं। ई x की गणना करता है |
5 | expt एक्सपेंसेशन फंक्शन, बेस और पावर दोनों लेता है। |
6 | sqrt यह एक संख्या के वर्गमूल की गणना करता है। |
7 | log लघुगणक समारोह। यह एक पैरामीटर दिया जाता है, फिर यह इसके प्राकृतिक लघुगणक की गणना करता है, अन्यथा दूसरे पैरामीटर का उपयोग आधार के रूप में किया जाता है। |
8 | conjugate यह एक संख्या के जटिल संयुग्म की गणना करता है। एक वास्तविक संख्या के मामले में, यह संख्या को ही वापस करता है। |
9 | abs यह किसी संख्या का पूर्ण मान (या परिमाण) लौटाता है। |
10 | gcd यह दी गई संख्याओं के सबसे बड़े सामान्य भाजक की गणना करता है। |
1 1 | lcm यह दी गई संख्याओं के कम से कम सामान्य गुणकों की गणना करता है। |
12 | isqrt यह किसी दिए गए प्राकृतिक संख्या के सटीक वर्गमूल से कम या उसके बराबर सबसे बड़ा पूर्णांक देता है। |
13 | floor, ceiling, truncate, round ये सभी कार्य एक संख्या के रूप में दो तर्क देते हैं और भागफल को लौटाते हैं; floor सबसे बड़ा पूर्णांक देता है जो अनुपात से अधिक नहीं है, ceiling छोटे पूर्णांक को चुनता है जो अनुपात से बड़ा हो, truncate समान चिह्न के पूर्णांक को अनुपात के साथ सबसे बड़े निरपेक्ष मान के साथ चुनता है जो अनुपात के निरपेक्ष मान से कम है, और round एक पूर्णांक चुनता है जो अनुपात के सबसे करीब है। |
14 | ffloor, fceiling, ftruncate, fround उपरोक्त के समान ही है, लेकिन भागफल को फ्लोटिंग पॉइंट संख्या के रूप में लौटाता है। |
15 | mod, rem शेष को एक डिवीजन ऑपरेशन में लौटाता है। |
16 | float एक वास्तविक संख्या को एक अस्थायी बिंदु संख्या में परिवर्तित करता है। |
17 | rational, rationalize एक वास्तविक संख्या को तर्कसंगत संख्या में रूपांतरित करता है। |
18 | numerator, denominator एक परिमेय संख्या के संबंधित भागों को लौटाता है। |
19 | realpart, imagpart एक जटिल संख्या का वास्तविक और काल्पनिक हिस्सा लौटाता है। |
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (/ 45 78))
(terpri)
(write (floor 45 78))
(terpri)
(write (/ 3456 75))
(terpri)
(write (floor 3456 75))
(terpri)
(write (ceiling 3456 75))
(terpri)
(write (truncate 3456 75))
(terpri)
(write (round 3456 75))
(terpri)
(write (ffloor 3456 75))
(terpri)
(write (fceiling 3456 75))
(terpri)
(write (ftruncate 3456 75))
(terpri)
(write (fround 3456 75))
(terpri)
(write (mod 3456 75))
(terpri)
(setq c (complex 6 7))
(write c)
(terpri)
(write (complex 5 -9))
(terpri)
(write (realpart c))
(terpri)
(write (imagpart c))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
15/26
0
1152/25
46
47
46
46
46.0
47.0
46.0
46.0
6
#C(6 7)
#C(5 -9)
6
7