我正在尝试构建一个数据结构来表示xtensor(3D矩阵,形状为(WIDTH,HEIGHT,3)形式的RGB图像。 每个“像素”包含通过像素坐标的函数收集的数据。基本上,我想复制这段代码在python中的作用:
image = [[cell_info(x, y) for x in range(WIDTH)]
for y in range(HEIGHT)]
其中单元格信息返回一个3个元素列表,代表颜色通道。
我认为执行此操作的正确方法应该是使用xgenerator,但老实说,我无法理解如何使用该类。
答案 0 :(得分:0)
我找到了解决方案:
我将cell_info更改为接受int channel
参数,以便它返回整数而不是数组。然后我这样写:
class img_generator_fn {
public:
using value_type = int;
img_generator_fn(const Map *map, const Position ¢er, shared_ptr<const Player> player,
const unsigned int field_radius)
: m_map(map), m_center(center), m_player(player), m_translation(-(field_radius + 1)) {}
~img_generator_fn() { m_map = nullptr; }
inline auto operator()(const unsigned int x, const unsigned int y, const unsigned int channel) const {
return m_map->at(m_center + Position(x, y))->cell_info(m_player, channel);
}
template <class It> inline auto element(It, It end) const {
return m_map->at(m_center + Position(*(end - 2) + m_translation, (*(end - 3)) + m_translation))
->cell_info(m_player, *(end - 1));
}
private:
const Map *m_map;
const Position &m_center;
shared_ptr<const Player> m_player;
const unsigned int m_translation;
};
template <unsigned int field_side> auto field(const Position ¢er, shared_ptr<const Player> player) const {
const array<unsigned int, 3> shape = {field_side, field_side, 3};
auto gen = xt::detail::make_xgenerator(img_generator_fn(this, center, player, (field_side - 1) / 2), shape);
return xt::xtensor_fixed<int, xt::xshape<field_side, field_side, 3>>(gen);
}
这里Map
代表2D矩阵,它是包含player
的togheter想要存储在图像中的信息的结构。函数at
在指定位置拾取地图单元(地图单元将转换为像素)。函数field
使用xgenerator从给定的Map生成一个以center
为中心的图像。