00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037 #ifndef __eoVector_comm_h
00038 #define __eoVector_comm_h
00039
00040 #include <eoVector.h>
00041
00042 #include "messaging.h"
00043
00044 template <class F, class T> void pack (const eoVector <F, T> & __v) {
00045
00046 pack (__v.fitness ()) ;
00047 unsigned len = __v.size ();
00048 pack (len);
00049 for (unsigned i = 0 ; i < len; i ++)
00050 pack (__v [i]);
00051 }
00052
00053 template <class F, class T> void unpack (eoVector <F, T> & __v) {
00054
00055 F fit;
00056 unpack (fit);
00057 __v.fitness (fit);
00058
00059 unsigned len;
00060 unpack (len);
00061 __v.resize (len);
00062 for (unsigned i = 0 ; i < len; i ++)
00063 unpack (__v [i]);
00064 }
00065
00066 template <class F, class T, class V> void pack (const eoVectorParticle <F, T, V> & __v) {
00067
00068 pack (__v.fitness ()) ;
00069 pack (__v.best());
00070 unsigned len = __v.size ();
00071 pack (len);
00072 for (unsigned i = 0 ; i < len; i ++)
00073 pack (__v [i]);
00074 for (unsigned i = 0 ; i < len; i ++)
00075 pack (__v.bestPositions[i]);
00076 for (unsigned i = 0 ; i < len; i ++)
00077 pack (__v.velocities[i]);
00078 }
00079
00080 template <class F, class T, class V> void unpack (eoVectorParticle <F, T, V> & __v) {
00081
00082 F fit;
00083 unpack(fit);
00084 __v.fitness (fit);
00085 unpack(fit);
00086 __v.best(fit);
00087 unsigned len;
00088 unpack (len);
00089 __v.resize (len);
00090 for (unsigned i = 0 ; i < len; i ++)
00091 unpack (__v [i]);
00092 for (unsigned i = 0 ; i < len; i ++)
00093 unpack (__v.bestPositions[i]);
00094 for (unsigned i = 0 ; i < len; i ++)
00095 unpack (__v.velocities[i]);
00096 }
00097
00098 #endif