MATLAB - त्वरित गाइड

MATLAB (मैट्रिक्स प्रयोगशाला) एक चौथी पीढ़ी की उच्च स्तरीय प्रोग्रामिंग भाषा और संख्यात्मक अभिकलन, दृश्य और प्रोग्रामिंग के लिए इंटरैक्टिव वातावरण है।

MATLAB को MathWorks द्वारा विकसित किया गया है।

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

इसमें कई अंतर्निहित कमांड और गणित कार्य हैं जो गणितीय गणनाओं में आपकी मदद करते हैं, भूखंडों का निर्माण करते हैं, और संख्यात्मक तरीकों का प्रदर्शन करते हैं।

MATLAB की कम्प्यूटेशनल गणित की शक्ति

MATLAB का उपयोग कम्प्यूटेशनल गणित के प्रत्येक पहलू में किया जाता है। निम्नलिखित कुछ गणितीय गणनाओं का उपयोग किया जाता है जहां इसका उपयोग सबसे अधिक किया जाता है -

  • Matrices और Arrays से निपटना
  • 2-डी और 3-डी प्लॉटिंग और ग्राफिक्स
  • रेखीय बीजगणित
  • बीजगणितीय समीकरण
  • गैर-रैखिक कार्य
  • Statistics
  • डेटा विश्लेषण
  • पथरी और विभेदक समीकरण
  • संख्यात्मक गणना
  • Integration
  • Transforms
  • कटाव फिटिंग
  • विभिन्न अन्य विशेष कार्य

MATLAB की विशेषताएं

MATLAB की मूल विशेषताएं निम्नलिखित हैं -

  • यह संख्यात्मक अभिकलन, विज़ुअलाइज़ेशन और अनुप्रयोग विकास के लिए एक उच्च-स्तरीय भाषा है।

  • यह पुनरावृत्ति अन्वेषण, डिजाइन और समस्या समाधान के लिए एक इंटरैक्टिव वातावरण भी प्रदान करता है।

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

  • यह कस्टम प्लॉट बनाने के लिए डेटा और उपकरणों की कल्पना के लिए अंतर्निहित ग्राफिक्स प्रदान करता है।

  • MATLAB का प्रोग्रामिंग इंटरफ़ेस कोड गुणवत्ता बनाए रखने में सुधार और प्रदर्शन को अधिकतम करने के लिए विकास उपकरण देता है।

  • यह कस्टम चित्रमय इंटरफेस के साथ अनुप्रयोगों के निर्माण के लिए उपकरण प्रदान करता है।

  • यह MATLAB आधारित एल्गोरिदम को बाहरी अनुप्रयोगों और भाषाओं जैसे C, Java, .NET और Microsoft Excel के साथ एकीकृत करने के लिए कार्य प्रदान करता है।

MATLAB के उपयोग

MATLAB का व्यापक रूप से विज्ञान और इंजीनियरिंग में एक कम्प्यूटेशनल उपकरण के रूप में उपयोग किया जाता है, जिसमें भौतिकी, रसायन विज्ञान, गणित और सभी इंजीनियरिंग धाराओं के क्षेत्र शामिल हैं। इसका उपयोग कई अनुप्रयोगों में किया जाता है -

  • सिग्नल प्रोसेसिंग और संचार
  • छवि और वीडियो प्रसंस्करण
  • नियंत्रण प्रणाली
  • परीक्षण और माप
  • कम्प्यूटेशनल वित्त
  • कम्प्यूटेशनल बायोलॉजी

स्थानीय पर्यावरण सेटअप

MATLAB वातावरण की स्थापना कुछ क्लिकों का मामला है। इंस्टॉलर को यहां से डाउनलोड किया जा सकता है ।

MathWorks लाइसेंस प्राप्त उत्पाद, एक परीक्षण संस्करण और एक छात्र संस्करण भी प्रदान करता है। आपको साइट पर लॉग इन करने और उनके अनुमोदन के लिए थोड़ा इंतजार करने की आवश्यकता है।

इंस्टॉलर को डाउनलोड करने के बाद कुछ क्लिक के माध्यम से सॉफ्टवेयर को स्थापित किया जा सकता है।

MATLAB पर्यावरण को समझना

MATLAB विकास IDE को डेस्कटॉप पर बनाए गए आइकन से लॉन्च किया जा सकता है। MATLAB में मुख्य काम करने वाली खिड़की को डेस्कटॉप कहा जाता है। जब MATLAB शुरू किया जाता है, तो डेस्कटॉप अपने डिफ़ॉल्ट लेआउट में दिखाई देता है -

डेस्कटॉप में निम्नलिखित पैनल हैं -

  • Current Folder - यह पैनल आपको प्रोजेक्ट फ़ोल्डर और फ़ाइलों तक पहुंचने की अनुमति देता है।

  • Command Window- यह मुख्य क्षेत्र है जहां कमांड लाइन पर कमांड दर्ज किए जा सकते हैं। यह कमांड प्रॉम्प्ट (>>) द्वारा इंगित किया गया है।

  • Workspace - कार्यक्षेत्र सभी चर बनाए गए और / या फ़ाइलों से आयात दिखाता है।

  • Command History - यह पैनल कमांड लाइन पर दर्ज किए गए कमांड को दिखाता या वापस करता है।

जीएनयू ऑक्टेव की स्थापना करें

यदि आप अपनी मशीन (लिनक्स, बीएसडी, ओएस एक्स या विंडोज) पर ऑक्टेव का उपयोग करने के इच्छुक हैं, तो कृपया जीएनयू ऑक्टेव से नवीनतम संस्करण डाउनलोड करें । आप अपने मशीन के लिए दिए गए इंस्टॉलेशन निर्देशों की जांच कर सकते हैं।

MATLAB पर्यावरण एक सुपर-जटिल कैलकुलेटर की तरह व्यवहार करता है। आप >> कमांड प्रॉम्प्ट पर कमांड दर्ज कर सकते हैं।

MATLAB एक व्याख्या किया गया वातावरण है। दूसरे शब्दों में, आप एक कमांड देते हैं और MATLAB इसे तुरंत निष्पादित करता है।

अभ्यास पर हाथ

उदाहरण के लिए, एक मान्य अभिव्यक्ति लिखें

5 + 5

और ENTER दबाएँ

जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, MATLAB इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम है -

ans = 10

आइए हम कुछ और उदाहरण लेते हैं -

3 ^ 2	       % 3 raised to the power of 2

जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, MATLAB इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम है -

ans = 9

एक और उदाहरण,

sin(pi /2)	  % sine of angle 90o

जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, MATLAB इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम है -

ans = 1

एक और उदाहरण,

7/0		      % Divide by zero

जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, MATLAB इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम है -

ans = Inf
warning: division by zero

एक और उदाहरण,

732 * 20.3

जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, MATLAB इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम है -

ans =  1.4860e+04

MATLAB कुछ गणितीय प्रतीकों के लिए कुछ विशेष भाव प्रदान करता है, जैसे Inf के लिए पाई, special के लिए Inf, etc.-1 के लिए i (और j) आदि। Nan 'एक संख्या नहीं' के लिए खड़ा है।

MATLAB में अर्धविराम (;) का उपयोग

अर्धविराम (;) कथन के अंत को इंगित करता है। हालाँकि, यदि आप एक अभिव्यक्ति के लिए MATLAB आउटपुट को दबाना और छिपाना चाहते हैं, तो अभिव्यक्ति के बाद अर्धविराम जोड़ें।

उदाहरण के लिए,

x = 3;
y = x + 5

जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, MATLAB इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम है -

y =  8

टिप्पणियाँ जोड़ना

प्रतिशत चिह्न (%) का उपयोग टिप्पणी लाइन को दर्शाने के लिए किया जाता है। उदाहरण के लिए,

x = 9	     % assign the value 9 to x

आप ब्लॉक कमेंट ऑपरेटर% {और%} का उपयोग करके टिप्पणियों का एक ब्लॉक भी लिख सकते हैं।

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

आमतौर पर ऑपरेटर्स और विशेष वर्णों का उपयोग किया जाता है

MATLAB निम्नलिखित आमतौर पर इस्तेमाल किए जाने वाले ऑपरेटरों और विशेष पात्रों का समर्थन करता है -

ऑपरेटर उद्देश्य
+ प्लस; इसके अलावा ऑपरेटर।
- माइनस; घटाव ऑपरेटर।
* स्केलर और मैट्रिक्स गुणन ऑपरेटर।
.* सरणी गुणन ऑपरेटर।
^ स्केलर और मैट्रिक्स घातांक ऑपरेटर।
.^ प्रतिपादक परिचालक।
\ लेफ्ट-डिवीजन ऑपरेटर।
/ राइट-डिवीजन ऑपरेटर।
.\ लेफ्ट-डिवीजन ऑपरेटर को एरियर।
./ राइट-डिवीजन ऑपरेटर को सरणी।
: बृहदान्त्र; नियमित रूप से स्थानिक तत्व उत्पन्न करता है और एक पूरी पंक्ति या स्तंभ का प्रतिनिधित्व करता है।
( ) कोष्ठक; फ़ंक्शन तर्क और सरणी सूचकांकों को संलग्न करता है; पूर्वता पर काबू पाता है।
[ ] कोष्ठक; संलग्नक सरणी तत्व।
. दशमलव बिंदु।
अंडाकार; लाइन-निरंतरता ऑपरेटर
, अल्पविराम; एक पंक्ति में कथनों और तत्वों को अलग करता है
; अर्द्धविराम; स्तंभों को अलग करता है और प्रदर्शन को दबाता है।
% प्रतिशत का संकेत; एक टिप्पणी तैयार करता है और स्वरूपण निर्दिष्ट करता है।
_ भाव चिह्न और संचालक परिचालक।
._ गैर-संयुग्मित संचालक।
= असाइनमेंट ऑपरेटर।

विशेष चर और अचर

MATLAB निम्नलिखित विशेष चर और स्थिरांक का समर्थन करता है -

नाम जिसका अर्थ है
ans सबसे हाल का जवाब।
eps फ्लोटिंग-पॉइंट सटीक की सटीकता।
i,j काल्पनिक इकाई imag-1।
Inf इन्फिनिटी।
NaN अनिर्धारित संख्यात्मक परिणाम (संख्या नहीं)।
pi संख्या π

नामकरण चर

परिवर्तनीय नामों में एक अक्षर होता है, जिसके बाद किसी भी संख्या में अक्षर, अंक या अंडरस्कोर होता है।

MATLAB है case-sensitive

परिवर्तनीय नाम किसी भी लम्बाई के हो सकते हैं, हालाँकि, MATLAB केवल पहले N वर्णों का उपयोग करता है, जहाँ N फ़ंक्शन द्वारा दिया जाता है namelengthmax

अपने काम को सहेजना

save कमांड का उपयोग कार्यक्षेत्र में सभी चर को सहेजने के लिए किया जाता है, वर्तमान निर्देशिका में .mat एक्सटेंशन के साथ एक फ़ाइल के रूप में।

उदाहरण के लिए,

save myfile

आप किसी भी समय बाद फ़ाइल को पुनः लोड कर सकते हैं load आदेश।

load myfile

MATLAB वातावरण में, प्रत्येक चर एक सरणी या मैट्रिक्स है।

आप सरल तरीके से चर असाइन कर सकते हैं। उदाहरण के लिए,

x = 3	       % defining x and initializing it with a value

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

x = 3

यह एक्स नाम से 1-बाय -1 मैट्रिक्स बनाता है और इसके तत्व में मूल्य 3 को संग्रहीत करता है। आइए एक और उदाहरण देखें,

x = sqrt(16) 	% defining x and initializing it with an expression

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

x = 4

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

  • एक बार जब एक चर प्रणाली में दर्ज किया जाता है, तो आप इसे बाद में संदर्भित कर सकते हैं।

  • चर का उपयोग करने से पहले उनके पास मान होना चाहिए।

  • जब कोई अभिव्यक्ति एक परिणाम देता है जिसे किसी भी चर को नहीं सौंपा जाता है, तो सिस्टम इसे ans नाम के चर को असाइन करता है, जिसे बाद में उपयोग किया जा सकता है।

उदाहरण के लिए,

sqrt(78)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans =  8.8318

आप इस चर का उपयोग कर सकते हैं ans -

sqrt(78);
9876/ans

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans =  1118.2

आइए एक और उदाहरण देखें -

x = 7 * 8;
y = x * 7.89

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

y =  441.84

एकाधिक असाइनमेंट

आपके पास एक ही पंक्ति में कई असाइनमेंट हो सकते हैं। उदाहरण के लिए,

a = 2; b = 7; c = a * b

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

c = 14

मैं चर चर भूल गया हूँ!

who कमांड आपके द्वारा उपयोग किए गए सभी चर नामों को प्रदर्शित करता है।

who

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

Your variables are:
a    ans  b    c

whos चर के बारे में कमांड अधिक प्रदर्शित करता है -

  • स्मृति में वर्तमान में चर
  • प्रत्येक चर का प्रकार
  • प्रत्येक चर के लिए आवंटित स्मृति
  • चाहे वे जटिल चर हों या न हों
whos

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

Attr Name        Size        Bytes      Class
==== ====        ====        ====       ===== 
   a             1x1           8        double
   ans           1x70         757        cell
   b             1x1           8        double
   c             1x1           8        double

Total is 73 elements using 781 bytes

clear आदेश मेमोरी से सभी (या निर्दिष्ट) चर को हटाता है।

clear x     % it will delete x, won't display anything
clear       % it will delete all variables in the workspace
            %  peacefully and unobtrusively

लंबे असाइनमेंट

दीर्घवृत्त (ellipses) का उपयोग करके लंबे कार्य को दूसरी पंक्ति में विस्तारित किया जा सकता है। उदाहरण के लिए,

initial_velocity = 0;
acceleration = 9.8;
time = 20;
final_velocity = initial_velocity + acceleration * time

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

final_velocity = 196

प्रारूप कमांड

डिफ़ॉल्ट रूप से, MATLAB चार दशमलव स्थान मानों के साथ संख्या प्रदर्शित करता है। इस रूप में जाना जाता हैshort format

हालाँकि, यदि आप अधिक सटीक चाहते हैं, तो आपको उपयोग करने की आवश्यकता है format आदेश।

format long दशमलव के बाद कमांड 16 अंक प्रदर्शित करता है।

उदाहरण के लिए -

format long
x = 7 + 10/3 + 5 ^ 1.2

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा

x = 17.2319816406394

एक और उदाहरण,

format short
x = 7 + 10/3 + 5 ^ 1.2

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

x = 17.232

format bankकमांड संख्याओं को दो दशमलव स्थानों तक ले जाती है। उदाहरण के लिए,

format bank
daily_wage = 177.45;
weekly_wage = daily_wage * 6

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

weekly_wage = 1064.70

MATLAB घातीय संकेतन का उपयोग करके बड़ी संख्या प्रदर्शित करता है।

format short e कमांड चार दशमलव स्थानों और घातांक के साथ घातीय रूप में प्रदर्शित करने की अनुमति देता है।

उदाहरण के लिए,

format short e
4.678 * 4.9

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans = 2.2922e+01

format long eकमांड चार दशमलव स्थानों और घातांक के साथ घातीय रूप में प्रदर्शित करने की अनुमति देता है। उदाहरण के लिए,

format long e
x = pi

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

x = 3.141592653589793e+00

format ratआदेश एक गणना से उत्पन्न निकटतम तर्कसंगत अभिव्यक्ति देता है। उदाहरण के लिए,

format rat
4.678 * 4.9

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans = 34177/1491

वैक्टर बनाना

एक सदिश संख्याओं का एक आयामी आयाम है। MATLAB दो प्रकार के वैक्टर बनाने की अनुमति देता है -

  • रो वैक्टर
  • कॉलम वैक्टर

Row vectors स्क्वायर ब्रैकेट में तत्वों के सेट को संलग्न करके बनाया गया है, तत्वों का परिसीमन करने के लिए स्थान या अल्पविराम का उपयोग किया जाता है।

उदाहरण के लिए,

r = [7 8 9 10 11]

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

r =

   7    8    9   10   11

एक और उदाहरण,

r = [7 8 9 10 11];
t = [2, 3, 4, 5, 6];
res = r + t

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

res =

         9         11         13         15         17

Column vectors वर्गाकार कोष्ठक में तत्वों के सेट को संलग्न करके बनाया गया है, तत्वों को परिसीमित करने के लिए अर्धविराम (;) का उपयोग किया जाता है।

c = [7;  8;  9;  10; 11]

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

c =
       7       
       8       
       9       
      10       
      11

मेट्रिसेस बनाना

एक मैट्रिक्स संख्याओं का द्वि-आयामी सरणी है।

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

m = [1 2 3; 4 5 6; 7 8 9]

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

m =
       1              2              3       
       4              5              6       
       7              8              9

MATLAB संख्यात्मक अभिकलन और डेटा विज़ुअलाइज़ेशन के लिए एक इंटरैक्टिव कार्यक्रम है। आप इसे MATLAB प्रॉम्प्ट '>>' पर टाइप करके कमांड दर्ज कर सकते हैंCommand Window

इस खंड में, हम सामान्य रूप से प्रयुक्त सामान्य MATLAB आदेशों की सूची प्रदान करेंगे।

एक सत्र के प्रबंधन के लिए कमान

MATLAB एक सत्र के प्रबंधन के लिए विभिन्न आदेश प्रदान करता है। निम्न तालिका ऐसे सभी आदेश प्रदान करती है -

आदेश उद्देश्य
सीएलसी क्लीयर कमांड विंडो।
स्पष्ट स्मृति से चर निकालता है।
मौजूद फ़ाइल या चर के अस्तित्व के लिए जाँच करता है।
वैश्विक चरों को वैश्विक बनाने की घोषणा करता है।
मदद एक मदद विषय के लिए खोज करता है।
ढूंढें कीवर्ड एक कीवर्ड के लिए प्रविष्टियों की मदद करते हैं।
छोड़ना MATLAB को रोकता है।
who वर्तमान चर को सूचीबद्ध करता है।
कौन वर्तमान चर (लंबे प्रदर्शन) को सूचीबद्ध करता है।

सिस्टम के साथ काम करने की आज्ञा देता है

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

यह अन्य सिस्टम से संबंधित गतिविधियों के लिए विभिन्न कमांड भी प्रदान करता है जैसे, तारीख प्रदर्शित करना, निर्देशिका में फ़ाइलें सूचीबद्ध करना, वर्तमान निर्देशिका प्रदर्शित करना, आदि।

निम्न तालिका कुछ सामान्य रूप से प्रयुक्त सिस्टम से संबंधित कमांड प्रदर्शित करती है -

आदेश उद्देश्य
सीडी वर्तमान निर्देशिका को बदलता है।
दिनांक वर्तमान दिनांक प्रदर्शित करता है।
हटाना एक फ़ाइल हटाता है।
डायरी डायरी फ़ाइल रिकॉर्डिंग चालू / बंद।
डिर वर्तमान निर्देशिका में सभी फाइलों को सूचीबद्ध करता है।
भार लोड एक फ़ाइल से कार्यक्षेत्र चर।
पथ खोज पथ प्रदर्शित करता है।
लोक निर्माण विभाग वर्तमान निर्देशिका प्रदर्शित करता है।
सहेजें फ़ाइल में कार्यक्षेत्र चर बचाता है।
प्रकार किसी फ़ाइल की सामग्री प्रदर्शित करता है।
क्या वर्तमान निर्देशिका में सभी MATLAB फ़ाइलों को सूचीबद्ध करता है।
wklread .Wk1 स्प्रेडशीट फ़ाइल पढ़ता है।

इनपुट और आउटपुट कमांड

MATLAB निम्नलिखित इनपुट और आउटपुट संबंधित कमांड प्रदान करता है -

आदेश उद्देश्य
disp किसी सरणी या स्ट्रिंग की सामग्री प्रदर्शित करता है।
fscanf किसी फ़ाइल से स्वरूपित डेटा पढ़ें।
प्रारूप स्क्रीन-डिस्प्ले प्रारूप को नियंत्रित करता है।
fprintf स्वरूपित प्रदर्शन स्क्रीन या फ़ाइल पर लिखते हैं।
इनपुट इनपुट के लिए संकेत देता है और प्रतीक्षा करता है।
; स्क्रीन प्रिंटिंग को दबा देता है।

fscanf तथा fprintfकमांड सी स्कैनफ और प्रिंटफ कार्यों की तरह व्यवहार करते हैं। वे निम्नलिखित प्रारूप कोड का समर्थन करते हैं -

प्रारूप कोड उद्देश्य
%s एक स्ट्रिंग के रूप में प्रारूपित करें।
%d पूर्णांक के रूप में प्रारूपित करें।
%f एक अस्थायी बिंदु मान के रूप में प्रारूपित करें।
%e वैज्ञानिक अंकन में एक अस्थायी बिंदु मान के रूप में प्रारूपित करें।
%g सबसे कॉम्पैक्ट रूप में प्रारूप:% f या% e।
\n आउटपुट स्ट्रिंग में एक नई लाइन डालें।
\t आउटपुट स्ट्रिंग में एक टैब डालें।

प्रारूप फ़ंक्शन में संख्यात्मक प्रदर्शन के लिए उपयोग किए जाने वाले निम्न रूप हैं -

प्रारूप फ़ंक्शन तक प्रदर्शित करें
प्रारूप छोटा चार दशमलव अंक (डिफ़ॉल्ट)।
प्रारूप लंबा 16 दशमलव अंक।
प्रारूप लघु ई पांच अंक प्लस एक्सपोनेंट।
प्रारूप लंबे ई 16 अंकों से अधिक का व्यय करने वाले।
प्रारूप बैंक दो दशमलव अंक।
प्रारूप + सकारात्मक, नकारात्मक या शून्य।
प्रारूप चूहा परिमेय सन्निकटन।
प्रारूप कॉम्पैक्ट कुछ लाइन फीड दबा देता है।
स्वरूप ढीला कम कॉम्पैक्ट डिस्प्ले मोड पर रीसेट करता है।

वेक्टर, मैट्रिक्स और ऐरे कमांड्स

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

