mirror of
https://github.com/slsdetectorgroup/slsDetectorPackage.git
synced 2025-04-22 03:40:04 +02:00
205 lines
4.4 KiB
C++
205 lines
4.4 KiB
C++
#include "fileIO.h"
|
|
|
|
using namespace std;
|
|
|
|
|
|
/* I/O */
|
|
|
|
/* generates file name without extension*/
|
|
|
|
string fileIO::createFileName() {
|
|
|
|
pthread_mutex_lock(&mf);
|
|
currentFileName=fileIOStatic::createFileName(filePath, \
|
|
fileName, \
|
|
getActionMask(), \
|
|
getCurrentScanVariable(0), \
|
|
getScanPrecision(0), \
|
|
getCurrentScanVariable(1), \
|
|
getScanPrecision(1), \
|
|
getCurrentPositionIndex(), \
|
|
getNumberOfPositions(), \
|
|
*fileIndex, \
|
|
frameIndex, \
|
|
detIndex \
|
|
);
|
|
|
|
//if (getDetectorsType()==JUNGFRAUCTB) {
|
|
// nBytes=2*getTotalNumberOfChannels();
|
|
//} else
|
|
nBytes=getDataBytes();
|
|
pthread_mutex_unlock(&mf);
|
|
return currentFileName;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* generates file prefix for receivers */
|
|
|
|
string fileIO::createReceiverFilePrefix() {
|
|
pthread_mutex_lock(&mf);
|
|
currentReceiverFilePrefix=fileIOStatic::createReceiverFilePrefix(fileName, \
|
|
getActionMask(), \
|
|
getCurrentScanVariable(0), \
|
|
getScanPrecision(0), \
|
|
getCurrentScanVariable(1), \
|
|
getScanPrecision(1), \
|
|
getCurrentPositionIndex(), \
|
|
getNumberOfPositions(), \
|
|
detIndex \
|
|
);
|
|
pthread_mutex_unlock(&mf);
|
|
return currentReceiverFilePrefix;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*writes raw data file */
|
|
|
|
int fileIO::writeDataFile(string fname, double *data, double *err, double *ang, char dataformat, int nch){
|
|
if (nch==-1)
|
|
nch=getTotalNumberOfChannels();
|
|
|
|
// cout << "Write filexxx...." << endl;
|
|
|
|
return fileIOStatic::writeDataFile(fname, nch, data, err, ang, dataformat);
|
|
|
|
}
|
|
int fileIO::writeDataFile(ofstream &outfile, double *data, double *err, double *ang, char dataformat, int nch, int offset){
|
|
if (nch==-1)
|
|
nch=getTotalNumberOfChannels();
|
|
|
|
//cout << "Write file...." << endl;
|
|
|
|
return fileIOStatic::writeDataFile(outfile, nch, data, err, ang, dataformat, offset);
|
|
|
|
}
|
|
|
|
|
|
int fileIO::writeDataFile(string fname, int *data){
|
|
|
|
return fileIOStatic::writeDataFile(fname, getTotalNumberOfChannels(), data);
|
|
}
|
|
|
|
|
|
|
|
|
|
int fileIO::writeDataFile(ofstream &outfile, int *data, int offset){
|
|
|
|
// cout << "Write raw file...." << endl;
|
|
return fileIOStatic::writeDataFile(outfile, getTotalNumberOfChannels(), data, offset);
|
|
}
|
|
|
|
|
|
|
|
int fileIO::writeDataFile(void *data, int iframe) {
|
|
|
|
if (iframe<0)
|
|
iframe=frameIndex;
|
|
|
|
if ((*framesPerFile)<2)
|
|
iframe=-1;
|
|
|
|
if ((iframe%(*framesPerFile))==0 || (iframe<0) || filefd==0) {
|
|
createFileName();
|
|
filefd = fopen((currentFileName+string(".raw")).c_str(), "w");
|
|
}
|
|
|
|
if (filefd){
|
|
// fileIOStatic::writeBinaryDataFile(filefd,getDataBytes(), data);
|
|
cout <<"Writing "<< nBytes<< " dataBytes"<< endl;
|
|
fileIOStatic::writeBinaryDataFile(filefd,nBytes, data);
|
|
iframe++;
|
|
}
|
|
|
|
if ((iframe%(*framesPerFile)==0) || (iframe<0)) {
|
|
if (filefd)
|
|
fclose(filefd);
|
|
filefd=NULL;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
|
|
|
|
int fileIO::closeDataFile() {
|
|
// cout << "close file...." << endl;
|
|
if (filefd)
|
|
fclose(filefd);
|
|
filefd=NULL;
|
|
return 0;
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int fileIO::writeDataFile(string fname, short int *data){
|
|
|
|
cout << "Write raw file...." << endl;
|
|
return fileIOStatic::writeDataFile(fname, getTotalNumberOfChannels(), data);
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int fileIO::writeDataFile(ofstream &outfile, short int *data, int offset){
|
|
|
|
return fileIOStatic::writeDataFile(outfile, getTotalNumberOfChannels(), data, offset);
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int fileIO::readDataFile(string fname, double *data, double *err, double *ang, char dataformat) {
|
|
return fileIOStatic::readDataFile(getTotalNumberOfChannels(), fname, data, err, ang, dataformat);
|
|
|
|
}
|
|
|
|
int fileIO::readDataFile(ifstream &infile, double *data, double *err, double *ang, char dataformat, int offset) {
|
|
return fileIOStatic::readDataFile(getTotalNumberOfChannels(), infile, data, err, ang, dataformat, offset);
|
|
|
|
}
|
|
|
|
|
|
|
|
int fileIO::readDataFile(string fname, int *data){
|
|
|
|
return fileIOStatic::readDataFile(fname, data, getTotalNumberOfChannels());
|
|
};
|
|
|
|
|
|
int fileIO::readDataFile(ifstream &infile, int *data, int offset){
|
|
|
|
return fileIOStatic::readDataFile(infile, data, getTotalNumberOfChannels(), offset);
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
int fileIO::readDataFile(string fname, short int *data){
|
|
|
|
return fileIOStatic::readDataFile(fname, data, getTotalNumberOfChannels());
|
|
};
|
|
|
|
|
|
int fileIO::readDataFile(ifstream &infile, short int *data, int offset){
|
|
|
|
return fileIOStatic::readDataFile(infile, data, getTotalNumberOfChannels(),offset);
|
|
};
|
|
|