Mathcad Toolbox - Contains analogs of functions from Mathcad - Сообщения





Contents:
DocumentDirectory(1) - Gets the fully qualified path of the current document.
GetFolderPath(1) - Gets the path to the system special folder identified by the specified enumeration.
GETWAVINFO(1) - Creates a vector with four elements containing information about file.
interp(4) - (vs,vx,vy,x) returns an interpolated value at x from the coefficients in vector vs, and the original data in vx and vy.
Play(1) - Play sound file.
pspline(2) - (vx,vy) returns a vector of second derivatives to build a cubic spline parabolic at the endpoints.
pspline(3) - (vx,vy,x) returns a vector of second derivatives to build a cubic spline parabolic at the endpoints.
lspline(2) - (vx,vy) returns a vector of second derivatives to build a cubic spline linear at the endpoints.
lspline(3) - (vx,vy,x) returns a vector of second derivatives to build a cubic spline linear at the endpoints.
READBIN(6) - ( file, type, endian, cols, skip, maxrows ) returns an array containing the binary data in file.
READBMP(1) - Creates an array containing a grayscale representation of a bitmap format image file.
READRGB(1) - Creates an array containing a red-green-blue packed matrix representation of the image file.
READWAV(1) - Creates a matrix containing signal amplitudes in file.
READ_BLUE(1) - Returns a matrix representing the RGB blue component of the image in file.
READ_GREEN(1) - Returns a matrix representing the RGB green component of the image in file.
READ_IMAGE(1) - Creates an array containing a grayscale representation of the image file.
READ_RED(1) - Returns a matrix representing the RGB red component of the image in file.
rfile(2) - ( path, filename ) Reads an expression from the file.
Rkadapt(3) - (ode,y(x),xmax) uses the Runge-Kutta-Fehlberg method (RKF45).
Rkadapt(4) - (ode,y(x),xmax,steps) uses the Runge-Kutta-Fehlberg method (RKF45).
Rkadapt(5) - (ics,xmin,xmax,steps,D(x,y)) uses the Runge-Kutta-Fehlberg method (RKF45).
rkfixed(3) - (ode,y(x),xmax) uses the fourth-order Runge-Kutta fixed-step method.
rkfixed(4) - (ode,y(x),xmax,steps) uses the fourth-order Runge-Kutta fixed-step method.
rkfixed(5) - (ics,xmin,xmax,steps,D(x,y)) uses the fourth-order Runge-Kutta fixed-step method.
wfile(3) - ( value, path, filename ) Writes the expression to the file.
WRITEBIN(4) - ( file, type, endian, M ) writes an array of scalars to the binary data file named file.
WRITEWAV(4) - ( file, s, b, M ) Creates a WAV signal file out of a matrix.
Examples:





7-13-Three-Planets (Mathcad Block).sm (34,77 КиБ) скачан 943 раз(а).
7-13-Three-Planets (Mathcad Block).pdf (57,94 КиБ) скачан 538 раз(а).
7-13-Three-Planets 2 (Mathcad Block).sm (30,04 КиБ) скачан 812 раз(а).
7-13-Three-Planets 2 (Mathcad Block).pdf (54,79 КиБ) скачан 440 раз(а).
7-13-Three-Planets 3 (Mathcad Block).sm (25,98 КиБ) скачан 798 раз(а).
7-13-Three-Planets 3 (Mathcad Block).pdf (55,99 КиБ) скачан 456 раз(а).
7-13-Three-Planets 4 (Mathcad Block).sm (30,7 КиБ) скачан 789 раз(а).
7-13-Three-Planets 4 (Mathcad Block).pdf (73,04 КиБ) скачан 443 раз(а).
7-13-Three-Planets 5 (Mathcad Block).sm (26,36 КиБ) скачан 868 раз(а).
7-13-Three-Planets 5 (Mathcad Block).pdf (61,72 КиБ) скачан 459 раз(а).
7-13-Three-Planets 6 (Mathcad Block).sm (26,11 КиБ) скачан 834 раз(а).
7-13-Three-Planets 6 (Mathcad Block).pdf (67,28 КиБ) скачан 430 раз(а).
Utility for call dsolvers for initial and boundary values problems from a solver block.
Mathcad Block. RKA (Razonar).sm (59 КиБ) скачан 804 раз(а).
Mathcad Block. RKA (Razonar).pdf (66,32 КиБ) скачан 431 раз(а).
RKA.sm (308,62 КиБ) скачан 890 раз(а). (last version)
RKA.pdf (931,16 КиБ) скачан 648 раз(а).
See also:
● [topic=17088]Intel ODE Solver Library[/topic]
● [topic=1918]DotNumerics[/topic]
● [topic=13809]SADEL[/topic]
● [topic=1970]Matlab C++ Math Library[/topic]
● [topic=17063]OSLO[/topic]
● [topic=17067]lsoda[/topic]
● [topic=1997]GNU Scientific Library (GSL)[/topic]
ODE_manual.pdf (239,74 КиБ) скачан 1119 раз(а).
325 сообщений из 2 052 понравились и 1 не понравились пользователям.
Группа: Moderator

