MATLAB - संख्या

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

आप किसी भी संख्या या संख्याओं की संख्या को पूर्णांक या एकल-सटीक संख्या के रूप में संग्रहीत करना चुन सकते हैं।

सभी संख्यात्मक प्रकार बुनियादी सरणी संचालन और गणितीय कार्यों का समर्थन करते हैं।

विभिन्न संख्यात्मक डेटा प्रकारों में रूपांतरण

MATLAB विभिन्न संख्यात्मक डेटा प्रकारों में परिवर्तित करने के लिए निम्नलिखित कार्य प्रदान करता है -

समारोह उद्देश्य
दोहरा डबल सटीक संख्या में कनवर्ट करता है
एक एकल सटीक संख्या में कनवर्ट करता है
int8 8-बिट हस्ताक्षरित पूर्णांक में कनवर्ट करता है
int16 16-बिट हस्ताक्षरित पूर्णांक में कनवर्ट करता है
int32 32-बिट हस्ताक्षरित पूर्णांक में कनवर्ट करता है
int64 64-बिट हस्ताक्षरित पूर्णांक में कनवर्ट करता है
uint8 8-बिट अहस्ताक्षरित पूर्णांक में कनवर्ट करता है
uint16 16-बिट अहस्ताक्षरित पूर्णांक में कनवर्ट करता है
uint32 32-बिट अहस्ताक्षरित पूर्णांक में कनवर्ट करता है
uint64 64-बिट अहस्ताक्षरित पूर्णांक में कनवर्ट करता है

उदाहरण

एक स्क्रिप्ट फ़ाइल बनाएँ और निम्न कोड टाइप करें -

x = single([5.32 3.47 6.28]) .* 7.5
x = double([5.32 3.47 6.28]) .* 7.5
x = int8([5.32 3.47 6.28]) .* 7.5
x = int16([5.32 3.47 6.28]) .* 7.5
x = int32([5.32 3.47 6.28]) .* 7.5
x = int64([5.32 3.47 6.28]) .* 7.5

जब आप फ़ाइल चलाते हैं, तो यह निम्न परिणाम दिखाता है -

x =

   39.900   26.025   47.100

x =

   39.900   26.025   47.100

x =

   38  23  45

x =

   38  23  45

x =

   38  23  45

x =

   38  23  45

उदाहरण

आइए हम पिछले उदाहरण को थोड़ा और बढ़ाएं। एक स्क्रिप्ट फ़ाइल बनाएँ और निम्न कोड टाइप करें -

x = int32([5.32 3.47 6.28]) .* 7.5
x = int64([5.32 3.47 6.28]) .* 7.5
x = num2cell(x)

जब आप फ़ाइल चलाते हैं, तो यह निम्न परिणाम दिखाता है -

x =

   38  23  45

x =

   38  23  45

x = 
{
   [1,1] = 38
   [1,2] = 23
   [1,3] = 45
}

सबसे छोटा और सबसे बड़ा पूर्णांक

कार्य करता है intmax() तथा intmin() अधिकतम और न्यूनतम मान लौटाएं जिन्हें सभी प्रकार के पूर्णांक संख्याओं के साथ दर्शाया जा सकता है।

दोनों फ़ंक्शन पूर्णांक डेटा प्रकार को तर्क के रूप में लेते हैं, उदाहरण के लिए, intmax (int8) या इंटमिन (int64) और अधिकतम और न्यूनतम मान लौटाते हैं जो आप पूर्णांक डेटा प्रकार के साथ प्रतिनिधित्व कर सकते हैं।

उदाहरण

निम्न उदाहरण दिखाता है कि पूर्णांकों के सबसे छोटे और सबसे बड़े मूल्यों को कैसे प्राप्त किया जाए। एक स्क्रिप्ट फ़ाइल बनाएँ और उसमें निम्न कोड लिखें -

% displaying the smallest and largest signed integer data
str = 'The range for int8 is:\n\t%d to %d ';
sprintf(str, intmin('int8'), intmax('int8'))

str = 'The range for int16 is:\n\t%d to %d ';
sprintf(str, intmin('int16'), intmax('int16'))

str = 'The range for int32 is:\n\t%d to %d ';
sprintf(str, intmin('int32'), intmax('int32'))

str = 'The range for int64 is:\n\t%d to %d ';
sprintf(str, intmin('int64'), intmax('int64'))
 
% displaying the smallest and largest unsigned integer data
str = 'The range for uint8 is:\n\t%d to %d ';
sprintf(str, intmin('uint8'), intmax('uint8'))

str = 'The range for uint16 is:\n\t%d to %d ';
sprintf(str, intmin('uint16'), intmax('uint16'))

str = 'The range for uint32 is:\n\t%d to %d ';
sprintf(str, intmin('uint32'), intmax('uint32'))

str = 'The range for uint64 is:\n\t%d to %d ';
sprintf(str, intmin('uint64'), intmax('uint64'))

जब आप फ़ाइल चलाते हैं, तो यह निम्न परिणाम दिखाता है -

ans = The range for int8 is:
	-128 to 127 
ans = The range for int16 is:
	-32768 to 32767 
ans = The range for int32 is:
	-2147483648 to 2147483647 
ans = The range for int64 is:
	0 to 0 
ans = The range for uint8 is:
	0 to 255 
ans = The range for uint16 is:
	0 to 65535 
ans = The range for uint32 is:
	0 to -1 
ans = The range for uint64 is:
	0 to 18446744073709551616

सबसे छोटा और सबसे बड़ा फ्लोटिंग पॉइंट नंबर

कार्य करता है realmax() तथा realmin() अधिकतम और न्यूनतम मान लौटाएं जिन्हें फ्लोटिंग पॉइंट नंबरों के साथ दर्शाया जा सकता है।

जब दोनों कार्यों को 'सिंगल' के साथ बुलाया जाता है, तो अधिकतम और न्यूनतम मान लौटाएं, जिसे आप एकल-सटीक डेटा प्रकार के साथ प्रतिनिधित्व कर सकते हैं और जब तर्क 'डबल' के साथ कहा जाता है, तो अधिकतम और न्यूनतम मान लौटाएं, जिनका आप प्रतिनिधित्व कर सकते हैं डबल-सटीक डेटा प्रकार।

उदाहरण

निम्न उदाहरण दिखाता है कि सबसे छोटी और सबसे बड़ी फ्लोटिंग पॉइंट संख्या कैसे प्राप्त करें। एक स्क्रिप्ट फ़ाइल बनाएँ और उसमें निम्न कोड लिखें -

% displaying the smallest and largest single-precision 
% floating point number
str = 'The range for single is:\n\t%g to %g and\n\t %g to  %g';
sprintf(str, -realmax('single'), -realmin('single'), ...
   realmin('single'), realmax('single'))

% displaying the smallest and largest double-precision 
% floating point number
str = 'The range for double is:\n\t%g to %g and\n\t %g to  %g';
sprintf(str, -realmax('double'), -realmin('double'), ...
   realmin('double'), realmax('double'))

जब आप फ़ाइल चलाते हैं, तो यह निम्न परिणाम प्रदर्शित करता है -

ans = The range for single is:                                                  
        -3.40282e+38 to -1.17549e-38 and                                        
         1.17549e-38 to  3.40282e+38                                            
ans = The range for double is:                                                  
        -1.79769e+308 to -2.22507e-308 and                                      
         2.22507e-308 to  1.79769e+308