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'बटन, सभी मापदंडों को डिफ़ॉल्ट रखते हुए (आप उन्हें सिमुलेशन मेनू से बदल सकते हैं)
आपको नीचे दिए गए ग्राफ को स्कोप से प्राप्त करना चाहिए।