mirror of
				https://github.com/paboyle/Grid.git
				synced 2025-10-25 18:19:34 +01:00 
			
		
		
		
	Added Scidac format with checksums to RNG files
This commit is contained in:
		| @@ -362,6 +362,13 @@ PARALLEL_CRITICAL | ||||
| 	ierr=MPI_File_open(grid->communicator,(char *) file.c_str(), MPI_MODE_RDONLY, MPI_INFO_NULL, &fh);    assert(ierr==0); | ||||
| 	ierr=MPI_File_set_view(fh, disp, mpiObject, fileArray, "native", MPI_INFO_NULL);    assert(ierr==0); | ||||
| 	ierr=MPI_File_read_all(fh, &iodata[0], 1, localArray, &status);    assert(ierr==0); | ||||
|  | ||||
|   MPI_Offset os; | ||||
|   MPI_File_get_position(fh, &os); | ||||
|   MPI_File_get_byte_offset(fh, os, &disp); | ||||
|   offset = disp; | ||||
|  | ||||
|  | ||||
| 	MPI_File_close(&fh); | ||||
| 	MPI_Type_free(&fileArray); | ||||
| 	MPI_Type_free(&localArray); | ||||
| @@ -370,11 +377,13 @@ PARALLEL_CRITICAL | ||||
| #endif | ||||
|       } else { | ||||
| 	std::cout << GridLogMessage <<"IOobject: C++ read I/O " << file << " : " | ||||
|                   << iodata.size() * sizeof(fobj) << " bytes" << std::endl; | ||||
|                   << iodata.size() * sizeof(fobj) << " bytes and offset " << offset << std::endl; | ||||
|         std::ifstream fin; | ||||
| 	fin.open(file, std::ios::binary | std::ios::in); | ||||
|         if (control & BINARYIO_MASTER_APPEND) | ||||
| 	      fin.open(file, std::ios::binary | std::ios::in); | ||||
|         if (0)//control & BINARYIO_MASTER_APPEND) | ||||
|         { | ||||
|           // Note Guido. Crosscheck this for the RNG case | ||||
|           // why the negative offset? | ||||
|           fin.seekg(-sizeof(fobj), fin.end); | ||||
|         } | ||||
|         else | ||||
| @@ -382,6 +391,7 @@ PARALLEL_CRITICAL | ||||
|           fin.seekg(offset + myrank * lsites * sizeof(fobj)); | ||||
|         } | ||||
|         fin.read((char *)&iodata[0], iodata.size() * sizeof(fobj)); | ||||
|         offset = fin.tellg(); | ||||
|         assert(fin.fail() == 0); | ||||
|         fin.close(); | ||||
|       } | ||||
| @@ -638,6 +648,11 @@ PARALLEL_CRITICAL | ||||
|     IOobject(w,grid,iodata,file,offset,format,BINARYIO_READ|BINARYIO_LEXICOGRAPHIC, | ||||
| 	     nersc_csum,scidac_csuma,scidac_csumb); | ||||
|  | ||||
|     std::cout << GridLogMessage << "RNG file nersc_checksum   " << std::hex << nersc_csum << std::dec << std::endl; | ||||
|     std::cout << GridLogMessage << "RNG file scidac_checksuma " << std::hex << scidac_csuma << std::dec << std::endl; | ||||
|     std::cout << GridLogMessage << "RNG file scidac_checksumb " << std::hex << scidac_csumb << std::dec << std::endl; | ||||
|  | ||||
|  | ||||
|     timer.Start(); | ||||
|     parallel_for(uint64_t lidx=0;lidx<lsites;lidx++){ | ||||
|       std::vector<RngStateType> tmp(RngStateCount); | ||||
| @@ -656,6 +671,11 @@ PARALLEL_CRITICAL | ||||
|       serial.SetState(tmp,0); | ||||
|     } | ||||
|  | ||||
|     std::cout << GridLogMessage << "RNG file checksum t " << std::hex << nersc_csum_tmp    << std::dec << std::endl; | ||||
|     std::cout << GridLogMessage << "RNG file checksuma t " << std::hex << scidac_csuma_tmp << std::dec << std::endl; | ||||
|     std::cout << GridLogMessage << "RNG file checksumb t " << std::hex << scidac_csumb_tmp << std::dec << std::endl; | ||||
|  | ||||
|  | ||||
|     nersc_csum   = nersc_csum   + nersc_csum_tmp; | ||||
|     scidac_csuma = scidac_csuma ^ scidac_csuma_tmp; | ||||
|     scidac_csumb = scidac_csumb ^ scidac_csumb_tmp; | ||||
| @@ -706,6 +726,11 @@ PARALLEL_CRITICAL | ||||
|  | ||||
|     IOobject(w,grid,iodata,file,offset,format,BINARYIO_WRITE|BINARYIO_LEXICOGRAPHIC, | ||||
| 	     nersc_csum,scidac_csuma,scidac_csumb); | ||||
|  | ||||
|     std::cout << GridLogMessage << "RNG file checksum " << std::hex << nersc_csum    << std::dec << std::endl; | ||||
|     std::cout << GridLogMessage << "RNG file checksuma " << std::hex << scidac_csuma << std::dec << std::endl; | ||||
|     std::cout << GridLogMessage << "RNG file checksumb " << std::hex << scidac_csumb << std::dec << std::endl; | ||||
|     | ||||
|     iodata.resize(1); | ||||
|     { | ||||
|       std::vector<RngStateType> tmp(RngStateCount); | ||||
| @@ -715,6 +740,11 @@ PARALLEL_CRITICAL | ||||
|     IOobject(w,grid,iodata,file,offset,format,BINARYIO_WRITE|BINARYIO_MASTER_APPEND, | ||||
| 	     nersc_csum_tmp,scidac_csuma_tmp,scidac_csumb_tmp); | ||||
|  | ||||
|     std::cout << GridLogMessage << "RNG file checksum t " << std::hex << nersc_csum_tmp    << std::dec << std::endl; | ||||
|     std::cout << GridLogMessage << "RNG file checksuma t " << std::hex << scidac_csuma_tmp << std::dec << std::endl; | ||||
|     std::cout << GridLogMessage << "RNG file checksumb t " << std::hex << scidac_csumb_tmp << std::dec << std::endl; | ||||
|   | ||||
|  | ||||
|     nersc_csum   = nersc_csum   + nersc_csum_tmp; | ||||
|     scidac_csuma = scidac_csuma ^ scidac_csuma_tmp; | ||||
|     scidac_csumb = scidac_csumb ^ scidac_csumb_tmp; | ||||
|   | ||||
| @@ -238,10 +238,52 @@ class GridLimeReader : public BinaryIO { | ||||
| 	// Verify checksums | ||||
| 	///////////////////////////////////////////// | ||||
| 	assert(scidacChecksumVerify(scidacChecksum_,scidac_csuma,scidac_csumb)==1); | ||||
|   std::cout << GridLogMessage<< " readLimeLatticeBinaryObject checksums match ! " <<std::endl; | ||||
| 	return; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   //////////////////////////////////////////// | ||||
|   // Read an RNG object and verify checksum | ||||
|   //////////////////////////////////////////// | ||||
|   void readLimeRNGObject(GridSerialRNG &sRNG, GridParallelRNG &pRNG,std::string record_name) | ||||
|   { | ||||
|     scidacChecksum scidacChecksum_; | ||||
|     uint32_t nersc_csum,scidac_csuma,scidac_csumb; | ||||
|  | ||||
|     while ( limeReaderNextRecord(LimeR) == LIME_SUCCESS ) {  | ||||
|       uint64_t file_bytes =limeReaderBytes(LimeR); | ||||
|  | ||||
|       //      std::cout << GridLogMessage << limeReaderType(LimeR) << " "<< file_bytes <<" bytes "<<std::endl; | ||||
|       //      std::cout << GridLogMessage<< " readLimeObject seeking "<<  record_name <<" found record :" <<limeReaderType(LimeR) <<std::endl; | ||||
|  | ||||
|       if ( !strncmp(limeReaderType(LimeR), record_name.c_str(),strlen(record_name.c_str()) )  ) { | ||||
|  | ||||
|         const int RngStateCount = GridSerialRNG::RngStateCount; | ||||
|         typedef std::array<typename GridSerialRNG::RngStateType,RngStateCount> RNGstate; | ||||
|  | ||||
| 	      uint64_t PayloadSize = sizeof(RNGstate) * (pRNG._grid->_gsites+1); | ||||
|  | ||||
|     	  assert(PayloadSize == file_bytes);// Must match or user error | ||||
|         uint64_t offset= ftello(File); | ||||
| 	    	std::cout << GridLogDebug << " ReadLatticeObject from offset "<<offset << std::endl; | ||||
| 	      BinaryIO::readRNG(sRNG, pRNG, filename, offset, nersc_csum,scidac_csuma,scidac_csumb); | ||||
|  | ||||
| 	      ///////////////////////////////////////////// | ||||
| 	      // Insist checksum is next record | ||||
| 	      ///////////////////////////////////////////// | ||||
| 	      readLimeObject(scidacChecksum_,std::string("scidacChecksum"),std::string(SCIDAC_CHECKSUM)); | ||||
|  | ||||
| 	      ///////////////////////////////////////////// | ||||
| 	      // Verify checksums | ||||
| 	      ///////////////////////////////////////////// | ||||
| 	      assert(scidacChecksumVerify(scidacChecksum_,scidac_csuma,scidac_csumb)==1); | ||||
|         std::cout << GridLogMessage<< " readLimeRNGObject checksums match ! " <<std::endl; | ||||
| 	      return; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   //////////////////////////////////////////// | ||||
|   // Read a generic serialisable object | ||||
|   //////////////////////////////////////////// | ||||
| @@ -429,6 +471,78 @@ class GridLimeWriter : public BinaryIO | ||||
|       writeLimeObject(0,1,checksum,std::string("scidacChecksum"),std::string(SCIDAC_CHECKSUM)); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|  | ||||
|   //////////////////////////////////////////////////// | ||||
|   // Write an rng object and csum | ||||
|   // This routine is Collectively called by all nodes | ||||
|   // in communicator used by the field._grid | ||||
|   //////////////////////////////////////////////////// | ||||
|   void writeLimeRNGObject(GridSerialRNG &sRNG, GridParallelRNG &pRNG, std::string record_name) | ||||
|   { | ||||
|     GridBase *grid = pRNG._grid; | ||||
|     assert(boss_node == pRNG._grid->IsBoss() ); | ||||
|  | ||||
|     const int RngStateCount = GridSerialRNG::RngStateCount; | ||||
|     typedef std::array<typename GridSerialRNG::RngStateType,RngStateCount> RNGstate; | ||||
|  | ||||
|     //////////////////////////////////////////// | ||||
|     // Create record header | ||||
|     //////////////////////////////////////////// | ||||
|     int err; | ||||
|     uint32_t nersc_csum,scidac_csuma,scidac_csumb; | ||||
|     uint64_t PayloadSize = sizeof(RNGstate) * (grid->_gsites+1); | ||||
|     std::cout << GridLogDebug << "Computed payload size " << PayloadSize << std::endl; | ||||
|     if ( boss_node ) { | ||||
|       createLimeRecordHeader(record_name, 0, 0, PayloadSize); | ||||
|       fflush(File); | ||||
|     } | ||||
|      | ||||
|     //////////////////////////////////////////////// | ||||
|     // Check all nodes agree on file position | ||||
|     //////////////////////////////////////////////// | ||||
|     uint64_t offset1; | ||||
|     if ( boss_node ) { | ||||
|       offset1 = ftello(File);     | ||||
|     } | ||||
|     grid->Broadcast(0,(void *)&offset1,sizeof(offset1)); | ||||
|  | ||||
|     /////////////////////////////////////////// | ||||
|     // The above is collective. Write by other means into the binary record | ||||
|     /////////////////////////////////////////// | ||||
|     uint64_t offset = offset1; | ||||
|     BinaryIO::writeRNG(sRNG, pRNG,filename, offset, nersc_csum,scidac_csuma,scidac_csumb); | ||||
|  | ||||
|     /////////////////////////////////////////// | ||||
|     // Wind forward and close the record | ||||
|     /////////////////////////////////////////// | ||||
|     if ( boss_node ) { | ||||
|       fseek(File,0,SEEK_END);              | ||||
|       uint64_t offset2 = ftello(File);     | ||||
|       std::cout << GridLogDebug << " now at offset "<<offset2 << std::endl; | ||||
|       assert( (offset2-offset1) == PayloadSize); | ||||
|     } | ||||
|  | ||||
|     ///////////////////////////////////////////////////////////// | ||||
|     // Check MPI-2 I/O did what we expect to file | ||||
|     ///////////////////////////////////////////////////////////// | ||||
|  | ||||
|     if ( boss_node ) {  | ||||
|       err=limeWriterCloseRecord(LimeW);  assert(err>=0); | ||||
|     } | ||||
|     //////////////////////////////////////// | ||||
|     // Write checksum element, propagaing forward from the BinaryIO | ||||
|     // Always pair a checksum with a binary object, and close message | ||||
|     //////////////////////////////////////// | ||||
|     scidacChecksum checksum; | ||||
|     std::stringstream streama; streama << std::hex << scidac_csuma; | ||||
|     std::stringstream streamb; streamb << std::hex << scidac_csumb; | ||||
|     checksum.suma= streama.str(); | ||||
|     checksum.sumb= streamb.str(); | ||||
|     if ( boss_node ) {  | ||||
|       writeLimeObject(0,1,checksum,std::string("scidacChecksum"),std::string(SCIDAC_CHECKSUM)); | ||||
|     } | ||||
|   } | ||||
| }; | ||||
|  | ||||
| class ScidacWriter : public GridLimeWriter { | ||||
| @@ -445,6 +559,27 @@ class ScidacWriter : public GridLimeWriter { | ||||
|       writeLimeObject(0,1,_userFile,_userFile.SerialisableClassName(),std::string(SCIDAC_FILE_XML)); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   void writeScidacRNGRecord(GridSerialRNG &sRNG, GridParallelRNG &pRNG)  | ||||
|   { | ||||
|     GridBase *grid = pRNG._grid; | ||||
|     FieldMetaData header; | ||||
|  | ||||
|     header.floating_point = "IEEE64BIG"; | ||||
|     header.checksum = 0x0; // Nersc checksum unused in ILDG, Scidac | ||||
|     GridMetaData(grid,header);  | ||||
|     MachineCharacteristics(header); | ||||
|      | ||||
|     ////////////////////////////////////////////// | ||||
|     // Fill the Lime file record by record | ||||
|     ////////////////////////////////////////////// | ||||
|     if ( this->boss_node ) { | ||||
|       writeLimeObject(1,0,header ,std::string("FieldMetaData"),std::string(GRID_FORMAT)); // Open message  | ||||
|     } | ||||
|     // Collective call | ||||
|     writeLimeRNGObject(sRNG, pRNG,std::string(ILDG_BINARY_DATA));      // Closes message with checksum | ||||
|   } | ||||
|    | ||||
|   //////////////////////////////////////////////// | ||||
|   // Write generic lattice field in scidac format | ||||
|   //////////////////////////////////////////////// | ||||
| @@ -473,6 +608,7 @@ class ScidacWriter : public GridLimeWriter { | ||||
|     // Collective call | ||||
|     writeLimeLatticeBinaryObject(field,std::string(ILDG_BINARY_DATA));      // Closes message with checksum | ||||
|   } | ||||
|    | ||||
| }; | ||||
|  | ||||
|  | ||||
| @@ -486,8 +622,27 @@ class ScidacReader : public GridLimeReader { | ||||
|      readLimeObject(_scidacFile,_scidacFile.SerialisableClassName(),std::string(SCIDAC_PRIVATE_FILE_XML)); | ||||
|      readLimeObject(_userFile,_userFile.SerialisableClassName(),std::string(SCIDAC_FILE_XML)); | ||||
|    } | ||||
|  | ||||
|   //////////////////////////////////////////////// | ||||
|   // Write generic lattice field in scidac format | ||||
|   // Read RNGobject in scidac format | ||||
|   //////////////////////////////////////////////// | ||||
|   void readScidacRNGRecord(GridSerialRNG &sRNG, GridParallelRNG &pRNG)  | ||||
|   { | ||||
|     GridBase * grid = pRNG._grid; | ||||
|  | ||||
|     //////////////////////////////////////// | ||||
|     // fill the Grid header | ||||
|     //////////////////////////////////////// | ||||
|     FieldMetaData header; | ||||
|   | ||||
|     ////////////////////////////////////////////// | ||||
|     // Fill the Lime file record by record | ||||
|     ////////////////////////////////////////////// | ||||
|     readLimeObject(header ,std::string("FieldMetaData"),std::string(GRID_FORMAT)); // Open message  | ||||
|     readLimeRNGObject(sRNG, pRNG, std::string(ILDG_BINARY_DATA)); | ||||
|   } | ||||
|   //////////////////////////////////////////////// | ||||
|   // Read generic lattice field in scidac format | ||||
|   //////////////////////////////////////////////// | ||||
|   template <class vobj, class userRecord> | ||||
|   void readScidacFieldRecord(Lattice<vobj> &field,userRecord &_userRecord)  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user