फोरट्रान - प्रक्रियाएं

procedureबयानों का एक समूह है जो एक अच्छी तरह से परिभाषित कार्य करता है और इसे आपके कार्यक्रम से आमंत्रित किया जा सकता है। सूचना (या डेटा) को कॉलिंग प्रोग्राम में तर्क के रूप में प्रक्रिया को पारित किया जाता है।

दो प्रकार की प्रक्रियाएँ हैं -

  • Functions
  • Subroutines

समारोह

एक फ़ंक्शन एक ऐसी प्रक्रिया है जो एक एकल मात्रा लौटाती है। एक फ़ंक्शन को अपने तर्कों को संशोधित नहीं करना चाहिए।

लौटाई गई मात्रा के रूप में जाना जाता है function value, और यह फ़ंक्शन नाम से चिह्नित है।

Syntax

किसी फ़ंक्शन के लिए सिंटैक्स निम्नानुसार है -

function name(arg1, arg2, ....)  
   [declarations, including those for the arguments]   
   [executable statements] 
end function [name]

निम्न उदाहरण area_of_circle नामक फ़ंक्शन को प्रदर्शित करता है। यह त्रिज्या आर के साथ एक सर्कल के क्षेत्र की गणना करता है।

program calling_func

   real :: a
   a = area_of_circle(2.0) 
   
   Print *, "The area of a circle with radius 2.0 is"
   Print *, a
   
end program calling_func


! this function computes the area of a circle with radius r  
function area_of_circle (r)  

! function result     
implicit none      

   ! dummy arguments        
   real :: area_of_circle   
   
   ! local variables 
   real :: r     
   real :: pi
   
   pi = 4 * atan (1.0)     
   area_of_circle = pi * r**2  
   
end function area_of_circle

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

The area of a circle with radius 2.0 is
   12.5663710

कृपया ध्यान दें कि -

  • आपको निर्दिष्ट करना होगा implicit none दोनों मुख्य कार्यक्रम में और साथ ही प्रक्रिया।

  • कहा फ़ंक्शन में तर्क आर कहा जाता है dummy argument

परिणाम विकल्प

यदि आप चाहते हैं कि लौटाया गया मान फ़ंक्शन नाम की तुलना में किसी अन्य नाम पर संग्रहीत किया जाए, तो आप इसका उपयोग कर सकते हैं result विकल्प।

आप रिटर्न वैरिएबल का नाम निम्नानुसार बता सकते हैं -

function name(arg1, arg2, ....) result (return_var_name)  
   [declarations, including those for the arguments]   
   [executable statements] 
end function [name]

सबरूटीन

एक सबरूटिन एक मूल्य नहीं लौटाता है, हालांकि यह अपने तर्कों को संशोधित कर सकता है।

Syntax

subroutine name(arg1, arg2, ....)    
   [declarations, including those for the arguments]    
   [executable statements]  
end subroutine [name]

एक सबरूटिन को बुलाना

आप का उपयोग कर एक सबरूटिन को आमंत्रित करने की आवश्यकता है call बयान।

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

program calling_func
implicit none

   real :: a, b
   a = 2.0
   b = 3.0
   
   Print *, "Before calling swap"
   Print *, "a = ", a
   Print *, "b = ", b
   
   call swap(a, b)
   
   Print *, "After calling swap"
   Print *, "a = ", a
   Print *, "b = ", b
   
end program calling_func


subroutine swap(x, y) 
implicit none

   real :: x, y, temp   
   
   temp = x  
   x = y 
   y = temp  
   
end subroutine swap

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

Before calling swap
a = 2.00000000    
b = 3.00000000    
After calling swap
a = 3.00000000    
b = 2.00000000

तर्क की मंशा निर्दिष्ट करना

आशय विशेषता आपको उस अभिप्राय को निर्दिष्ट करने की अनुमति देती है जिसके साथ प्रक्रिया में तर्कों का उपयोग किया जाता है। निम्न तालिका आशय विशेषता के मान प्रदान करती है -

