diff --git a/src/libnptm/Configuration.cpp b/src/libnptm/Configuration.cpp
index 2a2e325ef0bf5acee967f10fa83a1d39af161bce..765db12b651a78e3e548edc82a20d37bead138af 100644
--- a/src/libnptm/Configuration.cpp
+++ b/src/libnptm/Configuration.cpp
@@ -538,6 +538,7 @@ ScattererConfiguration* ScattererConfiguration::from_hdf5(string file_name) {
   unsigned int flags = H5F_ACC_RDONLY;
   HDFFile *hdf_file = new HDFFile(file_name, flags);
   herr_t status = hdf_file->get_status();
+  string str_name, str_type;
   if (status == 0) {
     int nsph;
     int *iog;
@@ -562,10 +563,47 @@ ScattererConfiguration* ScattererConfiguration::from_hdf5(string file_name) {
       if (iog[ci] < ci + 1) continue;
       configuration_count++;
     }
-    nshl_vector = new int[configuration_count];
-    ros_vector = new double[configuration_count];
-    // DA QUI
-    
+    nshl_vector = new int[configuration_count]();
+    ros_vector = new double[configuration_count]();
+    rcf_vector = new double*[configuration_count];
+    for (int i115 = 1; i115 <= nsph; i115++) {
+      if (iog[i115 - 1] < i115) continue;
+      str_name = "NSHL_" + to_string(iog[i115 - 1]);
+      str_type = "INT32_(1)";
+      status = hdf_file->read(str_name, str_type, (nshl_vector + i115 - 1));
+      str_name = "ROS_" + to_string(iog[i115 - 1]);
+      str_type = "FLOAT64_(1)";
+      status = hdf_file->read(str_name, str_type, (ros_vector + i115 - 1));
+      int nsh = nshl_vector[i115 - 1];
+      rcf_vector[i115 - 1] = new double[nsh]();
+      str_name = "RCF_" +  to_string(iog[i115 - 1]);
+      str_type = "FLOAT64_(" + to_string(nsh) + ")";
+      status = hdf_file->read(str_name, str_type, (rcf_vector[i115 - 1]));
+    }
+    xi_vec = new double[nxi];
+    str_name = "XIVEC";
+    str_type = "FLOAT64_(" + to_string(nxi) + ")";
+    status = hdf_file->read(str_name, str_type, xi_vec);
+
+    int dim3 = (_idfc == 0) ? nxi : 1;
+    int element_size = 2 * dim3 * nsph * configuration_count;
+    double *elements = new double[element_size]();
+    str_name = "DC0M";
+    str_type = "FLOAT64_(" + to_string(element_size) + ")";
+    status = hdf_file->read(str_name, str_type, elements);
+    dc0m = new complex<double>**[configuration_count];
+    for (int di = 0; di < configuration_count; di++) {
+      dc0m[di] = new complex<double>*[nsph];
+      for (int dj = 0; dj < nsph; dj++) {
+	dc0m[di][dj] = new complex<double>[dim3]();
+	for (int dk = 0; dk < dim3; dk++) {
+	  double rval = elements[(di * nsph) + (dj * dim3) + 2 * dk];
+	  double ival = elements[(di * nsph) + (dj * dim3) + 2 * dk + 1];
+	  dc0m[di][dj][dk] = complex<double>(rval, ival);
+	}
+      } // dj loop
+    } // di loop
+    delete[] elements;
     status = hdf_file->close();
     conf = new ScattererConfiguration(
 				      nsph,
@@ -608,6 +646,11 @@ ScattererConfiguration* ScattererConfiguration::from_legacy(string file_name) {
     for (int i = 0; i < nsph; i++) {
       input.read(reinterpret_cast<char *>(&(iog[i])), sizeof(int));
     }
+    int configuration_count = 0;
+    for (int i115 = 1; i115 <= nsph; i115++) {
+      if (iog[i115 - 1] < i115) continue;
+      configuration_count++;
+    }
     input.read(reinterpret_cast<char *>(&_exdc), sizeof(double));
     input.read(reinterpret_cast<char *>(&_wp), sizeof(double));
     input.read(reinterpret_cast<char *>(&_xip), sizeof(double));
@@ -621,25 +664,25 @@ ScattererConfiguration* ScattererConfiguration::from_legacy(string file_name) {
     for (int i = 0; i < nxi; i++) {
       input.read(reinterpret_cast<char *>(&(xi_vec[i])), sizeof(double));
     }
-    nshl_vector = new int[nsph]();
-    ros_vector = new double[nsph]();
-    rcf_vector = new double*[nsph];
+    nshl_vector = new int[configuration_count]();
+    ros_vector = new double[configuration_count]();
+    rcf_vector = new double*[configuration_count];
     for (int i115 = 1; i115 <= nsph; i115++) {
       if (iog[i115 - 1] < i115) {
 	rcf_vector[i115 - 1] = new double[1]();
 	continue;
       }
-      input.read(reinterpret_cast<char *>(&(nshl_vector[i115 - 1])), sizeof(int));
-      input.read(reinterpret_cast<char *>(&(ros_vector[i115 - 1])), sizeof(double));
-      int nsh = nshl_vector[i115 - 1];
+      input.read(reinterpret_cast<char *>(&(nshl_vector[i115 - 1])), sizeof(int)); // was not from IOG
+      input.read(reinterpret_cast<char *>(&(ros_vector[i115 - 1])), sizeof(double)); // was not from IOG
+      int nsh = nshl_vector[i115 - 1]; // was not from IOG
       if (max_ici < (nsh + 1) / 2) max_ici = (nsh + 1) / 2;
       try {
-	rcf_vector[i115 - 1] = new double[nsh]();
+	rcf_vector[i115 - 1] = new double[nsh](); // was not from IOG
       } catch (const bad_alloc &ex) {
 	throw UnrecognizedConfigurationException("Wrong parameter set: invalid number of layers " + to_string(nsh));
       }
       for (int nsi = 0; nsi < nsh; nsi++) {
-	input.read(reinterpret_cast<char *>(&(rcf_vector[i115 - 1][nsi])), sizeof(double));
+	input.read(reinterpret_cast<char *>(&(rcf_vector[i115 - 1][nsi])), sizeof(double)); // was not from IOG
       }
     }
     dc0m = new complex<double>**[max_ici];
@@ -654,7 +697,7 @@ ScattererConfiguration* ScattererConfiguration::from_legacy(string file_name) {
       if (_idfc != 0 && jxi468 > 1) continue;
       for (int i162 = 1; i162 <= nsph; i162++) {
 	if (iog[i162 - 1] < i162) continue;
-	int nsh = nshl_vector[i162 - 1];
+	int nsh = nshl_vector[iog[i162 - 1] - 1]; // was not from IOG
 	int ici = (nsh + 1) / 2; // QUESTION: is integer division really intended here?
 	for (int i157 = 0; i157 < ici; i157++) {
 	  double dc0_real, dc0_img;
@@ -787,19 +830,19 @@ void ScattererConfiguration::write_hdf5(string file_name) {
     str_name = "NSHL_" + to_string(i115);
     rec_name_list.append(str_name);
     rec_type_list.append("INT32_(1)");
-    rec_ptr_list.append(&(nshl_vec[i115 - 1]));
+    rec_ptr_list.append(&(nshl_vec[i115 - 1])); // was not from IOG
     str_name = "ROS_" + to_string(i115);
     rec_name_list.append(str_name);
     rec_type_list.append("FLOAT64_(1)");
-    rec_ptr_list.append(&(radii_of_spheres[i115 - 1]));
-    int nsh = nshl_vec[i115 - 1];
+    rec_ptr_list.append(&(radii_of_spheres[i115 - 1])); // was not from IOG
+    int nsh = nshl_vec[i115 - 1]; // was not from IOG
     if (i115 == 1) nsh += ies;
     if (max_ici < (nsh + 1) / 2) max_ici = nsh + 1 / 2;
-    str_name = "RCF_" + to_string(i115);
+    str_name = "RCF_" + to_string(i115); // was not from IOG
     str_type = "FLOAT64_(" + to_string(nsh) + ")";
     rec_name_list.append(str_name);
     rec_type_list.append(str_type);
-    rec_ptr_list.append(&(rcf[i115 - 1][0]));
+    rec_ptr_list.append(&(rcf[i115 - 1][0])); // was not from IOG
   }
 
   int dim3 = (idfc == 0) ? number_of_scales : 1;
@@ -810,7 +853,7 @@ void ScattererConfiguration::write_hdf5(string file_name) {
     if (idfc != 0 && jxi468 > 1) continue;
     for (int i162 = 1; i162 <= number_of_spheres; i162++) {
       if (iog_vec[i162 - 1] < i162) continue;
-      int nsh = nshl_vec[i162 - 1];
+      int nsh = nshl_vec[i162 - 1]; // was not from IOG
       int ici = (nsh + 1) / 2;
       if (i162 == 1) ici = ici + ies;
       for (int i157 = 0; i157 < ici; i157++) {
@@ -863,18 +906,18 @@ void ScattererConfiguration::write_legacy(string file_name) {
     output.write(reinterpret_cast<char *>(&(scale_vec[i])), sizeof(double));
   for (int i115 = 1; i115 <= number_of_spheres; i115++) {
     if (iog_vec[i115 - 1] < i115) continue;
-    output.write(reinterpret_cast<char *>(&(nshl_vec[i115 - 1])), sizeof(int));
-    output.write(reinterpret_cast<char *>(&(radii_of_spheres[i115 - 1])), sizeof(double));
-    int nsh = nshl_vec[i115 - 1];
+    output.write(reinterpret_cast<char *>(&(nshl_vec[i115 - 1])), sizeof(int)); // was not from IOG
+    output.write(reinterpret_cast<char *>(&(radii_of_spheres[i115 - 1])), sizeof(double)); // was not from IOG
+    int nsh = nshl_vec[i115 - 1]; // was not from IOG
     if (i115 == 1) nsh += ies;
     for (int nsi = 0; nsi < nsh; nsi++)
-      output.write(reinterpret_cast<char *>(&(rcf[i115 - 1][nsi])), sizeof(double));
+      output.write(reinterpret_cast<char *>(&(rcf[i115 - 1][nsi])), sizeof(double)); // was not from IOG
   }
   for (int jxi468 = 1; jxi468 <= number_of_scales; jxi468++) {
     if (idfc != 0 && jxi468 > 1) continue;
     for (int i162 = 1; i162 <= number_of_spheres; i162++) {
       if (iog_vec[i162 - 1] < i162) continue;
-      int nsh = nshl_vec[i162 - 1];
+      int nsh = nshl_vec[i162 - 1]; // was not from IOG
       int ici = (nsh + 1) / 2; // QUESTION: is integer division really intended here?
       if (i162 == 1) ici = ici + ies;
       for (int i157 = 0; i157 < ici; i157++) {