LSST Applications g0265f82a02+0e5473021a,g02d81e74bb+bd2ed33bd6,g1470d8bcf6+c6d6eb38e2,g14a832a312+9d12ad093c,g2079a07aa2+86d27d4dc4,g2305ad1205+91a32aca49,g295015adf3+88246b6574,g2bbee38e9b+0e5473021a,g337abbeb29+0e5473021a,g3ddfee87b4+c34e8be1fa,g487adcacf7+85dcfbcc36,g50ff169b8f+96c6868917,g52b1c1532d+585e252eca,g591dd9f2cf+ea1711114f,g5a732f18d5+53520f316c,g64a986408d+bd2ed33bd6,g858d7b2824+bd2ed33bd6,g8a8a8dda67+585e252eca,g99cad8db69+016a06b37a,g9ddcbc5298+9a081db1e4,ga1e77700b3+15fc3df1f7,ga8c6da7877+ef4e3a5875,gb0e22166c9+60f28cb32d,gb6a65358fc+0e5473021a,gba4ed39666+c2a2e4ac27,gbb8dafda3b+b6d7b42999,gc120e1dc64+f745648b3a,gc28159a63d+0e5473021a,gcf0d15dbbd+c34e8be1fa,gdaeeff99f8+f9a426f77a,ge6526c86ff+508d0e0a30,ge79ae78c31+0e5473021a,gee10cc3b42+585e252eca,gf18bd8381d+8d59551888,gf1cff7945b+bd2ed33bd6,w.2024.16
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: