Line Code
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
#include <iostream>
#include <fstream>
#include <vector>
#include <iostream>
#include <string>

int main(){

  const int MAX_SIZE = 252288;

  int old_index;
  float old_elem33, old_elem34,old_elem35,old_elem44,old_elem45,old_elem46,old_elem55,old_elem56;
  float old_elem57,old_elem66,old_elem67,old_elem77;
  std::vector<int> old_index_id;
  std::vector<float> old_el33;
  std::vector<float> old_el34;
  std::vector<float> old_el35;
  std::vector<float> old_el44;
  std::vector<float> old_el45;
  std::vector<float> old_el46;
  std::vector<float> old_el55;
  std::vector<float> old_el56;
  std::vector<float> old_el57;
  std::vector<float> old_el66;
  std::vector<float> old_el67;
  std::vector<float> old_el77;

  int new_index;
  float new_elem33,new_elem34,new_elem35,new_elem44,new_elem45,new_elem46,new_elem55,new_elem56;
  float new_elem57,new_elem66,new_elem67,new_elem77;
  std::vector<int> new_index_id;
  std::vector<float> new_el33;
  std::vector<float> new_el34;
  std::vector<float> new_el35;
  std::vector<float> new_el44;
  std::vector<float> new_el45;
  std::vector<float> new_el46;
  std::vector<float> new_el55;
  std::vector<float> new_el56;
  std::vector<float> new_el57;
  std::vector<float> new_el66;
  std::vector<float> new_el67;
  std::vector<float> new_el77;

  //differences
  std::vector<float> diff_el33;
  std::vector<float> diff_el34;
  std::vector<float> diff_el35;
  std::vector<float> diff_el44;
  std::vector<float> diff_el45;
  std::vector<float> diff_el46;
  std::vector<float> diff_el55;
  std::vector<float> diff_el56;
  std::vector<float> diff_el57;
  std::vector<float> diff_el66;
  std::vector<float> diff_el67;
  std::vector<float> diff_el77;

  //old vectors
  std::vector<float> myoldel33;
  std::vector<float> myoldel34;
  std::vector<float> myoldel35;
  std::vector<float> myoldel44;
  std::vector<float> myoldel45;
  std::vector<float> myoldel46;
  std::vector<float> myoldel55;
  std::vector<float> myoldel56;
  std::vector<float> myoldel57;
  std::vector<float> myoldel66;
  std::vector<float> myoldel67;
  std::vector<float> myoldel77;

  int counter,counter1;
  int old_nrlines=0;
  int new_nrlines=0;

  std::ifstream olddata; 
  olddata.open("goodMatrix2008_09_02.dat",std::ios::in); 
  if(!olddata) {
    std::cerr <<"Error: goodMatrix2008_09_02.dat -> no such file!"<< std::endl;
    exit(1);
  }
  
  while (!olddata.eof() ) { 
    olddata >> old_index >> old_elem33 >> old_elem34 >> old_elem44 >> old_elem35 >> old_elem45 >> old_elem55 >> old_elem46 >> old_elem56 >>old_elem66 >> old_elem57 >> old_elem67 >> old_elem77 ; 
    old_index_id.push_back(old_index);
    old_el33.push_back(old_elem33);
    old_el34.push_back(old_elem34);
    old_el35.push_back(old_elem35);
    old_el44.push_back(old_elem44);
    old_el45.push_back(old_elem45);
    old_el46.push_back(old_elem46);
    old_el55.push_back(old_elem55);
    old_el56.push_back(old_elem56);
    old_el57.push_back(old_elem57);
    old_el66.push_back(old_elem66);
    old_el67.push_back(old_elem67);
    old_el77.push_back(old_elem77);
    old_nrlines++;
  }
  olddata.close();

  std::ifstream newdata;
  std::ofstream myXtalkFile("diffMatrixOct_Aug109891.dat",std::ios::out);
  newdata.open("goodMatrix2009_08_07_run109891.dat",std::ios::in); 
  if(!newdata) {
    std::cerr <<"Error: goodMatrix2009_08_07_run109891.dat -> no such file!"<< std::endl;
    exit(1);
  }
  
  while (!newdata.eof() ) { 
    newdata >> new_index >> new_elem33 >> new_elem34 >> new_elem44 >> new_elem35 >> new_elem45 >> new_elem55 >> new_elem46 >> new_elem56 >>new_elem66 >> new_elem57 >> new_elem67 >> new_elem77; 
    new_index_id.push_back(new_index);
    new_el33.push_back(new_elem33);
    new_el34.push_back(new_elem34);
    new_el35.push_back(new_elem35);
    new_el44.push_back(new_elem44);
    new_el45.push_back(new_elem45);
    new_el46.push_back(new_elem46);
    new_el55.push_back(new_elem55);
    new_el56.push_back(new_elem56);
    new_el57.push_back(new_elem57);
    new_el66.push_back(new_elem66);
    new_el67.push_back(new_elem67);
    new_el77.push_back(new_elem77);
    new_nrlines++;
  }
  newdata.close();

  //resize
  diff_el33.resize(MAX_SIZE);
  diff_el34.resize(MAX_SIZE);
  diff_el35.resize(MAX_SIZE);
  diff_el44.resize(MAX_SIZE);
  diff_el45.resize(MAX_SIZE);
  diff_el46.resize(MAX_SIZE);
  diff_el55.resize(MAX_SIZE);
  diff_el56.resize(MAX_SIZE);
  diff_el57.resize(MAX_SIZE);
  diff_el66.resize(MAX_SIZE);
  diff_el67.resize(MAX_SIZE);
  diff_el77.resize(MAX_SIZE);

  myoldel33.resize(MAX_SIZE);
  myoldel34.resize(MAX_SIZE);
  myoldel35.resize(MAX_SIZE);
  myoldel44.resize(MAX_SIZE);
  myoldel45.resize(MAX_SIZE);
  myoldel46.resize(MAX_SIZE);
  myoldel55.resize(MAX_SIZE);
  myoldel56.resize(MAX_SIZE);
  myoldel57.resize(MAX_SIZE);
  myoldel66.resize(MAX_SIZE);
  myoldel67.resize(MAX_SIZE);
  myoldel77.resize(MAX_SIZE);

  for(int i=0; i<MAX_SIZE;++i){
    counter=old_index_id[i];  
    myoldel33[i]=old_el33[i];
    myoldel34[i]=old_el34[i];
    myoldel35[i]=old_el35[i];
    myoldel44[i]=old_el44[i];
    myoldel45[i]=old_el45[i];
    myoldel46[i]=old_el46[i];
    myoldel55[i]=old_el55[i];
    myoldel56[i]=old_el56[i];
    myoldel57[i]=old_el57[i];
    myoldel66[i]=old_el66[i];
    myoldel67[i]=old_el67[i];
    myoldel77[i]=old_el77[i];
    
    for (int k=0;k<new_index_id.size()-1;k++){
      counter1=new_index_id[k];
      if(counter == counter1){
	diff_el33[k]=old_el33[i] - new_el33[k];
	diff_el34[k]=old_el34[i] - new_el34[k];
	diff_el35[k]=old_el35[i] - new_el35[k];
	diff_el44[k]=old_el44[i] - new_el44[k];
	diff_el45[k]=old_el45[i] - new_el45[k];
	diff_el46[k]=old_el46[i] - new_el46[k];
	diff_el55[k]=old_el55[i] - new_el55[k];
	diff_el56[k]=old_el56[i] - new_el56[k];
	diff_el57[k]=old_el57[i] - new_el57[k];
	diff_el66[k]=old_el66[i] - new_el66[k];
	diff_el67[k]=old_el67[i] - new_el67[k];
	diff_el77[k]=old_el77[i] - new_el77[k];
	//std::cout<<old_el33[i]<<" new_el33[k]"<<new_el33[k]<<std::endl;
	myXtalkFile<<counter<<"  "<<diff_el33[k]<<"  "<< diff_el34[k]<<"  "<<diff_el35[k]<<"  "<<diff_el44[k]<<"  "<<diff_el45[k]<<"  "<<diff_el46[k]<<"  "<<diff_el55[k]<<"  "<<diff_el56[k]<<"  "<<diff_el57[k]<<"  "<<diff_el66[k]<<"  "<<diff_el67[k]<<"  "<<diff_el77[k]<<"  "<<std::endl;	
      }
    }
  }
}