SourceXtractorPlusPlus
0.13
Please provide a description of the project.
SEFramework
SEFramework
FITS
FitsWriter.h
Go to the documentation of this file.
1
17
/*
18
* FitsWriter.h
19
*
20
* Created on: May 23, 2017
21
* Author: mschefer
22
*/
23
24
#ifndef _SEFRAMEWORK_IMAGE_FITSWRITER_H_
25
#define _SEFRAMEWORK_IMAGE_FITSWRITER_H_
26
27
#include "
ElementsKernel/Logging.h
"
28
#include "
SEFramework/CoordinateSystem/CoordinateSystem.h
"
29
#include "
SEFramework/Image/Image.h
"
30
#include "
SEFramework/Image/WriteableBufferedImage.h
"
31
#include "
SEFramework/FITS/FitsImageSource.h
"
32
#include "
SEFramework/FITS/TemporaryFitsImageSource.h
"
33
34
namespace
SourceXtractor
{
35
36
static
Elements::Logging
fitsWriterLogger
=
Elements::Logging::getLogger
(
"FitsWriter"
);
37
43
class
FitsWriter
{
44
45
public
:
46
50
virtual
~FitsWriter
() =
default
;
51
52
template
<
typename
T>
53
static
void
writeFile
(
const
Image<T>
&image,
const
std::string
&
filename
,
54
const
std::shared_ptr<CoordinateSystem>
coord_system =
nullptr
,
bool
append
=
false
) {
55
auto
target_image = newImage<T>(
filename
, image.
getWidth
(), image.
getHeight
(), coord_system,
append
);
56
57
// FIXME optimize the copy by using tile boundaries, image chunks, etc
58
for
(
int
y
= 0;
y
< image.
getHeight
();
y
++) {
59
for
(
int
x
= 0;
x
< image.
getWidth
();
x
++) {
60
target_image->setValue(
x
,
y
, image.
getValue
(
x
,
y
));
61
}
62
}
63
}
64
65
template
<
typename
T>
66
static
std::shared_ptr<WriteableImage<T>
>
newImage
(
const
std::string
&
filename
,
int
width,
int
height,
67
const
std::shared_ptr<CoordinateSystem>
coord_system =
nullptr
,
bool
append
=
false
) {
68
fitsWriterLogger
.
debug
() <<
"Creating file "
<<
filename
;
69
70
auto
image_source = std::make_shared<FitsImageSource>(
filename
, width, height,
ImageTile::getTypeValue
(T()), coord_system,
append
);
71
return
WriteableBufferedImage<T>::create
(image_source);
72
}
73
74
template
<
typename
T>
75
static
std::shared_ptr<WriteableImage<T>
>
newTemporaryImage
(
const
std::string
&pattern,
int
width,
int
height) {
76
fitsWriterLogger
.
debug
() <<
"Creating temporary fits file"
;
77
78
auto
image_source = std::make_shared<TemporaryFitsImageSource>(pattern, width, height,
ImageTile::getTypeValue
(T()));
79
return
WriteableBufferedImage<T>::create
(image_source);
80
}
81
82
83
};
/* End of FitsReader class */
84
85
}
/* namespace SourceXtractor */
86
87
88
89
90
91
#endif
/* _SEFRAMEWORK_IMAGE_FITSWRITER_H_ */
SourceXtractor::FitsWriter::newImage
static std::shared_ptr< WriteableImage< T > > newImage(const std::string &filename, int width, int height, const std::shared_ptr< CoordinateSystem > coord_system=nullptr, bool append=false)
Definition:
FitsWriter.h:66
std::string
STL class.
std::shared_ptr
STL class.
WriteableBufferedImage.h
SourceXtractor::Image::getWidth
virtual int getWidth() const =0
Returns the width of the image in pixels.
conf.filename
string filename
Definition:
conf.py:63
Elements::Logging
SourceXtractor::FitsWriter::~FitsWriter
virtual ~FitsWriter()=default
Destructor.
TemporaryFitsImageSource.h
SourceXtractor::fitsWriterLogger
static Elements::Logging fitsWriterLogger
Definition:
FitsWriter.h:36
SourceXtractor::Image::getHeight
virtual int getHeight() const =0
Returns the height of the image in pixels.
SourceXtractor::Image
Interface representing an image.
Definition:
Image.h:43
CoordinateSystem.h
SourceXtractor
Definition:
Aperture.h:30
SourceXtractor::Image::getValue
virtual T getValue(int x, int y) const =0
Returns the value of the pixel with the coordinates (x,y)
Euclid::Table::FitsWriter
SourceXtractor::FitsWriter::writeFile
static void writeFile(const Image< T > &image, const std::string &filename, const std::shared_ptr< CoordinateSystem > coord_system=nullptr, bool append=false)
Definition:
FitsWriter.h:53
SourceXtractor::ImageTile::getTypeValue
static ImageType getTypeValue(float)
Definition:
ImageTile.h:109
Image.h
Elements::Logging::debug
void debug(const std::string &logMessage)
SourceXtractor::WriteableBufferedImage::create
static std::shared_ptr< WriteableBufferedImage< T > > create(std::shared_ptr< const ImageSource > source, std::shared_ptr< TileManager > tile_manager=TileManager::getInstance())
Definition:
WriteableBufferedImage.h:46
Elements::Logging::getLogger
static Logging getLogger(const std::string &name="")
SourceXtractor::FitsWriter::newTemporaryImage
static std::shared_ptr< WriteableImage< T > > newTemporaryImage(const std::string &pattern, int width, int height)
Definition:
FitsWriter.h:75
x
std::shared_ptr< DependentParameter< std::shared_ptr< EngineParameter > > > x
Definition:
MoffatModelFittingTask.cpp:94
Logging.h
Euclid::Table::FitsWriter::append
void append(const Table &table) override
y
std::shared_ptr< DependentParameter< std::shared_ptr< EngineParameter > > > y
Definition:
MoffatModelFittingTask.cpp:94
FitsImageSource.h
Generated by
1.8.20