Nonlinear Noise Reduction
From this section I added:
ghkss
Thus deprecating
Closer examination has revealed another interesting function in this section:
Phase Space Representation
From this section I added:
The function project
. It is important to note that data allocation in ghkss
(only) is done via new/delete
because of the way the function was originally written. In the future this will be replaced with OCTAVE_LOCAL_BUFFER
(OLB) macro.Closer examination has revealed another interesting function in this section:
nrlazy
, which according to the documentation is similar to lazy
. Because of this similarity porting it has low priority.Phase Space Representation
From this section I added:
- mutual
- false_nearest
- poincare
poincare
was discovered when further studying the documentation and was omitted in the initial plan, but as it seems important in the documentation it was ported.The function
false_nearest
is in a similar situation to ghkss
, that is, new/delete
is used instead of OLB. This will be improved on in the future.Since
corr
does not need to be ported, this section is complete.Nonlinear Prediction
This next section is well on the way as the following have been ported:
- upo
- upoembed
- lzo_test
predict
turned out to be essentially the same with lzo_test
. This had not been verified so far, but according to the documentation they do essentially the same. The additional option that predict
has (flag -v
) can be easily replaced using GNU Octave's std
when calling lzo_test
with parameter r
. Therefore porting predict
will be most likely unnecessary.The function
upoembed
is closely associated with upo
. It takes the output of upo
and creates a cell array of delay vectors for each orbit produced by upo
. It was not mentioned in the original outline, but it is an important function for the package.The state of
upo
is not optimal. The original implementation only supported input up to 1e6 data points. This might not be a big problem as calculating upo
on a 1e4 henon map takes about 8 seconds, so a 1e6 would take about 800 seconds ~ 15 min. Changing this might be problematic as the main data in the FORTAN program is in a common
block (it is stored in a global variable), which cannot contain arrays of variable dimensions. The authors of TISEAN chose 1e6, but because of how the program is written making it unlimited would not be trivial. It might be beneficial to lift this number to 1e8 or 1e9 but one must keep in mind that because of how the FORTRAN program is written it will always allocate a local array of the maximum size possible (currently 1e6 elements). If the maximum input length is lifted to 1e8 or 1e9 the size of the data allocated by Octave and the local copy that the FORTRAN program uses can be a sizable amount of memory to allocate. Moreover it is important to note that each data point will be a real*8
(not a real*4
). This brings me to the next point.FORTRAN data types
This topic has been problematic for me from the very beginning. I had trouble realizing just how the dummy variables work. After some research I found that one can pass
-freal-4-real-8
and promote all real*4
to real*8
. This is beneficial as the input into a FOTRAN program is passed as doubles. This caused serious issues as I needed to ensure that when I call any TISEAN or SLATEC function/subroutine I needed to use real*4
instead of real*8
. The solution I originally used was to copy the input variables into local variables. Apart from eliminating potential bugs and improving code complexity the previously mentioned flag also allows the FORTRAN programs to have the same type of precision expected from GNU Octave programs.Other things
I spent my time also on other things. I significantly changed the
Makefile
s, removed all compilation warnings and everywhere except for ghkss
and false_nearest
moved from new/delete
to OCTAVE_LOCAL_BUFFER
or some type of Array
.