forked from teuben/nemo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
TODO
397 lines (278 loc) · 12.7 KB
/
TODO
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
- a new CVS branch is dealing with a better definition of
images, basically doing FORDEF instead of CDEF.
CDEF has always been a bad idea... given that most our
image work is via FITS
- objects > 2GB or 4GB have issues, since allocate() deals
with int, not size_t. That's being addressed in 3.2.5
(May 2007)
[fixed now]
MacOSX problems: (a special macosx.html web page dedicated to this)
See: http://bima.astro.umd.edu/nemo/macosx.html
- configure leaves -lcrt.o etc. in, so they need manual removal
from makedefs and NEMORC.gen before continuing on
Also check http://www.astro.gla.ac.uk/users/norman/note/2004/restFP/
** most of this should be solved with the jan-2013 changes to
configure. I get a clean install on mac 10.8,
- see also:
http://www.fortran-2000.com/ArnaudRecipes/sharedlib.html
- src/nbody/evolve/aarseth/nbody0/Makefile
need to activate F77LIBS to include -lcc_dynamic (10.3 ?)
but sometimes you to take it out again...... (10.4 ?)
- directcode doesn't compile since it was derived from an earlier
release of hackcode1 with the multiple externs included by the
linker
- xyzview is too slow to be useful, we should recode it such that
OpenGL (and thus Mesa) can be linked. This would also remove the
immediate need for vogl.
-> now superseded by glnemo2
- one case had gcc in /usr/bin but g77 in /usr/local/bin, and not in
the path -> pgplot didn't get build.
- the sitation with compilers can be painful. Always make sure you
have the correct Xcode installed, and then choose:
- /usr/local/bin from hpc.sourceforge.com
- /sw/bin fink
- /opt/local/bin darwinports
For most of them you will either need to set your $PATH correctly and/or
setenv CC, CXX and F77 to the full path of the compilers.
GCC4 problems: (as tested on FC3/FC4)
- pgplot: needs a gfortran_gcc4.conf file for now
also: no more -fno-backslash
also: %VAL() does not seem to be supported anymore ???
also: some formatted reading that spans multi lines BAD (pgpack.f)
- no more -fno-globals for fortran
- no more -fwritable-strings in C
- -fno-globals
- g95 vs. gfortran, use the new m4 macros
- the linker is now more conservative, removing references to code
that is never used. get_atable and sqr come out in some tests
as missing...
The flag
-fno-unit-at-a-time
might work for a little bit.
- see also:
http://www.kegel.com/gcc/gcc4.html
http://womble.decadentplace.org.uk/c++/syntax-errors.html
-------------------------------------------------------------------------------
general things for 3.2.x
- make sure cfitsio stuff is ok in configure (THIS IS BROKEN NOW)
- the change in get_atable() should mean routines need to work
on buffered table read better
- ccdmath WCS is broken
- fix installation if no fortran is available
(fmath in potential not needed)
(some potential/data not needed)
- intel linker problems (use different technique to force loading?)
e.g. intel says to use
export GXX_ROOT=/usr/i686-pc-linux-gnu/gcc-bin/3.3/"
if compilers are in non-standard locations, and
export LC_ALL=C
if you're working on a non-english linux OS
- get a mini-NEMO going (Dehnen, BIMA/CARMA)
* remove environment variables from NEMORC.local that are needed in Makefiles
and move them into makedefs
- use some kind of global MAXBODY where we often use different values
**mostly done**
- gyrfalcON: still has some compiler dependant problems, is also hardcoded for
the GNU compiler (g++) and assumes Linux tools. Not mac friendly, though
a patch exists now.
The new version (V3.0.5; 22-mar-2006) has the one between []
On intel architecture:
3.2.2 ok [ok]
3.3.2 ok
3.3.4 ok [ok]
3.3.6 ok
3.4.1 fail
3.4.2 fail non-constant `(Ky + M2)' cannot be used as template argument
3.4.3 ok [ok]
3.4.5 ok
4.0.0 ok [ok]
4.0.2 ok
4.1.0 fail [fail] falcON::fieldset::fieldset(falcON::fieldbit)
might need to remove -ffast-math if you get segfaults
4.1.1 ok
4.1.2 ok
For MacOSX a bit more work is needed, since isnan() and isinf() are not known?
add: -Wno-long-double
remove: -rdynamic
On my 10.3.9:
gcc3 3.1 20021003 (build 1256) -- isinf/isnan problem
gcc -> 3.3 20030304 (Apple Computer, build 1495) -- isinf/isnan problem
On somebody's 10.4.5:
gcc -> 4.0.0 (build 4061) template problem??
gcc-3.3 -> build 1809 ok
On solaris mkdir is called with --parents and --mode=
they need to be -p -m $(PUBLICMODE)
and solaris flags to figure out
Also:
inc/tupel.cc:51: error: `std::isinf' has not been declared
inc/tupel.cc:52: error: `std::isnan' has not been declared
On mac as well as solaris: what's the way to enable STATIC compile,
since the default is dynamic and doesn't work well on sun4 and darwin?
doxygen may be absent, so you may need to use "make -i" instead
- need a gyrfalcON testsuite section
- falcON/utils install uses some linux dialect:
1) mkdir
mkdir --parents --mode=755 ...
on the mac this should be
mkdir -p -m 755 ....
2) linking: -rdynamic, -shared, -rpath are not understood
g++ .... -shared -o XXX.so
Walter uses:
-shared -o lib/libWDutils.so -march=i386 -mpreferred-stack-boundary=4
OSX/intel can use:
gcc -c -fno-common testlib.c
NO: gcc -dylib -flat_namespace -undefined suppress -o libtestlib.dylib testlib.o
YES: gcc -dynamiclib -o libtest.dylib -dylib t.o
on some (linux) distributions you may need to have to edit the
utils/make.gcc file (remove -march=native from OPTFLAGS :=), and edit
falcON/makedefs (remove -Wtype-limits from WARNINGS :=)
- a few snapshot I/O programs still use the old I/O, hence Position/Velocity data is
now difficult to make global.
--------------------------------------------------------------------------------
some other help on configure:
http://www.airs.com/ian/configure/
code & line coverage: (gcov, lcov)
http://ltp.sourceforge.net/coverage/lcov.php
- use cfortran? cfitsio also uses it.
- gyrfalcON uses potentials in such a way that only potential_float
is looked for ???
- compile under cygwin
- macro usage of some math function? real rlog2(real);
- fix problems when replacing gnu make with pmake
- unsio (and possibly a few more modules) won't link if e.g. pgplot was enabled
with png. are some interfaces not cleanly separated? maybe via yapp_pgplot ?
- if the code has to be C++ friendly, i.e. the nemo_main() be compiled
by c++, but the rest with CC, all extern's must be wrapped in
#if defined(__cplusplus)
extern "C" {
#endif
...
#if defined(__cplusplus)
}
#endif
- getparam: an option to produce an iraf .par file?
- getparam: finish the outkeys= stuff
- zeno: some more Zeno compatibility
- overal design:
separation of functionality and data format. E.g. to compute the
statistics of a variable in either a table, a snapshot or an image
should have the same set of keywords that control the statistics.
Yet accessing the data is different. This is done rather sloppy
and slightly different in different places.
- fortran-to-C
some fortran compilers need -nofor_main to prevent main getting
linked in from the fortran library
some linkers want to link with gcc, not g77 or vice versa? This
may require a configure macro in the makefiles
- still various problems in -DSINGLEPREC mode:
- nemo_io
- rotcur/rotcurshape: cube1/cube1.sig appears to create some NaN pixels
- mkommod has problems with out of bounds intervals
- hackdens doesn't compile
- configure should use more consistent use of the
--with-xxx-yyy=DIR
where xxx is any of e.g. x11,tk,tcl,,.... libaries
and yyy is either dir if it specifies -I DIR/ionclude -L DIR/lib
include if it specifies -I DIR
lib if it specifies -L DIR
- alternatives to autoconf?
Pre Make Kit = http://pmk.sourceforge.net/
cmake (KDE uses it)
also check the Autoconf Macro Archive: http://autoconf-archive.cryp.to/
- Testfile's: also needs a program to be added to the local Makefile,
as well as in the list of programs to be installed...
that's non-intuitive
- man pages vs. doxygen; especially the introduction of C++ is showing
the aging of man pages. should we switch to doxygen?
Linking:
--------
Linking can be done with ld, or with the compiler. But which compiler?
Should it be the one main() is written in, i.e. gcc for C programs,
and gfortran/g77 for PROGRAM's ?
The FLIBS macro from autoconf defines a bunch of -L..... -lg2c (-lgfortran)
The example where this linking got problematic is the mkkd95 tools.
mknemo mkkd95
shows the complexity in failure and success.
Intel compiler 9.0 (sep 2005):
------------------------------
- some warnings in the Tk drivers
- a number of these linking problems (e.g. cpgdemo's, but also libpgplot.so)
show up when multiple .o files are combined in an executable.
IPO link: can not find "("
icc: error: problem during multi-file optimization compilation (code 1)
make[1]: [libpgplot.so] Error 1 (ignored)
=
building shared vs. static:
gfortran -shared -O2 *.f -o libfoo.so -fPIC
gfortran -O2 -c *.f; ar cr libfoo.a *.o
optimize with: -mtune=pentium4 or -ffast-math
DYLD_LIBRARY_PATH (osx) vs. -rpath-link (linux) vs. LD_LIBRARY_PATH
==
on mac a few minor issues w/ gyrfalcON:
- inc/public/forces.cc:462: error: 'uint' has not been declared
uint must be unsigned
- src/public/lib/sample.cc:146: error: no matching function for call to 'isnan(double&)'
should be std::isnan()
- /usr/include/rpc/xdr.h:153: error: conflicting declaration 'typedef struct __rpc_xdr XDR'
need to #include <rpc/rpc.h> here
YES: gcc -dynamiclib -o libtest.dylib -dylib t.o
$(LIB)lib$(LIBNAME).so: $(falcON_objs)
$(CXX) $^ -shared -o $@
becomes:
bad is:
g++ lib/basic.o lib/body.o lib/tree.o lib/gravity.o lib/kernel.o lib/io.o lib/partner.o lib/nbody.o lib/forcesC.o lib/tools.o lib/sample.o lib/manip.o lib/profile.o lib/bodyfunc.o lib/neighbours.o lib/PotExp.o -dynamiclib -o lib/libfalcON.dylib
and in utils/Makefile
$(LIB)libWDutils.so: $(LIB)libWDutils.dylib
$(LIB)libWDutils.dylib: $(WDutils_objs)
$(CXX) $^ -dynamiclib -o $@ $(CPUFLAGS)
few more isnan() and isinf() fixes wiht std::
- old style diff and patch
diff file.old file.new > file.patch
patch file.old -i file.patch -o file.new
diff brent.for brent_dbl.f > test/brent.patch
cd test
cp ../brent.for .
patch brent.for -i brent.patch -o brent_dbl.f
diff brent.for ..
diff brent_dbl.f ..
git tricks
----------
0) commands beginners should know
git clone URL # get a new repo from URL
git pull # update the repo
git add FILE # add a new FILE
git commit FILE # commit the FILE
git push # push the commit's
1) working with tags
git tag --list # see what tags you have
git tag nemo_4_3_2 # make a new tag (locally)
git tag -d nemo_4_3_2 # delete that tag
git push origin nemo_4_3_2 # push it out to the world
git checkout nemo_4_3_2 # switch to a tag
git checkout master # revert back
todo: see if "git push --tags" also works
2) ? can you see what will be pushed when you "git push"
since you may have done a whole bunch of "git commit"
It would say something like
"Your branch is ahead of 'origin/master' by 8 commits"
git diff --stat --cached origin/master
3) if you accidentally edited a FILE and want to "undo" it,
i.e. revert back to the original FILE:
git checkout FILE
this will silently overwrite your modified FILE with the
original version
4) working with another remote upstream
Let say you work off a fork, and cloned that as you private workspace.
The original NEMO would be the upstream master:
git remote # see which ones you have
git remote add upstream https://github.com/teuben/nemo # add this one-time
git branch # check what branch you are on
git checkout master # ensure on your master
git fetch upstream # fetch the upstream
git merge upstream/master # merge in
git status # should be no new things
git push # push it to your origin
5) When pgplot changed their URL:
git remote -v
git remote rename origin teuben
git remote add origin https://github.com/astroumd/pgplot