Numerical Solution

조회 수: 1 (최근 30일)
Abdulaziz
Abdulaziz 2012년 5월 29일
Hi everybody,
I have an equation which is:
i*q=k*sin(q)
I need to use the matlab to find its roots. I want to set a specific values of k like (0.25, 0.5, 1, 2, 3) and find the values of q each time. Thanks in advance folks.

채택된 답변

Teja Muppirala
Teja Muppirala 2012년 6월 22일
Ok, your "q" will have an imaginary component, so you cannot use fzero directly. You can, however, solve it using fsolve, where you treat q as a 2-element vector containing the real and imaginary parts.
k = 4;
f = @(q) 1i.*[q(1) + 1i*q(2)]-k.*sin([q(1) + 1i*q(2)]);
x0 = [2; 0.5]
fsolve(@(q) norm(f(q)), x0)
This finds a zero at roughly [3; -0.7]. But since there are multiple minima, the result will depend on the initial conditions.
Note that you can make a plot of f, to visually see roughly where the zeros are. This will help you choose initial conditions.
k = 4;
f = @(q1,q2) 1i.*[q1 + 1i*q2]-k.*sin([q1 + 1i*q2]);
[Q1,Q2] = ndgrid(-10:.2:10);
surf(Q1,Q2, log(abs(f(Q1,Q2))));
  댓글 수: 1
Teja Muppirala
Teja Muppirala 2012년 6월 22일
Just as a note, instead of fsolve, fminsearch would work just as well.

댓글을 달려면 로그인하십시오.

추가 답변 (2개)

Walter Roberson
Walter Roberson 2012년 5월 29일
fsolve() or fzero() or one of the minimizers.
  댓글 수: 2
Abdulaziz
Abdulaziz 2012년 6월 21일
Hi Walter,
Tried, tried, and tried, but totally confused. Could you please help me applying fsolve() or fzero() in my case
Thanks again
Walter Roberson
Walter Roberson 2012년 6월 22일
fsolve() cannot deal directly with complex functions. Please see
http://www.mathworks.com/matlabcentral/answers/41458-fsolve-and-complex-solution

댓글을 달려면 로그인하십시오.


Image Analyst
Image Analyst 2012년 6월 21일
Funny, I just copied the example from the help, and never having used fzero before myself, got the answer in about 5 seconds:
i=2 % Pick some sample values.
k=4
f = @(q)i.*q-k.*sin(q); % Replace example equation with Abdulaziz's
% Then find the zero near 2:
z = fzero(f,2)
z = 1.8955
  댓글 수: 1
Abdulaziz
Abdulaziz 2012년 6월 22일
hi,
I would like to thank you for helping me, but my i here is not a number it represents a complex number or component. Tried what you did, and this what I got:
k=4
f = @(q)1i.*q-k.*sin(q); % Replace example equation with Abdulaziz's
% Then find the zero near 2:
z = fzero(f,2)
k =
4
Error using fzero (line 309)
Function value at starting guess must be finite and real.

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Solver Outputs and Iterative Display에 대해 자세히 알아보기

태그

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by