Newer
Older
// SaveNeXus
// @author Freddie Akeroyd, STFC ISIS Faility
// @author Ronald Fowler, STFC eScience. Modified to fit with SaveNexusProcessed
//----------------------------------------------------------------------
// Includes
//----------------------------------------------------------------------
#include "MantidDataHandling/SaveNexus.h"
#include "MantidDataObjects/Workspace2D.h"
Ronald Fowler
committed
#include "MantidKernel/ArrayProperty.h"
Gigg, Martyn Anthony
committed
#include "MantidAPI/FileProperty.h"
#include "MantidKernel/BoundedValidator.h"
#include <cmath>
#include <boost/shared_ptr.hpp>
namespace Mantid {
namespace DataHandling {
Russell Taylor
committed
// Register the algorithm into the algorithm factory
DECLARE_ALGORITHM(SaveNexus)
Russell Taylor
committed
using namespace Kernel;
using namespace API;
using namespace DataObjects;
Russell Taylor
committed
/// Empty default constructor
SaveNexus::SaveNexus() : Algorithm() {}
Russell Taylor
committed
/** Initialisation method.
*
*/
void SaveNexus::init() {
// Declare required parameters, filename with ext {.nx,.nx5,xml} and input
// workspac
declareProperty(
new WorkspaceProperty<Workspace>("InputWorkspace", "", Direction::Input),
"Name of the workspace to be saved");
Russell Taylor
committed
std::vector<std::string> exts;
Peterson, Peter
committed
exts.push_back(".nxs");
exts.push_back(".nx5");
exts.push_back(".xml");
Gigg, Martyn Anthony
committed
declareProperty(new FileProperty("Filename", "", FileProperty::Save, exts),
"The name of the Nexus file to write, as a full or relative\n"
"path");
Russell Taylor
committed
//
// Declare optional input parameters
// These are:
// Title - string to describe data
// EntryNumber - integer >0 to be used in entry name "mantid_workspace_<n>"
// Within a file the entries will be sequential from
// 1.
// This option should allow overwrite of existing
// entry,
Russell Taylor
committed
// *not* addition of out-of-sequence entry numbers.
// spectrum_min, spectrum_max - range of "spectra" numbers to write
// spectrum_list list of spectra values to write
//
declareProperty("Title", "", boost::make_shared<NullValidator>(),
"A title to describe the saved workspace");
auto mustBePositive = boost::make_shared<BoundedValidator<int>>();
Russell Taylor
committed
mustBePositive->setLower(0);
// declareProperty("EntryNumber", Mantid::EMPTY_INT(), mustBePositive,
// "(Not implemented yet) The index number of the workspace within the Nexus
// file\n"
Russell Taylor
committed
// "(default leave unchanged)" );
declareProperty(
"WorkspaceIndexMin", 0, mustBePositive,
"Number of first WorkspaceIndex to read, only for single period data.\n"
"Not yet implemented");
declareProperty(
"WorkspaceIndexMax", Mantid::EMPTY_INT(), mustBePositive,
"Number of last WorkspaceIndex to read, only for single period data.\n"
"Not yet implemented.");
declareProperty(
new ArrayProperty<int>("WorkspaceIndexList"),
"List of WorkspaceIndex numbers to read, only for single period data.\n"
Russell Taylor
committed
declareProperty("Append", false, "Determines whether .nxs file needs to be\n"
"over written or appended");
// option which might be required in future - should be a choice e.g.
// MantidProcessed/Muon1
Russell Taylor
committed
// declareProperty("Filetype","",new NullValidator<std::string>);
}
Russell Taylor
committed
Russell Taylor
committed
/** Execute the algorithm. Currently just calls SaveNexusProcessed but could
* call write other formats if support added
*
* @throw runtime_error Thrown if algorithm cannot execute
*/
Russell Taylor
committed
// Retrieve the filename from the properties
m_filename = getPropertyValue("FileName");
m_inputWorkspace = getProperty("InputWorkspace");
Sofia Antony
committed
runSaveNexusProcessed();
Russell Taylor
committed
return;
}
Sofia Antony
committed
/** virtual method to set the non workspace properties for this algorithm
Janik Zikovsky
committed
* @param alg :: pointer to the algorithm
* @param propertyName :: name of the property
* @param propertyValue :: value of the property
* @param perioidNum :: period number
Sofia Antony
committed
*/
void SaveNexus::setOtherProperties(IAlgorithm *alg,
const std::string &propertyName,
const std::string &propertyValue,
int perioidNum) {
if (!propertyName.compare("Append")) {
if (perioidNum != 1) {
alg->setPropertyValue(propertyName, "1");
} else
alg->setPropertyValue(propertyName, propertyValue);
} else
Algorithm::setOtherProperties(alg, propertyName, propertyValue, perioidNum);
}
void SaveNexus::runSaveNexusProcessed() {
IAlgorithm_sptr saveNexusPro =
createChildAlgorithm("SaveNexusProcessed", 0.0, 1.0, true);
Russell Taylor
committed
// Pass through the same output filename
saveNexusPro->setPropertyValue("Filename", m_filename);
// Set the workspace property
std::string inputWorkspace = "InputWorkspace";
saveNexusPro->setProperty(inputWorkspace, m_inputWorkspace);
Russell Taylor
committed
//
std::vector<int> specList = getProperty("WorkspaceIndexList");
Russell Taylor
committed
if (!specList.empty())
saveNexusPro->setPropertyValue("WorkspaceIndexList",
getPropertyValue("WorkspaceIndexList"));
Russell Taylor
committed
//
int specMax = getProperty("WorkspaceIndexMax");
if (specMax != Mantid::EMPTY_INT()) {
saveNexusPro->setPropertyValue("WorkspaceIndexMax",
getPropertyValue("WorkspaceIndexMax"));
saveNexusPro->setPropertyValue("WorkspaceIndexMin",
getPropertyValue("WorkspaceIndexMin"));
Russell Taylor
committed
}
std::string title = getProperty("Title");
if (!title.empty())
saveNexusPro->setPropertyValue("Title", getPropertyValue("Title"));
Russell Taylor
committed
// Pass through the append property
saveNexusPro->setProperty<bool>("Append", getProperty("Append"));
Russell Taylor
committed
// If we're tracking history, add the entry before we save it to file
if (trackingHistory()) {
m_history->fillAlgorithmHistory(
this, Mantid::Kernel::DateAndTime::getCurrentTime(), 0,
Algorithm::g_execCount);
if (!isChild()) {
m_inputWorkspace->history().addHistory(m_history);
}
// this is a child algorithm, but we still want to keep the history.
else if (isRecordingHistoryForChild() && m_parentHistory) {
m_parentHistory->addChildHistory(m_history);
}
}
// Now execute the Child Algorithm. Catch and log any error, but don't stop.
Russell Taylor
committed
saveNexusPro->execute();
} catch (std::runtime_error &) {
g_log.error(
"Unable to successfully run SaveNexusprocessed Child Algorithm");
Ronald Fowler
committed
}
Russell Taylor
committed
if (!saveNexusPro->isExecuted())
g_log.error(
"Unable to successfully run SaveNexusProcessed Child Algorithm");
Russell Taylor
committed
//
progress(1);
}
/**
Overriden process groups.
*/
bool SaveNexus::processGroups() {
this->exec();
// We finished successfully.
setExecuted(true);
notificationCenter().postNotification(
new FinishedNotification(this, isExecuted()));
} // namespace DataHandling
} // namespace Mantid