आदेश उद्देश्य
बिल्ली कॉनटेनेट्स एरे।
खोज नॉनजेरो तत्वों के सूचकांकों को ढूँढता है।
लंबाई तत्वों की संख्या की गणना करता है।
linspace नियमित रूप से सदिश स्थान बनाता है।
logspace लॉगरिदमिक रूप से तैयार वेक्टर।
मैक्स सबसे बड़ा तत्व देता है।
मिनट सबसे छोटा तत्व देता है।
ठेस प्रत्येक स्तंभ का उत्पाद।
आकृति बदलें आकार बदलता है।
आकार सरणी आकार की गणना करता है।
तरह प्रत्येक स्तंभ को सॉर्ट करता है।
योग प्रत्येक स्तंभ पर लिखा है।
आंख एक पहचान मैट्रिक्स बनाता है।
लोगों लोगों की एक सरणी बनाता है।
शून्य शून्य की एक सरणी बनाता है।
पार करना मैट्रिक्स क्रॉस उत्पादों की गणना करता है।
दूरसंचार विभाग मैट्रिक्स डॉट उत्पादों की गणना करता है।
det एक सरणी के निर्धारक की गणना करता है।
निवेश संबंधी निर्णय एक मैट्रिक्स के व्युत्क्रम की गणना करता है।
pinv एक मैट्रिक्स के छद्म बिंदु से गणना करता है।
पद एक मैट्रिक्स की रैंक की गणना करता है।
rref गणना ने रो इकोलोन रूप को कम कर दिया।
सेल कोशिका सरणी बनाता है।
celldisp सेल सरणी प्रदर्शित करता है।
cellplot सेल सरणी का चित्रमय प्रतिनिधित्व प्रदर्शित करता है।
num2cell संख्यात्मक सरणी को सेल सरणी में परिवर्तित करता है।
सौदा इनपुट और आउटपुट सूचियों से मेल खाता है।
iscell कोशिका सरणी की पहचान करता है।

प्लॉटिंग कमांड्स

MATLAB रेखांकन की साजिश रचने के लिए कई कमांड प्रदान करता है। नीचे दी गई तालिका में प्लॉटिंग के लिए आमतौर पर इस्तेमाल की जाने वाली कुछ कमांड्स को दिखाया गया है -

आदेश उद्देश्य
एक्सिस अक्ष सीमा निर्धारित करता है।
fplot कार्यों की बुद्धिमान साजिश।
ग्रिड ग्रिडलाइन प्रदर्शित करता है।
भूखंड Xy भूखंड उत्पन्न करता है।
प्रिंट प्रिंट्स प्लॉट या किसी फाइल को प्लॉट बचाता है।
शीर्षक साजिश के शीर्ष पर पाठ डालता है।
xlabel एक्स-अक्ष पर पाठ लेबल जोड़ता है।
ylabel पाठ लेबल को y- अक्ष में जोड़ता है।
कुल्हाड़ियों अक्षों को बनाता है।
बंद करे करंट प्लॉट को बंद कर देता है।
सब बंद करें सभी प्लॉट बंद कर देता है।
आकृति एक नई आकृति विंडो खोलता है।
gtext माउस द्वारा लेबल प्लेसमेंट सक्षम करता है।
होल्ड फ्रीज करंट प्लॉट।
किंवदंती माउस द्वारा लीजेंड प्लेसमेंट।
ताज़ा करना Redraws वर्तमान आंकड़ा विंडो।
सेट कुल्हाड़ियों जैसी वस्तुओं के गुणों को निर्दिष्ट करता है।
subplot सब-विंडो में प्लॉट बनाता है।
टेक्स्ट स्ट्रिंग में आंकड़ा।
बार बार चार्ट बनाता है।
loglog लॉग-लॉग प्लॉट बनाता है।
ध्रुवीय ध्रुवीय भूखंड बनाता है।
semilogx सेमीलॉग प्लॉट बनाता है। (लॉगरिदमिक एब्सिसा)।
semilogy सेमीलॉग प्लॉट बनाता है। (लॉगरिदमिक ऑर्डिनेट)।
सीढ़ियों सीढ़ियों की साजिश बनाता है।
स्टेम स्टेम प्लॉट बनाता है।

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

पिछले अध्यायों में, आपने सीखा है कि MATLAB कमांड प्रॉम्प्ट से कमांड कैसे दर्ज करें। MATLAB आपको एक फ़ाइल में कमांड की श्रृंखला लिखने और फ़ाइल को पूर्ण इकाई के रूप में निष्पादित करने की अनुमति देता है, जैसे एक फ़ंक्शन लिखना और उसे कॉल करना।

द एम फाइलें

MATLAB प्रोग्राम फ़ाइलों के दो प्रकार लिखने की अनुमति देता है -

  • Scripts - स्क्रिप्ट फाइलें प्रोग्राम फाइलों के साथ होती हैं .m extension। इन फ़ाइलों में, आप आदेशों की श्रृंखला लिखते हैं, जिन्हें आप एक साथ निष्पादित करना चाहते हैं। लिपियां इनपुट स्वीकार नहीं करती हैं और कोई आउटपुट वापस नहीं करती हैं। वे कार्यक्षेत्र में डेटा पर काम करते हैं।

  • Functions - फ़ंक्शंस फ़ाइल्स भी प्रोग्राम फ़ाइल्स हैं .m extension। फ़ंक्शंस इनपुट स्वीकार कर सकते हैं और आउटपुट वापस कर सकते हैं। आंतरिक चर समारोह के लिए स्थानीय हैं।

आप अपने बनाने के लिए MATLAB संपादक या किसी अन्य पाठ संपादक का उपयोग कर सकते हैं .mफ़ाइलें। इस खंड में, हम स्क्रिप्ट फ़ाइलों पर चर्चा करेंगे। एक स्क्रिप्ट फ़ाइल में MATLAB कमांड और फ़ंक्शन कॉल की कई अनुक्रमिक लाइनें होती हैं। आप कमांड लाइन पर इसका नाम लिखकर एक स्क्रिप्ट चला सकते हैं।

स्क्रिप्ट फ़ाइल बनाना और चलाना

स्क्रिप्ट फ़ाइलों को बनाने के लिए, आपको एक पाठ संपादक का उपयोग करने की आवश्यकता है। आप MATLAB संपादक को दो तरीकों से खोल सकते हैं -

  • कमांड प्रॉम्प्ट का उपयोग करना
  • आईडीई का उपयोग करना

यदि आप कमांड प्रॉम्प्ट का उपयोग कर रहे हैं, तो टाइप करें editकमांड प्रॉम्प्ट में। इससे एडिटर खुल जाएगा। आप सीधे टाइप कर सकते हैंedit और फिर फ़ाइल नाम (.m एक्सटेंशन के साथ)

edit 
Or
edit <filename>

उपरोक्त कमांड डिफ़ॉल्ट MATLAB डायरेक्टरी में फाइल बनाएगी। यदि आप सभी प्रोग्राम फ़ाइलों को एक विशिष्ट फ़ोल्डर में संग्रहीत करना चाहते हैं, तो आपको संपूर्ण पथ प्रदान करना होगा।

हमें progs नाम का एक फोल्डर बनाते हैं। कमांड प्रॉम्प्ट (>>) पर निम्न कमांड टाइप करें -

mkdir progs    % create directory progs under default directory
chdir progs    % changing the current directory to progs
edit  prog1.m  % creating an m file named prog1.m

यदि आप पहली बार फ़ाइल बना रहे हैं, तो MATLAB आपको इसकी पुष्टि करने के लिए संकेत देता है। हाँ पर क्लिक करें।

वैकल्पिक रूप से, यदि आप IDE का उपयोग कर रहे हैं, तो NEW -> स्क्रिप्ट चुनें। यह भी संपादक को खोलता है और शीर्षक रहित फ़ाइल बनाता है। कोड टाइप करने के बाद आप फाइल को नाम और सेव कर सकते हैं।

संपादक में निम्न कोड टाइप करें -

NoOfStudents = 6000;
TeachingStaff = 150;
NonTeachingStaff = 20;
Total = NoOfStudents + TeachingStaff ...
   + NonTeachingStaff;
disp(Total);

फ़ाइल बनाने और सहेजने के बाद, आप इसे दो तरीकों से चला सकते हैं -

  • क्लिक कर रहा है Run संपादक विंडो पर बटन या

  • कमांड प्रॉम्प्ट में फ़ाइल नाम (बिना एक्सटेंशन के) टाइप करना: >> prog1

कमांड विंडो प्रॉम्प्ट परिणाम प्रदर्शित करता है -

6170

उदाहरण

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

a = 5; b = 7;
c = a + b
d = c + sin(b)
e = 5 * d
f = exp(-d)

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

c =  12
d =  12.657
e =  63.285
f =    3.1852e-06

MATLAB को किसी भी प्रकार की घोषणा या आयाम कथन की आवश्यकता नहीं है। जब भी MATLAB एक नए चर नाम से सामना करता है, तो यह चर बनाता है और उचित मेमोरी स्पेस आवंटित करता है।

यदि चर पहले से मौजूद है, तो MATLAB नई सामग्री के साथ मूल सामग्री को बदल देता है और जहां आवश्यक हो, नए भंडारण स्थान आवंटित करता है।

उदाहरण के लिए,

Total = 42

उपरोक्त कथन 'टोटल' नाम से 1-बाय -1 मैट्रिक्स बनाता है और इसमें वैल्यू 42 को स्टोर करता है।

MATLAB में उपलब्ध डेटा प्रकार

MATLAB 15 मूलभूत डेटा प्रकार प्रदान करता है। प्रत्येक डेटा प्रकार डेटा को संग्रहीत करता है जो मैट्रिक्स या सरणी के रूप में होता है। इस मैट्रिक्स या सरणी का आकार न्यूनतम 0-बाय -0 है और यह किसी भी आकार के मैट्रिक्स या सरणी तक बढ़ सकता है।

निम्न तालिका MATLAB में सबसे अधिक उपयोग किए जाने वाले डेटा प्रकारों को दिखाती है -

अनु क्रमांक। डेटा प्रकार और विवरण
1

int8

8-बिट हस्ताक्षरित पूर्णांक

2

uint8

8-बिट अहस्ताक्षरित पूर्णांक

3

int16

16-बिट हस्ताक्षरित पूर्णांक

4

uint16

16-बिट अहस्ताक्षरित पूर्णांक

5

int32

32-बिट हस्ताक्षरित पूर्णांक

6

uint32

32-बिट अहस्ताक्षरित पूर्णांक

7

int64

64-बिट हस्ताक्षरित पूर्णांक

8

uint64

64-बिट अहस्ताक्षरित पूर्णांक

9

single

एकल सटीक संख्यात्मक डेटा

10

double

डबल सटीक संख्यात्मक डेटा

1 1

logical

1 या 0 के तार्किक मान, क्रमशः सही और गलत का प्रतिनिधित्व करते हैं

12

char

चरित्र डेटा (तार को वर्णों के वेक्टर के रूप में संग्रहीत किया जाता है)

13

cell array

अनुक्रमित कोशिकाओं की सरणी, प्रत्येक एक अलग आयाम और डेटा प्रकार की एक सरणी को संग्रहीत करने में सक्षम है

14

structure

सी-जैसी संरचनाएं, प्रत्येक संरचना के नाम वाले क्षेत्र एक अलग आयाम और डेटा प्रकार की एक सरणी को संग्रहीत करने में सक्षम हैं

15

function handle

एक फ़ंक्शन के लिए सूचक

16

user classes

उपयोगकर्ता द्वारा परिभाषित वर्ग से निर्मित वस्तुएं

17

java classes

जावा क्लास से निर्मित वस्तुएं

उदाहरण

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

str = 'Hello World!'
n = 2345
d = double(n)
un = uint32(789.50)
rn = 5678.92347
c = int32(rn)

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

str = Hello World!
n =  2345
d =  2345
un = 790
rn = 5678.9
c =  5679

डेटा प्रकार रूपांतरण

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

समारोह उद्देश्य
चार चरित्र सरणी (स्ट्रिंग) में बदलें
int2str पूर्णांक डेटा को स्ट्रिंग में बदलें
mat2str मैट्रिक्स को स्ट्रिंग में बदलें
num2str संख्या को स्ट्रिंग में बदलें
str2double स्ट्रिंग को डबल-सटीक मान में बदलें
str2num स्ट्रिंग को संख्या में बदलें
native2unicode संख्यात्मक बाइट्स को यूनिकोड वर्णों में बदलें
unicode2native यूनिकोड वर्णों को संख्यात्मक बाइट में कनवर्ट करें
base2dec बेस एन नंबर स्ट्रिंग को दशमलव संख्या में बदलें
BIN2DEC बाइनरी नंबर स्ट्रिंग को दशमलव संख्या में बदलें
dec2base दशमलव को आधार संख्या में स्ट्रिंग में परिवर्तित करें
dec2bin स्ट्रिंग में दशमलव को बाइनरी संख्या में बदलें
DEC2HEX दशमलव को हेक्साडेसिमल संख्या में स्ट्रिंग में बदलें
HEX2DEC हेक्साडेसिमल संख्या स्ट्रिंग को दशमलव संख्या में बदलें
hex2num हेक्साडेसिमल संख्या स्ट्रिंग को डबल-सटीक संख्या में परिवर्तित करें
num2hex एकल और युगल IEEE हेक्साडेसिमल स्ट्रिंग्स में कनवर्ट करें
cell2mat सेल एरे को न्यूमेरिक ऐरे में कन्वर्ट करें
cell2struct सेल सरणी को संरचना सरणी में बदलें
cellstr चरित्र सरणी से स्ट्रिंग की सेल सरणी बनाएँ
mat2cell संभावित भिन्न आकार की कोशिकाओं के साथ सरणी को सेल सरणी में बदलें
num2cell लगातार आकार की कोशिकाओं के साथ सरणी को सेल सरणी में बदलें
struct2cell सेल सरणी में संरचना बदलें

डेटा प्रकारों का निर्धारण

MATLAB एक चर के डेटा प्रकार की पहचान करने के लिए विभिन्न कार्य प्रदान करता है।

निम्नलिखित तालिका एक चर के डेटा प्रकार का निर्धारण करने के लिए कार्य प्रदान करती है -

समारोह उद्देश्य
है राज्य का पता लगाएं
एक है निर्धारित करें कि इनपुट निर्दिष्ट वर्ग की वस्तु है या नहीं
iscell निर्धारित करें कि इनपुट सेल ऐरे है
iscellstr निर्धारित करें कि इनपुट स्ट्रिंग्स का सेल एरे है
ischar निर्धारित करें कि क्या आइटम चरित्र सरणी है
isfield निर्धारित करें कि इनपुट संरचना सरणी क्षेत्र है या नहीं
isfloat निर्धारित करें कि इनपुट फ्लोटिंग-पॉइंट ऐरे है
ishghandle हैंडल ग्राफिक्स ऑब्जेक्ट हैंडल के लिए सही है
isinteger निर्धारित करें कि इनपुट पूर्णांक सरणी है
isjava यह निर्धारित करें कि इनपुट जावा ऑब्जेक्ट है या नहीं
ISLOGICAL निर्धारित करें कि क्या इनपुट तार्किक सरणी है
isnumeric निर्धारित करें कि क्या इनपुट संख्यात्मक सरणी है
isobject निर्धारित करें कि इनपुट MATLAB ऑब्जेक्ट है या नहीं
सत्य है जांचें कि इनपुट वास्तविक सरणी है
isscalar निर्धारित करें कि क्या इनपुट अदिश है
isstr निर्धारित करें कि इनपुट चरित्र सरणी है या नहीं
isstruct निर्धारित करें कि क्या इनपुट संरचना सरणी है
isvector निर्धारित करें कि क्या इनपुट वेक्टर है
कक्षा वस्तु का वर्ग निर्धारित करना
validateattributes सरणी की वैधता की जाँच करें
कौन आकार और प्रकारों के साथ कार्यक्षेत्र में सूची चर

उदाहरण

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

x = 3
isinteger(x)
isfloat(x)
isvector(x)
isscalar(x)
isnumeric(x)
 
x = 23.54
isinteger(x)
isfloat(x)
isvector(x)
isscalar(x)
isnumeric(x)
 
x = [1 2 3]
isinteger(x)
isfloat(x)
isvector(x)
isscalar(x)
 
x = 'Hello'
isinteger(x)
isfloat(x)
isvector(x)
isscalar(x)
isnumeric(x)

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

x = 3
ans = 0
ans = 1
ans = 1
ans = 1
ans = 1
x = 23.540
ans = 0
ans = 1
ans = 1
ans = 1
ans = 1
x =

          1          2          3

ans = 0
ans = 1
ans = 1
ans = 0
x = Hello
ans = 0
ans = 0
ans = 1
ans = 0
ans = 0

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

  • अंकगणितीय आपरेटर
  • संबंधपरक संकारक
  • लॉजिकल ऑपरेटर्स
  • बिटवाइज ऑपरेशन
  • संचालन सेट करें

अंकगणितीय आपरेटर

MATLAB अंकगणितीय संचालन के दो अलग-अलग प्रकारों की अनुमति देता है -

  • मैट्रिक्स अंकगणितीय संचालन
  • अंकगणित संचालन

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

मैट्रिक्स ऑपरेटर और सरणी ऑपरेटर अवधि (।) प्रतीक द्वारा विभेदित हैं। हालाँकि, जैसा कि जोड़ और घटाव ऑपरेशन मेट्रिस और एरेज़ के लिए समान है, ऑपरेटर दोनों मामलों के लिए समान है। निम्नलिखित तालिका ऑपरेटरों का संक्षिप्त विवरण देती है -

उदाहरण दिखाएं

अनु क्रमांक। ऑपरेटर और विवरण
1

+

जोड़ या अनार्य प्लस। A + B वैरिएबल A और B में संग्रहीत मानों को जोड़ता है। A और B का आकार समान होना चाहिए, जब तक कि कोई एक स्केलर न हो। एक स्केलर को किसी भी आकार के मैट्रिक्स में जोड़ा जा सकता है।

2

-

घटाव या एकात्मक शून्य। AB, A से B का मान घटाता है और B का आकार समान होना चाहिए, जब तक कि कोई एक स्केलर न हो। एक स्केलर को किसी भी आकार के मैट्रिक्स से घटाया जा सकता है।

3

*

मैट्रिक्स गुणन। सी = ए * बी मेट्रिसेस ए और बी का रैखिक बीजगणितीय उत्पाद है। अधिक सटीक,

For non-scalar A and B, the number of columns of A must be equal to the number of rows of B. A scalar can multiply a matrix of any size.

4

.*

Array multiplication. A.*B is the element-by-element product of the arrays A and B. A and B must have the same size, unless one of them is a scalar.

5

/

Slash or matrix right division. B/A is roughly the same as B*inv(A). More precisely, B/A = (A'\B')'.

6

./

Array right division. A./B is the matrix with elements A(i,j)/B(i,j). A and B must have the same size, unless one of them is a scalar.

7

\

Backslash or matrix left division. If A is a square matrix, A\B is roughly the same as inv(A)*B, except it is computed in a different way. If A is an n-by-n matrix and B is a column vector with n components, or a matrix with several such columns, then X = A\B is the solution to the equation AX = B. A warning message is displayed if A is badly scaled or nearly singular.

8

.\

Array left division. A.\B is the matrix with elements B(i,j)/A(i,j). A and B must have the same size, unless one of them is a scalar.

9

^

Matrix power. X^p is X to the power p, if p is a scalar. If p is an integer, the power is computed by repeated squaring. If the integer is negative, X is inverted first. For other values of p, the calculation involves eigenvalues and eigenvectors, such that if [V,D] = eig(X), then X^p = V*D.^p/V.

10

.^

Array power. A.^B is the matrix with elements A(i,j) to the B(i,j) power. A and B must have the same size, unless one of them is a scalar.

11

'

Matrix transpose. A' is the linear algebraic transpose of A. For complex matrices, this is the complex conjugate transpose.

12

.'

Array transpose. A.' is the array transpose of A. For complex matrices, this does not involve conjugation.

Relational Operators

Relational operators can also work on both scalar and non-scalar data. Relational operators for arrays perform element-by-element comparisons between two arrays and return a logical array of the same size, with elements set to logical 1 (true) where the relation is true and elements set to logical 0 (false) where it is not.

The following table shows the relational operators available in MATLAB −

Show Examples

Sr.No. Operator & Description
1

<

Less than

2

<=

Less than or equal to

3

>

Greater than

4

>=

Greater than or equal to

5

==

Equal to

6

~=

Not equal to

Logical Operators

MATLAB offers two types of logical operators and functions −

  • Element-wise − These operators operate on corresponding elements of logical arrays.

  • Short-circuit − These operators operate on scalar and, logical expressions.

Element-wise logical operators operate element-by-element on logical arrays. The symbols &, |, and ~ are the logical array operators AND, OR, and NOT.

Short-circuit logical operators allow short-circuiting on logical operations. The symbols && and || are the logical short-circuit operators AND and OR.

Show Examples

Bitwise Operations

Bitwise operators work on bits and perform bit-by-bit operation. The truth tables for &, |, and ^ are as follows −

p q p & q p | q p ^ q
0 0 0 0 0
0 1 0 1 1
1 1 1 1 0
1 0 0 1 1

Assume if A = 60; and B = 13; Now in binary format they will be as follows −

A = 0011 1100

B = 0000 1101

-----------------

A&B = 0000 1100

A|B = 0011 1101

A^B = 0011 0001

~A  = 1100 0011

MATLAB provides various functions for bit-wise operations like 'bitwise and', 'bitwise or' and 'bitwise not' operations, shift operation, etc.

The following table shows the commonly used bitwise operations −

Show Examples

Function Purpose
bitand(a, b) Bit-wise AND of integers a and b
bitcmp(a) Bit-wise complement of a
bitget(a,pos) Get bit at specified position pos, in the integer array a
bitor(a, b) Bit-wise OR of integers a and b
bitset(a, pos) Set bit at specific location pos of a
bitshift(a, k) Returns a shifted to the left by k bits, equivalent to multiplying by 2k. Negative values of k correspond to shifting bits right or dividing by 2|k| and rounding to the nearest integer towards negative infinite. Any overflow bits are truncated.
bitxor(a, b) Bit-wise XOR of integers a and b
swapbytes Swap byte ordering