मूल्य इसके समान इस्तेमाल किया व्याख्या
में आशय (में) इनपुट मान के रूप में उपयोग किया जाता है, फ़ंक्शन में नहीं बदला जाता है
बाहर आशय (बाहर) आउटपुट मूल्य के रूप में उपयोग किया जाता है, वे ओवरराइट किए जाते हैं
अंदर बाहर आशय (inout) तर्क दोनों का उपयोग और अधिलेखित किया जाता है

निम्नलिखित उदाहरण अवधारणा को प्रदर्शित करता है -

program calling_func
implicit none

   real :: x, y, z, disc
   
   x = 1.0
   y = 5.0
   z = 2.0
   
   call intent_example(x, y, z, disc)
   
   Print *, "The value of the discriminant is"
   Print *, disc
   
end program calling_func


subroutine intent_example (a, b, c, d)     
implicit none     

   ! dummy arguments      
   real, intent (in) :: a     
   real, intent (in) :: b      
   real, intent (in) :: c    
   real, intent (out) :: d   
   
   d = b * b - 4.0 * a * c 
   
end subroutine intent_example

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

The value of the discriminant is
   17.0000000

पुनरावर्ती प्रक्रियाएं

पुनरावृत्ति तब होती है जब एक प्रोग्रामिंग भाषा आपको उसी फ़ंक्शन के अंदर एक फ़ंक्शन को कॉल करने की अनुमति देती है। इसे फ़ंक्शन का पुनरावर्ती कॉल कहा जाता है।

जब कोई प्रक्रिया स्वयं को प्रत्यक्ष या अप्रत्यक्ष रूप से पुकारती है, तो पुनरावर्ती प्रक्रिया कहलाती है। आपको इस तरह की प्रक्रियाओं को शब्द से पहले घोषित करना चाहिएrecursive इसकी घोषणा से पहले।

जब एक फ़ंक्शन को पुनरावर्ती रूप से उपयोग किया जाता है, तो result विकल्प का उपयोग करना होगा।

निम्नलिखित एक उदाहरण है, जो एक पुनरावर्ती प्रक्रिया का उपयोग करके दिए गए संख्या के लिए भाज्य की गणना करता है -

program calling_func
implicit none

   integer :: i, f
   i = 15
   
   Print *, "The value of factorial 15 is"
   f = myfactorial(15)
   Print *, f
   
end program calling_func

! computes the factorial of n (n!)      
recursive function myfactorial (n) result (fac)  
! function result     
implicit none     

   ! dummy arguments     
   integer :: fac     
   integer, intent (in) :: n     
   
   select case (n)         
      case (0:1)         
         fac = 1         
      case default    
         fac = n * myfactorial (n-1)  
   end select 
   
end function myfactorial

आंतरिक प्रक्रियाएं

जब एक कार्यक्रम के भीतर एक प्रक्रिया निहित होती है, तो इसे प्रोग्राम की आंतरिक प्रक्रिया कहा जाता है। आंतरिक प्रक्रिया रखने का सिंटैक्स इस प्रकार है -

program program_name     
   implicit none         
   ! type declaration statements         
   ! executable statements    
   . . .     
   contains         
   ! internal procedures      
   . . .  
end program program_name

निम्नलिखित उदाहरण अवधारणा को प्रदर्शित करता है -

program mainprog  
implicit none 

   real :: a, b 
   a = 2.0
   b = 3.0
   
   Print *, "Before calling swap"
   Print *, "a = ", a
   Print *, "b = ", b
   
   call swap(a, b)
   
   Print *, "After calling swap"
   Print *, "a = ", a
   Print *, "b = ", b
 
contains   
   subroutine swap(x, y)     
      real :: x, y, temp      
      temp = x 
      x = y  
      y = temp   
   end subroutine swap 
   
end program mainprog

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

Before calling swap
a = 2.00000000    
b = 3.00000000    
After calling swap
a = 3.00000000    
b = 2.00000000