Solving system of equations? - Сообщения
I'm not figuring out how to symbolically solve a non-linear system of equations. I created a mostly blank Wiki page in the hopes that someone could help to create a solution:
https://smath.com/wiki/Solving%20Non-Linear%20Systems%20of%20Equations.ashx
In MathCad this would be a Given / Solve block kind of thing.
Very pleased with SMath so far; Excellent work! Very much looking forward to further development in creating documents with it.
325 сообщений из 2 052 понравились и 1 не понравились пользователям.
Группа: Moderator
WroteI'm not figuring out how to symbolically solve a non-linear system of equations.
That is not implemented yet.
Regards,
Radovan
Check out the last four links in this web site:
http://www.neng.usu.edu/cee/faculty/gurro/Classes/ClassNotesAllClasses/CEE3510/Lectures/CEE3510_Lecture15a.htm
They are:
Pipes converging at a junction - pdf file: see pages 5-12 in this pdf file
Pipes converging at a junction (SMath Studio files): SMath Studio file with examples
Creating function "fNewtonm.sm" to solve multiple equations OPTIONAL VIDEO - explains how to create the code snippet for the function
Using function "fNewtonm.sm" to solve problems of pipe at a junction VIDEO - shows how to use SMath Studio to solve junction problems
Note: the "norme" function in the most recent version of SMath Studio (July 2012) is not working properly, so you'll have to implement your own "norme" function, e.g.:
NormE(F):line(nn:length(F),sqrt(sum((el(F,k)^2),k,1,nn)),2,1)
NOTE: copy the line above and paste it in your SMath Studio worksheet, but not as text.
The function that solves the system of non-linear equations is:
fNewtonm(f(x),xs,x0,ε,Nmax):line(fJ(x):Jacob(f(x),xs),k:0,xG:x0,while(((k≤Nmax)&(NormE(f(xG))>ε)),line(JJ:eval(fJ(xG)),JJI:eval(invert(JJ)),fxG:eval(f(xG)),DxG:eval(JJI*fxG),xGp1:eval(xG-DxG),k:k+1,xG:xGp1,7,1)),mat(xG,k,2,1),5,1)
Again, copy the line above and paste it in your SMath Studio worksheet, but not as text.
Find the file: JeppsonCh01Prob13MomentumApplication.zip in the File Manager of the SMath Studio wiki for an example
http://www.neng.usu.edu/cee/faculty/gurro/Classes/ClassNotesAllClasses/CEE3510/LectureNotes/AdditionalPipelineProblems/SimultaneousEQuationsInSMathStudio.pdf
But make sure to use your own "norme" function:
NormE(F):line(nn:length(F),sqrt(sum((el(F,k)^2),k,1,nn)),2,1)
325 сообщений из 2 052 понравились и 1 не понравились пользователям.
Группа: Moderator
You are right about norme(). Some strange error - Atempted to read or write protected memory...This must be a bug, I think.
Moreover, your fNewtonm() function is very useful in order to solve the system of nonlinear equations numerically by Newton method although there is roots() function in SMath. Actually, sometimes there is no other way then writing our own functions (often quite uneficient and slow) because of the problems with roots() and solve() functions. There is still a drawback in fNewtonm() because your function argument "xs" must have vector named elements as "x" actually,
[MATH=eng]xs:mat(el(x,1),el(x,2),2,1)[/MATH]
because of this line in the function
[MATH=eng]fJ(x):Jacob(f(x),xs)[/MATH]
this is not your fault but the way SMath and Jacob() function are working. To make long story short - If we want to use your function we can not use variables named "x" before its use.
I was convinced many times and reported at this Forum problems with nonlinear equations solvers roots() - system of nonlin. equations/single equations , solve() - single nonlinear equations:
http://en.smath.info/forum/yaf_postst1263_solve---and-roots-----again.aspx
http://en.smath.info/forum/yaf_postst1253_roots---problems.aspx
Andrey did his best to resolve all the problems with those root finding functions but they are still not good enough. Unfortunately, there is still no library with strictly numerical solvers in SMath and, as the time is passing, I do not believe if there would ever be any. On the other hand, making plugins by myself is far beyond my capabilities. To be honest, I got frustrated many times because of that
 .
 . Regards,
Radovan
After I posted my earlier message highlighting the use of "fNewtonm", I found your posting about using "roots", and I'm convinced it's a simpler approach. I'm winding down the use of "fNewtonm" in my classes and replacing it with "roots".
Thanks,
Gilberto
325 сообщений из 2 052 понравились и 1 не понравились пользователям.
Группа: Moderator
From my experience, I have to point out once more that roots() will fail sometimes and your function using Newtomn-Raphson will sometimes do the job in that case. Unfortunately, I could not solve many of my class problems with roots() when even few simple Newton-Raphson iterations will solve the same system. It might be quite cumbersome and quite frustrating sometimes. Therefore I pointed out (desperately) many times that SMath needs some more powerful and robust nonlinear solvers made from some well known numerical libraries. Unfortunately, it seems that this is not likely to happen due to the SMath internal structure. Therefore, roots() and solve() are the only two functions we can count on at the moment.
Regards,
Radovan
P.S Just few minutes ago I've seen this post Broyden().
325 сообщений из 2 052 понравились и 1 не понравились пользователям.
Группа: Moderator
WroteAfter I posted my earlier message highlighting the use of "fNewtonm", I found your posting about using "roots", and I'm convinced it's a simpler approach. I'm winding down the use of "fNewtonm" in my classes and replacing it with "roots".
At the same time we posted here, there were few additional nonlinear solvers posted here Non-Linear solvers . You might find them useful as I do

By the way, If you want to use your fNewtonm() function without the mentioned restriction about the vector of variables names (must be "x" ), here is a bit changed version. There is one parameter excluded (vector of unknows).
[MATH=eng]fNewtonm(f(x#),x0,ε,Nmax):line(fJ(f(x#),x#):line(n:length(x#),for(i,range(1,n),for(j,range(1,n),el(J,i,j):diff(el(f(x#),i),el(x#,j)))),J,3,1),k:0,xG:x0,while(((k≤Nmax)&(NormE(f(xG))>ε)),line(JJ:eval(fJ(f(x#),xG)),JJI:eval(invert(JJ)),fxG:eval(f(xG)),DxG:eval(JJI*fxG),xGp1:eval(xG-DxG),k:k+1,xG:xGp1,7,1)),mat(xG,k,2,1),5,1)[/MATH]
[MATH=eng]F(X):mat(el(X,1)+el(X,2)+el(X,3)-6,el(X,1)*el(X,2)*el(X,3)-6,el(X,1)^2+el(X,2)^2+el(X,3)^2-14,3,1)[/MATH]
[MATH=eng]fNewtonm(F(x#),x0,ε,Nmax)=mat(mat(2,1,3,3,1),5,2,1)[/MATH]
Regards,
Radovan
fWNewton-1.sm (11,07 КиБ) скачан 579 раз(а).
Thanks for the updated version of "fNewtonm". I'm going to use it in my classes.
Gilberto Urroz
325 сообщений из 2 052 понравились и 1 не понравились пользователям.
Группа: Moderator
 ,
 ,Regards,
Radovan
- Новые сообщения
- Нет новых сообщений