Set Operations

MATLAB provides various functions for set operations, like union, intersection and testing for set membership, etc.

The following table shows some commonly used set operations −

Show Examples

Sr.No. Function & Description
1

intersect(A,B)

Set intersection of two arrays; returns the values common to both A and B. The values returned are in sorted order.

2

intersect(A,B,'rows')

Treats each row of A and each row of B as single entities and returns the rows common to both A and B. The rows of the returned matrix are in sorted order.

3

ismember(A,B)

Returns an array the same size as A, containing 1 (true) where the elements of A are found in B. Elsewhere, it returns 0 (false).

4

ismember(A,B,'rows')

Treats each row of A and each row of B as single entities and returns a vector containing 1 (true) where the rows of matrix A are also rows of B. Elsewhere, it returns 0 (false).

5

issorted(A)

Returns logical 1 (true) if the elements of A are in sorted order and logical 0 (false) otherwise. Input A can be a vector or an N-by-1 or 1-by-N cell array of strings. A is considered to be sorted if A and the output of sort(A) are equal.

6

issorted(A, 'rows')

Returns logical 1 (true) if the rows of two-dimensional matrix A is in sorted order, and logical 0 (false) otherwise. Matrix A is considered to be sorted if A and the output of sortrows(A) are equal.

7

setdiff(A,B)

Sets difference of two arrays; returns the values in A that are not in B. The values in the returned array are in sorted order.

8

setdiff(A,B,'rows')

Treats each row of A and each row of B as single entities and returns the rows from A that are not in B. The rows of the returned matrix are in sorted order.

The 'rows' option does not support cell arrays.

9

setxor

Sets exclusive OR of two arrays

10

union

Sets union of two arrays

11

unique

Unique values in array

Decision making structures require that the programmer should specify one or more conditions to be evaluated or tested by the program, along with a statement or statements to be executed if the condition is determined to be true, and optionally, other statements to be executed if the condition is determined to be false.

Following is the general form of a typical decision making structure found in most of the programming languages −

MATLAB provides following types of decision making statements. Click the following links to check their detail −

Sr.No. Statement & Description
1 if ... end statement

An if ... end statement consists of a boolean expression followed by one or more statements.

2 if...else...end statement

An if statement can be followed by an optional else statement, which executes when the boolean expression is false.

3 If... elseif...elseif...else...end statements

An if statement can be followed by one (or more) optional elseif... and an else statement, which is very useful to test various conditions.

4 nested if statements

You can use one if or elseif statement inside another if or elseif statement(s).

5 switch statement

A switch statement allows a variable to be tested for equality against a list of values.

6 nested switch statements

You can use one switch statement inside another switch statement(s).

There may be a situation when you need to execute a block of code several number of times. In general, statements are executed sequentially. The first statement in a function is executed first, followed by the second, and so on.

Programming languages provide various control structures that allow for more complicated execution paths.

A loop statement allows us to execute a statement or group of statements multiple times and following is the general form of a loop statement in most of the programming languages −

MATLAB provides following types of loops to handle looping requirements. Click the following links to check their detail −

Sr.No. Loop Type & Description
1 while loop

Repeats a statement or group of statements while a given condition is true. It tests the condition before executing the loop body.

2 for loop

Executes a sequence of statements multiple times and abbreviates the code that manages the loop variable.

3 nested loops

You can use one or more loops inside any another loop.

Loop Control Statements

Loop control statements change execution from its normal sequence. When execution leaves a scope, all automatic objects that were created in that scope are destroyed.

MATLAB supports the following control statements. Click the following links to check their detail.

Sr.No. Control Statement & Description
1 break statement

Terminates the loop statement and transfers execution to the statement immediately following the loop.

2 continue statement

Causes the loop to skip the remainder of its body and immediately retest its condition prior to reiterating.

A vector is a one-dimensional array of numbers. MATLAB allows creating two types of vectors −

  • Row vectors
  • Column vectors

Row Vectors

Row vectors are created by enclosing the set of elements in square brackets, using space or comma to delimit the elements.

r = [7 8 9 10 11]

MATLAB will execute the above statement and return the following result −

r =

   7    8    9   10   11

Column Vectors

Column vectors are created by enclosing the set of elements in square brackets, using semicolon to delimit the elements.

c = [7;  8;  9;  10; 11]

MATLAB will execute the above statement and return the following result −

c =
      7       
      8       
      9       
      10       
      11

Referencing the Elements of a Vector

You can reference one or more of the elements of a vector in several ways. The ith component of a vector v is referred as v(i). For example −

v = [ 1; 2; 3; 4; 5; 6];	% creating a column vector of 6 elements
v(3)

MATLAB will execute the above statement and return the following result −

ans =  3

When you reference a vector with a colon, such as v(:), all the components of the vector are listed.

v = [ 1; 2; 3; 4; 5; 6];	% creating a column vector of 6 elements
v(:)

MATLAB will execute the above statement and return the following result −

ans =
     1
     2
     3
     4
     5
     6

MATLAB allows you to select a range of elements from a vector.

For example, let us create a row vector rv of 9 elements, then we will reference the elements 3 to 7 by writing rv(3:7) and create a new vector named sub_rv.

rv = [1 2 3 4 5 6 7 8 9];
sub_rv = rv(3:7)

MATLAB will execute the above statement and return the following result −

sub_rv =

   3   4   5   6   7

Vector Operations

In this section, let us discuss the following vector operations −

  • Addition and Subtraction of Vectors

  • Scalar Multiplication of Vectors

  • Transpose of a Vector

  • Appending Vectors

  • Magnitude of a Vector

  • Vector Dot Product

  • Vectors with Uniformly Spaced Elements

A matrix is a two-dimensional array of numbers.

In MATLAB, you create a matrix by entering elements in each row as comma or space delimited numbers and using semicolons to mark the end of each row.

For example, let us create a 4-by-5 matrix a

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8]

MATLAB will execute the above statement and return the following result −

a =
      1     2     3     4     5
      2     3     4     5     6
      3     4     5     6     7
      4     5     6     7     8

Referencing the Elements of a Matrix

To reference an element in the mth row and nth column, of a matrix mx, we write −

mx(m, n);

उदाहरण के लिए, 2 एनडी पंक्ति और 5 वें कॉलम में तत्व का उल्लेख करने के लिए, मैट्रिक्स का , जैसा कि पिछले अनुभाग में बनाया गया है, हम टाइप करते हैं -

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8];
a(2,5)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans =  6

M वें कॉलम के सभी तत्वों को संदर्भित करने के लिए हम A (:, m) टाइप करते हैं।

आइए हम मैट्रिक्स के 4 वें रो के तत्वों से एक कॉलम वेक्टर v बनाते हैं -

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8];
v = a(:,4)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

v =
      4
      5
      6
      7

आप n वें कॉलम के माध्यम से m वें में तत्वों का चयन कर सकते हैं, इसके लिए हम लिखते हैं -

a(:,m:n)

आइए हम दूसरे और तीसरे कॉलम से तत्वों को लेते हुए एक छोटा मैट्रिक्स बनाते हैं -

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8];
a(:, 2:3)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans =
      2     3
      3     4
      4     5
      5     6

उसी तरह, आप एक मैट्रिक्स का उप-भाग लेते हुए एक उप-मैट्रिक्स बना सकते हैं।

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8];
a(:, 2:3)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans =
      2     3
      3     4
      4     5
      5     6

उसी तरह, आप एक मैट्रिक्स का उप-भाग लेते हुए एक उप-मैट्रिक्स बना सकते हैं।

उदाहरण के लिए, हमें एक उप मैट्रिक्स बनाने सा एक के भीतरी subpart लेने -

3     4     5     
4     5     6

ऐसा करने के लिए, लिखें -

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8];
sa = a(2:3,2:4)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

sa =
      3     4     5
      4     5     6

मैट्रिक्स में रो या कॉलम को हटाना

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

उदाहरण के लिए, आइए हम चौथी पंक्ति को हटाते हैं -

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8];
a( 4 , : ) = []

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

a =
      1     2     3     4     5
      2     3     4     5     6
      3     4     5     6     7

अगला, हम पाँचवाँ कॉलम हटाते हैं -

a = [ 1 2 3 4 5; 2 3 4 5 6; 3 4 5 6 7; 4 5 6 7 8];
a(: , 5)=[]

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

a =
      1     2     3     4
      2     3     4     5
      3     4     5     6
      4     5     6     7

उदाहरण

इस उदाहरण में, हम एक 3-बाय -3 मैट्रिक्स एम बनाते हैं, फिर हम 4-बाय -3 मैट्रिक्स बनाने के लिए इस मैट्रिक्स की दूसरी और तीसरी पंक्तियों को दो बार कॉपी करेंगे।

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

a = [ 1 2 3 ; 4 5 6; 7 8 9];
new_mat = a([2,3,2,3],:)

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

new_mat =
      4     5     6
      7     8     9
      4     5     6
      7     8     9

मैट्रिक्स ऑपरेशन

इस खंड में, हम निम्नलिखित बुनियादी और आमतौर पर उपयोग किए जाने वाले मैट्रिक्स कार्यों पर चर्चा करते हैं -

  • मेट्रिसेस का जोड़ और घटाव

  • मेट्रिसेस का विभाजन

  • Matrices का स्केलर संचालन

  • एक मैट्रिक्स का संक्रमण

  • संबंधित मैट्रिसेस

  • मैट्रिक्स गुणा

  • एक मैट्रिक्स का निर्धारक

  • एक मैट्रिक्स का उलटा

MATLAB में सभी डेटा प्रकार के सभी चर बहुआयामी सरणियाँ हैं। एक वेक्टर एक आयामी आयाम है और एक मैट्रिक्स एक दो आयामी सरणी है।

हमने पहले ही वैक्टर और मैट्रिस पर चर्चा की है। इस अध्याय में, हम बहुआयामी सरणियों पर चर्चा करेंगे। हालाँकि, इससे पहले, आइए कुछ विशेष प्रकार के सरणियों पर चर्चा करें।

MATLAB में विशेष ऐरे

इस अनुभाग में, हम कुछ कार्यों पर चर्चा करेंगे जो कुछ विशेष सरणियों का निर्माण करते हैं। इन सभी कार्यों के लिए, एक एकल तर्क एक वर्ग सरणी बनाता है, डबल तर्क आयताकार सरणी बनाते हैं।

zeros() फ़ंक्शन सभी शून्य का एक सरणी बनाता है -

उदाहरण के लिए -

zeros(5)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans =
      0     0     0     0     0
      0     0     0     0     0
      0     0     0     0     0
      0     0     0     0     0
      0     0     0     0     0

ones() फ़ंक्शन सभी का एक सरणी बनाता है -

उदाहरण के लिए -

ones(4,3)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans =
      1     1     1
      1     1     1
      1     1     1
      1     1     1

eye() फ़ंक्शन एक पहचान मैट्रिक्स बनाता है।

उदाहरण के लिए -

eye(4)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans =
      1     0     0     0
      0     1     0     0
      0     0     1     0
      0     0     0     1

rand() फ़ंक्शन (0,1) पर समान रूप से वितरित यादृच्छिक संख्याओं का एक सरणी बनाता है -

उदाहरण के लिए -

rand(3, 5)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans =
   0.8147    0.9134    0.2785    0.9649    0.9572
   0.9058    0.6324    0.5469    0.1576    0.4854
   0.1270    0.0975    0.9575    0.9706    0.8003

एक मैजिक स्क्वायर

magic square एक वर्ग है जो समान राशि का उत्पादन करता है, जब इसके तत्वों को पंक्ति-वार, कॉलम-वार या तिरछे जोड़ दिया जाता है।

magic()समारोह एक जादू वर्ग सरणी बनाता है। यह एक विलक्षण तर्क लेता है जो वर्ग का आकार देता है। तर्क का स्केलर 3 से अधिक या उसके बराबर होना चाहिए।

magic(4)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans =
   16     2     3    13
   5    11    10     8
   9     7     6    12
   4    14    15     1

बहुआयामी Arrays

दो से अधिक आयाम वाले सरणी को MATLAB में बहुआयामी सरणी कहा जाता है। MATLAB में बहुआयामी सरणियाँ सामान्य द्वि-आयामी मैट्रिक्स का एक विस्तार हैं।

आमतौर पर एक बहुआयामी सरणी उत्पन्न करने के लिए, हम पहले एक दो आयामी सरणी बनाते हैं और इसे विस्तारित करते हैं।

उदाहरण के लिए, आइए एक द्वि-आयामी सरणी बनाएं।

a = [7 9 5; 6 1 9; 4 3 2]

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

a =
   7     9     5
   6     1     9
   4     3     2

सरणी एक 3-बाय -3 सरणी है; हम करने के लिए एक तिहाई आयाम जोड़ सकते हैं एक , जैसे अर्थ प्रदान करते हुए -

a(:, :, 2)= [ 1 2 3; 4 5 6; 7 8 9]

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

a =

ans(:,:,1) =

   0   0   0
   0   0   0
   0   0   0

ans(:,:,2) =

   1   2   3
   4   5   6
   7   8   9

हम भी (), शून्य () या रैंड () फ़ंक्शन का उपयोग करके बहुआयामी सरणियों का निर्माण कर सकते हैं।

उदाहरण के लिए,

b = rand(4,3,2)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

b(:,:,1) =
   0.0344    0.7952    0.6463
   0.4387    0.1869    0.7094
   0.3816    0.4898    0.7547
   0.7655    0.4456    0.2760

b(:,:,2) =
   0.6797    0.4984    0.2238
   0.6551    0.9597    0.7513
   0.1626    0.3404    0.2551
   0.1190    0.5853    0.5060

हम भी उपयोग कर सकते हैं cat()बहुआयामी सरणियों के निर्माण के लिए कार्य करता है। यह एक निर्दिष्ट आयाम के साथ सरणियों की एक सूची प्रदान करता है -

बिल्ली के लिए सिंटैक्स () फ़ंक्शन है -

B = cat(dim, A1, A2...)

कहाँ पे,

  • B नया सरणी बनाया गया है

  • ए 1 , ए 2 , ... कॉन्टेक्ट्स को संक्षिप्त किया जाना है

  • मंद वह आयाम है जिसके साथ सरणियों को जोड़ना है

उदाहरण

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

a = [9 8 7; 6 5 4; 3 2 1];
b = [1 2 3; 4 5 6; 7 8 9];
c = cat(3, a, b, [ 2 3 1; 4 7 8; 3 9 0])

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

c(:,:,1) =
      9     8     7
      6     5     4
      3     2     1
c(:,:,2) =
      1     2     3
      4     5     6
      7     8     9
c(:,:,3) =
      2     3     1
      4     7     8
      3     9     0

ऐरे कार्य

MATLAB सामग्री को सॉर्ट करने, घुमाने, परमिट करने, रीसेट करने, या शिफ्ट करने के लिए निम्न कार्य प्रदान करता है।

समारोह उद्देश्य
लंबाई वेक्टर की लंबाई या सबसे बड़ी सरणी आयाम
ndims सरणी आयामों की संख्या
numel सरणी तत्वों की संख्या
आकार एरे आयाम
iscolumn निर्धारित करता है कि इनपुट कॉलम वेक्टर है या नहीं
खाली है निर्धारित करता है कि क्या सरणी खाली है
ismatrix निर्धारित करता है कि इनपुट मैट्रिक्स है या नहीं
isrow निर्धारित करता है कि इनपुट पंक्ति वेक्टर है या नहीं
isscalar निर्धारित करता है कि इनपुट अदिश है
isvector निर्धारित करता है कि इनपुट वेक्टर है या नहीं
blkdiag इनपुट तर्कों से विकर्ण मैट्रिक्स को ब्लॉक करता है
circshift सरणी को गोलाकार रूप से
ctranspose जटिल संयुग्म संक्रमण
निदान विकर्ण मैट्रिक्स और मैट्रिक्स के विकर्ण
flipdim निर्दिष्ट आयाम के साथ फ़्लिप सरणी
fliplr मैट्रिक्स को बाएं से दाएं तरफ फ़्लिप करता है
flipud फ़्लिप मैट्रिक्स नीचे तक
ipermute एनडी सरणी के आयाम आयामों को उलट देता है
दूसरे स्थान पर रखना एनडी सरणी के आयामों को पुनर्व्यवस्थित करता है
repmat प्रतिकृति और टाइल सरणी
आकृति बदलें रेज़हैप्स सरणी
rot90 मैट्रिक्स 90 डिग्री घूमता है
shiftdim आयामों को बदलता है
issorted निर्धारित करता है कि सेट तत्व क्रमबद्ध क्रम में हैं या नहीं
तरह आरोही या अवरोही क्रम में सरणी तत्वों को सॉर्ट करता है
sortrows आरोही क्रम में पंक्तियाँ बनाता है
निचोड़ सिंगलटन आयामों को निकालता है
पक्षांतरित खिसकाना
vectorize व्यंजक की व्याख्या करता है

उदाहरण

निम्नलिखित उदाहरण ऊपर वर्णित कुछ कार्यों का वर्णन करते हैं।

Length, Dimension and Number of elements −

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

x = [7.1, 3.4, 7.2, 28/4, 3.6, 17, 9.4, 8.9];
length(x)      % length of x vector
y = rand(3, 4, 5, 2);
ndims(y)       % no of dimensions in array y
s = ['Zara', 'Nuha', 'Shamim', 'Riz', 'Shadab'];
numel(s)       % no of elements in s

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

ans =  8
ans =  4
ans =  23

Circular Shifting of the Array Elements −

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

a = [1 2 3; 4 5 6; 7 8 9]  % the original array a
b = circshift(a,1)         %  circular shift first dimension values down by 1.
c = circshift(a,[1 -1])    % circular shift first dimension values % down by 1 
                           % and second dimension values to the left % by 1.

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

a =
   1     2     3
   4     5     6
   7     8     9

b =
   7     8     9
   1     2     3
   4     5     6

c =
   8     9     7
   2     3     1
   5     6     4

छँटाई Arrays

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

v = [ 23 45 12 9 5 0 19 17]  % horizontal vector
sort(v)                      % sorting v
m = [2 6 4; 5 3 9; 2 0 1]    % two dimensional array
sort(m, 1)                   % sorting m along the row
sort(m, 2)                   % sorting m along the column

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

v =
   23    45    12     9     5     0    19    17
ans =
   0     5     9    12    17    19    23    45
m =
   2     6     4
   5     3     9
   2     0     1
ans =
   2     0     1
   2     3     4
   5     6     9
ans =
   2     4     6
   3     5     9
   0     1     2

सेल ऐरे

सेल सरणियाँ अनुक्रमित कोशिकाओं के एरे हैं, जहां प्रत्येक सेल विभिन्न आयामों और डेटा प्रकारों की एक सरणी स्टोर कर सकता है।

cellफ़ंक्शन का उपयोग सेल सरणी बनाने के लिए किया जाता है। सेल फ़ंक्शन के लिए सिंटैक्स है -

C = cell(dim)
C = cell(dim1,...,dimN)
D = cell(obj)

कहाँ पे,

  • सी सेल सरणी है;

  • मंद एक स्केलर पूर्णांक या पूर्णांक का वेक्टर है जो सेल सरणी C के आयामों को निर्दिष्ट करता है;

  • dim1, ..., dimN स्केलर पूर्णांक हैं जो C के आयामों को निर्दिष्ट करते हैं;

  • obj निम्नलिखित में से एक है -

    • जावा सरणी या वस्तु
    • .NET सरणी का प्रकार System.String या System.Object

उदाहरण

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

c = cell(2, 5);
c = {'Red', 'Blue', 'Green', 'Yellow', 'White'; 1 2 3 4 5}

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

c = 
{
   [1,1] = Red
   [2,1] =  1
   [1,2] = Blue
   [2,2] =  2
   [1,3] = Green
   [2,3] =  3
   [1,4] = Yellow
   [2,4] =  4
   [1,5] = White
   [2,5] =  5
}

सेल एरे में डेटा एक्सेस करना

सेल ऐरे के तत्वों को संदर्भित करने के दो तरीके हैं -

  • कोशिकाओं के सेट को संदर्भित करने के लिए पहले ब्रैकेट () में सूचकांकों को संलग्न करना
  • व्यक्तिगत कोशिकाओं के भीतर डेटा को संदर्भित करने के लिए ब्रेसिज़ {} में सूचकांकों को संलग्न करना

जब आप पहले ब्रैकेट में सूचकांक को संलग्न करते हैं, तो यह कोशिकाओं के सेट को संदर्भित करता है।

चिकनी कोष्ठकों में सेल सरणी सूचक कोशिकाओं के सेट को संदर्भित करता है।

उदाहरण के लिए -

c = {'Red', 'Blue', 'Green', 'Yellow', 'White'; 1 2 3 4 5};
c(1:2,1:2)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans = 
{
   [1,1] = Red
   [2,1] =  1
   [1,2] = Blue
   [2,2] =  2
}

आप घुंघराले ब्रेसिज़ के साथ अनुक्रमण करके कोशिकाओं की सामग्री तक भी पहुंच सकते हैं।

उदाहरण के लिए -

c = {'Red', 'Blue', 'Green', 'Yellow', 'White'; 1 2 3 4 5};
c{1, 2:4}

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans = Blue
ans = Green
ans = Yellow

colon(:)MATLAB में सबसे उपयोगी ऑपरेटर में से एक है। इसका उपयोग वैक्टर, सबस्क्रिप्ट एरेज़ और बनाने के लिए किया जाता हैspecify for iterations

यदि आप एक पंक्ति वेक्टर बनाना चाहते हैं, जिसमें 1 से 10 तक पूर्णांक होते हैं, तो आप लिखते हैं -

1:10

MATLAB कथन को निष्पादित करता है और एक पंक्ति वेक्टर देता है जिसमें पूर्णांक 1 से 10 तक होता है -

ans =                                                                           
                                                                                
   1    2    3    4    5    6    7    8    9   10

यदि आप उदाहरण के लिए, एक से अधिक वृद्धि मूल्य निर्दिष्ट करना चाहते हैं -

100: -5: 50

MATLAB कथन को निष्पादित करता है और निम्नलिखित परिणाम देता है -

ans =
   100    95    90    85    80    75    70    65    60    55    50

एक और उदाहरण लेते हैं -

