MATLAB - बीजगणित

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

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

MATLAB में मूल बीजगणितीय समीकरणों को हल करना

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

उदाहरण के लिए, x को समीकरण x -5 = 0 में हल करते हैं

solve('x-5=0')

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

ans =
   5

आप हल फ़ंक्शन को निम्न के रूप में भी कॉल कर सकते हैं -

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

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

y =
   5

आप समीकरण के दाहिने हाथ को भी शामिल नहीं कर सकते हैं -

solve('x-5')

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

ans =
   5

यदि समीकरण में कई प्रतीक शामिल हैं, तो MATLAB डिफ़ॉल्ट रूप से मानता है कि आप x के लिए हल कर रहे हैं, हालांकि, हल फ़ंक्शन का दूसरा रूप है -

solve(equation, variable)

जहाँ, आप चर का भी उल्लेख कर सकते हैं।

उदाहरण के लिए, हम समीकरण v - u - 3t 2 = 0 को हल करते हैं , v के लिए। इस मामले में, हमें लिखना चाहिए -

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

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

ans =
   3*t^2 + u

ऑक्टेव में बुनियादी बीजगणितीय समीकरणों को हल करना

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

उदाहरण के लिए, x को समीकरण x -5 = 0 में हल करते हैं

roots([1, -5])

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

ans = 5

आप हल फ़ंक्शन को निम्न के रूप में भी कॉल कर सकते हैं -

y = roots([1, -5])

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

y = 5

MATLAB में द्विघात समीकरण को हल करना

solveफ़ंक्शन उच्च क्रम समीकरणों को भी हल कर सकता है। इसका उपयोग अक्सर द्विघात समीकरणों को हल करने के लिए किया जाता है। फ़ंक्शन किसी सरणी में समीकरण की जड़ों को लौटाता है।

निम्न उदाहरण द्विघात समीकरण को हल करता है x 2 -7x +12 = 0. एक स्क्रिप्ट फ़ाइल बनाएँ और निम्न कोड टाइप करें -

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));

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

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

ऑक्टेव में द्विघात समीकरणों को हल करना

निम्नलिखित उदाहरण अष्टक में द्विघात समीकरण x 2 -7x +12 = 0 को हल करता है । एक स्क्रिप्ट फ़ाइल बनाएँ और निम्न कोड टाइप करें -

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

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

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

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

MATLAB में उच्च आदेश समीकरणों को हल करना

solveफ़ंक्शन उच्च क्रम समीकरणों को भी हल कर सकता है। उदाहरण के लिए, आइए एक घन समीकरण को हल करें (x-3) 2 (x-7) = 0

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

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

ans =
   3
   3
   7

उच्च क्रम समीकरणों के मामले में, जड़ें लंबे समय तक कई शर्तों से युक्त होती हैं। आप ऐसी जड़ों के संख्यात्मक मूल्य को दोहरे में परिवर्तित करके प्राप्त कर सकते हैं। निम्नलिखित उदाहरण चौथे क्रम समीकरण x 4 - 7x 3 + 3x 2 - 5x + 9 = 0 को हल करता है ।

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

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)));

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

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

कृपया ध्यान दें कि अंतिम दो जड़ें जटिल संख्याएँ हैं।

ऑक्टेव में उच्च आदेश समीकरणों को हल करना

निम्नलिखित उदाहरण चौथे क्रम समीकरण x 4 - 7x 3 + 3x 2 - 5x + 9 = 0 को हल करता है ।

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

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)));

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

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

MATLAB में समीकरणों की प्रणाली का समाधान

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

आइए हम समीकरणों को हल करते हैं -

5x + 9y = 5

3x - 6y = 4

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

s = solve('5*x + 9*y = 5','3*x - 6*y = 4');
s.x
s.y

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

ans =
   22/19
ans =
   -5/57

उसी तरह, आप बड़े रैखिक प्रणालियों को हल कर सकते हैं। समीकरणों के निम्नलिखित सेट पर विचार करें -

x + 3y -2z = 5

3x + 5y + 6z = 7

2x + 4y + 3z = 8

ऑक्टेव में समीकरणों की प्रणाली का समाधान

'N' अज्ञात में 'n' रैखिक समीकरणों की प्रणाली को हल करने के लिए हमारे पास थोड़ा अलग दृष्टिकोण है। आइए इस प्रयोग को प्रदर्शित करने के लिए एक सरल उदाहरण लेते हैं।

आइए हम समीकरणों को हल करते हैं -

5x + 9y = 5

3x - 6y = 4

रैखिक समीकरणों की ऐसी प्रणाली को एकल मैट्रिक्स समीकरण एक्स = बी के रूप में लिखा जा सकता है, जहां ए गुणांक मैट्रिक्स है, बी स्तंभ वेक्टर है जिसमें रैखिक समीकरणों के दाहिने हाथ हैं और x स्तंभ वेक्टर है जो समाधान के रूप में प्रतिनिधित्व करता है। नीचे कार्यक्रम में दिखाया गया है -

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

A = [5, 9; 3, -6];
b = [5;4];
A \ b

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

ans =

   1.157895
  -0.087719

उसी तरह, आप बड़े रैखिक प्रणालियों को हल कर सकते हैं जैसा कि नीचे दिया गया है -

x + 3y -2z = 5

3x + 5y + 6z = 7

2x + 4y + 3z = 8

MATLAB में समीकरणों का विस्तार और संग्रह करना

expand और यह collectफ़ंक्शन क्रमशः एक समीकरण का विस्तार और संग्रह करता है। निम्नलिखित उदाहरण अवधारणाओं को प्रदर्शित करता है -

जब आप कई प्रतीकात्मक कार्यों के साथ काम करते हैं, तो आपको यह घोषित करना चाहिए कि आपके चर प्रतीकात्मक हैं।

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

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))

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

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

ऑक्टेव में विस्तार और एकत्रित समीकरण

आपके पास होना चाहिए symbolic पैकेज, जो प्रदान करता है expand और यह collectक्रमशः एक समीकरण का विस्तार और संग्रह करने के लिए कार्य करते हैं। निम्नलिखित उदाहरण अवधारणाओं को प्रदर्शित करता है -

जब आप कई प्रतीकात्मक कार्यों के साथ काम करते हैं, तो आपको यह घोषणा करनी चाहिए कि आपके चर प्रतीकात्मक हैं लेकिन ऑक्टेव में प्रतीकात्मक चर को परिभाषित करने के लिए अलग-अलग दृष्टिकोण हैं। के उपयोग पर ध्यान देंSin तथा Cos, जिसे प्रतीकात्मक पैकेज में भी परिभाषित किया गया है।

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

% 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)

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

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)

बीजगणितीय अभिव्यक्तियों का गुणन और सरलीकरण

factor समारोह एक अभिव्यक्ति का कारक है और simplifyफ़ंक्शन एक अभिव्यक्ति को सरल करता है। निम्नलिखित उदाहरण अवधारणा को प्रदर्शित करता है -

उदाहरण

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

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))

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

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