53 template<
typename dtype>
64 for (
uint32 row = 0; row < inShape.
rows; ++row)
67 for (
uint32 col = 0; col < inShape.
cols - 1; ++col)
69 sum +=
static_cast<double>(inArray(row, col + 1) - inArray(row, col)) / 2.0 +
70 static_cast<double>(inArray(row, col));
73 returnArray[row] =
sum * dx;
81 const Shape transShape = arrayTranspose.
shape();
83 for (
uint32 row = 0; row < transShape.
rows; ++row)
86 for (
uint32 col = 0; col < transShape.
cols - 1; ++col)
88 sum +=
static_cast<double>(arrayTranspose(row, col + 1) - arrayTranspose(row, col)) / 2.0 +
89 static_cast<double>(arrayTranspose(row, col));
92 returnArray[row] =
sum * dx;
100 for (
uint32 i = 0; i < inArray.
size() - 1; ++i)
102 sum +=
static_cast<double>(inArray[i + 1] - inArray[i]) / 2.0 +
static_cast<double>(inArray[i]);
129 template<
typename dtype>
135 if (inShapeY != inShapeX)
145 for (
uint32 row = 0; row < inShapeY.
rows; ++row)
148 for (
uint32 col = 0; col < inShapeY.
cols - 1; ++col)
150 const auto dx =
static_cast<double>(inArrayX(row, col + 1) - inArrayX(row, col));
151 sum += dx * (
static_cast<double>(inArrayY(row, col + 1) - inArrayY(row, col)) / 2.0 +
152 static_cast<double>(inArrayY(row, col)));
155 returnArray[row] =
sum;
164 const Shape transShape = arrayYTranspose.
shape();
166 for (
uint32 row = 0; row < transShape.
rows; ++row)
169 for (
uint32 col = 0; col < transShape.
cols - 1; ++col)
171 const auto dx =
static_cast<double>(arrayXTranspose(row, col + 1) - arrayXTranspose(row, col));
172 sum += dx * (
static_cast<double>(arrayYTranspose(row, col + 1) - arrayYTranspose(row, col)) / 2.0 +
173 static_cast<double>(arrayYTranspose(row, col)));
176 returnArray[row] =
sum;
184 for (
uint32 i = 0; i < inArrayY.
size() - 1; ++i)
186 const auto dx =
static_cast<double>(inArrayX[i + 1] - inArrayX[i]);
187 sum += dx * (
static_cast<double>(inArrayY[i + 1] - inArrayY[i]) / 2.0 +
static_cast<double>(inArrayY[i]));