Your examples are very interesting (Russian side of the Forum) and I hope that some additional ODE solvers will be implemented as plugins in the near future.
BTW, I've noted that the function used in rkfixed (Система(t;x) in this example) is tolerant to the argument names (t;x here). Actually, rkfixed will not complain if the variables t and x have been already defined - we should be carefull about it.
Regards,
Radovan
ЦитатаI hope that some additional ODE solvers will be implemented as plugins in the near future.
Now it's not so hard. I'll try to implement odesolversolve() from AlgLib project. At this moment I have some functions from there:
AlgLib Plugin (based on ALGLIB 3.1.0)
Дополнение обрабатывает следующие вхождения:
al_airy("число"
- Returns the Airy function: Ai(x), Ai'(x), Bi(x) and Bi'(x).
al_beta("1:число"; "2:число"
- Beta function
al_convr1d("1:вектор"; "2:число"; "3:вектор"; "4:число"
- 1-dimensional real convolution.
al_fftc1d("1:вектор"; "2:число"
- 1-dimensional complex FFT
al_fftc1dinv("1:вектор"; "2:число"
- 1-dimensional complex FFT
I think I can to implement full functionality. Also (if anybody need) it's possible to create plotting functions like: CreateMesh(), CreateSpace(), implicitplot2d() and implicitplot3d().
P.S. Three functions (CreateMesh(), implicitplot2d() and implicitplot3d()) based on SMath programming tools already exists.
325 сообщений из 2 052 понравились и 1 не понравились пользователям.
Группа: Moderator

Regards,
Radovan
will be wonderful if based on your experience you can write ( if possible ) a further tutorial on how to develop a plugin for Smath for super NewBie like me and probably many others.
I have seen that your program is very detailed/commented but would be nice to have a diary of how you have put toghether the bit an pieces to develop the plugin , the difficulties that you have overcome , which are the biggest problem to face in writing a plug in amd the things that one person should be more carefull to succed .
Thanks a lot for your help
Francesco
P.S. In the last months I am following the Smath forum in Russian af far as is possible through the google traslate approach ( from Russian to English ..whose traslation is better then from Russian to Italian my mother tongue) and is really very interesting . Need to try to learn better Russian language ..hope to find something useful to this aim on Internet, I guess that we are missing a universe of knowledge due to ignoring the language
Цитатаwill be wonderful if based on your experience you can write ( if possible ) a further tutorial on how to develop a plugin for Smath for super NewBie like me and probably many others.
Unfortunately, I don't have the full manual for plugin development. There is a good video-manual for beginners on wiki: Tutorials for Creating Plugins. I used it and also examples from svn. As I see, in English much more materials on this subject than in Russian or other language.
ЦитатаI have seen that your program is very detailed/commented but would be nice to have a diary of how you have put toghether the bit an pieces to develop the plugin , the difficulties that you have overcome , which are the biggest problem to face in writing a plug in amd the things that one person should be more carefull to succed.
"Step by step" instructions you mean? It will depend on type of a plugin and algorithm of function. rkfixed() is a difficult example. The main problem was: how to work with function in a plugin? It is better to begin with simple examples like combin() function from video-manual.
I'll try to include all those examples in English in SMath Studio. You can try translate.ru.ЦитатаIn the last months I am following the Smath forum in Russian af far as is possible through the google traslate approach ( from Russian to English ..whose traslation is better then from Russian to Italian my mother tongue) and is really very interesting
325 сообщений из 2 052 понравились и 1 не понравились пользователям.
Группа: Moderator
WroteNew version: ODESolvers.dll
It works more correctly than previous.
Many thanks for your efforts on making this plugin

The ODE solvers are on the top of my "wish list".
I tested it a bit and this version is indeed much faster then the previous one.
Here is one of my simple test examples for ODE solvers:
And your solvers worked as expected, thank you

This is also a test for a stiff ODE. As the rkfixed and Rkadapt are not stiff solvers, the result is as presented in the graph. Stiff ODE solver should cope with the situation when y2 is approaching zero.
Here are some of my comments, if you do not mind:
- I am not a programmer but am rather surprised how you managed to get the function as a function parameter (D(t,y) in this case - my congratulations

- I tried to define function D as a multiline function but this will not work.
Anyway, I am very grateful to you for this plugin.
Regards,
Radovan
Цитата- I tried to define function D as a multiline function but this will not work.
I asked Andrey about it and he has explained a problem. You can try newnew version: ODESolvers.dll
About comments

It is not so simply to explain in a few words about how I do that. May be later, specially for those who is interested.ЦитатаI am not a programmer but am rather surprised how you managed to get the function as a function parameter (D(t,y).
325 сообщений из 2 052 понравились и 1 не понравились пользователям.
Группа: Moderator
WroteRkadapt() algorithm. Unfortunately, it doesn't work.
Rkadapt prog.sm
I took a look at this sm file. On the basis of the error message about the function Rkadapt2 - "The matrix element does'nt exist." and by some inspection I think that there might be a mistake about vectors and row matrix. There might be that you used the single index for row matrix regarding it as a vector, and you might forgot to use two instead of one index.
Regards,
Radovan
P.S. I am not able to test the new *.dll at the moment because I do not know how to use it with portable 0.89_8 version (unfortunately, have no possibility to install SMath at my home computer).
325 сообщений из 2 052 понравились и 1 не понравились пользователям.
Группа: Moderator
I tested a little bit rkfixed and Rkadapt. Here is a simple picture:
It seems, as you mentioned, that Rkadapt will not work with multiline function. However, it is very good that rkfixed will work with it - a bit surprise for me. I also tried to define function f(x,t) by using "eval" - it does not work either with rkfixed or Rkadapt. Due to my previous experience, I thought it would not work. I know that this kind of functions, like you did with rkfixed and Rkadapt, will have troubles due to the SMath way of working. Never mind, I hope that SMath will have tha ability to cope with this kind of problems some day.
Regards,
Radovan
325 сообщений из 2 052 понравились и 1 не понравились пользователям.
Группа: Moderator
I might miss that feature, but it should be pointed out that this is very nice and useful


I hope that some stiff solvers would be available sooner or later

Regards,
Radovan
ODE-Lorentz.sm (11,12 КиБ) скачан 856 раз(а).


Usual, in such cases I use a different way of passing parameters, but it doesn't work for this example.
EDIT: I was wrong, it works.

ODE-Lorentz-uni.sm (13,74 КиБ) скачан 785 раз(а).
325 сообщений из 2 052 понравились и 1 не понравились пользователям.
Группа: Moderator
WroteOh, you found a bug, well, I'll fix it
Usual, in such cases I use a different way of passing parameters, but it doesn't work for this example.
EDIT: I was wrong, it works.
Actually, I thought this was by design and that I missed it


I also tried this one and it worked as well


Uni, please keep it this way and do not change it

Regards,
Radovan
ODE-Lorentz-2.sm (11,87 КиБ) скачан 798 раз(а).
325 сообщений из 2 052 понравились и 1 не понравились пользователям.
Группа: Moderator
WroteHow about this dirty parameter handling...
Hmm... why dirty? Do not understand, sorry. This looks quite regular to me, except that it is not flexible. The third parameter must always have the same name as in the definition of D().
Regards,
Radovan
- Новые сообщения
- Нет новых сообщений