LSST Applications 27.0.0,g0265f82a02+469cd937ee,g02d81e74bb+21ad69e7e1,g1470d8bcf6+cbe83ee85a,g2079a07aa2+e67c6346a6,g212a7c68fe+04a9158687,g2305ad1205+94392ce272,g295015adf3+81dd352a9d,g2bbee38e9b+469cd937ee,g337abbeb29+469cd937ee,g3939d97d7f+72a9f7b576,g487adcacf7+71499e7cba,g50ff169b8f+5929b3527e,g52b1c1532d+a6fc98d2e7,g591dd9f2cf+df404f777f,g5a732f18d5+be83d3ecdb,g64a986408d+21ad69e7e1,g858d7b2824+21ad69e7e1,g8a8a8dda67+a6fc98d2e7,g99cad8db69+f62e5b0af5,g9ddcbc5298+d4bad12328,ga1e77700b3+9c366c4306,ga8c6da7877+71e4819109,gb0e22166c9+25ba2f69a1,gb6a65358fc+469cd937ee,gbb8dafda3b+69d3c0e320,gc07e1c2157+a98bf949bb,gc120e1dc64+615ec43309,gc28159a63d+469cd937ee,gcf0d15dbbd+72a9f7b576,gdaeeff99f8+a38ce5ea23,ge6526c86ff+3a7c1ac5f1,ge79ae78c31+469cd937ee,gee10cc3b42+a6fc98d2e7,gf1cff7945b+21ad69e7e1,gfbcc870c63+9a11dc8c8f
LSST Data Management Base Package
Loading...
Searching...
No Matches
Public Member Functions | Public Attributes | List of all members
lsst::afw::math::Kernel::PersistenceHelper Struct Reference

#include <KernelPersistenceHelper.h>

Public Member Functions

 PersistenceHelper (int nSpatialFunctions)
 
 PersistenceHelper (afw::table::Schema const &schema_)
 
std::shared_ptr< afw::table::BaseRecordwrite (afw::table::io::OutputArchiveHandle &handle, Kernel const &kernel) const
 
void writeSpatialFunctions (afw::table::io::OutputArchiveHandle &handle, afw::table::BaseRecord &record, std::vector< SpatialFunctionPtr > const &spatialFunctionList) const
 
std::vector< SpatialFunctionPtrreadSpatialFunctions (afw::table::io::InputArchive const &archive, afw::table::BaseRecord const &record) const
 

Public Attributes

afw::table::Schema schema
 
afw::table::PointKey< int > dimensions
 
afw::table::PointKey< int > center
 
afw::table::Key< afw::table::Array< int > > spatialFunctions
 

Detailed Description

Definition at line 39 of file KernelPersistenceHelper.h.

Constructor & Destructor Documentation

◆ PersistenceHelper() [1/2]

lsst::afw::math::Kernel::PersistenceHelper::PersistenceHelper ( int nSpatialFunctions)
explicit

Definition at line 33 of file KernelPersistenceHelper.cc.

34 : schema(),
36 "dimensions of a Kernel's images", "pixel")),
37 center(afw::table::PointKey<int>::addFields(schema, "center", "center point in a Kernel image",
38 "pixel")) {
39 if (nSpatialFunctions > 0) {
40 spatialFunctions = schema.addField<afw::table::Array<int>>(
41 "spatialfunctions", "archive IDs for the Kernel's spatial functions", nSpatialFunctions);
42 }
43}
static PointKey addFields(Schema &schema, std::string const &name, std::string const &doc, std::string const &unit)
Add a pair of _x, _y fields to a Schema, and return a PointKey that points to them.
Definition aggregates.cc:36
afw::table::Key< afw::table::Array< int > > spatialFunctions

◆ PersistenceHelper() [2/2]

lsst::afw::math::Kernel::PersistenceHelper::PersistenceHelper ( afw::table::Schema const & schema_)
explicit

