Table of Contents
This algorithm constructs a MatrixWorkspace when passed a vector for each of the X, Y, and E data values.
Name | Direction | Type | Default | Description |
---|---|---|---|---|
OutputWorkspace | Output | MatrixWorkspace | Mandatory | Name to be given to the created workspace. |
DataX | Input | dbl list | Mandatory | X-axis data values for workspace. |
DataY | Input | dbl list | Mandatory | Y-axis data values for workspace (measures). |
DataE | Input | dbl list | Error values for workspace. Optional. | |
NSpec | Input | number | 1 | Number of spectra to divide data into. |
UnitX | Input | string | The unit to assign to the XAxis | |
VerticalAxisUnit | Input | string | SpectraNumber | The unit to assign to the second Axis (leave blank for default Spectra number). Allowed values: [‘Degrees’, ‘DeltaE’, ‘DeltaE_inFrequency’, ‘DeltaE_inWavenumber’, ‘dSpacing’, ‘dSpacingPerpendicular’, ‘Empty’, ‘Energy’, ‘Energy_inWavenumber’, ‘Label’, ‘Momentum’, ‘MomentumTransfer’, ‘QSquared’, ‘SpinEchoLength’, ‘SpinEchoTime’, ‘Time’, ‘TOF’, ‘Wavelength’, ‘SpectraNumber’, ‘Text’] |
VerticalAxisValues | Input | str list | Values for the VerticalAxis. | |
Distribution | Input | boolean | False | Whether OutputWorkspace should be marked as a distribution. |
YUnitLabel | Input | string | Label for Y Axis | |
WorkspaceTitle | Input | string | Title for Workspace | |
ParentWorkspace | Input | MatrixWorkspace | Name of a parent workspace. | |
ParallelStorageMode | Input | string | Parallel::StorageMode::Cloned | The parallel storage mode of the output workspace for MPI builds. Allowed values: [‘Parallel::StorageMode::Cloned’, ‘Parallel::StorageMode::Distributed’, ‘Parallel::StorageMode::MasterOnly’] |
This algorithm constructs a MatrixWorkspace when passed a vector for each of the X, Y, and E data values. The unit for the X Axis can optionally be specified as any of the units in the Mantid Unit Factory (see the list of units currently available). Multiple spectra may be created by supplying the NSpec Property (integer, default 1). When this is provided the vectors are split into equal-sized spectra (all X, Y, E values must still be in a single vector for input).
When you use the input property ParentWorkspace, the new workspace is created with the same instrument (including its parameters), sample and run information, and comment field as the parent. The Y units and title are also copied from the parent workspace unless they are provided in the input properties passed to the algorithm.
Until release 3.11 (inclusive) this algorithm created a default (and potentially wrong) mapping from spectra to detectors if no parent workspace was given. This change has no effect if any of the following applies:
That is, only the following use is affected:
# See usage example below for setting up input data.
ws = CreateWorkspace(DataX=dataX, DataY=dataY, DataE=dataE, NSpec=4, UnitX="Wavelength")
LoadInstrument(ws, InstrumentName='MARI', RewriteSpectraMap=False)
# None of the spectra in `ws` maps to any detectors since detectors were not known
# at the time of workspace creation. The old behavior used to map spectra 1,2,3,4
# to detector IDs 1,2,3,4. This worked only accidentally if MARI contains detectors
# with IDs 1,2,3,4. Accidental mappings are not a feature anymore.
The solution to this is to set RewriteSpectraMapping=True, set the correct mapping by hand via ws.getSpectrum(i).setDetectorID(id), or use CreateWorkspace with a parent workspace that contains the correct instrument and mapping.
dataX = [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16]
dataY = [1,2,3,4,5,6,7,8,9,10,11,12]
dataE = [1,2,3,4,5,6,7,8,9,10,11,12]
# The workspace will be named "dataWS"
dataWS = CreateWorkspace(DataX=dataX, DataY=dataY, DataE=dataE, NSpec=4,UnitX="Wavelength")
Categories: Algorithms | Utility\Workspaces
C++ source: CreateWorkspace.cpp (last modified: 2018-03-07)
C++ header: CreateWorkspace.h (last modified: 2018-03-07)