solve an equation by iterration

Hello everyone!
I haven't been using matlab for a while and I struggle on a simple equation.
I need to obtain this result: Sigma = solve( Sigma== Sigma0*(1+k*(Epsilon-Sigma/E))^n; ) All parameters sigma0, k, Epsilon, E and n=0.2; are known. The only reason for witch I need matlab is the fact that sigma (the unknown), is on both side of the equation, and I need a iterative solver.
I though about the ode45 function but I can not find a example that fit's what I want to obtain. if I am not mistaken, I can find the derivative of the function.
dSigma= -n*Sigma0*(1+k*(Epsilon-Sigma/E))^(n-1)*(k/E)
Can someone tell me the few lines required to solve this? Thank you!

Respuestas (2)

Massimo Zanetti
Massimo Zanetti el 8 de Oct. de 2016

2 votos

Put Sigma in the other side of the equation by changing it sign, and then use fsolve. https://it.mathworks.com/help/optim/ug/fsolve.html

1 comentario

Brice Thomas
Brice Thomas el 11 de Oct. de 2016
I still strugle, could you give a example of code? As I detailled in the answer.
Thank you!

Iniciar sesión para comentar.

Brice Thomas
Brice Thomas el 8 de Oct. de 2016

0 votos

Sorry, I struggled one hour one this simple problem without seeing the program works at the end of the day...
I decided to make a simple example to test the fsolve, but even here, it does not compile and give me my root.
Here is a screen-shot of the example and the code.
function [r] = H(X) % a general function that take imput: [0:0.01:4] and must give me the % roots of sine (X) on the interval.
function [ Y ] = Test1( X )
Y=(log(X)-2); plot(X,Y); end
function [Z]=Myroot(X) X0=0.3; Z=fsolve(Test1(X),X0) end
r=Myroot(X) end
My real problem requires only for me to find the root of the expression. For this I wanted to make a function and solve it. But as I said, I strugle. Maybe helping pointing what is wrong here will help me on the other problem.
Thank you!

2 comentarios

John D'Errico
John D'Errico el 8 de Oct. de 2016
Please stop adding answers every time you make a comment. This is not an answer. There is a button to make a comment. Use it.
Torsten
Torsten el 11 de Oct. de 2016
Use
Z=fsolve(@Test1,X0)
instead of
Z=fsolve(Test1(X),X0)
Best wishes
Torsten.

Iniciar sesión para comentar.

Categorías

Más información sobre Mathematics en Centro de ayuda y File Exchange.

Preguntada:

el 8 de Oct. de 2016

Comentada:

el 11 de Oct. de 2016

Community Treasure Hunt

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

Start Hunting!

Translated by