- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我试图实现/弄清楚什么
我试图找出为任意维数编写通用容器( vector 、矩阵、高维对象)的最佳方法。应在编译时指定维数以及每个维的元素数,如下所示:
3
给出一个包含 3 个元素的 vector 10, 10
给出一个包含 100 个元素的矩阵 7, 5, 3
给出一个具有 105 个元素的二阶张量 double
) 元素乘以标量
double
,按元素添加两个兼容的容器等。此外,应该能够循环遍历所有元素,知道它们每个维度的相应索引,例如来自
(0, 0, 0)
至
(6, 4, 2)
对于张量。
template<
int N, // the number of elements to iterate for this dimension
int... otherN // the other dimension's lengths
> class dimIterator;
boxIterator
请记住这只是
dimIterator
的包装器秒
template<
typename dataType,
int... allN
> class boxIterator : public dimIterator<allN...> { // tried as member or inheritance
protected:
dataType* data;
public:
boxIterator(dataType* data) :
dimIterator<allN...>(),
data(data)
{
//cout << "constructing box iterator." << endl;
}
int getIndex() const {
int result = dimIterator<allN...>::getIndex();
return result;
}
dataType* getPtr() {
dataType* result = data + this->getIndex();
return result;
}
const dataType* getPtr() const {
dataType* result = data + this->getIndex();
return result;
}
bool isDone() const {return dimIterator<allN...>::isDone();}
boxIterator<dataType, allN...>& operator ++() {
dimIterator<allN...>::operator++();
return *this;
}
dataType& operator *() {return *(this->getPtr());}
const dataType& operator *() const {return *(this->getPtr());}
};
template<
int N, // the number of elements to iterate for this dimension
int... otherN // the other dimension's lengths
> class dimIterator : public dimIterator<otherN...> { // tried as member or inheritance
protected:
int i;
public:
dimIterator() :
dimIterator<otherN...>(),
i(0)
{
//cout << "constructing level with " << N << " gridpoints." << endl;
}
int getIndex() const {
int result = i + N*dimIterator<otherN...>::getIndex();
return result;
}
bool isDone() const {return dimIterator<otherN...>::isDone();}
dimIterator<N, otherN...>& operator ++() {
if(i<N-1) {
++i;
}
else {
i = 0;
dimIterator<otherN...>::operator++();
}
return *this;
}
};
template<int N> // stop recursion if only one dimension left
class dimIterator<N> {
protected:
int i;
public:
dimIterator() :
i(0)
{
//cout << "constructing last level with " << N << " gridpoints." << endl;
}
int getIndex() const {
int result = i;
return result;
}
bool isDone() const {return ( i>= N );}
dimIterator<N>& operator ++() {
++i;
return *this;
}
};
for
一样快的东西。循环。我有一个未初始化的 double 和可重复的空乘法测试
for
循环 for
循环? g++ -O3 -std=c++11
.版本是
g++ (GCC) 4.8.1
.
#include <iostream>
using namespace std;
template<int first, int... other>
class integerPack {
public:
constexpr static int length = 1 + integerPack<other...>::length;
constexpr static int product = first*integerPack<other...>::product;
};
template<int only>
class integerPack<only> {
public:
constexpr static int length = 1;
constexpr static int product = only;
};
template<
int N, // the number of elements to iterate for this dimension
int... otherN // the other dimension's lengths
> class dimIterator;
template<
typename dataType,
int... allN
> class boxIterator : public dimIterator<allN...> { // tried as member or inheritance
protected:
dataType* data;
public:
boxIterator(dataType* data) :
dimIterator<allN...>(),
data(data)
{
//cout << "constructing box iterator." << endl;
}
int getIndex() const {
int result = dimIterator<allN...>::getIndex();
return result;
}
dataType* getPtr() {
dataType* result = data + this->getIndex();
return result;
}
const dataType* getPtr() const {
dataType* result = data + this->getIndex();
return result;
}
bool isDone() const {return dimIterator<allN...>::isDone();}
boxIterator<dataType, allN...>& operator ++() {
dimIterator<allN...>::operator++();
return *this;
}
dataType& operator *() {return *(this->getPtr());}
const dataType& operator *() const {return *(this->getPtr());}
};
template<
int N, // the number of elements to iterate for this dimension
int... otherN // the other dimension's lengths
> class dimIterator : public dimIterator<otherN...> { // tried as member or inheritance
protected:
int i;
public:
dimIterator() :
dimIterator<otherN...>(),
i(0)
{
//cout << "constructing level with " << N << " gridpoints." << endl;
}
int getIndex() const {
int result = i + N*dimIterator<otherN...>::getIndex();
return result;
}
bool isDone() const {return dimIterator<otherN...>::isDone();}
dimIterator<N, otherN...>& operator ++() {
if(i<N-1) {
++i;
}
else {
i = 0;
dimIterator<otherN...>::operator++();
}
return *this;
}
};
template<int N> // stop recursion if only one dimension left
class dimIterator<N> {
protected:
int i;
public:
dimIterator() :
i(0)
{
//cout << "constructing last level with " << N << " gridpoints." << endl;
}
int getIndex() const {
int result = i;
return result;
}
bool isDone() const {return ( i>= N );}
dimIterator<N>& operator ++() {
++i;
return *this;
}
};
template<
int... allN
> class box {
public:
constexpr static int dimension = integerPack<allN...>::length;
constexpr static int NN = integerPack<allN...>::product;
template<typename dataType>
using iterator = boxIterator<dataType, allN...>;
};
template<typename dataType, typename boxType>
class boxQuantity {
public:
typedef typename boxType::template iterator<dataType> iterator;
constexpr static int dimension = boxType::dimension;
constexpr static int NN = boxType::NN;
typedef boxQuantity<dataType, boxType> thisClass;
protected:
boxType mybox;
dataType* data;
iterator myit;
public:
boxQuantity(
const boxType& mybox
) :
mybox(mybox),
data(new dataType[NN]),
myit(data)
{
cout << "I am a quantity of dimension " << dimension
<< " with " << NN << " gridpoints." << endl;
}
virtual ~boxQuantity() {
delete[] data;
}
iterator begin() const {
iterator it(data);
return it;
}
dataType& operator [] (int i) {return data[i];}
const dataType& operator [] (int i) const {return data[i];}
// iterator syntax with recursive for-like logic: 5 s
virtual thisClass& operator *= (const thisClass& rhs) {
thisClass& lhs = *this;
for(iterator it=lhs.begin(); !it.isDone(); ++it) {
lhs[myit.getIndex()] *= rhs[myit.getIndex()];
}
return *this;
}
// plain nested native for loops: 2.5 s
/*virtual thisClass& operator *= (const thisClass& rhs) {
thisClass& lhs = *this;
for(int yindex=0; yindex<1000; ++yindex) {
for(int xindex=0; xindex<1000; ++xindex) {
lhs[yindex*1000 + xindex] *= rhs[yindex*1000 + xindex];
}
}
return *this;
}*/
};
typedef box<1000, 1000> boxType;
typedef boxQuantity<double, boxType> qType;
int main() {
boxType qBox;
qType q1(qBox);
qType q2(qBox);
for(int i=0; i<2000; ++i) {
q1 *= q2;
}
return 0;
}
virtual
关键词
virtual
不像我的例子那样明显没用。我预计
virtual
主要影响
的时间调用 函数/运算符,但不适用于
正在执行 它。据我所知,执行时间的主要部分花在循环内,我忘记删除
virtual
.但是,删除
virtual
在我的情况下不会带来显着的性能优势? (我根据您的建议进行了测试。)
dimIterator
)
template<int dindex>
int getCoord() const {
if(1 == dindex) {
return i;
}
return otherDims.template getCoord<dindex-1>();
}
最佳答案
boxQuantity
的 virtual operator*=()
不会被内联,这会阻止很多优化。在您的示例中,您不是从此类派生的。删除此 virtual
运算符允许内联代码和使用 SIMD 指令:
00861330 movsd xmm0,mmword ptr [edx+eax*8]
00861335 mulsd xmm0,mmword ptr [edi+eax*8]
0086133A movsd mmword ptr [edi+eax*8],xmm0
0086133F dec ecx
00861340 jne main+90h (0861330h)
关于c++ - 等效于嵌套 for 循环的迭代器显示 50% 的性能故障 - 为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17839260/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!