LSSTApplications
20.0.0
LSSTDataManagementBasePackage
stack
1a1d771
Linux64
astshim
20.0.0
src
PermMap.cc
Go to the documentation of this file.
1
/*
2
* LSST Data Management System
3
* Copyright 2017 AURA/LSST.
4
*
5
* This product includes software developed by the
6
* LSST Project (http://www.lsst.org/).
7
*
8
* This program is free software: you can redistribute it and/or modify
9
* it under the terms of the GNU General Public License as published by
10
* the Free Software Foundation, either version 3 of the License, or
11
* (at your option) any later version.
12
*
13
* This program is distributed in the hope that it will be useful,
14
* but WITHOUT ANY WARRANTY; without even the implied warranty of
15
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
* GNU General Public License for more details.
17
*
18
* You should have received a copy of the LSST License Statement and
19
* the GNU General Public License along with this program. If not,
20
* see <https://www.lsstcorp.org/LegalNotices/>.
21
*/
22
#include <memory>
23
#include <algorithm>
// for std::max
24
#include <sstream>
25
#include <stdexcept>
26
27
#include "
astshim/base.h
"
28
#include "
astshim/Mapping.h
"
29
#include "
astshim/PermMap.h
"
30
31
namespace
{
32
40
void
checkConstant(
int
numConst,
std::vector<int>
const
& perm,
std::string
const
&
name
) {
41
int
maxConst = 0;
42
for
(
int
const
& innum : perm) {
43
maxConst =
std::max
(maxConst, -innum);
44
}
45
if
(maxConst > numConst) {
46
std::ostringstream
os
;
47
os
<<
name
<<
" specifies max constant number (min negative number) "
<< maxConst <<
", but only "
48
<< numConst <<
" constants are available"
;
49
throw
std::invalid_argument
(
os
.str());
50
}
51
}
52
53
}
// anonymous namespace
54
55
namespace
ast
{
56
57
AstPermMap* PermMap::makeRawMap(
std::vector<int>
const
& inperm,
std::vector<int>
const
& outperm,
58
std::vector<double>
const
& constant,
std::string
const
& options) {
59
if
(inperm.
empty
()) {
60
throw
std::invalid_argument
(
"inperm has no elements"
);
61
}
62
if
(outperm.
empty
()) {
63
throw
std::invalid_argument
(
"outperm has no elements"
);
64
}
65
// check `constant` (since AST does not)
66
checkConstant(constant.
size
(), inperm,
"inperm"
);
67
checkConstant(constant.
size
(), outperm,
"outperm"
);
68
69
double
const
* constptr = constant.
size
() > 0 ? constant.
data
() :
nullptr
;
70
auto
result
= astPermMap(inperm.
size
(), inperm.
data
(), outperm.
size
(), outperm.
data
(), constptr,
"%s"
,
71
options.
c_str
());
72
assertOK
();
73
return
result
;
74
}
75
76
}
// namespace ast
std::string
STL class.
ast::assertOK
void assertOK(AstObject *rawPtr1=nullptr, AstObject *rawPtr2=nullptr)
Throw std::runtime_error if AST's state is bad.
Definition:
base.cc:49
std::vector< int >
std::vector::size
T size(T... args)
base.h
PermMap.h
lsst::afw::geom.transform.transformContinued.name
string name
Definition:
transformContinued.py:32
std::string::c_str
T c_str(T... args)
std::invalid_argument
STL class.
result
py::object result
Definition:
_schema.cc:429
std::ostringstream
STL class.
ast
AST wrapper classes and functions.
Definition:
attributes_channel.dox:1
os
std::ostream * os
Definition:
Schema.cc:746
Mapping.h
std::vector::empty
T empty(T... args)
std::max
T max(T... args)
std::vector::data
T data(T... args)
Generated on Wed Jun 24 2020 18:10:06 for LSSTApplications by
1.8.18