0:pi/8:pi

MATLAB कथन को निष्पादित करता है और निम्नलिखित परिणाम देता है -

ans =
   Columns 1 through 7
      0    0.3927    0.7854    1.1781    1.5708    1.9635    2.3562
   Columns 8 through 9
      2.7489    3.1416

आप पंक्तियों, स्तंभों या सरणियों के तत्वों का चयन करने के लिए सूचकांक के वेक्टर बनाने के लिए कोलन ऑपरेटर का उपयोग कर सकते हैं।

निम्न तालिका इस उद्देश्य के लिए इसके उपयोग का वर्णन करती है (हमें मैट्रिक्स ए है) -

प्रारूप उद्देश्य
A(:,j) A का jth कॉलम है
A(i,:) A की ith पंक्ति है।
A(:,:) समतुल्य द्वि-आयामी सरणी है। मैट्रिस के लिए यह ए के समान ही है।
A(j:k) A (j), A (j + 1), ..., A (k) है।
A(:,j:k) ए (:, जे), ए (:, जे + 1), ..., ए (:, के) है।
A(:,:,k) तीन आयामी सरणी ए का k वें पृष्ठ है
A(i,j,k,:) एक वेक्टर है जो चार-आयामी सरणी में है। वेक्टर में A (i, j, k, 1), A (i, j, k, 2), A (i, j, k, 3), और इसी तरह शामिल हैं।
A(:) एक कॉलम के रूप में माना जाता है, ए के सभी तत्व हैं। असाइनमेंट स्टेटमेंट के बाईं ओर, A (:) ए भरता है, जो पहले से अपने आकार को संरक्षित करता है। इस स्थिति में, सही पक्ष में ए के समान तत्व शामिल होने चाहिए।

उदाहरण

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

A = [1 2 3 4; 4 5 6 7; 7 8 9 10]
A(:,2)      % second column of A
A(:,2:3)    % second and third column of A
A(2:3,2:3)  % second and third rows and second and third columns

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

A =
      1     2     3     4
      4     5     6     7
      7     8     9    10

ans =
      2
      5
      8

ans =
      2     3
      5     6
      8     9