Definition at line 45 of file KernelPersistenceHelper.cc.

46 : schema(schema_), dimensions(schema["dimensions"]), center(schema["center"]) {
47 try {
48 spatialFunctions = schema["spatialfunctions"];
49 } catch (...) {
50 }
51}

Member Function Documentation

◆ readSpatialFunctions()

std::vector< std::shared_ptr< Kernel::SpatialFunction > > lsst::afw::math::Kernel::PersistenceHelper::readSpatialFunctions ( afw::table::io::InputArchive const & archive,
afw::table::BaseRecord const & record ) const

Definition at line 75 of file KernelPersistenceHelper.cc.

76 {
77 ndarray::Array<int const, 1, 1> array = record[spatialFunctions];
78 std::vector<std::shared_ptr<Kernel::SpatialFunction>> spatialFunctionList(array.getSize<0>());
79 for (std::size_t n = 0; n < spatialFunctionList.size(); ++n) {
80 spatialFunctionList[n] = archive.get<SpatialFunction>(array[n]);
81 LSST_ARCHIVE_ASSERT(array[n] == 0 || (spatialFunctionList[n]));
82 }
83 return spatialFunctionList;
84}
#define LSST_ARCHIVE_ASSERT(EXPR)
An assertion macro used to validate the structure of an InputArchive.
Definition Persistable.h:48
lsst::afw::math::Function2< double > SpatialFunction
Definition Kernel.h:114

◆ write()

std::shared_ptr< afw::table::BaseRecord > lsst::afw::math::Kernel::PersistenceHelper::write ( afw::table::io::OutputArchiveHandle & handle,
Kernel const & kernel ) const

Definition at line 53 of file KernelPersistenceHelper.cc.

54 {
55 afw::table::BaseCatalog catalog = handle.makeCatalog(schema);
56 std::shared_ptr<afw::table::BaseRecord> record = catalog.addNew();
57 record->set(dimensions, lsst::geom::Point2I(kernel.getDimensions()));
58 record->set(center, kernel.getCtr());
59 if (spatialFunctions.isValid()) {
60 writeSpatialFunctions(handle, *record, kernel._spatialFunctionList);
61 }
62 handle.saveCatalog(catalog);
63 return record;
64}
CatalogT< BaseRecord > BaseCatalog
Definition fwd.h:72
void writeSpatialFunctions(afw::table::io::OutputArchiveHandle &handle, afw::table::BaseRecord &record, std::vector< SpatialFunctionPtr > const &spatialFunctionList) const

◆ writeSpatialFunctions()

void lsst::afw::math::Kernel::PersistenceHelper::writeSpatialFunctions ( afw::table::io::OutputArchiveHandle & handle,
afw::table::BaseRecord & record,
std::vector< SpatialFunctionPtr > const & spatialFunctionList ) const

Definition at line 66 of file KernelPersistenceHelper.cc.

68 {
69 ndarray::Array<int, 1, 1> array = record[spatialFunctions];
70 for (std::size_t n = 0; n < spatialFunctionList.size(); ++n) {
71 array[n] = handle.put(spatialFunctionList[n]);
72 }
73}
T size(T... args)

Member Data Documentation

◆ center

afw::table::PointKey<int> lsst::afw::math::Kernel::PersistenceHelper::center

Definition at line 42 of file KernelPersistenceHelper.h.

◆ dimensions

afw::table::PointKey<int> lsst::afw::math::Kernel::PersistenceHelper::dimensions

Definition at line 41 of file KernelPersistenceHelper.h.

◆ schema

afw::table::Schema lsst::afw::math::Kernel::PersistenceHelper::schema

Definition at line 40 of file KernelPersistenceHelper.h.

◆ spatialFunctions

afw::table::Key<afw::table::Array<int> > lsst::afw::math::Kernel::PersistenceHelper::spatialFunctions

Definition at line 43 of file KernelPersistenceHelper.h.


The documentation for this struct was generated from the following files: