फोरट्रान - न्यूमेरिक परिशुद्धता

हम पहले ही चर्चा कर चुके हैं कि, फोरट्रान के पुराने संस्करणों में, दो थे real प्रकार: डिफ़ॉल्ट वास्तविक प्रकार और double precision प्रकार।

हालांकि, फोरट्रान 90/95 वास्तविक और पूर्णांक डेटा प्रकारों की सटीकता पर अधिक नियंत्रण प्रदान करता है kind specifie।

तरह की विशेषता

अलग-अलग तरह के नंबर कंप्यूटर के अंदर अलग-अलग तरीके से स्टोर होते हैं। kindविशेषता आपको यह निर्दिष्ट करने की अनुमति देती है कि किसी संख्या को आंतरिक रूप से कैसे संग्रहीत किया जाता है। उदाहरण के लिए,

real, kind = 2 :: a, b, c
real, kind = 4 :: e, f, g
integer, kind = 2 :: i, j, k
integer, kind = 3 :: l, m, n

उपरोक्त घोषणा में, वास्तविक चर e, f और g में वास्तविक चर a, b और c की तुलना में अधिक सटीकता है। पूर्णांक चर l, m और n, बड़े मानों को संग्रहीत कर सकते हैं और पूर्णांक चर i, j और k की तुलना में संग्रहण के लिए अधिक अंक हो सकते हैं। हालांकि यह मशीन पर निर्भर है।

उदाहरण

program kindSpecifier
implicit none

   real(kind = 4) :: a, b, c
   real(kind = 8) :: e, f, g
   integer(kind = 2) :: i, j, k
   integer(kind = 4) :: l, m, n
   integer :: kind_a, kind_i, kind_e, kind_l
   
   kind_a = kind(a)
   kind_i = kind(i)
   kind_e = kind(e)
   kind_l = kind(l)
   
   print *,'default kind for real is', kind_a
   print *,'default kind for int is', kind_i
   print *,'extended kind for real is', kind_e
   print *,'default kind for int is', kind_l
   
end program kindSpecifier

जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं तो यह निम्नलिखित परिणाम उत्पन्न करता है -

default kind for real is 4
default kind for int is 2
extended kind for real is 8
default kind for int is 4

चर का आकार प्राप्त करना

कई आंतरिक कार्य हैं जो आपको संख्याओं के आकार को पूछताछ करने की अनुमति देते हैं।

उदाहरण के लिए, bit_size(i)आंतरिक फ़ंक्शन भंडारण के लिए उपयोग किए जाने वाले बिट्स की संख्या को निर्दिष्ट करता है। वास्तविक संख्या के लिए,precision(x) आंतरिक फ़ंक्शन, सटीक के दशमलव अंकों की संख्या देता है, जबकि range(x) आंतरिक समारोह प्रतिपादक की दशमलव सीमा लौटाता है।

उदाहरण

program getSize
implicit none

   real (kind = 4) :: a
   real (kind = 8) :: b
   integer (kind = 2) :: i
   integer (kind = 4) :: j

   print *,'precision of real(4) =', precision(a)
   print *,'precision of real(8) =', precision(b)
   
   print *,'range of real(4) =', range(a)
   print *,'range of real(8) =', range(b)
   

   print *,'maximum exponent of real(4) =' , maxexponent(a)
   print *,'maximum exponent of real(8) =' , maxexponent(b)
  
   print *,'minimum exponent of real(4) =' , minexponent(a)
   print *,'minimum exponent of real(8) =' , minexponent(b)
   
   print *,'bits in integer(2) =' , bit_size(i)
   print *,'bits in integer(4) =' , bit_size(j)
   
end program getSize

जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं तो यह निम्नलिखित परिणाम उत्पन्न करता है -

precision of real(4) = 6
precision of real(8) = 15
range of real(4) = 37
range of real(8) = 307
maximum exponent of real(4) = 128
maximum exponent of real(8) = 1024
minimum exponent of real(4) = -125
minimum exponent of real(8) = -1021
bits in integer(2) = 16
bits in integer(4) = 32

काइंड वैल्यू प्राप्त करना

फ़ोर्ट्रान पूर्णांक और रियल्स की आवश्यक परिशुद्धता के लिए समान मूल्य प्राप्त करने के लिए दो और आंतरिक कार्य प्रदान करता है -

  • चयनित_इंट_इंडिया (आर)
  • चयनित_आयाल_किंड ([पी, आर])

चयनित_रियल_हाइंड फ़ंक्शन एक पूर्णांक देता है जो किसी दिए गए दशमलव सटीक p और दशमलव घातांक श्रेणी r के लिए आवश्यक प्रकार का पैरामीटर मान है। दशमलव सटीकता महत्वपूर्ण अंकों की संख्या है, और दशमलव घातांक सीमा सबसे छोटी और सबसे बड़ी प्रतिनिधित्व योग्य संख्या को निर्दिष्ट करती है। सीमा इस प्रकार 10-आर से 10 + आर तक है।

उदाहरण के लिए, select_real_kind (p = 10, r = 99) 10 दशमलव स्थानों की सटीकता के लिए आवश्यक प्रकार का मान लौटाता है, और कम से कम 10-99 से 10 + 99 की सीमा होती है।

उदाहरण

program getKind
implicit none

   integer:: i
   i = selected_real_kind (p = 10, r = 99) 
   print *,'selected_real_kind (p = 10, r = 99)', i
   
end program getKind

जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं तो यह निम्नलिखित परिणाम उत्पन्न करता है -

selected_real_kind (p = 10, r = 99) 8