ans =
      5     6
      8     9

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) या intmin (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

MATLAB में एक चरित्र स्ट्रिंग बनाना काफी सरल है। वास्तव में, हमने कई बार इसका उपयोग किया है। उदाहरण के लिए, आप कमांड प्रॉम्प्ट में निम्नलिखित टाइप करें -

my_string = 'Tutorials Point'

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

my_string = Tutorials Point

MATLAB सभी चर को सरणियों के रूप में मानता है, और तार को वर्ण सरणियों के रूप में माना जाता है। हमें उपयोग करते हैंwhos ऊपर बनाए गए चर की जांच करने के लिए कमांड -

whos

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

Name           Size            Bytes  Class    Attributes
my_string      1x16               32  char

दिलचस्प है, आप संख्यात्मक रूपांतरण कार्यों का उपयोग कर सकते हैं uint8 या uint16स्ट्रिंग में वर्णों को उनके संख्यात्मक कोड में बदलने के लिए। char फ़ंक्शन पूर्णांक वेक्टर को वर्णों में परिवर्तित करता है -

उदाहरण

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

my_string = 'Tutorial''s Point';
str_ascii = uint8(my_string)        % 8-bit ascii values
str_back_to_char= char(str_ascii)  
str_16bit = uint16(my_string)       % 16-bit ascii values
str_back_to_char = char(str_16bit)

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

str_ascii =

   84  117  116  111  114  105   97  108   39  115   32   80  111  105  110  116

str_back_to_char = Tutorial's Point
str_16bit =

   84  117  116  111  114  105   97  108   39  115   32   80  111  105  110  116

str_back_to_char = Tutorial's Point

आयताकार चरित्र सरणी

अब तक जिन स्ट्रिंग्स पर हमने चर्चा की है, वे एक आयामी चरित्र सरणियाँ हैं; हालाँकि, हमें इससे अधिक स्टोर करने की आवश्यकता है। हमें अपने कार्यक्रम में अधिक आयामी पाठ्य सामग्री संग्रहीत करने की आवश्यकता है। यह आयताकार चरित्र सरणियों का निर्माण करके प्राप्त किया जाता है।

एक आयताकार चरित्र सरणी बनाने का सबसे सरल तरीका दो या दो से अधिक एक आयामी चरित्र सरणियों को समतल करना है, या तो लंबवत या क्षैतिज रूप से आवश्यक है।

आप निम्न में से किसी एक तरीके से तार को जोड़ सकते हैं -

  • MATLAB संघनन ऑपरेटर का उपयोग करना []और प्रत्येक पंक्ति को अर्धविराम (;) के साथ अलग करना। कृपया ध्यान दें कि इस विधि में प्रत्येक पंक्ति में समान संख्या में वर्ण होने चाहिए। विभिन्न लंबाई वाले तारों के लिए, आपको आवश्यकतानुसार अंतरिक्ष वर्णों के साथ पैड करना चाहिए।

  • का उपयोग करते हुए charसमारोह। यदि तार अलग-अलग लंबाई के हैं, तो चार पंक्तियों के साथ छोटे तार को चिपका दें ताकि प्रत्येक पंक्ति में समान वर्ण हों।

उदाहरण

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

doc_profile = ['Zara Ali                             '; ...
               'Sr. Surgeon                          '; ...
               'R N Tagore Cardiology Research Center']
doc_profile = char('Zara Ali', 'Sr. Surgeon', ...
                  'RN Tagore Cardiology Research Center')

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

doc_profile =
Zara Ali                             
Sr. Surgeon                          
R N Tagore Cardiology Research Center
doc_profile =
Zara Ali                            
Sr. Surgeon                         
RN Tagore Cardiology Research Center

आप निम्न में से किसी भी तरीके से क्षैतिज रूप से तार जोड़ सकते हैं -

  • MATLAB संघनन ऑपरेटर का उपयोग करना, []और इनपुट स्ट्रिंग्स को अल्पविराम या एक स्थान के साथ अलग करना। यह विधि इनपुट सरणियों में किसी भी अनुगामी रिक्त स्थान को संरक्षित करती है।

  • स्ट्रिंग संयोजन समारोह का उपयोग करना, strcat। यह विधि इनपुट्स में अनुगामी रिक्त स्थान को हटा देती है।

उदाहरण

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

name =     'Zara Ali                             ';
position = 'Sr. Surgeon                          '; 
worksAt =  'R N Tagore Cardiology Research Center';
profile = [name ', ' position ', ' worksAt]
profile = strcat(name, ', ', position, ', ', worksAt)

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

profile = Zara Ali      , Sr. Surgeon      , R N Tagore Cardiology Research Center
profile = Zara Ali,Sr. Surgeon,R N Tagore Cardiology Research Center

एक सेल ऐरे में स्ट्रिंग्स का संयोजन

हमारी पिछली चर्चा से, यह स्पष्ट है कि अलग-अलग लंबाई के साथ तार जुड़ना एक दर्द हो सकता है क्योंकि सरणी में सभी तार एक ही लंबाई के होने चाहिए। हमने स्ट्रिंग्स के अंत में रिक्त स्थानों का उपयोग उनकी लंबाई को बराबर करने के लिए किया है।

हालांकि, स्ट्रिंग्स को संयोजित करने का एक अधिक कुशल तरीका परिणामी सरणी को सेल सरणी में बदलना है।

MATLAB सेल सरणी एक सरणी में विभिन्न आकारों और प्रकार के डेटा को पकड़ सकती है। सेल एरे अलग-अलग लंबाई के तारों को स्टोर करने के लिए अधिक लचीला तरीका प्रदान करते हैं।

cellstr फ़ंक्शन एक वर्ण सरणी को स्ट्रिंग के सेल सरणी में परिवर्तित करता है।

उदाहरण

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

name =     'Zara Ali                             ';
position = 'Sr. Surgeon                          '; 
worksAt =  'R N Tagore Cardiology Research Center';
profile = char(name, position, worksAt);
profile = cellstr(profile);
disp(profile)

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

{                                                                               
   [1,1] = Zara Ali                                                              
   [2,1] = Sr. Surgeon                                                           
   [3,1] = R N Tagore Cardiology Research Center                                 
}

MATLAB में स्ट्रिंग फ़ंक्शंस

MATLAB तार बनाने, संयोजन, पार्स करने, तुलना करने और हेरफेर करने के लिए कई स्ट्रिंग फ़ंक्शन प्रदान करता है।

निम्नलिखित तालिका MATLAB में स्ट्रिंग कार्यों का संक्षिप्त विवरण प्रदान करती है -

समारोह उद्देश्य
चरित्र सरणियों में पाठ संग्रहीत करने के लिए कार्य, वर्ण सारणी गठबंधन, आदि।
कारतूस रिक्त वर्णों की स्ट्रिंग बनाएँ
cellstr चरित्र सरणी से स्ट्रिंग की सेल सरणी बनाएँ
चार चरित्र सरणी (स्ट्रिंग) में बदलें
iscellstr निर्धारित करें कि इनपुट स्ट्रिंग्स का सेल एरे है
ischar निर्धारित करें कि क्या आइटम चरित्र सरणी है
sprintf स्ट्रिंग में डेटा प्रारूपित करें
strcat क्षैतिज रूप से तार समेटें
strjoin एकल स्ट्रिंग में सेल सरणी में तार शामिल हों
तारों के कुछ हिस्सों की पहचान करने के लिए फ़ंक्शंस खोजें और प्रतिस्थापित करें
ischar निर्धारित करें कि क्या आइटम चरित्र सरणी है
isletter ऐरे तत्व जो वर्णमाला के अक्षर हैं
isspace एरे तत्व जो अंतरिक्ष वर्ण हैं
isstrprop निर्धारित करें कि क्या स्ट्रिंग निर्दिष्ट श्रेणी की है
sscanf स्ट्रिंग से स्वरूपित डेटा पढ़ें
strfind दूसरे के भीतर एक तार खोजें
strrep ढूँढें और प्रतिस्थापन प्रतिस्थापित करें
strsplit निर्दिष्ट सीमांकक पर विभाजित स्ट्रिंग
strtok स्ट्रिंग के चयनित भाग
validatestring टेक्स्ट स्ट्रिंग की वैधता की जाँच करें
symvar अभिव्यक्ति में प्रतीकात्मक चर निर्धारित करें
रेगुलर एक्सप्रेशन मैच रेगुलर एक्सप्रेशन (केस सेंसिटिव)
regexpi नियमित अभिव्यक्ति से मिलान करें (केस असंवेदनशील)
regexprep नियमित अभिव्यक्ति का उपयोग करके स्ट्रिंग बदलें
regexptranslate स्ट्रिंग को नियमित अभिव्यक्ति में अनुवाद करें
स्ट्रिंग तुलना के लिए कार्य
strcmp तार की तुलना करें (मामला संवेदनशील)
strcmpi तार की तुलना करें (केस असंवेदनशील)
strncmp तार के पहले n अक्षर की तुलना करें (मामला संवेदनशील)
strncmpi तार के पहले n वर्णों की तुलना करें (केस असंवेदनशील)
स्ट्रिंग को ऊपरी या निचले हिस्से में बदलने के लिए कार्य, सफेद स्थान बनाना या निकालना
deblank स्ट्रिंग के अंत से स्ट्रीपिंग ब्लैंकिंग
strtrim स्ट्रिंग से सफेद स्थान की अग्रणी और अनुगामी निकालें
कम स्ट्रिंग को लोअरकेस में बदलें
अपर स्ट्रिंग को अपरकेस में बदलें
strjust चरित्र सरणी का औचित्य सिद्ध करें

उदाहरण

निम्नलिखित उदाहरण उपर्युक्त स्ट्रिंग कार्यों में से कुछ का वर्णन करते हैं -

स्वरूपण स्ट्रिंग्स

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

A = pi*1000*ones(1,5);
sprintf(' %f \n %.2f \n %+.2f \n %12.2f \n %012.2f \n', A)

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

ans =  3141.592654 
   3141.59 
   +3141.59 
      3141.59 
   000003141.59

तार जुड़ना

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

%cell array of strings
str_array = {'red','blue','green', 'yellow', 'orange'};

% Join strings in cell array into single string
str1 = strjoin(str_array, "-")
str2 = strjoin(str_array, ",")

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

str1 = red-blue-green-yellow-orange
str2 = red,blue,green,yellow,orange

स्ट्रिंग्स ढूँढना और बदलना

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

students = {'Zara Ali', 'Neha Bhatnagar', ...
            'Monica Malik', 'Madhu Gautam', ...
            'Madhu Sharma', 'Bhawna Sharma',...
            'Nuha Ali', 'Reva Dutta', ...
            'Sunaina Ali', 'Sofia Kabir'};
 
% The strrep function searches and replaces sub-string.
new_student = strrep(students(8), 'Reva', 'Poulomi')
% Display first names
first_names = strtok(students)

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

new_student = 
{
   [1,1] = Poulomi Dutta
}
first_names = 
{
   [1,1] = Zara
   [1,2] = Neha
   [1,3] = Monica
   [1,4] = Madhu
   [1,5] = Madhu
   [1,6] = Bhawna
   [1,7] = Nuha
   [1,8] = Reva
   [1,9] = Sunaina
   [1,10] = Sofia
}

तुलना स्ट्रिंग्स

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

str1 = 'This is test'
str2 = 'This is text'
if (strcmp(str1, str2))
   sprintf('%s and %s are equal', str1, str2)
else
   sprintf('%s and %s are not equal', str1, str2)
end

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

str1 = This is test
str2 = This is text
ans = This is test and This is text are not equal

एक फ़ंक्शन एक कथन का एक समूह है जो एक साथ एक कार्य करता है। MATLAB में, फ़ंक्शंस को अलग-अलग फ़ाइलों में परिभाषित किया गया है। फ़ाइल और फ़ंक्शन का नाम समान होना चाहिए।

फ़ंक्शंस अपने स्वयं के कार्यक्षेत्र के भीतर चर पर काम करते हैं, जिसे भी कहा जाता है local workspace, MATLAB कमांड प्रॉम्प्ट पर आपके द्वारा उपयोग किए जाने वाले कार्यक्षेत्र से अलग है जिसे कहा जाता है base workspace

फ़ंक्शंस एक से अधिक इनपुट तर्कों को स्वीकार कर सकते हैं और एक से अधिक आउटपुट तर्कों को वापस कर सकते हैं।

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

function [out1,out2, ..., outN] = myfun(in1,in2,in3, ..., inN)

उदाहरण

निम्नलिखित समारोह नामित mymax एक फ़ाइल का नाम में लिखा जाना चाहिए mymax.m । यह तर्क के रूप में पांच नंबर लेता है और अधिकतम संख्या देता है।

एक फ़ंक्शन फ़ाइल बनाएँ, जिसका नाम mymax.m है और उसमें निम्न कोड टाइप करें -

function max = mymax(n1, n2, n3, n4, n5)

%This function calculates the maximum of the
% five numbers given as input
max =  n1;
if(n2 > max)
   max = n2;
end
if(n3 > max)
   max = n3;
end
if(n4 > max)
   max = n4;
end
if(n5 > max)
   max = n5;
end

किसी फ़ंक्शन की पहली पंक्ति कीवर्ड से शुरू होती है function। यह तर्कों के कार्य और क्रम का नाम देता है। हमारे उदाहरण में, mymax फ़ंक्शन में पांच इनपुट तर्क और एक आउटपुट तर्क है।

फ़ंक्शन स्टेटमेंट के ठीक बाद आने वाली टिप्पणी लाइनें सहायता पाठ प्रदान करती हैं। जब आप टाइप करते हैं तो ये लाइनें प्रिंट की जाती हैं -

help mymax

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

This function calculates the maximum of the
   five numbers given as input

आप फ़ंक्शन को इस रूप में कह सकते हैं -

mymax(34, 78, 89, 23, 11)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans = 89

अनाम कार्य

एक अनाम फ़ंक्शन पारंपरिक प्रोग्रामिंग भाषाओं में एक इनलाइन फ़ंक्शन की तरह है, जो एकल MATLAB स्टेटमेंट में परिभाषित किया गया है। इसमें एक एकल MATLAB अभिव्यक्ति और किसी भी संख्या में इनपुट और आउटपुट तर्क शामिल हैं।

आप MATLAB कमांड लाइन पर या किसी फ़ंक्शन या स्क्रिप्ट के भीतर एक अनाम फ़ंक्शन को परिभाषित कर सकते हैं।

इस तरह आप उनके लिए एक फ़ाइल बनाए बिना सरल कार्य बना सकते हैं।

एक अभिव्यक्ति से एक अनाम फ़ंक्शन बनाने का सिंटैक्स है

f = @(arglist)expression

उदाहरण

इस उदाहरण में, हम पावर नाम का एक अनाम फ़ंक्शन लिखेंगे, जो इनपुट के रूप में दो नंबर लेगा और दूसरे नंबर की शक्ति के लिए उठाया गया पहला नंबर लौटाएगा।

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

power = @(x, n) x.^n;
result1 = power(7, 3)
result2 = power(49, 0.5)
result3 = power(10, -10)
result4 = power (4.5, 1.5)

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

result1 =  343
result2 =  7
result3 =  1.0000e-10
result4 =  9.5459

प्राथमिक और उप-कार्य

अनाम फ़ंक्शन के अलावा किसी भी फ़ंक्शन को फ़ाइल के भीतर परिभाषित किया जाना चाहिए। प्रत्येक फ़ंक्शन फ़ाइल में एक आवश्यक प्राथमिक फ़ंक्शन होता है जो पहले दिखाई देता है और किसी भी संख्या में वैकल्पिक उप-फ़ंक्शन जो प्राथमिक फ़ंक्शन के बाद आता है और इसके द्वारा उपयोग किया जाता है।

प्राथमिक फ़ंक्शन को फ़ाइल के बाहर से बुलाया जा सकता है जो उन्हें परिभाषित करता है, या तो कमांड लाइन से या अन्य फ़ंक्शन से, लेकिन फ़ंक्शन फ़ाइल के बाहर कमांड लाइन या अन्य फ़ंक्शन से उप-फ़ंक्शन को नहीं बुलाया जा सकता है।

उप-फ़ंक्शन केवल प्राथमिक फ़ंक्शन और फ़ंक्शन फ़ाइल के भीतर अन्य उप-फ़ंक्शन दिखाई देते हैं जो उन्हें परिभाषित करता है।

उदाहरण

आइए हम द्विघात नामक एक फ़ंक्शन लिखें जो एक द्विघात समीकरण की जड़ों की गणना करेगा। समारोह में तीन इनपुट, द्विघात सह-कुशल, रैखिक सह-कुशल और निरंतर शब्द होंगे। यह जड़ों को वापस कर देगा।

फ़ंक्शन फ़ाइल quadratic.m में प्राथमिक फ़ंक्शन द्विघात और उप-फ़ंक्शन डिस्क शामिल होगी , जो विभेदक की गणना करती है।

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

function [x1,x2] = quadratic(a,b,c)

%this function returns the roots of 
% a quadratic equation.
% It takes 3 input arguments
% which are the co-efficients of x2, x and the 
%constant term
% It returns the roots
d = disc(a,b,c); 
x1 = (-b + d) / (2*a);
x2 = (-b - d) / (2*a);
end   % end of quadratic

function dis = disc(a,b,c) 
%function calculates the discriminant
dis = sqrt(b^2 - 4*a*c);
end   % end of sub-function

आप उपर्युक्त फ़ंक्शन को कमांड प्रॉम्प्ट से कॉल कर सकते हैं -

quadratic(2,4,-4)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans = 0.7321

नेस्टेड कार्य

आप किसी अन्य फ़ंक्शन के शरीर के भीतर कार्यों को परिभाषित कर सकते हैं। इन्हें नेस्टेड फ़ंक्शन कहा जाता है। एक नेस्टेड फ़ंक्शन में किसी भी या किसी अन्य फ़ंक्शन के सभी घटक होते हैं।

नेस्टेड फ़ंक्शंस को किसी अन्य फ़ंक्शन के दायरे में परिभाषित किया गया है और वे युक्त फ़ंक्शन के कार्यक्षेत्र तक पहुंच साझा करते हैं।

एक नेस्टेड फ़ंक्शन निम्न सिंटैक्स का अनुसरण करता है -

function x = A(p1, p2)
...
B(p2)
   function y = B(p3)
   ...
   end
...
end

उदाहरण

हम पिछले उदाहरण से, फ़ंक्शन द्विघात को फिर से लिखते हैं , हालांकि, इस बार डिस्क फ़ंक्शन एक नेस्टेड फ़ंक्शन होगा।

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

function [x1,x2] = quadratic2(a,b,c)
function disc  % nested function
d = sqrt(b^2 - 4*a*c);
end   % end of function disc

disc;
x1 = (-b + d) / (2*a);
x2 = (-b - d) / (2*a);
end   % end of function quadratic2

आप उपर्युक्त फ़ंक्शन को कमांड प्रॉम्प्ट से कॉल कर सकते हैं -

quadratic2(2,4,-4)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans =  0.73205

निजी कार्य

एक निजी फ़ंक्शन एक प्राथमिक फ़ंक्शन है जो केवल अन्य फ़ंक्शन के सीमित समूह को दिखाई देता है। यदि आप किसी फ़ंक्शन के कार्यान्वयन को उजागर नहीं करना चाहते हैं, तो आप उन्हें निजी कार्यों के रूप में बना सकते हैं।

निजी कार्यों में रहते हैं subfolders विशेष नाम के साथ private

वे केवल मूल फ़ोल्डर में फ़ंक्शन के लिए दिखाई देते हैं।

उदाहरण

हमें द्विघात फ़ंक्शन को फिर से लिखना है । इस बार, हालांकि, भेदभाव करने वाले की गणना करने वाला डिस्क फ़ंक्शन एक निजी फ़ंक्शन होगा।

कार्यशील निर्देशिका में निजी नाम का सबफ़ोल्डर बनाएँ। इसमें निम्नलिखित फंक्शन फाइल को रखें

function dis = disc(a,b,c) 
%function calculates the discriminant
dis = sqrt(b^2 - 4*a*c);
end      % end of sub-function

अपनी कार्य निर्देशिका में एक फ़ंक्शन quadratic3.m बनाएँ और उसमें निम्न कोड टाइप करें -

function [x1,x2] = quadratic3(a,b,c)

%this function returns the roots of 
% a quadratic equation.
% It takes 3 input arguments
% which are the co-efficient of x2, x and the 
%constant term
% It returns the roots
d = disc(a,b,c); 

x1 = (-b + d) / (2*a);
x2 = (-b - d) / (2*a);
end      % end of quadratic3

आप उपर्युक्त फ़ंक्शन को कमांड प्रॉम्प्ट से कॉल कर सकते हैं -

quadratic3(2,4,-4)

MATLAB उपरोक्त कथन को निष्पादित करेगा और निम्नलिखित परिणाम लौटाएगा -

ans =  0.73205

सार्वत्रिक चर

वैश्विक चर को एक से अधिक फ़ंक्शन द्वारा साझा किया जा सकता है। इसके लिए आपको चर को सभी कार्यों में वैश्विक घोषित करने की आवश्यकता है।

यदि आप उस चर को आधार कार्यक्षेत्र से एक्सेस करना चाहते हैं, तो कमांड लाइन पर चर घोषित करें।

वैरिएबल डिक्लेरेशन को किसी फ़ंक्शन में वास्तव में उपयोग किए जाने से पहले होना चाहिए। वैश्विक चर के नामों के लिए बड़े अक्षरों का उपयोग करने के लिए उन्हें अन्य चर से अलग करना एक अच्छा अभ्यास है।

उदाहरण

चलिए एक औसत नाम की एक फंक्शन फाइल बनाते हैं और उसमें निम्न कोड टाइप करते हैं -

function avg = average(nums)
global TOTAL
avg = sum(nums)/TOTAL;
end

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

global TOTAL;
TOTAL = 10;
n = [34, 45, 25, 45, 33, 19, 40, 34, 38, 42];
av = average(n)

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

av =  35.500

MATLAB में डेटा आयात करने का मतलब बाहरी फ़ाइल से डेटा लोड करना है। importdataफ़ंक्शन विभिन्न प्रारूपों के विभिन्न डेटा फ़ाइलों को लोड करने की अनुमति देता है। इसके निम्नलिखित पाँच रूप हैं -

अनु क्रमांक। समारोह विवरण
1

A = importdata(filename)

फ़ाइल नाम से चिह्नित फ़ाइल A से सरणी डेटा में भार ।

2

A = importdata('-pastespecial')

फ़ाइल से बजाय सिस्टम क्लिपबोर्ड से डेटा लोड करता है।

3

A = importdata(___, delimiterIn)

व्याख्या delimiterIn ASCII फ़ाइल, फ़ाइल नाम, या क्लिपबोर्ड डेटा में स्तंभ विभाजक के रूप में। आप उपरोक्त सिंटैक्स में किसी भी इनपुट तर्क के साथ सीमांकक का उपयोग कर सकते हैं ।

4

A = importdata(___, delimiterIn, headerlinesIn)

ASCII फ़ाइल, फ़ाइल नाम या क्लिपबोर्ड से डेटा लोड करना, लाइन हैडरलाइन से शुरू होने वाले संख्यात्मक डेटा पढ़ना + 1

5

[A, delimiterOut, headerlinesOut] = importdata(___)

पिछले सिंटैक्स में किसी भी इनपुट तर्कों का उपयोग करके सीमांकक में इनपुट ASCII फ़ाइल के लिए सीमांकित फ़ाइल और हेडलाइनर में हेडर लाइनों की संख्या का पता लगाया है ।

डिफ़ॉल्ट रूप से, ऑक्टेव में इंपोर्टडेटा () फ़ंक्शन के लिए समर्थन नहीं है , इसलिए आपको अपने ऑक्टेव इंस्टॉलेशन के साथ निम्नलिखित उदाहरणों को काम करने के लिए इस पैकेज को खोजना और इंस्टॉल करना होगा।

उदाहरण 1

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

filename = 'smile.jpg';
A = importdata(filename);
image(A);

जब आप फ़ाइल चलाते हैं, तो MATLAB छवि फ़ाइल प्रदर्शित करता है। हालाँकि, आपको इसे वर्तमान निर्देशिका में संग्रहीत करना होगा।

उदाहरण 2

इस उदाहरण में, हम एक टेक्स्ट फ़ाइल आयात करते हैं और Delimiter और Column Header निर्दिष्ट करते हैं। हमें कॉलम हेडर के साथ एक स्पेस-सीमांकित एएससीआईआई फ़ाइल बनाते हैं, जिसका नाम साप्ताहिकडाटा है

हमारी पाठ फ़ाइल साप्ताहिकडाक। Txt इस तरह दिखती है -

SunDay  MonDay  TuesDay  WednesDay  ThursDay  FriDay  SaturDay
95.01   76.21   61.54    40.57       55.79    70.28   81.53
73.11   45.65   79.19    93.55       75.29    69.87   74.68
60.68   41.85   92.18    91.69       81.32    90.38   74.51
48.60   82.14   73.82    41.03       0.99     67.22   93.18
89.13   44.47   57.63    89.36       13.89    19.88   46.60

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

filename = 'weeklydata.txt';
delimiterIn = ' ';
headerlinesIn = 1;
A = importdata(filename,delimiterIn,headerlinesIn);

% View data
for k = [1:7]
   disp(A.colheaders{1, k})
   disp(A.data(:, k))
   disp(' ')
end

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

SunDay
   95.0100
   73.1100
   60.6800
   48.6000
   89.1300
 
MonDay
   76.2100
   45.6500
   41.8500
   82.1400
   44.4700
 
TuesDay
   61.5400
   79.1900
   92.1800
   73.8200
   57.6300

WednesDay
   40.5700
   93.5500
   91.6900
   41.0300
   89.3600
 
ThursDay
   55.7900
   75.2900
   81.3200
   0.9900
   13.8900
 
FriDay
   70.2800
   69.8700
   90.3800
   67.2200
   19.8800

SaturDay
   81.5300
   74.6800
   74.5100
   93.1800
   46.6000

उदाहरण 3

इस उदाहरण में, हम क्लिपबोर्ड से डेटा आयात करते हैं।

निम्नलिखित पंक्तियों को क्लिपबोर्ड पर कॉपी करें -

Mathematics is simple

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

A = importdata('-pastespecial')

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

A = 
   'Mathematics is simple'

निम्न-स्तरीय फ़ाइल I / O

IMPORTDATA समारोह एक उच्च स्तरीय कार्य है। MATLAB में निम्न-स्तरीय फ़ाइल I / O फ़ंक्शन किसी फ़ाइल में डेटा पढ़ने या लिखने पर सबसे अधिक नियंत्रण की अनुमति देता है। हालाँकि, इन कार्यों को कुशलतापूर्वक काम करने के लिए आपकी फ़ाइल के बारे में अधिक विस्तृत जानकारी की आवश्यकता है।

MATLAB बाइट या चरित्र स्तर पर पढ़ने और लिखने के संचालन के लिए निम्नलिखित कार्य प्रदान करता है -

समारोह विवरण
fclose एक या सभी खुली हुई फाइलें बंद करें
feof फ़ाइल के अंत के लिए परीक्षण करें
ferror फ़ाइल I / O त्रुटियों के बारे में जानकारी
fgetl फ़ाइल से लाइन पढ़ें, newline वर्ण हटा दें
fgets न्यूलाइन अक्षरों को रखते हुए फ़ाइल से लाइन पढ़ें
fopen ओपन फाइल, या ओपन फाइल के बारे में जानकारी प्राप्त करना
fprintf पाठ फ़ाइल में डेटा लिखें
fread बाइनरी फ़ाइल से डेटा पढ़ें
frewind खुली फ़ाइल की शुरुआत के लिए फ़ाइल स्थिति सूचक को स्थानांतरित करें
fscanf पाठ फ़ाइल से डेटा पढ़ें
fseek फ़ाइल में निर्दिष्ट स्थान पर जाएं
ftell खुली फाइल में स्थिति
fwrite बाइनरी फ़ाइल में डेटा लिखें

निम्न-स्तर I / O के साथ पाठ डेटा फ़ाइलें आयात करें

MATLAB पाठ डेटा फ़ाइलों के निम्न-स्तरीय आयात के लिए निम्नलिखित कार्य प्रदान करता है -

  • fscanf फ़ंक्शन पाठ या ASCII फ़ाइल में स्वरूपित डेटा पढ़ता है।

  • fgetl तथा fgets फ़ंक्शन एक समय में एक फ़ाइल की एक पंक्ति पढ़ते हैं, जहां एक नई रेखा प्रत्येक पंक्ति को अलग करती है।

  • fread फ़ंक्शन बाइट या बिट स्तर पर डेटा की एक धारा को पढ़ता है।

उदाहरण

हमारे पास हमारी वर्किंग डायरेक्टरी में सेव एक टेक्स्ट डेटा फाइल 'myfile.txt' है। फ़ाइल तीन महीने के लिए वर्षा डेटा संग्रहीत करती है; वर्ष 2012 के लिए जून, जुलाई और अगस्त।

Myfile.txt के आंकड़ों में पांच स्थानों पर समय, महीने और वर्षा माप के बार-बार सेट हैं। शीर्ष लेख डेटा महीने की संख्या को संग्रहीत करता है M; इसलिए हम माप के एम सेट है।

फ़ाइल इस तरह दिखती है -

Rainfall Data
Months: June, July, August
 
M = 3
12:00:00
June-2012
17.21  28.52  39.78  16.55 23.67
19.15  0.35   17.57  NaN   12.01
17.92  28.49  17.40  17.06 11.09
9.59   9.33   NaN    0.31  0.23 
10.46  13.17  NaN    14.89 19.33
20.97  19.50  17.65  14.45 14.00
18.23  10.34  17.95  16.46 19.34
09:10:02
July-2012
12.76  16.94  14.38  11.86 16.89
20.46  23.17  NaN    24.89 19.33
30.97  49.50  47.65  24.45 34.00
18.23  30.34  27.95  16.46 19.34
30.46  33.17  NaN    34.89  29.33
30.97  49.50  47.65  24.45 34.00
28.67  30.34  27.95  36.46 29.34
15:03:40
August-2012
17.09  16.55  19.59  17.25 19.22
17.54  11.45  13.48  22.55 24.01
NaN    21.19  25.85  25.05 27.21
26.79  24.98  12.23  16.99 18.67
17.54  11.45  13.48  22.55 24.01
NaN    21.19  25.85  25.05 27.21
26.79  24.98  12.23  16.99 18.67

हम इस फ़ाइल से डेटा आयात करेंगे और इस डेटा को प्रदर्शित करेंगे। निम्नलिखित कदम उठाएं -

  • के साथ फ़ाइल खोलें fopen फ़ंक्शन और फ़ाइल पहचानकर्ता प्राप्त करें।

  • फ़ाइल के साथ डेटा का वर्णन करें format specifiers, जैसे कि '%s'एक तार के लिए,'%d'एक पूर्णांक के लिए, या'%f'फ्लोटिंग-पॉइंट नंबर के लिए।

  • फ़ाइल में शाब्दिक वर्णों को छोड़ने के लिए, उन्हें प्रारूप विवरण में शामिल करें। डेटा फ़ील्ड को छोड़ने के लिए, विनिर्देशक में एक तारांकन चिह्न ('*') का उपयोग करें।

    उदाहरण के लिए, हेडर पढ़ने के लिए और एम के लिए एकल मान वापस करने के लिए, हम लिखते हैं -

    M = fscanf(fid, '%*s %*s\n%*s %*s %*s %*s\nM=%d\n\n', 1);
  • डिफ़ॉल्ट रूप से, fscanfहमारे प्रारूप विवरण के अनुसार डेटा को तब तक पढ़ता है जब तक कि यह डेटा के लिए कोई मेल नहीं खाता है, या यह फ़ाइल के अंत तक पहुंचता है। यहां हम 3 सेट डेटा और हर बार पढ़ने के लिए लूप का उपयोग करेंगे, यह 7 पंक्तियों और 5 कॉलम को पढ़ेगा।

  • हम फ़ाइल से पढ़े गए डेटा को संग्रहीत करने के लिए कार्यक्षेत्र में mydata नामक एक संरचना बनाएंगे । इस संरचना के तीन क्षेत्र हैं - समय , महीना और रददता सरणी।

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

filename = '/data/myfile.txt';
rows = 7;
cols = 5;
 
% open the file
fid = fopen(filename);
 
% read the file headers, find M (number of months)
M = fscanf(fid, '%*s %*s\n%*s %*s %*s %*s\nM=%d\n\n', 1);
 
% read each set of measurements
for n = 1:M
   mydata(n).time = fscanf(fid, '%s', 1);
   mydata(n).month = fscanf(fid, '%s', 1);
 
   % fscanf fills the array in column order,
   % so transpose the results
   mydata(n).raindata  = ...
      fscanf(fid, '%f', [rows, cols]);
end
for n = 1:M
   disp(mydata(n).time), disp(mydata(n).month)
   disp(mydata(n).raindata)
end
 
% close the file
fclose(fid);

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

12:00:00
June-2012
   17.2100   17.5700   11.0900   13.1700   14.4500
   28.5200       NaN    9.5900       NaN   14.0000
   39.7800   12.0100    9.3300   14.8900   18.2300
   16.5500   17.9200       NaN   19.3300   10.3400
   23.6700   28.4900    0.3100   20.9700   17.9500
   19.1500   17.4000    0.2300   19.5000   16.4600
   0.3500   17.0600   10.4600   17.6500   19.3400

09:10:02
July-2012
   12.7600       NaN   34.0000   33.1700   24.4500
   16.9400   24.8900   18.2300       NaN   34.0000
   14.3800   19.3300   30.3400   34.8900   28.6700
   11.8600   30.9700   27.9500   29.3300   30.3400
   16.8900   49.5000   16.4600   30.9700   27.9500
   20.4600   47.6500   19.3400   49.5000   36.4600
   23.1700   24.4500   30.4600   47.6500   29.3400

15:03:40
August-2012
   17.0900   13.4800   27.2100   11.4500   25.0500
   16.5500   22.5500   26.7900   13.4800   27.2100
   19.5900   24.0100   24.9800   22.5500   26.7900
   17.2500       NaN   12.2300   24.0100   24.9800
   19.2200   21.1900   16.9900       NaN   12.2300
   17.5400   25.8500   18.6700   21.1900   16.9900
   11.4500   25.0500   17.5400   25.8500   18.6700

MATLAB में डेटा निर्यात (या आउटपुट) का मतलब फाइलों में लिखना है। MATLAB आपको एक अन्य एप्लिकेशन में अपने डेटा का उपयोग करने की अनुमति देता है जो ASCII फ़ाइलों को पढ़ता है। इसके लिए, MATLAB कई डेटा निर्यात विकल्प प्रदान करता है।

आप निम्न प्रकार की फाइलें बना सकते हैं -

  • आयताकार, एक सरणी से ASCII डेटा फ़ाइल को सीमांकित किया गया।

  • कीस्ट्रोक की डायरी (या लॉग) फ़ाइल और परिणामस्वरूप पाठ आउटपुट।

  • निम्न स्तर के फ़ंक्शंस जैसे फ़र्फ़रफ़ का उपयोग करके विशिष्ट ASCII फ़ाइल।

  • अपने C / C ++ या फोरट्रान रूटीन को एक्सेस करने के लिए MEX- फाइल जो एक विशेष टेक्स्ट फाइल फॉर्मेट में लिखता है।

इसके अलावा, आप स्प्रैडशीट को डेटा निर्यात भी कर सकते हैं।

एक सीमांकित सरणी को सीमांकित ASCII डेटा फ़ाइल के रूप में निर्यात करने के दो तरीके हैं -

  • का उपयोग करते हुए save कार्य और निर्दिष्ट करना -ascii क्वालीफायर

  • का उपयोग करते हुए dlmwrite समारोह

सहेजें फ़ंक्शन का उपयोग करने के लिए सिंटैक्स है -

save my_data.out num_array -ascii

जहाँ, my_data.out सीमांकित ASCII डेटा फ़ाइल है, num_array एक संख्यात्मक सरणी है और−ascii विशिष्ट है।

का उपयोग करने के लिए सिंटैक्स dlmwrite कार्य है -

dlmwrite('my_data.out', num_array, 'dlm_char')

जहाँ, my_data.out सीमांकित ASCII डेटा फ़ाइल है, num_array एक संख्यात्मक सरणी है और dlm_char सीमांकक वर्ण है।

उदाहरण

निम्नलिखित उदाहरण अवधारणा को प्रदर्शित करता है। एक स्क्रिप्ट फ़ाइल बनाएँ और निम्न कोड टाइप करें -

num_array = [ 1 2 3 4 ; 4 5 6 7; 7 8 9 0];
save array_data1.out num_array -ascii;
type array_data1.out
dlmwrite('array_data2.out', num_array, ' ');
type array_data2.out

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

1.0000000e+00   2.0000000e+00   3.0000000e+00   4.0000000e+00
   4.0000000e+00   5.0000000e+00   6.0000000e+00   7.0000000e+00
   7.0000000e+00   8.0000000e+00   9.0000000e+00   0.0000000e+00

1 2 3 4
4 5 6 7
7 8 9 0

कृपया ध्यान दें कि save -ascii कमांड और dlmwrite फ़ंक्शन इनपुट के रूप में सेल सरणियों के साथ काम नहीं करता है। सेल सरणी की सामग्री से एक सीमांकित ASCII फ़ाइल बनाने के लिए, आप कर सकते हैं

  • या तो, सेल ऐरे को मैट्रिक्स का उपयोग करके कन्वर्ट करें cell2mat समारोह

  • या निम्न-स्तरीय फ़ाइल I / O फ़ंक्शन का उपयोग करके सेल ऐरे को निर्यात करें।

यदि आप उपयोग करते हैं save एक ASCII फ़ाइल के लिए एक चरित्र सरणी लिखने के लिए कार्य करता है, यह ASCII वर्णों के बराबर फ़ाइल में लिखता है।

उदाहरण के लिए, 'फाइल' शब्द को किसी फाइल में लिखें -

h = 'hello';
save textdata.out h -ascii
type textdata.out

MATLAB उपरोक्त कथनों को निष्पादित करता है और निम्नलिखित परिणाम प्रदर्शित करता है। जो 8-अंकीय ASCII प्रारूप में स्ट्रिंग 'हैलो' के अक्षर हैं।

1.0400000e+02   1.0100000e+02   1.0800000e+02   1.0800000e+02   1.1100000e+02

डायरी फ़ाइलों को लेखन

डायरी फाइलें आपके MATLAB सत्र की गतिविधि लॉग हैं। डायरी फ़ंक्शन ग्राफिक्स को छोड़कर डिस्क फ़ाइल में आपके सत्र की एक सटीक प्रतिलिपि बनाता है।

डायरी का कार्य चालू करने के लिए, टाइप करें -

diary

वैकल्पिक रूप से, आप लॉग फ़ाइल का नाम दे सकते हैं, कहते हैं -

diary logdata.out

डायरी समारोह बंद करने के लिए -

diary off

आप एक पाठ संपादक में डायरी फ़ाइल खोल सकते हैं।

निम्न-स्तर I / O के साथ पाठ डेटा फ़ाइलों को डेटा निर्यात करना

अब तक, हमने संख्यात्मक सरणियों का निर्यात किया है। हालाँकि, आपको अन्य पाठ फ़ाइलों को बनाने की आवश्यकता हो सकती है, जिसमें संख्यात्मक और चरित्र डेटा के संयोजन, गैर-सही आउटपुट फ़ाइलें, या गैर-ASCII एन्कोडिंग योजनाओं वाली फाइलें शामिल हैं। इन उद्देश्यों के लिए, MATLAB निम्न-स्तर प्रदान करता हैfprintf समारोह।

निम्न-स्तरीय I / O फ़ाइल गतिविधियों में, निर्यात करने से पहले, आपको फ़ाइल खोलने या बनाने की आवश्यकता है fopenफ़ंक्शन और फ़ाइल पहचानकर्ता प्राप्त करें। डिफ़ॉल्ट रूप से, fopen केवल-पढ़ने के लिए एक फ़ाइल खोलता है। आपको लिखने या अपील करने की अनुमति निर्दिष्ट करनी चाहिए, जैसे 'w' या 'a'।

फ़ाइल को संसाधित करने के बाद, आपको इसे बंद करने की आवश्यकता है fclose(fid) समारोह।

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

उदाहरण

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

% create a matrix y, with two rows
x = 0:10:100;
y = [x; log(x)];
 
% open a file for writing
fid = fopen('logtable.txt', 'w');
 
% Table Header
fprintf(fid, 'Log     Function\n\n');
 
% print values in column order
% two values appear on each row of the file
fprintf(fid, '%f    %f\n', y);
fclose(fid);

% display the file created
type logtable.txt

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

Log         Function

0.000000    -Inf
10.000000    2.302585
20.000000    2.995732
30.000000    3.401197
40.000000    3.688879
50.000000    3.912023
60.000000    4.094345
70.000000    4.248495
80.000000    4.382027
90.000000    4.499810
100.000000    4.605170

किसी फ़ंक्शन के ग्राफ को प्लॉट करने के लिए, आपको निम्नलिखित कदम उठाने होंगे -

  • परिभाषित x, निर्दिष्ट करके range of values चर के लिए xजिसके लिए फंक्शन प्लॉट किया जाना है

  • फ़ंक्शन को परिभाषित करें, y = f(x)

  • बुलाएं plot कमान, के रूप में plot(x, y)

उदाहरण के बाद अवधारणा प्रदर्शित होगी। आइए हम सरल फ़ंक्शन को प्लॉट करेंy = x 5 के वेतन वृद्धि के साथ x से 0 के लिए मानों की श्रेणी के लिए।

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

x = [0:5:100];
y = x;
plot(x, y)

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

फ़ंक्शन y = x 2 को प्लॉट करने के लिए एक और उदाहरण लेते हैं । इस उदाहरण में, हम एक ही फ़ंक्शन के साथ दो ग्राफ़ खींचेंगे, लेकिन दूसरी बार में, हम वेतन वृद्धि के मूल्य को कम कर देंगे। कृपया ध्यान दें कि जैसे-जैसे हम वेतन वृद्धि को कम करते जाते हैं, वैसे-वैसे ग्राफ चिकना होता जाता है।

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

x = [1 2 3 4 5 6 7 8 9 10];
x = [-100:20:100];
y = x.^2;
plot(x, y)

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

कोड फ़ाइल को थोड़ा बदलें, वेतन वृद्धि को 5 तक कम करें -

x = [-100:5:100];
y = x.^2;
plot(x, y)

MATLAB एक चिकना ग्राफ खींचता है -

ग्राफ पर शीर्षक, लेबल, ग्रिड लाइन्स और स्केलिंग जोड़ना

MATLAB आपको एक्स-अक्ष और y- अक्ष, ग्रिड लाइनों के साथ शीर्षक, लेबल जोड़ने के लिए और ग्राफ़ को सजाना के लिए कुल्हाड़ियों को समायोजित करने की अनुमति देता है।

  • xlabel तथा ylabel आदेश x- अक्ष और y- अक्ष के साथ लेबल उत्पन्न करते हैं।

  • title कमांड आपको ग्राफ पर एक शीर्षक लगाने की अनुमति देता है।

  • grid on कमांड आपको ग्राफ पर ग्रिड लाइनें डालने की अनुमति देता है।

  • axis equal कमांड एक ही स्केल कारकों और दोनों कुल्हाड़ियों पर रिक्त स्थान के साथ भूखंड उत्पन्न करने की अनुमति देता है।

  • axis square आदेश एक वर्ग भूखंड उत्पन्न करता है।

उदाहरण

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

x = [0:0.01:10];
y = sin(x);
plot(x, y), xlabel('x'), ylabel('Sin(x)'), title('Sin(x) Graph'),
grid on, axis equal

MATLAB निम्नलिखित ग्राफ उत्पन्न करता है -

एक ही ग्राफ पर कई कार्य आरेखण

आप एक ही भूखंड पर कई रेखांकन खींच सकते हैं। निम्नलिखित उदाहरण अवधारणा को प्रदर्शित करता है -

उदाहरण

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

x = [0 : 0.01: 10];
y = sin(x);
g = cos(x);
plot(x, y, x, g, '.-'), legend('Sin(x)', 'Cos(x)')

MATLAB निम्नलिखित ग्राफ उत्पन्न करता है -

ग्राफ़ पर रंग सेट करना

MATLAB रेखांकन रेखांकन के लिए आठ बुनियादी रंग विकल्प प्रदान करता है। निम्न तालिका रंगों और उनके कोड को दिखाती है -

कोड रंग
w सफेद
काली
नीला
आर लाल
सी सियान
जी हरा
मैजेंटा
y पीला

उदाहरण

आइए हम दो बहुपदों के ग्राफ को खींचते हैं

  • f (x) = 3x 4 + 2x 3 + 7x 2 + 2x + 9 और

  • g (x) = 5x 3 + 9x + 2

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

x = [-10 : 0.01: 10];
y = 3*x.^4 + 2 * x.^3 + 7 * x.^2 + 2 * x + 9;
g = 5 * x.^3 + 9 * x + 2;
plot(x, y, 'r', x, g, 'g')

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

एक्सिस स्केल सेट करना

axisकमांड आपको अक्ष तराजू सेट करने की अनुमति देता है। आप एक्स और वाई कुल्हाड़ियों के लिए न्यूनतम और अधिकतम मान प्रदान कर सकते हैं, जो निम्न प्रकार से हैं।

axis ( [xmin xmax ymin ymax] )

निम्न उदाहरण से पता चलता है -

उदाहरण

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

x = [0 : 0.01: 10];
y = exp(-x).* sin(2*x + 3);
plot(x, y), axis([0 10 -1 1])

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

उप-भूखंडों का निर्माण

जब आप एक ही आकृति में भूखंडों की एक सरणी बनाते हैं, तो इनमें से प्रत्येक भूखंड को एक सबप्लॉट कहा जाता है। subplot सबप्लॉट बनाने के लिए कमांड का उपयोग किया जाता है।

कमांड के लिए सिंटैक्स है -

subplot(m, n, p)

जहाँ, m और n प्लॉट एरे की पंक्तियों और कॉलमों की संख्या है और पी निर्दिष्ट करते हैं कि किसी विशेष प्लॉट को कहाँ रखा जाए।

सबप्लॉट कमांड के साथ बनाए गए प्रत्येक प्लॉट की अपनी विशेषताएं हो सकती हैं। निम्नलिखित उदाहरण अवधारणा को प्रदर्शित करता है -

उदाहरण

आइए हम दो प्लॉट तैयार करें -

y = e = 1.5x पाप (10x)

y = e = 2x पाप (10x)

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

x = [0:0.01:5];
y = exp(-1.5*x).*sin(10*x);
subplot(1,2,1)
plot(x,y), xlabel('x'),ylabel('exp(–1.5x)*sin(10x)'),axis([0 5 -1 1])
y = exp(-2*x).*sin(10*x);
subplot(1,2,2)
plot(x,y),xlabel('x'),ylabel('exp(–2x)*sin(10x)'),axis([0 5 -1 1])

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

यह अध्याय MATLAB की प्लॉटिंग और ग्राफिक्स क्षमताओं की खोज जारी रखेगा। हम चर्चा करेंगे -

  • ड्राइंग बार चार्ट
  • चित्र बनाना
  • तीन आयामी भूखंड

ड्राइंग बार चार्ट

barकमांड एक दो आयामी बार चार्ट बनाता है। आइए हम विचार प्रदर्शित करने के लिए एक उदाहरण लें।

उदाहरण

आइए हम 10 छात्रों के साथ एक काल्पनिक कक्षा रखें। हम जानते हैं कि इन छात्रों द्वारा प्राप्त अंकों का प्रतिशत 75, 58, 90, 87, 50, 85, 92, 75, 60 और 95 है। हम इस डेटा के लिए बार चार्ट तैयार करेंगे।

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

x = [1:10];
y = [75, 58, 90, 87, 50, 85, 92, 75, 60, 95];
bar(x,y), xlabel('Student'),ylabel('Score'),
title('First Sem:')
print -deps graph.eps

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

ड्रॉइंग कंट्रोस

दो चर के एक समारोह की एक समोच्च रेखा एक वक्र है जिसके साथ फ़ंक्शन का एक स्थिर मान है। समोच्च रेखाओं का उपयोग किसी दिए गए स्तर के बराबर ऊंचाई के बिंदुओं से जुड़कर समोच्च मानचित्र बनाने के लिए किया जाता है, जैसे कि समुद्र तल।

MATLAB एक प्रदान करता है contour समोच्च नक्शे खींचने के लिए कार्य करते हैं।

उदाहरण

आइए हम एक समोच्च मानचित्र बनाते हैं जो किसी दिए गए फ़ंक्शन g = f (x, y) के लिए समोच्च रेखाएं दिखाता है। इस फ़ंक्शन के दो चर हैं। तो, हमें दो स्वतंत्र चर उत्पन्न करने होंगे, यानी दो डेटा सेट x और y। यह कॉल करके किया जाता हैmeshgrid आदेश।

meshgrid आदेश का उपयोग उन तत्वों के एक मैट्रिक्स को उत्पन्न करने के लिए किया जाता है जो प्रत्येक मामले में वेतन वृद्धि के विनिर्देश के साथ-साथ x और y पर सीमा देते हैं।

आइए हम अपने फंक्शन g = f (x, y) को प्लॉट करें, जहां ≤5 ≤ x, 5, −3 Let y ≤ 3. आइए हम दोनों मानों के लिए 0.1 की वेतन वृद्धि लें। चर के रूप में सेट कर रहे हैं -

[x,y] = meshgrid(–5:0.1:5, –3:0.1:3);

अंत में, हमें फंक्शन असाइन करने की आवश्यकता है। हमारे कार्य करते हैं: x 2 + y 2

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

[x,y] = meshgrid(-5:0.1:5,-3:0.1:3);   %independent variables
g = x.^2 + y.^2;                       % our function
contour(x,y,g)                         % call the contour function
print -deps graph.eps

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

मानचित्र को स्प्रूस करने के लिए कोड को थोड़ा संशोधित करें

[x,y] = meshgrid(-5:0.1:5,-3:0.1:3);   %independent variables
g = x.^2 + y.^2;                       % our function
[C, h] = contour(x,y,g);               % call the contour function
set(h,'ShowText','on','TextStep',get(h,'LevelStep')*2)
print -deps graph.eps

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

तीन आयामी भूखंड

तीन आयामी भूखंड मूल रूप से दो चर, g = f (x, y) में एक फ़ंक्शन द्वारा परिभाषित सतह को प्रदर्शित करते हैं।

पहले की तरह, जी को परिभाषित करने के लिए, हम सबसे पहले फंक्शन के डोमेन पर (x, y) बिंदुओं का एक सेट बनाते हैं meshgridआदेश। अगला, हम फ़ंक्शन को स्वयं असाइन करते हैं। अंत में, हम उपयोग करते हैंsurf एक सतह भूखंड बनाने के लिए आदेश।

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

उदाहरण

हमें फ़ंक्शन g = xe के लिए एक 3D सतह मानचित्र बनाते हैं - (x 2 + y 2 )

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

[x,y] = meshgrid(-2:.2:2);
g = x .* exp(-x.^2 - y.^2);
surf(x, y, g)
print -deps graph.eps

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

आप भी उपयोग कर सकते हैं meshएक त्रि-आयामी सतह उत्पन्न करने के लिए कमांड। हालांकिsurf कमांड दोनों कनेक्टिंग लाइनों और सतह के चेहरों को रंग में प्रदर्शित करता है, जबकि, mesh कमांड रंगीन बिंदुओं को परिभाषित बिंदुओं को जोड़ने वाली वायरफ्रेम सतह बनाता है।

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

हम बीजीय भावों के गुणन और सरलीकरण पर भी चर्चा करेंगे।

Solving Basic Algebraic Equations in MATLAB

The solve function is used for solving algebraic equations. In its simplest form, the solve function takes the equation enclosed in quotes as an argument.

For example, let us solve for x in the equation x-5 = 0

solve('x-5=0')

MATLAB will execute the above statement and return the following result −

ans =
   5

You can also call the solve function as −

y = solve('x-5 = 0')

MATLAB will execute the above statement and return the following result −

y =
   5

You may even not include the right hand side of the equation −

solve('x-5')

MATLAB will execute the above statement and return the following result −

ans =
   5

If the equation involves multiple symbols, then MATLAB by default assumes that you are solving for x, however, the solve function has another form −

solve(equation, variable)

where, you can also mention the variable.

For example, let us solve the equation v – u – 3t2 = 0, for v. In this case, we should write −

solve('v-u-3*t^2=0', 'v')

MATLAB will execute the above statement and return the following result −

ans =
   3*t^2 + u

Solving Basic Algebraic Equations in Octave

The roots function is used for solving algebraic equations in Octave and you can write above examples as follows −

For example, let us solve for x in the equation x-5 = 0

roots([1, -5])

Octave will execute the above statement and return the following result −

ans = 5

You can also call the solve function as −

y = roots([1, -5])

Octave will execute the above statement and return the following result −

y = 5

Solving Quadratic Equations in MATLAB

The solve function can also solve higher order equations. It is often used to solve quadratic equations. The function returns the roots of the equation in an array.

The following example solves the quadratic equation x2 -7x +12 = 0. Create a script file and type the following code −

eq = 'x^2 -7*x + 12 = 0';
s = solve(eq);
disp('The first root is: '), disp(s(1));
disp('The second root is: '), disp(s(2));

When you run the file, it displays the following result −

The first root is: 
   3
The second root is: 
   4

Solving Quadratic Equations in Octave

The following example solves the quadratic equation x2 -7x +12 = 0 in Octave. Create a script file and type the following code −

s = roots([1, -7, 12]);

disp('The first root is: '), disp(s(1));
disp('The second root is: '), disp(s(2));

When you run the file, it displays the following result −

The first root is: 
   4
The second root is: 
   3

Solving Higher Order Equations in MATLAB

The solve function can also solve higher order equations. For example, let us solve a cubic equation as (x-3)2(x-7) = 0

solve('(x-3)^2*(x-7)=0')

MATLAB will execute the above statement and return the following result −

ans =
   3
   3
   7

In case of higher order equations, roots are long containing many terms. You can get the numerical value of such roots by converting them to double. The following example solves the fourth order equation x4 − 7x3 + 3x2 − 5x + 9 = 0.

Create a script file and type the following code −

eq = 'x^4 - 7*x^3 + 3*x^2 - 5*x + 9 = 0';
s = solve(eq);
disp('The first root is: '), disp(s(1));
disp('The second root is: '), disp(s(2));
disp('The third root is: '), disp(s(3));
disp('The fourth root is: '), disp(s(4));

% converting the roots to double type
disp('Numeric value of first root'), disp(double(s(1)));
disp('Numeric value of second root'), disp(double(s(2)));
disp('Numeric value of third root'), disp(double(s(3)));
disp('Numeric value of fourth root'), disp(double(s(4)));

When you run the file, it returns the following result −

The first root is: 
6.630396332390718431485053218985
 The second root is: 
1.0597804633025896291682772499885
 The third root is: 
- 0.34508839784665403032666523448675 - 1.0778362954630176596831109269793*i
 The fourth root is: 
- 0.34508839784665403032666523448675 + 1.0778362954630176596831109269793*i
Numeric value of first root
   6.6304
Numeric value of second root
   1.0598
Numeric value of third root
   -0.3451 - 1.0778i
Numeric value of fourth root
   -0.3451 + 1.0778i

Please note that the last two roots are complex numbers.

Solving Higher Order Equations in Octave

The following example solves the fourth order equation x4 − 7x3 + 3x2 − 5x + 9 = 0.

Create a script file and type the following code −

v = [1, -7,  3, -5, 9];
s = roots(v);

% converting the roots to double type
disp('Numeric value of first root'), disp(double(s(1)));
disp('Numeric value of second root'), disp(double(s(2)));
disp('Numeric value of third root'), disp(double(s(3)));
disp('Numeric value of fourth root'), disp(double(s(4)));

When you run the file, it returns the following result −

Numeric value of first root
 6.6304
Numeric value of second root
-0.34509 + 1.07784i
Numeric value of third root
-0.34509 - 1.07784i
Numeric value of fourth root
 1.0598

Solving System of Equations in MATLAB

The solve function can also be used to generate solutions of systems of equations involving more than one variables. Let us take up a simple example to demonstrate this use.

Let us solve the equations −

5x + 9y = 5

3x – 6y = 4

Create a script file and type the following code −

s = solve('5*x + 9*y = 5','3*x - 6*y = 4');
s.x
s.y

When you run the file, it displays the following result −

ans =
   22/19
ans =
   -5/57

In same way, you can solve larger linear systems. Consider the following set of equations −

x + 3y -2z = 5

3x + 5y + 6z = 7

2x + 4y + 3z = 8

Solving System of Equations in Octave

We have a little different approach to solve a system of 'n' linear equations in 'n' unknowns. Let us take up a simple example to demonstrate this use.

Let us solve the equations −

5x + 9y = 5

3x – 6y = 4

Such a system of linear equations can be written as the single matrix equation Ax = b, where A is the coefficient matrix, b is the column vector containing the right-hand side of the linear equations and x is the column vector representing the solution as shown in the below program −

Create a script file and type the following code −

A = [5, 9; 3, -6];
b = [5;4];
A \ b

When you run the file, it displays the following result −

ans =

   1.157895
  -0.087719

In same way, you can solve larger linear systems as given below −

x + 3y -2z = 5

3x + 5y + 6z = 7

2x + 4y + 3z = 8

Expanding and Collecting Equations in MATLAB

The expand and the collect function expands and collects an equation respectively. The following example demonstrates the concepts −

When you work with many symbolic functions, you should declare that your variables are symbolic.

Create a script file and type the following code −

syms x   %symbolic variable x
syms y   %symbolic variable x
% expanding equations
expand((x-5)*(x+9))
expand((x+2)*(x-3)*(x-5)*(x+7))
expand(sin(2*x))
expand(cos(x+y))
 
% collecting equations
collect(x^3 *(x-7))
collect(x^4*(x-3)*(x-5))

When you run the file, it displays the following result −

ans =
   x^2 + 4*x - 45
ans =
   x^4 + x^3 - 43*x^2 + 23*x + 210
ans =
   2*cos(x)*sin(x)
ans =
   cos(x)*cos(y) - sin(x)*sin(y)
ans =
   x^4 - 7*x^3
ans =
   x^6 - 8*x^5 + 15*x^4

Expanding and Collecting Equations in Octave

You need to have symbolic package, which provides expand and the collect function to expand and collect an equation, respectively. The following example demonstrates the concepts −

When you work with many symbolic functions, you should declare that your variables are symbolic but Octave has different approach to define symbolic variables. Notice the use of Sin and Cos, which are also defined in symbolic package.

Create a script file and type the following code −

% first of all load the package, make sure its installed.
pkg load symbolic

% make symbols module available
symbols

% define symbolic variables
x = sym ('x');
y = sym ('y');
z = sym ('z');

% expanding equations
expand((x-5)*(x+9))
expand((x+2)*(x-3)*(x-5)*(x+7))
expand(Sin(2*x))
expand(Cos(x+y))
 
% collecting equations
collect(x^3 *(x-7), z)
collect(x^4*(x-3)*(x-5), z)

When you run the file, it displays the following result −

ans =

-45.0+x^2+(4.0)*x
ans =

210.0+x^4-(43.0)*x^2+x^3+(23.0)*x
ans =

sin((2.0)*x)
ans =

cos(y+x)
ans =

x^(3.0)*(-7.0+x)
ans =

(-3.0+x)*x^(4.0)*(-5.0+x)

Factorization and Simplification of Algebraic Expressions

The factor function factorizes an expression and the simplify function simplifies an expression. The following example demonstrates the concept −

Example

Create a script file and type the following code −

syms x
syms y
factor(x^3 - y^3)
factor([x^2-y^2,x^3+y^3])
simplify((x^4-16)/(x^2-4))

When you run the file, it displays the following result −

ans =
   (x - y)*(x^2 + x*y + y^2)
ans =
   [ (x - y)*(x + y), (x + y)*(x^2 - x*y + y^2)]
ans =
   x^2 + 4

MATLAB provides various ways for solving problems of differential and integral calculus, solving differential equations of any degree and calculation of limits. Best of all, you can easily plot the graphs of complex functions and check maxima, minima and other stationery points on a graph by solving the original function, as well as its derivative.

This chapter will deal with problems of calculus. In this chapter, we will discuss pre-calculus concepts i.e., calculating limits of functions and verifying the properties of limits.

In the next chapter Differential, we will compute derivative of an expression and find the local maxima and minima on a graph. We will also discuss solving differential equations.

Finally, in the Integration chapter, we will discuss integral calculus.

Calculating Limits

MATLAB provides the limit function for calculating limits. In its most basic form, the limit function takes expression as an argument and finds the limit of the expression as the independent variable goes to zero.

For example, let us calculate the limit of a function f(x) = (x3 + 5)/(x4 + 7), as x tends to zero.

syms x
limit((x^3 + 5)/(x^4 + 7))

MATLAB will execute the above statement and return the following result −

ans =
   5/7

The limit function falls in the realm of symbolic computing; you need to use the syms function to tell MATLAB which symbolic variables you are using. You can also compute limit of a function, as the variable tends to some number other than zero. To calculate lim x->a(f(x)), we use the limit command with arguments. The first being the expression and the second is the number, that x approaches, here it is a.

For example, let us calculate limit of a function f(x) = (x-3)/(x-1), as x tends to 1.

limit((x - 3)/(x-1),1)

MATLAB will execute the above statement and return the following result −

ans =
   NaN

Let's take another example,

limit(x^2 + 5, 3)

MATLAB will execute the above statement and return the following result −

ans =
   14

Calculating Limits using Octave

Following is Octave version of the above example using symbolic package, try to execute and compare the result −

pkg load symbolic
symbols

x = sym("x");
subs((x^3+5)/(x^4+7),x,0)

Octave will execute the above statement and return the following result −

ans =
   0.7142857142857142857

Verification of Basic Properties of Limits

Algebraic Limit Theorem provides some basic properties of limits. These are as follows −

Let us consider two functions −

  • f(x) = (3x + 5)/(x - 3)
  • g(x) = x2 + 1.

Let us calculate the limits of the functions as x tends to 5, of both functions and verify the basic properties of limits using these two functions and MATLAB.

Example

Create a script file and type the following code into it −

syms x
f = (3*x + 5)/(x-3);
g = x^2 + 1;
l1 = limit(f, 4)
l2 = limit (g, 4)
lAdd = limit(f + g, 4)
lSub = limit(f - g, 4)
lMult = limit(f*g, 4)
lDiv = limit (f/g, 4)

When you run the file, it displays −

l1 =
   17
  
l2 =
   17
  
lAdd =
   34
 
lSub =
   0
  
lMult =
   289
  
lDiv =
   1

Verification of Basic Properties of Limits using Octave

Following is Octave version of the above example using symbolic package, try to execute and compare the result −

pkg load symbolic
symbols

x = sym("x");
f = (3*x + 5)/(x-3);
g = x^2 + 1;

l1 = subs(f, x, 4)
l2 = subs (g, x, 4)
lAdd = subs (f+g, x, 4)
lSub = subs (f-g, x, 4)
lMult = subs (f*g, x, 4)
lDiv = subs (f/g, x, 4)

Octave will execute the above statement and return the following result −

l1 =
   17.0
l2 =
   17.0
lAdd =
   34.0
lSub =
   0.0
lMult =
   289.0
lDiv =
   1.0

Left and Right Sided Limits

When a function has a discontinuity for some particular value of the variable, the limit does not exist at that point. In other words, limits of a function f(x) has discontinuity at x = a, when the value of limit, as x approaches x from left side, does not equal the value of the limit as x approaches from right side.

This leads to the concept of left-handed and right-handed limits. A left-handed limit is defined as the limit as x -> a, from the left, i.e., x approaches a, for values of x < a. A right-handed limit is defined as the limit as x -> a, from the right, i.e., x approaches a, for values of x > a. When the left-handed limit and right-handed limit are not equal, the limit does not exist.

Let us consider a function −

f(x) = (x - 3)/|x - 3|

We will show that limx->3 f(x) does not exist. MATLAB helps us to establish this fact in two ways −

  • By plotting the graph of the function and showing the discontinuity.
  • By computing the limits and showing that both are different.

The left-handed and right-handed limits are computed by passing the character strings 'left' and 'right' to the limit command as the last argument.

Example

Create a script file and type the following code into it −

f = (x - 3)/abs(x-3);
ezplot(f,[-1,5])
l = limit(f,x,3,'left')
r = limit(f,x,3,'right')

When you run the file, MATLAB draws the following plot

After this following output is displayed −

l =
   -1
  
r =
   1

MATLAB provides the diff command for computing symbolic derivatives. In its simplest form, you pass the function you want to differentiate to diff command as an argument.

For example, let us compute the derivative of the function f(t) = 3t2 + 2t-2

Example

Create a script file and type the following code into it −

syms t
f = 3*t^2 + 2*t^(-2);
diff(f)

When the above code is compiled and executed, it produces the following result −

ans =
6*t - 4/t^3

Following is Octave equivalent of the above calculation −

pkg load symbolic
symbols

t = sym("t");
f = 3*t^2 + 2*t^(-2);
differentiate(f,t)

Octave executes the code and returns the following result −

ans =
   -(4.0)*t^(-3.0)+(6.0)*t

Verification of Elementary Rules of Differentiation

Let us briefly state various equations or rules for differentiation of functions and verify these rules. For this purpose, we will write f'(x) for a first order derivative and f"(x) for a second order derivative.

Following are the rules for differentiation −

Rule 1

For any functions f and g and any real numbers a and b are the derivative of the function −

h(x) = af(x) + bg(x) with respect to x is given by −

h'(x) = af'(x) + bg'(x)

Rule 2

The sum and subtraction rules state that if f and g are two functions, f' and g' are their derivatives respectively, then,

(f + g)' = f' + g'

(f - g)' = f' - g'

Rule 3

The product rule states that if f and g are two functions, f' and g' are their derivatives respectively, then,

(f.g)' = f'.g + g'.f

Rule 4

The quotient rule states that if f and g are two functions, f' and g' are their derivatives respectively, then,

(f/g)' = (f'.g - g'.f)/g2

Rule 5

The polynomial or elementary power rule states that, if y = f(x) = xn, then f' = n. x(n-1)

A direct outcome of this rule is that the derivative of any constant is zero, i.e., if y = k, any constant, then

f' = 0

Rule 6

The chain rule states that, derivative of the function of a function h(x) = f(g(x)) with respect to x is,

h'(x)= f'(g(x)).g'(x)

Example

Create a script file and type the following code into it −

syms x
syms t

f = (x + 2)*(x^2 + 3)
der1 = diff(f)
f = (t^2 + 3)*(sqrt(t) + t^3)
der2 = diff(f)
f = (x^2 - 2*x + 1)*(3*x^3 - 5*x^2 + 2)
der3 = diff(f)
f = (2*x^2 + 3*x)/(x^3 + 1)
der4 = diff(f)
f = (x^2 + 1)^17
der5 = diff(f)
f = (t^3 + 3* t^2 + 5*t -9)^(-6)
der6 = diff(f)

When you run the file, MATLAB displays the following result −

f =
   (x^2 + 3)*(x + 2)
 
   der1 =
   2*x*(x + 2) + x^2 + 3
  
f =
   (t^(1/2) + t^3)*(t^2 + 3)
 
   der2 =
   (t^2 + 3)*(3*t^2 + 1/(2*t^(1/2))) + 2*t*(t^(1/2) + t^3)
  
f =
   (x^2 - 2*x + 1)*(3*x^3 - 5*x^2 + 2)
  
der3 =
   (2*x - 2)*(3*x^3 - 5*x^2 + 2) - (- 9*x^2 + 10*x)*(x^2 - 2*x + 1)
 
f =
   (2*x^2 + 3*x)/(x^3 + 1)
  
der4 =
   (4*x + 3)/(x^3 + 1) - (3*x^2*(2*x^2 + 3*x))/(x^3 + 1)^2
  
f =
   (x^2 + 1)^17
  
der5 =
   34*x*(x^2 + 1)^16
  
f =
   1/(t^3 + 3*t^2 + 5*t - 9)^6
  
der6 =
   -(6*(3*t^2 + 6*t + 5))/(t^3 + 3*t^2 + 5*t - 9)^7

Following is Octave equivalent of the above calculation −

pkg load symbolic
symbols

x = sym("x");
t = sym("t");
f = (x + 2)*(x^2 + 3) 
der1 = differentiate(f,x) 
f = (t^2 + 3)*(t^(1/2) + t^3) 
der2 = differentiate(f,t) 
f = (x^2 - 2*x + 1)*(3*x^3 - 5*x^2 + 2) 
der3 = differentiate(f,x) 
f = (2*x^2 + 3*x)/(x^3 + 1) 
der4 = differentiate(f,x) 
f = (x^2 + 1)^17 
der5 = differentiate(f,x) 
f = (t^3 + 3* t^2 + 5*t -9)^(-6) 
der6 = differentiate(f,t)

Octave executes the code and returns the following result −

f =

(2.0+x)*(3.0+x^(2.0))
der1 =

3.0+x^(2.0)+(2.0)*(2.0+x)*x
f =

(t^(3.0)+sqrt(t))*(3.0+t^(2.0))
der2 =

(2.0)*(t^(3.0)+sqrt(t))*t+((3.0)*t^(2.0)+(0.5)*t^(-0.5))*(3.0+t^(2.0))
f =

(1.0+x^(2.0)-(2.0)*x)*(2.0-(5.0)*x^(2.0)+(3.0)*x^(3.0))
der3 =

(-2.0+(2.0)*x)*(2.0-(5.0)*x^(2.0)+(3.0)*x^(3.0))+((9.0)*x^(2.0)-(10.0)*x)*(1.0+x^(2.0)-(2.0)*x)
f =

(1.0+x^(3.0))^(-1)*((2.0)*x^(2.0)+(3.0)*x)
der4 =

(1.0+x^(3.0))^(-1)*(3.0+(4.0)*x)-(3.0)*(1.0+x^(3.0))^(-2)*x^(2.0)*((2.0)*x^(2.0)+(3.0)*x)
f =

(1.0+x^(2.0))^(17.0)
der5 =

(34.0)*(1.0+x^(2.0))^(16.0)*x
f =

(-9.0+(3.0)*t^(2.0)+t^(3.0)+(5.0)*t)^(-6.0)
der6 =

-(6.0)*(-9.0+(3.0)*t^(2.0)+t^(3.0)+(5.0)*t)^(-7.0)*(5.0+(3.0)*t^(2.0)+(6.0)*t)

Derivatives of Exponential, Logarithmic and Trigonometric Functions

The following table provides the derivatives of commonly used exponential, logarithmic and trigonometric functions −

Function Derivative
ca.x ca.x.ln c.a (ln is natural logarithm)
ex ex
ln x 1/x
lncx 1/x.ln c
xx xx.(1 + ln x)
sin(x) cos(x)
cos(x) -sin(x)
tan(x) sec2(x), or 1/cos2(x), or 1 + tan2(x)
cot(x) -csc2(x), or -1/sin2(x), or -(1 + cot2(x))
sec(x) sec(x).tan(x)
csc(x) -csc(x).cot(x)

Example

Create a script file and type the following code into it −

syms x
y = exp(x)
diff(y)
y = x^9
diff(y)
y = sin(x)
diff(y)
y = tan(x)
diff(y)
y = cos(x)
diff(y)
y = log(x)
diff(y)
y = log10(x)
diff(y)
y = sin(x)^2
diff(y)
y = cos(3*x^2 + 2*x + 1)
diff(y)
y = exp(x)/sin(x)
diff(y)

When you run the file, MATLAB displays the following result −

y =
   exp(x)
   ans =
   exp(x)

y =
   x^9
   ans =
   9*x^8
  
y =
   sin(x)
   ans =
   cos(x)
  
y =
   tan(x)
   ans =
   tan(x)^2 + 1
 
y =
   cos(x)
   ans =
   -sin(x)
  
y =
   log(x)
   ans =
   1/x
  
y =
   log(x)/log(10)
   ans =
   1/(x*log(10))
 
y =
   sin(x)^2
   ans =
   2*cos(x)*sin(x)
 
y =
   cos(3*x^2 + 2*x + 1)
   ans =
   -sin(3*x^2 + 2*x + 1)*(6*x + 2)
  
y =
   exp(x)/sin(x)
   ans =
   exp(x)/sin(x) - (exp(x)*cos(x))/sin(x)^2

Following is Octave equivalent of the above calculation −

pkg load symbolic
symbols

x = sym("x");
y = Exp(x)
differentiate(y,x)

y = x^9
differentiate(y,x)

y = Sin(x)
differentiate(y,x)

y = Tan(x)
differentiate(y,x)

y = Cos(x)
differentiate(y,x)

y = Log(x)
differentiate(y,x)

% symbolic packages does not have this support
%y = Log10(x)
%differentiate(y,x)

y = Sin(x)^2
differentiate(y,x)

y = Cos(3*x^2 + 2*x + 1)
differentiate(y,x)

y = Exp(x)/Sin(x)
differentiate(y,x)

Octave executes the code and returns the following result −

y =

exp(x)
ans =

exp(x)
y =

x^(9.0)
ans =

(9.0)*x^(8.0)
y =

sin(x)
ans =

cos(x)
y =

tan(x)
ans =

1+tan(x)^2
y =

cos(x)
ans =

-sin(x)
y =

log(x)
ans =

x^(-1)
y =

sin(x)^(2.0)
ans =

(2.0)*sin(x)*cos(x)
y =

cos(1.0+(2.0)*x+(3.0)*x^(2.0))
ans =

-(2.0+(6.0)*x)*sin(1.0+(2.0)*x+(3.0)*x^(2.0))
y =

sin(x)^(-1)*exp(x)
ans =

sin(x)^(-1)*exp(x)-sin(x)^(-2)*cos(x)*exp(x)

Computing Higher Order Derivatives

To compute higher derivatives of a function f, we use the syntax diff(f,n).

Let us compute the second derivative of the function y = f(x) = x .e-3x

f = x*exp(-3*x);
diff(f, 2)

MATLAB executes the code and returns the following result −

ans =
9*x*exp(-3*x) - 6*exp(-3*x)

Following is Octave equivalent of the above calculation −

pkg load symbolic
symbols

x = sym("x");
f = x*Exp(-3*x);
differentiate(f, x, 2)

Octave executes the code and returns the following result −

ans =

(9.0)*exp(-(3.0)*x)*x-(6.0)*exp(-(3.0)*x)

Example

In this example, let us solve a problem. Given that a function y = f(x) = 3 sin(x) + 7 cos(5x). We will have to find out whether the equation f" + f = -5cos(2x) holds true.

Create a script file and type the following code into it −

syms x
y = 3*sin(x)+7*cos(5*x);  % defining the function
lhs = diff(y,2)+y;        %evaluting the lhs of the equation
rhs = -5*cos(2*x);        %rhs of the equation
if(isequal(lhs,rhs))
   disp('Yes, the equation holds true');
else
   disp('No, the equation does not hold true');
end
disp('Value of LHS is: '), disp(lhs);

When you run the file, it displays the following result −

No, the equation does not hold true
Value of LHS is: 
-168*cos(5*x)

Following is Octave equivalent of the above calculation −

pkg load symbolic
symbols

x = sym("x");
y = 3*Sin(x)+7*Cos(5*x);           % defining the function
lhs = differentiate(y, x, 2) + y;  %evaluting the lhs of the equation
rhs = -5*Cos(2*x);                 %rhs of the equation

if(lhs == rhs)
   disp('Yes, the equation holds true');
else
   disp('No, the equation does not hold true');
end
disp('Value of LHS is: '), disp(lhs);

ऑक्टेव कोड निष्पादित करता है और निम्नलिखित परिणाम लौटाता है -

No, the equation does not hold true
Value of LHS is: 
-(168.0)*cos((5.0)*x)

एक वक्र के मैक्सिमा और मिनिमा ढूँढना

यदि हम एक ग्राफ़ के लिए स्थानीय मैक्सिमा और मिनिमा की खोज कर रहे हैं, तो हम मूल रूप से किसी विशेष इलाके में फ़ंक्शन के ग्राफ पर उच्चतम या निम्नतम बिंदुओं की तलाश कर रहे हैं, या प्रतीकात्मक चर के मूल्यों की एक विशेष श्रेणी के लिए।

फ़ंक्शन y = f (x) के लिए ग्राफ पर उन बिंदुओं पर जहां ग्राफ में शून्य ढलान है, कहा जाता है stationary points। दूसरे शब्दों में स्थिर बिंदु हैं जहाँ f '(x) = 0।

एक फ़ंक्शन के स्थिर बिंदुओं को खोजने के लिए हम अंतर करते हैं, हमें व्युत्पन्न को शून्य के बराबर सेट करने और समीकरण को हल करने की आवश्यकता है।

उदाहरण

आइए फ़ंक्शन के स्थिर बिंदुओं को खोजें च (x) = 2x 3 + 3x 2 - 12x + 17

निम्नलिखित कदम उठाएं -

First let us enter the function and plot its graph.

syms x
y = 2*x^3 + 3*x^2 - 12*x + 17;   % defining the function
ezplot(y)

MATLAB कोड निष्पादित करता है और निम्नलिखित प्लॉट लौटाता है -

यहाँ उपरोक्त उदाहरण के लिए ऑक्टेव समतुल्य कोड है -

pkg load symbolic
symbols

x = sym('x');
y = inline("2*x^3 + 3*x^2 - 12*x + 17");

ezplot(y)
print -deps graph.eps

Our aim is to find some local maxima and minima on the graph, so let us find the local maxima and minima for the interval [-2, 2] on the graph.

syms x
y = 2*x^3 + 3*x^2 - 12*x + 17;   % defining the function
ezplot(y, [-2, 2])

MATLAB कोड निष्पादित करता है और निम्नलिखित प्लॉट लौटाता है -

यहाँ उपरोक्त उदाहरण के लिए ऑक्टेव समतुल्य कोड है -

pkg load symbolic
symbols

x = sym('x');
y = inline("2*x^3 + 3*x^2 - 12*x + 17");

ezplot(y, [-2, 2])
print -deps graph.eps

Next, let us compute the derivative.

g = diff(y)

MATLAB कोड निष्पादित करता है और निम्नलिखित परिणाम देता है -

g =
   6*x^2 + 6*x - 12

यहाँ उपरोक्त गणना के बराबर ऑक्टेव है -

pkg load symbolic
symbols

x = sym("x");
y = 2*x^3 + 3*x^2 - 12*x + 17;
g = differentiate(y,x)

ऑक्टेव कोड निष्पादित करता है और निम्नलिखित परिणाम लौटाता है -

g =
   -12.0+(6.0)*x+(6.0)*x^(2.0)

Let us solve the derivative function, g, to get the values where it becomes zero.

s = solve(g)

MATLAB कोड निष्पादित करता है और निम्नलिखित परिणाम देता है -

s =
   1
   -2

उपरोक्त गणना के बराबर ऑक्टेव निम्नलिखित है -

pkg load symbolic
symbols

x = sym("x");
y = 2*x^3 + 3*x^2 - 12*x + 17;
g = differentiate(y,x)
roots([6, 6, -12])

ऑक्टेव कोड निष्पादित करता है और निम्नलिखित परिणाम लौटाता है -

g =

-12.0+(6.0)*x^(2.0)+(6.0)*x
ans =

  -2
   1

This agrees with our plot. So let us evaluate the function f at the critical points x = 1, -2. हम एक प्रतीकात्मक कार्य में एक मान को प्रतिस्थापित कर सकते हैं subs आदेश।

subs(y, 1), subs(y, -2)

MATLAB कोड निष्पादित करता है और निम्नलिखित परिणाम देता है -

ans =
   10
ans =
   37

उपरोक्त गणना के बराबर ऑक्टेव निम्नलिखित है -

pkg load symbolic
symbols

x = sym("x");
y = 2*x^3 + 3*x^2 - 12*x + 17;
g = differentiate(y,x)

roots([6, 6, -12])
subs(y, x, 1), subs(y, x, -2)

ans =
   10.0
ans =
   37.0-4.6734207789940138748E-18*I

इसलिए, फ़ंक्शन f (x) = 2x 3 + 3x 2 - 12x + 17, अंतराल पर न्यूनतम और अधिकतम मान [-2,2] में 10 और 37 हैं।

विभेदक समीकरणों को हल करना

MATLAB प्रदान करता है dsolve प्रतीकात्मक रूप से अंतर समीकरणों को हल करने के लिए कमांड।

का सबसे बुनियादी रूप है dsolve एकल समीकरण का हल खोजने की कमान है

dsolve('eqn')

जहाँ eqn एक पाठ स्ट्रिंग है जिसका उपयोग समीकरण में प्रवेश करने के लिए किया जाता है।

यह एक मनमाना स्थिरांक के सेट के साथ एक प्रतीकात्मक समाधान देता है जो MATLAB C1, C2, और इसी तरह लेबल करता है।

आप समस्या के लिए प्रारंभिक और सीमा की शर्तों को भी निर्दिष्ट कर सकते हैं, क्योंकि समीकरण के बाद अल्पविराम-सीमांकित सूची -

dsolve('eqn','cond1', 'cond2',…)

Dsolve कमांड का उपयोग करने के उद्देश्य से, derivatives are indicated with a D। उदाहरण के लिए, f '(t) = -2 * f + लागत (t) जैसे समीकरण को इस प्रकार दर्ज किया जाता है -

'Df = -2*f + cos(t)'

व्युत्पन्न के क्रम द्वारा डी का पालन करके उच्चतर व्युत्पन्न का संकेत दिया जाता है।

उदाहरण के लिए समीकरण f "(x) + 2f '(x) = 5s33x को इस रूप में दर्ज किया जाना चाहिए -

'D2y + 2Dy = 5*sin(3*x)'

आइए हम पहले क्रम अंतर समीकरण का एक सरल उदाहरण लेते हैं: y '= 5y।

s = dsolve('Dy = 5*y')

MATLAB कोड निष्पादित करता है और निम्नलिखित परिणाम देता है -

s =
   C2*exp(5*t)

आइए हम एक दूसरे क्रम के अंतर समीकरण का दूसरा उदाहरण लेते हैं जैसे: y "- y = 0, y (0) = -1, y '(0) = 2।

dsolve('D2y - y = 0','y(0) = -1','Dy(0) = 2')

MATLAB कोड निष्पादित करता है और निम्नलिखित परिणाम देता है -

ans =
   exp(t)/2 - (3*exp(-t))/2

एकीकरण दो अनिवार्य रूप से विभिन्न प्रकार की समस्याओं से संबंधित है।

  • पहले प्रकार में, एक फ़ंक्शन का व्युत्पन्न दिया जाता है और हम फ़ंक्शन को ढूंढना चाहते हैं। इसलिए, हम मूल रूप से भेदभाव की प्रक्रिया को उल्टा करते हैं। इस रिवर्स प्रक्रिया को एंटी-डिफरेंशियल के रूप में जाना जाता है, या आदिम फ़ंक्शन को खोजने, या खोजने के लिएindefinite integral

  • दूसरी प्रकार की समस्याओं में बहुत बड़ी मात्रा में बहुत अधिक मात्राएँ शामिल होना और फिर मात्राओं के आकार को शून्य तक ले जाना एक सीमा है, जबकि शर्तों की संख्या अनन्तता तक होती है। इस प्रक्रिया की परिभाषा की ओर जाता हैdefinite integral

निश्चित अभिन्न का उपयोग क्षेत्र, मात्रा, गुरुत्वाकर्षण के केंद्र, जड़ता के क्षण, एक बल द्वारा किए गए कार्य और कई अन्य अनुप्रयोगों में खोजने के लिए किया जाता है।

MATLAB का उपयोग करते हुए अनिश्चितकालीन इंटीग्रल ढूँढना

परिभाषा के अनुसार, यदि किसी फ़ंक्शन f (x) का व्युत्पन्न f '(x) है, तो हम कहते हैं कि x के संबंध में f' (x) का अनिश्चितकालीन इंटीग्रेशन f (x) है। उदाहरण के लिए, चूंकि x 2 का व्युत्पन्न (x के संबंध में) 2x है, इसलिए हम कह सकते हैं कि 2x का अनिश्चितकालीन अभिन्न x 2 है

प्रतीकों में -

f'(x2) = 2x, इसलिए,

∫ 2xdx = x2.

अनिश्चित इंटीग्रल अद्वितीय नहीं है, क्योंकि एक स्थिर सी के किसी भी मूल्य के लिए x 2 + c का व्युत्पन्न भी 2x होगा।

इसे प्रतीकों में व्यक्त किया गया है -

∫ 2xdx = x2 + c

जहाँ, c को 'मनमाना स्थिरांक' कहा जाता है।

MATLAB एक प्रदान करता है intएक अभिव्यक्ति के अभिन्न गणना के लिए आदेश। किसी फ़ंक्शन के अनिश्चितकालीन अभिन्न के लिए एक अभिव्यक्ति प्राप्त करने के लिए, हम लिखते हैं -

int(f);

उदाहरण के लिए, हमारे पिछले उदाहरण से -

syms x 
int(2*x)

MATLAB उपरोक्त कथन को निष्पादित करता है और निम्नलिखित परिणाम देता है -

ans =
   x^2

उदाहरण 1

इस उदाहरण में, आइए हम कुछ सामान्य रूप से प्रयुक्त भावों के अभिन्न का पता लगाएं। एक स्क्रिप्ट फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें -

syms x n

int(sym(x^n))
f = 'sin(n*t)'
int(sym(f))
syms a t
int(a*cos(pi*t))
int(a^x)

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

ans =
   piecewise([n == -1, log(x)], [n ~= -1, x^(n + 1)/(n + 1)])
f =
sin(n*t)
ans =
   -cos(n*t)/n
   ans =
   (a*sin(pi*t))/pi
   ans =
   a^x/log(a)

उदाहरण 2

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

syms x n
int(cos(x))
int(exp(x))
int(log(x))
int(x^-1)
int(x^5*cos(5*x))
pretty(int(x^5*cos(5*x)))
int(x^-5)
int(sec(x)^2)
pretty(int(1 - 10*x + 9 * x^2))
int((3 + 5*x -6*x^2 - 7*x^3)/2*x^2)
pretty(int((3 + 5*x -6*x^2 - 7*x^3)/2*x^2))

ध्यान दें कि pretty फ़ंक्शन एक अधिक पठनीय प्रारूप में एक अभिव्यक्ति देता है।

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

ans =
   sin(x)
 
ans =
   exp(x)
 
ans =
   x*(log(x) - 1)
 
ans =
   log(x)
 
ans =
(24*cos(5*x))/3125 + (24*x*sin(5*x))/625 - (12*x^2*cos(5*x))/125 + (x^4*cos(5*x))/5 - (4*x^3*sin(5*x))/25 + (x^5*sin(5*x))/5
                                    2             4 
   24 cos(5 x)   24 x sin(5 x)   12 x  cos(5 x)   x  cos(5 x) 
   ----------- + ------------- - -------------- + ------------ 
      3125            625             125              5 
   
        3             5 
 
   4 x  sin(5 x)   x  sin(5 x) 
   ------------- + ----------- 
         25              5
 
ans =
-1/(4*x^4)
 
ans =
tan(x)
        2 
  x (3 x  - 5 x + 1)
 
ans = 
- (7*x^6)/12 - (3*x^5)/5 + (5*x^4)/8 + x^3/2
 
      6      5      4    3 
    7 x    3 x    5 x    x 
  - ---- - ---- + ---- + -- 
     12     5      8     2

MATLAB का उपयोग करके निश्चित इंटीग्रल ढूँढना

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

int फ़ंक्शन का उपयोग उन सीमाओं को पार करके निश्चित एकीकरण के लिए किया जा सकता है, जिन पर आप अभिन्न की गणना करना चाहते हैं।

की गणना करना

हम लिखते हैं,

int(x, a, b)

उदाहरण के लिए,

हम लिखने के मूल्य की गणना करने के लिए -

int(x, 4, 9)

MATLAB उपरोक्त कथन को निष्पादित करता है और निम्नलिखित परिणाम देता है -

ans =
   65/2

उपरोक्त गणना के बराबर ऑक्टेव निम्नलिखित है -

pkg load symbolic
symbols

x = sym("x");
f = x;
c = [1, 0];
integral = polyint(c);

a = polyval(integral, 9) - polyval(integral, 4);
display('Area: '), disp(double(a));

ऑक्टेव कोड निष्पादित करता है और निम्नलिखित परिणाम लौटाता है -

Area: 

   32.500

ऑक्टेव द्वारा दिए गए क्वाड () फ़ंक्शन का उपयोग करके एक वैकल्पिक समाधान दिया जा सकता है -

pkg load symbolic
symbols

f = inline("x");
[a, ierror, nfneval] = quad(f, 4, 9);

display('Area: '), disp(double(a));

ऑक्टेव कोड निष्पादित करता है और निम्नलिखित परिणाम लौटाता है -

Area: 
   32.500

उदाहरण 1

आइए एक्स-अक्ष और वक्र y = x 3 the2x + 5 के बीच के क्षेत्र की गणना करें और x = 1 और x = 2 का निर्देशन करें।

आवश्यक क्षेत्र इसके द्वारा दिया गया है -

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

f = x^3 - 2*x +5;
a = int(f, 1, 2)
display('Area: '), disp(double(a));

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

a =
23/4
Area: 
   5.7500

उपरोक्त गणना के बराबर ऑक्टेव निम्नलिखित है -

pkg load symbolic
symbols

x = sym("x");
f = x^3 - 2*x +5;
c = [1, 0, -2, 5];
integral = polyint(c);

a = polyval(integral, 2) - polyval(integral, 1);
display('Area: '), disp(double(a));

ऑक्टेव कोड निष्पादित करता है और निम्नलिखित परिणाम लौटाता है -

Area: 

   5.7500

ऑक्टेव द्वारा दिए गए क्वाड () फ़ंक्शन का उपयोग करके एक वैकल्पिक समाधान दिया जा सकता है -

pkg load symbolic
symbols

x = sym("x");
f = inline("x^3 - 2*x +5");

[a, ierror, nfneval] = quad(f, 1, 2);
display('Area: '), disp(double(a));

ऑक्टेव कोड निष्पादित करता है और निम्नलिखित परिणाम लौटाता है -

Area: 
   5.7500

उदाहरण 2

वक्र के नीचे का क्षेत्रफल ज्ञात करें: f (x) = x 2 cos (x) ≤4 ≤ x। 9 के लिए।

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

f = x^2*cos(x);
ezplot(f, [-4,9])
a = int(f, -4, 9)
disp('Area: '), disp(double(a));

जब आप फ़ाइल चलाते हैं, तो MATLAB ग्राफ़ को प्लॉट करता है -

आउटपुट नीचे दिया गया है -

a = 
8*cos(4) + 18*cos(9) + 14*sin(4) + 79*sin(9)
 
Area: 
   0.3326

उपरोक्त गणना के बराबर ऑक्टेव निम्नलिखित है -

pkg load symbolic
symbols

x = sym("x");
f = inline("x^2*cos(x)");

ezplot(f, [-4,9])
print -deps graph.eps

[a, ierror, nfneval] = quad(f, -4, 9);
display('Area: '), disp(double(a));

MATLAB बहुपत्नी शक्तियों के रूप में आदेशित गुणांक वाले पंक्ति वैक्टर के रूप में बहुपद का प्रतिनिधित्व करता है। उदाहरण के लिए, समीकरण P (x) = x 4 + 7x 3 - 5x + 9 को इस रूप में दर्शाया जा सकता है -

p = [1 7 0 -5 -5];

बहुपद का मूल्यांकन

polyvalफ़ंक्शन का उपयोग एक निर्दिष्ट मूल्य पर एक बहुपद के मूल्यांकन के लिए किया जाता है। उदाहरण के लिए, हमारे पिछले बहुपद का मूल्यांकन करने के लिएp, x = 4 पर, टाइप करें -

p = [1 7 0  -5 9];
polyval(p,4)

MATLAB उपरोक्त कथनों को निष्पादित करता है और निम्नलिखित परिणाम देता है -

ans = 693

MATLAB भी प्रदान करता है polyvalmएक मैट्रिक्स बहुपद का मूल्यांकन करने के लिए कार्य करता है। एक मैट्रिक्स बहुपद एक हैpolynomial चर के रूप में मैट्रिसेस के साथ।

उदाहरण के लिए, आइए हम एक वर्ग मैट्रिक्स X बनाएँ और X पर बहुपद p का मूल्यांकन करें -

p = [1 7 0  -5 9];
X = [1 2 -3 4; 2 -5 6 3; 3 1 0 2; 5 -7 3 8];
polyvalm(p, X)

MATLAB उपरोक्त कथनों को निष्पादित करता है और निम्नलिखित परिणाम देता है -

ans =
      2307       -1769        -939        4499
      2314       -2376        -249        4695
      2256       -1892        -549        4310
      4570       -4532       -1062        9269

बहुपद की जड़ें खोजना

rootsफ़ंक्शन एक बहुपद की जड़ों की गणना करता है। उदाहरण के लिए, हमारे बहुपद p की जड़ों की गणना करने के लिए, -

p = [1 7 0  -5 9];
r = roots(p)

MATLAB उपरोक्त कथनों को निष्पादित करता है और निम्नलिखित परिणाम देता है -

r =
   -6.8661 + 0.0000i
   -1.4247 + 0.0000i
   0.6454 + 0.7095i
   0.6454 - 0.7095i

कार्यक्रम polyजड़ों के कार्य का विलोम है और बहुपद गुणांक पर लौटता है। उदाहरण के लिए -

p2 = poly(r)

MATLAB उपरोक्त कथनों को निष्पादित करता है और निम्नलिखित परिणाम देता है -

p2 =

   Columns 1 through 3:

      1.00000 + 0.00000i   7.00000 + 0.00000i   0.00000 + 0.00000i

   Columns 4 and 5:

      -5.00000 - 0.00000i   9.00000 + 0.00000i

बहुपद वक्र फिटिंग

polyfitफ़ंक्शन एक बहुपद के गुणांक को पाता है जो कम से कम वर्गों में डेटा के एक सेट को फिट बैठता है। यदि x और y दो वैक्टर हैं जिसमें x और y डेटा को n-डिग्री बहुपद में फिट किया जाना है, तो हम लिखकर बहुपद को डेटा फिटिंग करते हैं -

p = polyfit(x,y,n)

उदाहरण

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

x = [1 2 3 4 5 6]; y = [5.5 43.1 128 290.7 498.4 978.67];   %data
p = polyfit(x,y,4)   %get the polynomial

% Compute the values of the polyfit estimate over a finer range, 
% and plot the estimate over the real data values for comparison:
x2 = 1:.1:6;          
y2 = polyval(p,x2);
plot(x,y,'o',x2,y2)
grid on

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

p =
   4.1056  -47.9607  222.2598 -362.7453  191.1250

और निम्नलिखित ग्राफ भूखंडों -

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

उदाहरण के लिए, फूरियर रूपांतरण हमें एक संकेत को आवृत्ति के एक समारोह में समय के एक समारोह के रूप में परिवर्तित करने की अनुमति देता है। लाप्लास रूपांतरण हमें एक विभेदक समीकरण को एक बीजीय समीकरण में बदलने की अनुमति देता है।

MATLAB प्रदान करता है laplace, fourier तथा fft लाप्लास, फूरियर और फास्ट फूरियर रूपांतरण के साथ काम करने की आज्ञा देता है।

लाप्लास ट्रांसफ़ॉर्म

समय एफ (टी) के एक समारोह का लाप्लास रूपांतरण निम्नलिखित अभिन्न द्वारा दिया गया है -

लाप्लास परिवर्तन को एफ (टी) से एफ (एस) के रूप में भी परिवर्तित किया जाता है। आप देख सकते हैं कि यह परिवर्तन या एकीकरण प्रक्रिया एक दूसरे चर f के साथ f (t), प्रतीकात्मक चर t के एक फ़ंक्शन को दूसरे फ़ंक्शन F (s) में परिवर्तित करती है।

लाप्लास ट्रांसफॉर्मेशन समीकरणों को बीजीय लोगों में बदल देता है। फ़ंक्शन च (t) के लाप्लास रूपांतरण की गणना करने के लिए, लिखें -

laplace(f(t))

उदाहरण

इस उदाहरण में, हम कुछ आमतौर पर उपयोग किए जाने वाले कार्यों के लाप्लास रूपांतरण की गणना करेंगे।

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

syms s t a b w

laplace(a)
laplace(t^2)
laplace(t^9)
laplace(exp(-b*t))
laplace(sin(w*t))
laplace(cos(w*t))

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

ans =
   1/s^2

ans =
   2/s^3

ans =
   362880/s^10

ans =
   1/(b + s)
  
ans =
   w/(s^2 + w^2)
  
ans =
   s/(s^2 + w^2)

उलटा लाप्लास ट्रांसफॉर्म

MATLAB हमें कमांड का उपयोग करके उलटा लाप्लास रूपांतरण की गणना करने की अनुमति देता है ilaplace

उदाहरण के लिए,

ilaplace(1/s^3)

MATLAB उपरोक्त कथन को निष्पादित करेगा और परिणाम प्रदर्शित करेगा -

ans =
   t^2/2

उदाहरण

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

syms s t a b w

ilaplace(1/s^7)
ilaplace(2/(w+s))
ilaplace(s/(s^2+4))
ilaplace(exp(-b*t))
ilaplace(w/(s^2 + w^2))
ilaplace(s/(s^2 + w^2))

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

ans =
   t^6/720

ans =
   2*exp(-t*w)

ans =
   cos(2*t)

ans =
   ilaplace(exp(-b*t), t, x)

ans =
   sin(t*w)

ans =
   cos(t*w)

फूरियर रूपांतरण

फूरियर आमतौर पर समय, एफ (टी) के एक गणितीय कार्य को एक नए फ़ंक्शन में बदल देता है, जिसे कभी-कभी या एफ द्वारा निरूपित किया जाता है, जिसका तर्क प्रति सेकंड साइकल / एस (हर्ट्ज) या रेडियन की इकाइयों के साथ आवृत्ति है। तब नए फ़ंक्शन को फूरियर रूपांतरण और / या फ़ंक्शन के आवृत्ति स्पेक्ट्रम के रूप में जाना जाता है।

उदाहरण

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

syms x 
f = exp(-2*x^2);     %our function
ezplot(f,[-2,2])     % plot of our function
FT = fourier(f)      % Fourier transform

जब आप फ़ाइल चलाते हैं, तो MATLAB निम्नलिखित ग्राफ को प्लॉट करता है -

निम्न परिणाम प्रदर्शित किया जाता है -

FT =
   (2^(1/2)*pi^(1/2)*exp(-w^2/8))/2

फूरियर रूपांतरण के रूप में प्लॉटिंग -

ezplot(FT)

निम्नलिखित ग्राफ देता है -

उलटा फूरियर रूपांतरण

MATLAB प्रदान करता है ifourierकिसी फ़ंक्शन के व्युत्क्रम फूरियर रूपांतरण की गणना के लिए कमांड। उदाहरण के लिए,

f = ifourier(-2*exp(-abs(w)))

MATLAB उपरोक्त कथन को निष्पादित करेगा और परिणाम प्रदर्शित करेगा -

f =
   -2/(pi*(x^2 + 1))

GNU ऑक्टेव MATLAB की तरह एक उच्च स्तरीय प्रोग्रामिंग भाषा है और यह MATLAB के साथ ज्यादातर संगत है। इसका उपयोग संख्यात्मक अभिकलन के लिए भी किया जाता है।

ऑक्टेव में MATLAB के साथ निम्नलिखित सामान्य विशेषताएं हैं -

  • मैट्रिसेस मौलिक डेटा प्रकार हैं
  • इसमें जटिल संख्याओं के लिए अंतर्निहित समर्थन है
  • इसमें अंतर्निहित गणित कार्य और पुस्तकालय हैं
  • यह उपयोगकर्ता द्वारा परिभाषित कार्यों का समर्थन करता है

GNU ऑक्टेव भी स्वतंत्र रूप से पुनर्वितरण सॉफ्टवेयर है। आप नि: शुल्क सॉफ्टवेयर फाउंडेशन द्वारा प्रकाशित के रूप में इसे GNU जनरल पब्लिक लाइसेंस (GPL) की शर्तों के तहत पुनर्वितरित और / या संशोधित कर सकते हैं।

MATLAB बनाम ऑक्टेव

अधिकांश MATLAB प्रोग्राम ऑक्टेव में चलते हैं, लेकिन कुछ ऑक्टेव प्रोग्राम MATLAB में नहीं चल सकते हैं क्योंकि, ऑक्टेव कुछ सिंटैक्स की अनुमति देता है जो MATLAB नहीं करता है।

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

संगत उदाहरण

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

यह उदाहरण फ़ंक्शन g = xe - (x 2 + y 2 ) के लिए 3D सतह मानचित्र बनाता है । एक स्क्रिप्ट फ़ाइल बनाएँ और निम्न कोड टाइप करें -

[x,y] = meshgrid(-2:.2:2);
g = x .* exp(-x.^2 - y.^2);
surf(x, y, g)
print -deps graph.eps

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

गैर-संगत उदाहरण

हालांकि MATLAB की सभी मुख्य कार्यक्षमता ऑक्टेव में उपलब्ध है, उदाहरण के लिए, कुछ अंतर और एकीकरण गणना के लिए कुछ कार्यक्षमता हैं, जो दोनों भाषाओं में बिल्कुल मेल नहीं खाती हैं। इस ट्यूटोरियल ने दोनों प्रकार के उदाहरण देने की कोशिश की है जहाँ वे अपने वाक्यविन्यास में भिन्न होते हैं।

निम्नलिखित उदाहरण पर विचार करें जहां MATLAB और ऑक्टेव वक्र के क्षेत्र को प्राप्त करने के लिए विभिन्न कार्यों का उपयोग करते हैं: f (x) = x 2 cos (x) −4 ≤ x L के लिए 9. निम्नलिखित कोड का MATLAB संस्करण है -

f = x^2*cos(x);
ezplot(f, [-4,9])
a = int(f, -4, 9)
disp('Area: '), disp(double(a));

जब आप फ़ाइल चलाते हैं, तो MATLAB ग्राफ़ को प्लॉट करता है -

निम्न परिणाम प्रदर्शित किया जाता है

a =
8*cos(4) + 18*cos(9) + 14*sin(4) + 79*sin(9)
 
Area: 
   0.3326

लेकिन ऑक्टेव में एक ही वक्र का क्षेत्र देने के लिए, आपको इसका उपयोग करना होगा symbolic पैकेज निम्नानुसार है -

pkg load symbolic
symbols

x = sym("x");
f = inline("x^2*cos(x)");

ezplot(f, [-4,9])
print -deps graph.eps

[a, ierror, nfneval] = quad(f, -4, 9);
display('Area: '), disp(double(a));

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

यह आपको MATLAB एल्गोरिदम को मॉडल में शामिल करने के साथ-साथ आगे के विश्लेषण के लिए MATLAB में सिमुलेशन परिणामों को निर्यात करने की अनुमति देता है।

Simulink का समर्थन करता है -

  • सिस्टम-स्तरीय डिज़ाइन
  • simulation
  • स्वचालित कोड पीढ़ी
  • एम्बेडेड सिस्टम का परीक्षण और सत्यापन

मैथवर्क्स और तीसरे पक्ष के हार्डवेयर और सॉफ्टवेयर उत्पादों द्वारा प्रदान किए गए कई अन्य ऐड-ऑन उत्पाद हैं जो सिमुलिंक के साथ उपयोग के लिए उपलब्ध हैं।

निम्नलिखित सूची उनमें से कुछ का संक्षिप्त विवरण देती है -

  • Stateflow राज्य मशीनों और प्रवाह चार्ट विकसित करने की अनुमति देता है।

  • Simulink Coder स्वचालित रूप से सिस्टम के वास्तविक समय के कार्यान्वयन के लिए सी स्रोत कोड की पीढ़ी की अनुमति देता है।

  • xPC Target के साथ साथ x86-based real-time systems भौतिक प्रणाली पर वास्तविक समय में सिमुलिंक और स्टेटफ्लो मॉडल का अनुकरण और परीक्षण करने के लिए एक वातावरण प्रदान करें।

  • Embedded Coder विशिष्ट एम्बेडेड लक्ष्य का समर्थन करता है।

  • HDL Coder स्वचालित रूप से संश्लेषित VHDL और वेरिलॉग उत्पन्न करने की अनुमति देता है।

  • SimEvents मॉडलिंग कतार प्रणाली के लिए ग्राफिकल बिल्डिंग ब्लॉकों का एक पुस्तकालय प्रदान करता है।

सिमुलिंक मॉडलिंग शैली की जाँच, आवश्यकताओं के पारगम्यता और मॉडल कवरेज विश्लेषण के माध्यम से मॉडल के व्यवस्थित सत्यापन और सत्यापन में सक्षम है।

Simulink Design Verifier आपको डिज़ाइन त्रुटियों की पहचान करने और मॉडल जाँच के लिए परीक्षण केस परिदृश्य उत्पन्न करने की अनुमति देता है।

Simulink का उपयोग करना

Simulink खोलने के लिए, MATLAB कार्य स्थान में टाइप करें -

simulink

Simulink के साथ खुलता है Library Browser। लाइब्रेरी ब्राउज़र का उपयोग सिमुलेशन मॉडल के निर्माण के लिए किया जाता है।

बाईं ओर खिड़की के फलक पर, आपको विभिन्न प्रणालियों के आधार पर वर्गीकृत कई पुस्तकालय मिलेंगे, जिनमें से प्रत्येक पर क्लिक करके दाएं विंडो फलक पर डिज़ाइन ब्लॉक प्रदर्शित होंगे।

बिल्डिंग मॉडल

एक नया मॉडल बनाने के लिए, क्लिक करें Newलाइब्रेरी ब्राउजर के टूलबार पर बटन। यह एक नया शीर्षक रहित मॉडल विंडो खोलता है।

एक Simulink मॉडल एक ब्लॉक आरेख है।

मॉडल तत्वों को लाइब्रेरी ब्राउज़र से उपयुक्त तत्वों का चयन करके और उन्हें मॉडल विंडो में खींचकर जोड़ा जाता है।

वैकल्पिक रूप से, आप मॉडल तत्वों को कॉपी कर सकते हैं और उन्हें मॉडल विंडो में पेस्ट कर सकते हैं।

उदाहरण

अपनी परियोजना बनाने के लिए सिमुलिंक लाइब्रेरी से आइटम खींचें और छोड़ें।

इस उदाहरण के प्रयोजन के लिए, सिमुलेशन के लिए दो ब्लॉकों का उपयोग किया जाएगा - ए Source (एक संकेत) और ए Sink(एक स्कोप)। एक सिग्नल जनरेटर (स्रोत) एक एनालॉग सिग्नल उत्पन्न करता है, जिसे तब स्कोप (सिंक) द्वारा ग्राफिक रूप से देखा जाएगा।

लाइब्रेरी से प्रोजेक्ट विंडो तक आवश्यक ब्लॉकों को खींचकर शुरू करें। फिर, उन ब्लॉकों को एक साथ जोड़ते हैं जो कनेक्टर्स से कनेक्टर्स को एक ब्लॉक से दूसरे ब्लॉक पर खींचकर किया जा सकता है।

आइए हम मॉडल में 'साइन वेव' ब्लॉक खींचें।

लाइब्रेरी से 'सिंक' चुनें और मॉडल में 'स्कोप' ब्लॉक खींचें।

साइन वेव ब्लॉक के आउटपुट से सिग्नल लाइन को स्कोप ब्लॉक के इनपुट तक खींचें।

'दबाकर सिमुलेशन चलाएँRun'बटन, सभी मापदंडों को डिफ़ॉल्ट रखते हुए (आप उन्हें सिमुलेशन मेनू से बदल सकते हैं)

आपको नीचे दिए गए ग्राफ को स्कोप से प्राप्त करना चाहिए।