- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试一个看似扭曲的想法,但我喜欢挑战,尽管它只是我发明的 C++ 练习。
任务是在 d 维度中存储一系列 n 标量。想象一下,有一个 vector 、矩阵或 n double 或整数或其他任何东西的 3D 矩阵,并在运行时选择有多少(手动计算,没什么特别的)。
比方说,我想要一个长 4
的一维数组,包含两个 double 值(n == 2
,d == 1
,在运行时我说我想要存储 4
):
| d0 d1 | d0 d1 | d0 d1 | d0 d1 |
或者 3 个 double 的 2D 2x4
网格(n == 3
,d == 2
,在运行时我说我想要一个2 * 4
的存储):
| d0 d1 d2 | d0 d1 d2 | d0 d1 d2 | d0 d1 d2 |
| d0 d1 d2 | d0 d1 d2 | d0 d1 d2 | d0 d1 d2 |
例如,我如何访问网格的第 i, j
元素?当然,使用运算符......但我想编写一个单个运算符,将引用元组返回给三个 double 。
给出一个想法:
template <std::size_t n, std::size_t d, typename Number>
class storage
{
public:
// Magic tricks here?
auto operator()(std::size_t i_0, ..., std::size_t i_d) -> std::tuple<n std::ref<Number>s>
{
}
};
问题是,我怎样才能在这里玩一些神奇的模板技巧来定义一个返回同类类型元组的运算符?
我发现特别难以思考如何定义该元组,当然还有必须恰好有 d 个参数的运算符。
至于用法,我希望能够像这样工作,例如在 2D 示例中:
// define a matrix of three doubles
storage<3, 2, double> storageobj(8);
// get a block, these should be references
auto block = storageobj(0, 1);
std::get<0>(block) = -123.456;
请注意,我现在不关心如何访问内存中的元素的实际实现,但返回类型的定义和如何制作 operator()
是主要目标这个练习。
一些神奇的 TMP 能帮上忙吗?
最佳答案
我将 MultiArray
从 How to allocate & access 3D, 4D, 5D arrays? 更改为具有一些带有 std::array
的静态大小:
template <typename T, std::size_t Dim>
class MultiArray
{
public:
explicit MultiArray(const std::array<std::size_t, Dim>& dimensions) :
dimensions(dimensions),
values(computeTotalSize(dimensions))
{
assert(!values.empty());
}
const T& get(const std::array<std::size_t, Dim>& indexes) const
{
return values[computeIndex(indexes)];
}
T& get(const std::array<std::size_t>& indexes)
{
return values[computeIndex(indexes)];
}
std::size_t computeIndex(const std::array<std::size_t, Dim>& indexes) const
{
size_t index = 0;
size_t mul = 1;
for (size_t i = 0; i != dimensions.size(); ++i) {
assert(indexes[i] < dimensions[i]);
index += indexes[i] * mul;
mul *= dimensions[i];
}
assert(index < values.size());
return index;
}
std::array<std::size_t, Dim> computeIndexes(std::size_t index) const
{
assert(index < values.size());
std::array<std::size_t, Dim> res;
std::size_t mul = values.size();
for (std::size_t i = dimensions.size(); i != 0; --i) {
mul /= dimensions[i - 1];
res[i - 1] = index / mul;
assert(res[i - 1] < dimensions[i - 1]);
index -= res[i - 1] * mul;
}
return res;
}
private:
std::size_t computeTotalSize(const std::array<std::size_t, Dim>& dimensions) const
{
std::size_t totalSize = 1;
for (auto i : dimensions) {
totalSize *= i;
}
return totalSize;
}
private:
std::array<std::size_t, Dim> dimensions;
std::vector<T> values;
};
然后添加层使其适应您的界面(为了避免这种情况,MultiArray
的编写可能类似于 storage_impl
)。
为了将 array<std::size_t, N>
转换为 std::size_t, .., std::size_t
,我们使用 std::index_sequence<0, 1, 2, .., N - 1>
来允许可变参数扩展。然后我们只需要将其转换为类型:
template <std::size_t, typename T>
using always_type = T;
template <std::size_t n, typename Seq, typename Number>
class storage_impl;
template <std::size_t n, typename Number, std::size_t ... Is>
class storage_impl<n, std::index_sequence<Is...>, Number>
{
public:
storage_impl(always_type<Is, std::size_t>... dims) : array{{{dims...}}} ()
std::array<Number, n>&
operator()(always_type<Is, std::size_t>... indexes)
{
return array.get({{indexes...}});
}
const std::array<Number, n>&
operator()(always_type<Is, std::size_t>... indexes) const
{
return array.get({{indexes...}});
}
private:
MultiArray<std::array<Number, n>, sizeof...(Is)> array;
};
最后:
template <std::size_t n, std::size_t d, typename Number>
using storage = storage_impl<n, std::make_index_sequence<d>, Number>;
用法类似于:
// define a 2D matrix of three doubles
storage<3, 2, double> storageobj(2, 4); // matrix 2x4 of std::array<double, 3>
auto&& block = storageobj(0, 1); // std::array<double, 3>&
std::get<0>(block) = -123.456; // or block[0] = -123.456
关于c++ - 定义 d 维度的数字元组并访问它们,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52971550/
我想使用批处理从文件夹中读取图像。但是解码后,当我使用tf.train.batch时可能会出现一些问题。这是代码。 def get_batch(image, label, batch_size, ca
我正在使用 tf.unsorted_segment_sum TensorFlow 的方法,当我作为数据给出的张量只有一行时,它工作正常。例如: tf.unsorted_segment_sum(tf.c
我想创建一个正则表达式来检查有效维度JavaScript 中的长度 x 宽度 x 高度。 例如90.49 x 34.93 x 40.64 我打算使用的示例代码: var dimensionRegex
ViewPager 是否必须是 Activity 布局中唯一存在的对象?我正在尝试实现这样的东西: 我应该在什么地方有一个大的寻呼机在顶部滚动(我有)和一个较小的画廊在它下面滚动。这只向我显示寻
据我所知,(维度、维度属性和事实)差异的最佳示例如下所示: 维度 - 产品、帐户、客户 维度属性 - ProductName、ProductNumber、CustomerName、CustomerNu
我是 Numpy 的新手,正在尝试理解什么是维度的基本问题, 我尝试了以下命令并试图理解为什么最后两个数组的 ndim 相同? >>> a= array([1,2,3]) >>> a.ndim 1 >
我对 MDX 比较陌生,正在尝试完成我认为应该很容易的事情,但我还没有找到任何解决方案。 我有一个销售立方体,其中一个衡量标准是利润,它可以是负数也可以是正数。我想得到一个有效的正利润总和的度量,即只
在大多数情况下,维度内层次结构的每个级别代表不同的概念(即国家->地区->城市、年->月->日),这很简单,可以在多维数据集中使用。 我感兴趣的是可变深度层次结构,它往往由相同概念的实例组成,即计算机
我正在尝试创建一个方法来总结潜在的项目并从数组返回该总和。以下是一些预期的示例输入: arraySum(new int[10]); // 10 arraySum(new int[2][5]); //
我正在尝试初始化一个二维数组(我创建的类对象),但我仍然遇到相同的运行时错误: Exception in thread "main" java.lang.NullPoointerException
(我是一名学生,这是我第一次发帖,所以请放轻松。)我想创建一个将二维数组作为参数的函数,并且在该数组中,我想要一个变量,稍后我想在代码中对其进行修改。这是最接近我想要的例子的东西: int size;
我想我可能会问一个虚拟问题,但我对 Android 编程还是个新手,而且我无法(尽管我付出了所有努力)在 Google 上找到我的答案。 问题是,我正在尝试使用 2D 图形开发一个小游戏。我希望我的“
如何使用 Crossfilter 过滤一系列日期?当我知道该时间段之间存在事实记录时,以下内容不起作用。 Var myDimension = CrossFilterObj.dimension(func
我正在启动另一个应用程序并设置其主要 HWND 位置和大小。我正在使用 STARTUPINFO指定窗口尺寸的标志,但看起来只有在新进程使用 CW_USEDEFAULT 时才会遵循这些尺寸在其 Crea
我正在尝试使用 Keras 构建我的第一个神经网络。我的经验为零,我似乎无法弄清楚为什么我的维度不对。我无法从他们的文档中弄清楚这个错误在提示什么,甚至是什么层导致了它。 我的模型接受一个 32 字节
我有一个水平导航栏,我的 a 元素没有扩展到父 li 元素的宽度和高度。 如何修改我的 CSS,使 a 元素与外部/父级 li 元素一样宽和高?
如何只更改需要 Dimension 对象的组件的宽度或高度?目前我是这样做的: jbutton.setPreferredSize(new Dimension(button.getPreferredSi
哪些 OLAP 工具支持动态、动态地创建维度或层次结构? 例如,层次结构将成员定义为:“前 5 名”、“前 6-10 名”、“其他”... 计算成员是通常的答案,我正在寻找不同的东西。计算器的问题。成
我使用 1 个 div 元素为我的网站制作 .background 。它的高度将是 100%。为了实现这一点,我使用 jQuery 尺寸实用程序。 用这个脚本来获取高度 $('.background
MultiArray与使用 std::vector 创建多数组相比,在 boost 中有很多优势。但是,我对 BOOST 中的 MultiArray 感到不舒服的一件事是创建一个可以轻松更改其大小的多
我是一名优秀的程序员,十分优秀!