52 template<
typename dtype>
58 Shape outShape(inShape);
59 outShape.
rows += inBoundarySize * 2;
60 outShape.
cols += inBoundarySize * 2;
63 outArray.
put(
Slice(inBoundarySize, inBoundarySize + inShape.
rows),
64 Slice(inBoundarySize, inBoundarySize + inShape.
cols), inImage);
66 for (
uint32 row = 0; row < inBoundarySize; ++row)
70 Slice(inBoundarySize, inBoundarySize + inShape.
cols),
71 inImage(inBoundarySize - row,
Slice(0, inShape.
cols)));
74 outArray.
put(row + inBoundarySize + inShape.
rows,
75 Slice(inBoundarySize, inBoundarySize + inShape.
cols),
79 for (
uint32 col = 0; col < inBoundarySize; ++col)
82 outArray.
put(
Slice(inBoundarySize, inBoundarySize + inShape.
rows),
84 inImage(
Slice(0, inShape.
rows), inBoundarySize - col));
87 outArray.
put(
Slice(inBoundarySize, inBoundarySize + inShape.
rows),
88 col + inBoundarySize + inShape.
cols,
94 Slice(0, inBoundarySize)));
98 const uint32 upperRowStart = outShape.
rows - 2 * inBoundarySize - 1;
100 Slice(0, inBoundarySize)));
104 outArray.
put(
Slice(0, inBoundarySize),
Slice(0, inBoundarySize), lowerLeft);
105 outArray.
put(
Slice(0, inBoundarySize),
Slice(outShape.
cols - inBoundarySize, outShape.
cols), lowerRight);
107 Slice(0, inBoundarySize), upperLeft);
109 Slice(outShape.
cols - inBoundarySize, outShape.
cols), upperRight);
#define STATIC_ASSERT_ARITHMETIC(dtype)
Definition: StaticAsserts.hpp:37
Holds 1D and 2D arrays, the main work horse of the NumCpp library.
Definition: NdArrayCore.hpp:72
NdArray< dtype > & put(int32 inIndex, value_type inValue)
Definition: NdArrayCore.hpp:3856
Shape shape() const noexcept
Definition: NdArrayCore.hpp:4483
A Shape Class for NdArrays.
Definition: Core/Shape.hpp:41
uint32 rows
Definition: Core/Shape.hpp:44
uint32 cols
Definition: Core/Shape.hpp:45
A Class for slicing into NdArrays.
Definition: Slice.hpp:44
NdArray< dtype > mirror2d(const NdArray< dtype > &inImage, uint32 inBoundarySize)
Definition: mirror2d.hpp:53
Definition: Coordinate.hpp:45
NdArray< dtype > flipud(const NdArray< dtype > &inArray)
Definition: flipud.hpp:48
std::uint32_t uint32
Definition: Types.hpp:40