BornAgain
1.19.0
Simulate and fit neutron and x-ray scattering at grazing incidence
|
Real data loader for Q/R/E reflectometry CSV files. More...
Classes | |
struct | ColumnDefinition |
struct | ErrorDefinition |
Contains a line related error (stored in the import result). More... | |
struct | ImportResult |
Result of the file import. More... | |
struct | ImportSettings |
Settings for importing the file. More... | |
Signals | |
void | contentsProcessed () |
Emitted whenever contents have been processed. More... | |
void | importSettingsChanged () |
Emitted whenever an import setting changed. More... | |
Public Member Functions | |
QREDataLoader () | |
virtual void | applyImportSettings () override |
Read all values from the properties UI into the internal variables. More... | |
virtual AbstractDataLoader * | clone () const override |
Create a complete clone, including all internal states. More... | |
virtual AbstractDataLoaderResultModel * | createResultModel () const override |
Create a table model which contains the import information like original file content, raw content, processed content The returned pointer will be owned by the caller. More... | |
virtual QByteArray | defaultImportSettings () const |
Return the default import settings. More... | |
virtual void | deserialize (const QByteArray &data) override |
Initialize from serialization data. More... | |
virtual QByteArray | fileContent () const override |
Returns the original file content. More... | |
virtual void | guessSettings () override |
Guess appropriate settings (for example the separator in a CSV file). More... | |
virtual void | initWithDefaultImportSettings () override |
Set import settings to defaults. More... | |
virtual QStringList | lineUnrelatedErrors () const override |
Errors not related to a particular line. More... | |
virtual QString | name () const override |
The name shown in the format selection combo. More... | |
virtual int | numErrors () const override |
Number of errors found while processing the content. More... | |
virtual int | numLineRelatedErrors () const override |
Number of errors related to a specific line. More... | |
virtual QString | persistentClassName () const override |
A name which can be used for save/load purposes (which will not change ever more) More... | |
virtual void | populateImportSettingsWidget (QWidget *parent) override |
Fills the widget on the import dialog pane. More... | |
virtual void | processContents () override |
Process the file contents. More... | |
RealDataItem * | realDataItem () |
The real data item on which the import shall work. More... | |
const RealDataItem * | realDataItem () const |
The real data item on which the import shall work. More... | |
virtual QByteArray | serialize () const override |
Returns every internal setting so it can be restored completely. More... | |
virtual void | setFileContents (const QByteArray &fileContent) override |
Sets the file contents to be imported. More... | |
void | setRealDataItem (RealDataItem *item) |
Define the real data item on which the import shall work. More... | |
Protected Types | |
enum class | Error { DifferendNumberOfColumns } |
Protected Attributes | |
RealDataItem * | m_item |
Private Types | |
enum class | DataType { Q , R , dR } |
enum class | UnitInFile { none , perNanoMeter , perAngstrom , other } |
Private Member Functions | |
void | calculateFromParseResult () const |
void | createOutputDataFromParsingResult (RealDataItem *item) const |
void | parseFileContent () const |
Private Attributes | |
QByteArray | m_fileContent |
ImportResult | m_importResult |
struct QREDataLoader::ImportSettings | m_importSettings |
QPointer< QREDataLoaderProperties > | m_propertiesWidget |
Friends | |
QDataStream & | operator<< (QDataStream &stream, const QREDataLoader::ErrorDefinition &s) |
QDataStream & | operator<< (QDataStream &stream, const QREDataLoader::ImportSettings &s) |
QDataStream & | operator>> (QDataStream &stream, QREDataLoader::ErrorDefinition &s) |
QDataStream & | operator>> (QDataStream &stream, QREDataLoader::ImportSettings &s) |
class | QREDataLoaderResultModel |
Real data loader for Q/R/E reflectometry CSV files.
Definition at line 27 of file QREDataLoader.h.
|
strongprivate |
|
strongprotectedinherited |
Enumerator | |
---|---|
DifferendNumberOfColumns |
Definition at line 119 of file AbstractDataLoader.h.
|
strongprivate |
QREDataLoader::QREDataLoader | ( | ) |
Definition at line 78 of file QREDataLoader.cpp.
References initWithDefaultImportSettings().
Referenced by clone().
|
overridevirtual |
Read all values from the properties UI into the internal variables.
Reimplemented from AbstractDataLoader.
Definition at line 591 of file QREDataLoader.cpp.
References QREDataLoader::ImportSettings::columnDefinitions, dR, QREDataLoader::ImportSettings::headerPrefix, QREDataLoader::ImportSettings::linesToSkip, m_importSettings, m_propertiesWidget, perAngstrom, perNanoMeter, Q, and QREDataLoader::ImportSettings::separator.
|
private |
Definition at line 445 of file QREDataLoader.cpp.
References QREDataLoader::ImportResult::addError(), QREDataLoader::ImportResult::clearCalculatedValues(), QREDataLoader::ImportSettings::columnDefinitions, QREDataLoader::ErrorDefinition::columnDoesNotContainValidNumber, dR, QREDataLoader::ErrorDefinition::duplicateQ, QREDataLoader::ImportResult::eValues, QREDataLoader::ImportResult::lines, m_importResult, m_importSettings, perAngstrom, Q, QREDataLoader::ImportResult::qValues, R, QREDataLoader::ImportResult::rawValues, QREDataLoader::ErrorDefinition::RGreaterOne, QREDataLoader::ErrorDefinition::RLessZero, QREDataLoader::ImportResult::rValues, QREDataLoader::ImportResult::validCalculatedLines, and QREDataLoader::ErrorDefinition::wrongQOrder.
Referenced by processContents().
|
overridevirtual |
Create a complete clone, including all internal states.
Implements AbstractDataLoader.
Definition at line 213 of file QREDataLoader.cpp.
References QREDataLoader(), and serialize().
|
signalinherited |
Emitted whenever contents have been processed.
Referenced by AutomaticDataLoader1D::processContents(), processContents(), and RealDataItem::setDataLoader().
|
private |
Definition at line 532 of file QREDataLoader.cpp.
References OutputData< T >::addAxis(), QREDataLoader::ImportResult::calculationErrors, OutputData< T >::clone(), SessionItem::getItem(), RealDataItem::initNativeData(), AxisNames::InitSpecAxis(), QREDataLoader::ImportResult::lines, m_importResult, JobItemUtils::nameFromAxesUnits(), DataItem::P_AXES_UNITS, QREDataLoader::ImportResult::qValues, QREDataLoader::ImportResult::rValues, SpecularDataItem::setAxesRangeToData(), SessionItem::setItemValue(), RealDataItem::setNativeDataUnits(), RealDataItem::setNativeOutputData(), SpecularDataItem::setOutputData(), OutputData< T >::setRawDataVector(), SessionItem::setVisible(), SpecularDataItem::setXaxisTitle(), SpecularDataItem::setYaxisTitle(), RealDataItem::specularDataItem(), and ComboProperty::variant().
Referenced by processContents().
|
overridevirtual |
Create a table model which contains the import information like original file content, raw content, processed content The returned pointer will be owned by the caller.
This base class' implementation does nothing (return nullptr).
Reimplemented from AbstractDataLoader.
Definition at line 293 of file QREDataLoader.cpp.
References m_importResult, and QREDataLoaderResultModel.
|
virtualinherited |
Return the default import settings.
Definition at line 31 of file AbstractDataLoader.cpp.
References AbstractDataLoader::clone().
|
overridevirtual |
Initialize from serialization data.
If any error occurred, then a DeserializationException has to be thrown. The complete state has to be restored. Therefore if e.g. errors occurred in the former serialization, but errors are not serialized, then they have to be regenerated/recalculated in here.
Reimplemented from AbstractDataLoader.
Definition at line 178 of file QREDataLoader.cpp.
References QREDataLoader::ImportResult::calculationErrors, QREDataLoader::ImportResult::clear(), QREDataLoader::ImportSettings::columnDefinitions, QREDataLoader::ImportResult::error, QREDataLoader::ImportResult::eValues, QREDataLoader::ImportResult::importSettings, QREDataLoader::ImportResult::lines, m_fileContent, m_importResult, m_importSettings, QREDataLoader::ImportResult::maxColumnCount, QREDataLoader::ImportResult::qValues, QREDataLoader::ImportResult::rawValues, QREDataLoader::ImportResult::rValues, DeserializationException::streamError(), DeserializationException::tooNew(), DeserializationException::tooOld(), and QREDataLoader::ImportResult::validCalculatedLines.
|
overridevirtual |
Returns the original file content.
If not available any more (like for legacy project file import), then an empty array will be returned.
Reimplemented from AbstractDataLoader.
Definition at line 298 of file QREDataLoader.cpp.
References m_fileContent.
Referenced by setFileContents().
|
overridevirtual |
Guess appropriate settings (for example the separator in a CSV file).
Is called only once, directly after setting the file content.
Reimplemented from AbstractDataLoader.
Definition at line 303 of file QREDataLoader.cpp.
References m_fileContent, m_importSettings, and QREDataLoader::ImportSettings::separator.
|
signalinherited |
Emitted whenever an import setting changed.
Referenced by UserDefinedDataLoader1D::UserDefinedDataLoader1D(), SpecularDataImportWidget::onFormatSelectionChanged(), and SpecularDataImportWidget::setItem().
|
overridevirtual |
Set import settings to defaults.
Reimplemented from AbstractDataLoader.
Definition at line 135 of file QREDataLoader.cpp.
References QREDataLoader::ImportSettings::columnDefinitions, dR, QREDataLoader::ImportSettings::headerPrefix, QREDataLoader::ImportSettings::linesToSkip, m_importSettings, none, perNanoMeter, Q, R, and QREDataLoader::ImportSettings::separator.
Referenced by QREDataLoader().
|
overridevirtual |
Errors not related to a particular line.
Reimplemented from AbstractDataLoader.
Definition at line 285 of file QREDataLoader.cpp.
References QREDataLoader::ImportResult::error, and m_importResult.
|
overridevirtual |
The name shown in the format selection combo.
Implements AbstractDataLoader.
Definition at line 83 of file QREDataLoader.cpp.
|
overridevirtual |
Number of errors found while processing the content.
An error means that either a particular content (line) can't be used or may be suspicious (line related error), or that the whole content can't be used (e.g. only 1 line present).
Reimplemented from AbstractDataLoader.
Definition at line 275 of file QREDataLoader.cpp.
References QREDataLoader::ImportResult::calculationErrors, QREDataLoader::ImportResult::error, and m_importResult.
|
overridevirtual |
Number of errors related to a specific line.
Such an error means that a particular content (line) can't be used or may be suspicious.
Reimplemented from AbstractDataLoader.
Definition at line 280 of file QREDataLoader.cpp.
References QREDataLoader::ImportResult::calculationErrors, and m_importResult.
|
private |
Definition at line 372 of file QREDataLoader.cpp.
References QREDataLoader::ImportResult::clear(), QREDataLoader::ImportSettings::headerPrefix, QREDataLoader::ImportResult::lines, QREDataLoader::ImportSettings::linesToSkip, m_fileContent, m_importResult, m_importSettings, QREDataLoader::ImportResult::maxColumnCount, QREDataLoader::ImportResult::rawValues, and QREDataLoader::ImportSettings::separator.
Referenced by processContents().
|
overridevirtual |
A name which can be used for save/load purposes (which will not change ever more)
Implements AbstractDataLoader.
Definition at line 88 of file QREDataLoader.cpp.
|
overridevirtual |
Fills the widget on the import dialog pane.
This base class' implementation does nothing (meaning "no editable properties")
Reimplemented from AbstractDataLoader.
Definition at line 93 of file QREDataLoader.cpp.
References QREDataLoader::ImportSettings::columnDefinitions, dR, QREDataLoader::ImportSettings::headerPrefix, QREDataLoader::ImportSettings::linesToSkip, m_importSettings, m_propertiesWidget, perAngstrom, QREDataLoaderProperties::propertiesChanged(), Q, R, and QREDataLoader::ImportSettings::separator.
|
overridevirtual |
Process the file contents.
Can be called more than once, e.g. if the import settings have changed. Any error has to be stored in the loader (see numErrors()).
Implements AbstractDataLoader.
Definition at line 220 of file QREDataLoader.cpp.
References ASSERT, calculateFromParseResult(), QREDataLoader::ImportSettings::columnDefinitions, AbstractDataLoader::contentsProcessed(), createOutputDataFromParsingResult(), QREDataLoader::ImportResult::error, QREDataLoader::ImportSettings::headerPrefix, QREDataLoader::ImportResult::importSettings, RealDataItem::isSpecularData(), QREDataLoader::ImportSettings::linesToSkip, m_importResult, m_importSettings, AbstractDataLoader::m_item, parseFileContent(), RealDataItem::removeNativeData(), QREDataLoader::ImportSettings::separator, SpecularDataItem::setOutputData(), RealDataItem::specularDataItem(), and QREDataLoader::ImportResult::validCalculatedLines.
|
inherited |
The real data item on which the import shall work.
Definition at line 70 of file AbstractDataLoader.cpp.
References AbstractDataLoader::m_item.
|
inherited |
The real data item on which the import shall work.
Definition at line 75 of file AbstractDataLoader.cpp.
References AbstractDataLoader::m_item.
|
overridevirtual |
Returns every internal setting so it can be restored completely.
Reimplemented from AbstractDataLoader.
Definition at line 151 of file QREDataLoader.cpp.
References QREDataLoader::ImportResult::calculationErrors, QREDataLoader::ImportResult::error, QREDataLoader::ImportResult::eValues, QREDataLoader::ImportResult::importSettings, QREDataLoader::ImportResult::lines, m_fileContent, m_importResult, m_importSettings, QREDataLoader::ImportResult::maxColumnCount, QREDataLoader::ImportResult::qValues, QREDataLoader::ImportResult::rawValues, QREDataLoader::ImportResult::rValues, and QREDataLoader::ImportResult::validCalculatedLines.
Referenced by clone(), and QREDataLoader::ImportSettings::operator!=().
|
overridevirtual |
Sets the file contents to be imported.
If the file was a compressed file, here already the decompressed content will be overhanded.
Implements AbstractDataLoader.
Definition at line 367 of file QREDataLoader.cpp.
References fileContent(), and m_fileContent.
|
inherited |
Define the real data item on which the import shall work.
Definition at line 65 of file AbstractDataLoader.cpp.
References AbstractDataLoader::m_item.
Referenced by ImportDataUtils::Import1dData(), and SpecularDataImportWidget::onFormatSelectionChanged().
|
friend |
Definition at line 759 of file QREDataLoader.cpp.
|
friend |
Definition at line 577 of file QREDataLoader.cpp.
|
friend |
Definition at line 773 of file QREDataLoader.cpp.
|
friend |
Definition at line 583 of file QREDataLoader.cpp.
|
friend |
Definition at line 134 of file QREDataLoader.h.
Referenced by createResultModel().
|
private |
Definition at line 126 of file QREDataLoader.h.
Referenced by deserialize(), fileContent(), guessSettings(), parseFileContent(), serialize(), and setFileContents().
|
mutableprivate |
Definition at line 125 of file QREDataLoader.h.
Referenced by calculateFromParseResult(), createOutputDataFromParsingResult(), createResultModel(), deserialize(), lineUnrelatedErrors(), numErrors(), numLineRelatedErrors(), parseFileContent(), processContents(), and serialize().
|
private |
|
protectedinherited |
Definition at line 122 of file AbstractDataLoader.h.
Referenced by AutomaticDataLoader1D::createResultModel(), AutomaticDataLoader1D::processContents(), processContents(), AbstractDataLoader::realDataItem(), and AbstractDataLoader::setRealDataItem().
|
private |
Definition at line 128 of file QREDataLoader.h.
Referenced by applyImportSettings(), and populateImportSettingsWidget().