| 1 | #include<iostream> | 
|---|
| 2 | #include"CLHEP/Matrix/Matrix.h" | 
|---|
| 3 | #include"CLHEP/Matrix/SymMatrix.h" | 
|---|
| 4 |  | 
|---|
| 5 | /* ------------------------------------------------- | 
|---|
| 6 | Test comparatif (pour SOPHYA) des matrices CLHep | 
|---|
| 7 | R. Ansari , Juin 2005 | 
|---|
| 8 |  | 
|---|
| 9 | Pour compiler : | 
|---|
| 10 | definir flag/chemin include et librariries CLHep, | 
|---|
| 11 | Au CC-IN2P3 par exemple, | 
|---|
| 12 | csh> set inchep = '-I/usr/local/lhcxx/CLHEP/pro/include/' | 
|---|
| 13 | csh> set libhep = '-L/usr/local/lhcxx/CLHEP/pro/lib -lCLHEP' | 
|---|
| 14 | csh> cc -c timing.c | 
|---|
| 15 | csh> g++ -c $inchep mtxclhep.cc | 
|---|
| 16 | csh> g++ -o mtxclhep mtxclhep.o timing.o $libhep | 
|---|
| 17 |  | 
|---|
| 18 | Execution : | 
|---|
| 19 | Acces aux elements et operation add/multcst | 
|---|
| 20 | csh> time ./mtxclhep 50 1000 500 | 
|---|
| 21 | Inversion / multiplication | 
|---|
| 22 | csh> time ./mtxclhep 1 1000 1000 | 
|---|
| 23 | ------------------------------------------- */ | 
|---|
| 24 |  | 
|---|
| 25 |  | 
|---|
| 26 | extern "C" { | 
|---|
| 27 | void InitTim(void); | 
|---|
| 28 | void PrtTim(const char *Comm); | 
|---|
| 29 | } | 
|---|
| 30 |  | 
|---|
| 31 | using namespace std; | 
|---|
| 32 |  | 
|---|
| 33 | int main(int narg, char* arg[]) | 
|---|
| 34 | { | 
|---|
| 35 |  | 
|---|
| 36 | if (narg < 3) { | 
|---|
| 37 | cout << "\n mtxclhep - missing arguments\n" | 
|---|
| 38 | << "     Usage:  mtxclhep NLoop NRow NCol \n" | 
|---|
| 39 | << " if nrow==ncol ==>  test inverse/mtx multiply (one time)" << endl; | 
|---|
| 40 | return 1; | 
|---|
| 41 | } | 
|---|
| 42 |  | 
|---|
| 43 | int N = 10; | 
|---|
| 44 | int nrow = 2; | 
|---|
| 45 | int ncol = 2; | 
|---|
| 46 |  | 
|---|
| 47 | N = atoi(arg[1]); | 
|---|
| 48 |  | 
|---|
| 49 | nrow = atoi(arg[2]); | 
|---|
| 50 | ncol = atoi(arg[3]); | 
|---|
| 51 |  | 
|---|
| 52 | cout << " ---- mtxclhep: NLoop=" << N << " NRow= " << nrow | 
|---|
| 53 | << " NCol= " << ncol << " ---- " << endl; | 
|---|
| 54 |  | 
|---|
| 55 | InitTim(); | 
|---|
| 56 | srand48(10); | 
|---|
| 57 |  | 
|---|
| 58 | //ATTENTION :  L'indexage commence a 1 | 
|---|
| 59 | try { | 
|---|
| 60 | int i,j,k; | 
|---|
| 61 |  | 
|---|
| 62 | HepMatrix m1(nrow, ncol); | 
|---|
| 63 | HepMatrix m2(nrow, ncol); | 
|---|
| 64 | HepMatrix m3(nrow, ncol); | 
|---|
| 65 | HepMatrix m4(nrow, ncol); | 
|---|
| 66 | HepMatrix m5(nrow, ncol); | 
|---|
| 67 |  | 
|---|
| 68 |  | 
|---|
| 69 | for(k=0; k<N; k++) { | 
|---|
| 70 | double xxr = drand48(); | 
|---|
| 71 | double yyr = 2.*drand48(); | 
|---|
| 72 | for(i=1; i<=nrow; i++) | 
|---|
| 73 | for(j=1; j<=ncol; j++) { | 
|---|
| 74 | m1(i,j) = k*300+10.*i+j+xxr; | 
|---|
| 75 | m2(i,j) = k*550+20.*i+2.*j+yyr; | 
|---|
| 76 | m3(i,j) = k*860.+40.*i+7.*j+yyr*3.14; | 
|---|
| 77 | } | 
|---|
| 78 | } | 
|---|
| 79 | cout << " (1) Element access done ---" << endl; | 
|---|
| 80 | PrtTim(" (1) -- "); | 
|---|
| 81 |  | 
|---|
| 82 | for(k=0; k<N; k++) { | 
|---|
| 83 | double c1 = drand48() + 1.2; | 
|---|
| 84 | double c2 = drand48() + 3.5; | 
|---|
| 85 | double c3 = drand48() + 6.7; | 
|---|
| 86 | m5 = m1*c1+m2*c2+m3*c3; | 
|---|
| 87 | } | 
|---|
| 88 | cout << " (3) Add/CstMult: m1*c1 + m2*c2 + m3*c3 done ---" << endl; | 
|---|
| 89 | PrtTim(" (3) -- "); | 
|---|
| 90 |  | 
|---|
| 91 |  | 
|---|
| 92 |  | 
|---|
| 93 | if (nrow == ncol) { | 
|---|
| 94 | cout << " mtxclhep/inverse , mtx multiply A(N,N)  N=" << nrow << endl; | 
|---|
| 95 | HepMatrix A(nrow, nrow); | 
|---|
| 96 |  | 
|---|
| 97 | for(i=1; i<=nrow; i++) | 
|---|
| 98 | for(j=0; j<=nrow; j++)   A(i,j) = drand48(); | 
|---|
| 99 |  | 
|---|
| 100 | cout << " (91)  A(i,j) = drand48() done ---" << endl; | 
|---|
| 101 | PrtTim(" (91) -- "); | 
|---|
| 102 |  | 
|---|
| 103 | int ierr; | 
|---|
| 104 | HepMatrix Ainv = A.inverse(ierr); | 
|---|
| 105 | cout << " (92)  Ainv = A.inverse() done ---" << endl; | 
|---|
| 106 | PrtTim(" (92) -- "); | 
|---|
| 107 | if (ierr == 0) { | 
|---|
| 108 | cout << " A.inverse(ierr) OK computing A*Ainv ..." << endl; | 
|---|
| 109 | HepMatrix mxx = A*Ainv; | 
|---|
| 110 | cout << " (93)  mxx = A*Ainv done ---" << endl; | 
|---|
| 111 | PrtTim(" (93) -- "); | 
|---|
| 112 | } | 
|---|
| 113 | } | 
|---|
| 114 | } | 
|---|
| 115 | catch (std::exception & sex) { | 
|---|
| 116 | cerr << " mtxclhep/ catched std::exception what()=" << sex.what() << endl; | 
|---|
| 117 | } | 
|---|
| 118 | catch (...) { | 
|---|
| 119 | cerr << " mtxclhep/catched unknown (...) exception " << endl; | 
|---|
| 120 | } | 
|---|
| 121 | cout << " ------ FIN mtxclhep -------- " << endl; | 
|---|
| 122 | return 0; | 
|---|
| 123 | } | 
|---|