Solving complex nonpolynomial equation and find all complex roots
Mostra commenti meno recenti
I am trying to solve a nonpolynomial equation like z^n*exp(a*(1-z))+a_0z^0+a_1z^1+...+a_nz^n=0. z is within or on the unit circle in complex plane. When using the solve(eqn,var) function, it only returns one numeric solution. Actually, the above equation will have n roots in z<=1. I checked the feature of "solve" function:"The numeric solver does not try to find all numeric solutions for this equation. Instead, it returns only the first solution it finds."
Can anyone help me solve all n roots of complex nonpolynomial equations?
4 Commenti
Walter Roberson
il 3 Ott 2016
In the exp(a*(1-z)) part, is that a vector a like in the a_* part? So that each a_k would occur twice in the sum, once multiplied by z^k and once z^n*exp(a_k*(1-z)) ?
Xiang Zhong
il 3 Ott 2016
Walter Roberson
il 4 Ott 2016
The coefficients that I tested with had more than n roots for this, even if you filtered down to abs(z) <= 1 . The exp() term introduces the possibility of two values (possibly related by LambertW in theory) modifying the normal n roots you would expect for order n.
Is there a specific limited range for the a_[i] coefficients?
sasahan mawani
il 17 Ott 2018
Modificato: Walter Roberson
il 25 Ott 2018
Walter Roberson , can you help me to solve a similar problem? https://www.mathworks.com/matlabcentral/answers/424395-find-all-complex-roots-of-complex-nonpolynomial-equation
Risposte (1)
Massimo Zanetti
il 3 Ott 2016
3 voti
To find all solutions you need global solvers, but they don't exist.. One thing that you can do is trying to initialize fsolve with different guesses, so that at least you can try to find some different solutions. Suggestion: try to start the solver with points equally spaced on the unit circle boundary.
Categorie
Scopri di più su Numerical Integration and Differentiation in Centro assistenza e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!