STIR
6.2.0
|
Implementation of OutputFileFormat paradigm for the ECAT7 format. More...
#include "stir/IO/ECAT7ParametricDensityOutputFileFormat.h"
Public Member Functions | |
ECAT7ParametricDensityOutputFileFormat (const NumericType &=NumericType::SHORT, const ByteOrder &=ByteOrder::native) | |
virtual NumericType | set_type_of_numbers (const NumericType &, const bool warn=false) |
Set type of numbers to be used for output. More... | |
virtual ByteOrder | set_byte_order (const ByteOrder &, const bool warn=false) |
Set byte order to be used for output. More... | |
Public Member Functions inherited from stir::RegisteredParsingObject< ECAT7ParametricDensityOutputFileFormat< DiscretisedDensityT >, OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > >, OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > > > | |
std::string | get_registered_name () const override |
Returns Derived::registered_name. | |
std::string | parameter_info () override |
Returns a string with all parameters and their values, in a form suitable for parsing again. | |
Public Member Functions inherited from stir::OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > > | |
OutputFileFormat (const NumericType &=NumericType::FLOAT, const ByteOrder &=ByteOrder::native) | |
Succeeded | write_to_file (std::string &filename, const ParametricDiscretisedDensity< DiscretisedDensityT > &data) const |
Write a single image to file. More... | |
Succeeded | write_to_file (const std::string &filename, const ParametricDiscretisedDensity< DiscretisedDensityT > &density) const |
write a single image to file More... | |
NumericType | get_type_of_numbers () const |
get type used for outputting numbers | |
ByteOrder | get_byte_order () |
get byte order used for output | |
float | get_scale_to_write_data () const |
get scale to write the data More... | |
virtual void | set_byte_order_and_type_of_numbers (ByteOrder &, NumericType &, const bool warn=false) |
set byte order and data type used for output More... | |
virtual float | set_scale_to_write_data (const float new_scale_to_write_data, const bool warn=false) |
set scale outputting numbers More... | |
Public Member Functions inherited from stir::ParsingObject | |
ParsingObject (const ParsingObject &) | |
ParsingObject & | operator= (const ParsingObject &) |
void | ask_parameters () |
bool | parse (std::istream &f) |
bool | parse (const char *const filename) |
Public Attributes | |
std::string | default_scanner_name |
Static Public Attributes | |
static const char *const | registered_name = "ECAT7" |
Name which will be used when parsing an OutputFileFormat object. | |
Protected Member Functions | |
virtual Succeeded | actual_write_to_file (std::string &output_filename, const ParametricDiscretisedDensity< DiscretisedDensityT > &density) const |
virtual function called by write_to_file() More... | |
virtual void | set_defaults () |
Set defaults before parsing. | |
virtual void | initialise_keymap () |
Initialise all keywords. | |
virtual bool | post_processing () |
This will be called at the end of the parsing. More... | |
Protected Member Functions inherited from stir::OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > > | |
void | set_defaults () override |
sets value for output data type More... | |
void | initialise_keymap () override |
sets keys for output data type for parsing More... | |
bool | post_processing () override |
Checks if parameters have sensible values after parsing. More... | |
void | set_key_values () override |
overloaded member for ParsingObject::set_key_values() More... | |
Additional Inherited Members | |
Static Public Member Functions inherited from stir::RegisteredParsingObject< ECAT7ParametricDensityOutputFileFormat< DiscretisedDensityT >, OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > >, OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > > > | |
static OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > > * | read_from_stream (std::istream *) |
Construct a new object (of type Derived) by parsing the istream. More... | |
Static Public Member Functions inherited from stir::OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > > | |
static shared_ptr< OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > > > | default_sptr () |
A function to return a default output file format. | |
Static Public Member Functions inherited from stir::RegisteredObject< OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > > > | |
static OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > > * | read_registered_object (std::istream *in, const std::string ®istered_name) |
Construct a new object (of a type derived from Root, its actual type determined by the registered_name parameter) by parsing the istream. More... | |
static OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > > * | ask_type_and_parameters () |
ask the user for the type, and then calls read_registered_object(0, type) More... | |
static void | list_registered_names (std::ostream &stream) |
List all possible registered names to the stream. More... | |
Protected Types inherited from stir::RegisteredObject< OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > > > | |
typedef OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > > *(* | RootFactory) (std::istream *) |
The type of a root factory is a function, taking an istream* as argument, and returning a Root*. | |
typedef FactoryRegistry< std::string, RootFactory, interfile_less > | RegistryType |
The type of the registry. | |
Static Protected Member Functions inherited from stir::RegisteredObject< OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > > > | |
static RegistryType & | registry () |
Static function returning the registry. More... | |
Protected Attributes inherited from stir::OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > > | |
NumericType | type_of_numbers |
type used for outputting numbers | |
ByteOrder | file_byte_order |
byte order used for output | |
float | scale_to_write_data |
scale to write the data More... | |
Protected Attributes inherited from stir::ParsingObject | |
KeyParser | parser |
Implementation of OutputFileFormat paradigm for the ECAT7 format.
|
virtual |
Set type of numbers to be used for output.
Currently the return value will always be NumericType::SHORT
Reimplemented from stir::OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > >.
References stir::warning().
|
virtual |
Set byte order to be used for output.
Currently the return value will always be ByteOrder::BIGENDIAN
Reimplemented from stir::OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > >.
References stir::warning().
|
protectedvirtual |
virtual function called by write_to_file()
This function has to be overloaded by the derived class.
The reason we do not simply make write_to_file() virtual is that we have 2 versions of write_to_file. C++ rules are such that overloading the virtual function in a derived class means that the other version gets hidden. Having the non-virtual write_to_file() call the virtual actual_write_to_file() solves this problem.
Implements stir::OutputFileFormat< ParametricDiscretisedDensity< DiscretisedDensityT > >.
References stir::add_extension(), stir::ParametricDiscretisedDensity< DiscDensT >::construct_single_density(), stir::ecat::ecat7::DiscretisedDensity_to_ECAT7(), stir::ecat::ecat7::make_ECAT7_main_header(), and stir::warning().
|
protectedvirtual |
This will be called at the end of the parsing.
Reimplemented from stir::ParsingObject.
References stir::ecat::find_ECAT_system_type(), and stir::warning().