Loading...
Searching...
No Matches
PolarProductOp.h
1/*
2
3MIT License
4
5Copyright (c) 2017 FMI Open Development / Markus Peura, first.last@fmi.fi
6
7Permission is hereby granted, free of charge, to any person obtaining a copy
8of this software and associated documentation files (the "Software"), to deal
9in the Software without restriction, including without limitation the rights
10to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11copies of the Software, and to permit persons to whom the Software is
12furnished to do so, subject to the following conditions:
13
14The above copyright notice and this permission notice shall be included in all
15copies or substantial portions of the Software.
16
17THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23SOFTWARE.
24
25*/
26/*
27Part of Rack development has been done in the BALTRAD projects part-financed
28by the European Union (European Regional Development Fund and European
29Neighbourhood Partnership Instrument, Baltic Sea Region Programme 2007-2013)
30*/
31
32#ifndef RACK_PolarProductOP
33#define RACK_PolarProductOP
34
35#include "data/PolarODIM.h"
36#include "VolumeOp.h"
37
38namespace rack {
39
40// using namespace drain::image;
41
43
59class PolarProductOp : public VolumeOp<PolarODIM> {
60public:
61
62 PolarProductOp(const std::string & name = __FUNCTION__, const std::string & description = "");
63
64
66
67 virtual
69
70 static
71 const CoordinatePolicy polarCoordPolicy;
72
73
74
75protected:
76
77 bool aboveSeaLevel; // True, if altitude (input or output) is measured from sea level or radar site.
78
79 inline
80 void copyPolarGeometry(const PolarODIM & srcODIM, PlainData<PolarDst> & dstData) const {
81 dstData.odim.area.width = srcODIM.area.width;
82 dstData.odim.area.height = srcODIM.area.height;
83 dstData.odim.rscale = srcODIM.rscale;
84 dstData.data.setGeometry(dstData.odim.area.width, dstData.odim.area.height);
85 if (!dstData.odim.type.empty()){
86 dstData.data.setType(dstData.odim.type.at(0));
87 }
88 else {
89 // warn type not set?
90 }
91 };
92
93 // Copy Polar could be enough?
94 virtual inline
95 void setGeometry(const PolarODIM & srcODIM, PlainData<PolarDst> & dstData) const {
96 copyPolarGeometry(srcODIM, dstData);
97 }
98
100
112 virtual
113 void deriveDstGeometry(const DataSetMap<PolarSrc> & srcSweeps, PolarODIM & dstOdim, bool MINIMISE_RSCALE=false) const;
114
116
121 virtual
122 void determineMetadata(const DataSetMap<PolarSrc> & srcSweeps, PolarODIM & dstOdim) const;
123
124
125};
126
127
128} // namespace rack
129
130#endif /* RACKOP_H_ */
131
132// Rack
Policies for coordinate underflows and overflows.
Definition CoordinatePolicy.h:106
Definition Data.h:1370
Essential class for storing radar data.
Definition Data.h:300
Metadata structure for single-radar data (polar scans, volumes and products).
Definition PolarODIM.h:45
double & rscale
Beam-directional bin length [m].
Definition PolarODIM.h:77
Base class for flat (2D) products computed in the polar coordinate system. Volume is used as input.
Definition PolarProductOp.h:59
virtual void deriveDstGeometry(const DataSetMap< PolarSrc > &srcSweeps, PolarODIM &dstOdim, bool MINIMISE_RSCALE=false) const
Based on input data, find geometry that maximises range and ray count.
Definition PolarProductOp.cpp:101
virtual void determineMetadata(const DataSetMap< PolarSrc > &srcSweeps, PolarODIM &dstOdim) const
Update timestamps etc.
Definition PolarProductOp.cpp:199
Base class for radar data processors.
Definition VolumeOp.h:88
Definition DataSelector.cpp:44