这是我用 std::vector<double> 试过的一个循环和普通的旧double* .
对于 1000 万个元素, vector 版本的运行时间是 double* 的大约 80%。版本需要;对于 N 的几乎任何值, vector 明显更快。
查看 GCC STL 源代码,我没有看到 std::vector正在做任何比 double* 本质上更有趣的事情习语正在做(即,使用普通旧 new[] 分配, operator[] 取消引用偏移量)。 This question也是这么说的。
知道为什么 vector 版本更快吗?
Compiler: GCC 4.6.1
Example compile line: g++ -Ofast -march=native -DNDEBUG \
-ftree-vectorizer-verbose=2 -o vector.bin \
vector.cpp -lrt
OS: CentOS 5
CPU: Opteron 8431
RAM: 128 GB
如果我使用 icpc 11.1 或在 Xeon 上运行,结果在质量上是相同的。此外,向量化器转储表示只有 std::vector 中的填充操作。的构造函数被矢量化。
vector 版:
#include <vector>
#include <iostream>
#include <boost/lexical_cast.hpp>
#include "util.h"
#include "rkck_params.h"
using namespace std;
int main( int argc, char* argv[] )
{
const size_t N = boost::lexical_cast<size_t>( argv[ 1 ] );
vector<double> y_old( N );
vector<double> y_new( N );
vector<double> y_err( N );
vector<double> k0( N );
vector<double> k1( N );
vector<double> k2( N );
vector<double> k3( N );
vector<double> k4( N );
vector<double> k5( N );
const double h = 0.5;
const timespec start = clock_tick();
for ( size_t i = 0 ; i < N ; ++i )
{
y_new[ i ] = y_old[ i ]
+ h
*(
rkck::c[ 0 ]*k0[ i ]
+ rkck::c[ 2 ]*k2[ i ]
+ rkck::c[ 3 ]*k3[ i ]
+ rkck::c[ 5 ]*k5[ i ]
);
y_err[ i ] = h
*(
rkck::cdiff[ 0 ]*k0[ i ]
+ rkck::cdiff[ 2 ]*k2[ i ]
+ rkck::cdiff[ 3 ]*k3[ i ]
+ rkck::cdiff[ 4 ]*k4[ i ]
+ rkck::cdiff[ 5 ]*k5[ i ]
);
}
const timespec stop = clock_tick();
const double total_time = seconds( start, stop );
// Output
cout << "vector\t" << N << "\t" << total_time << endl;
return 0;
}
double*版本:
#include <iostream>
#include <boost/lexical_cast.hpp>
#include "util.h"
#include "rkck_params.h"
using namespace std;
int main( int argc, char* argv[] )
{
const size_t N = boost::lexical_cast<size_t>( argv[ 1 ] );
double* y_old = new double[ N ];
double* y_new = new double[ N ];
double* y_err = new double[ N ];
double* k0 = new double[ N ];
double* k1 = new double[ N ];
double* k2 = new double[ N ];
double* k3 = new double[ N ];
double* k4 = new double[ N ];
double* k5 = new double[ N ];
const double h = 0.5;
const timespec start = clock_tick();
for ( size_t i = 0 ; i < N ; ++i )
{
y_new[ i ]
= y_old[ i ]
+ h
*(
rkck::c[ 0 ]*k0[ i ]
+ rkck::c[ 2 ]*k2[ i ]
+ rkck::c[ 3 ]*k3[ i ]
+ rkck::c[ 5 ]*k5[ i ]
);
y_err[ i ]
= h
*(
rkck::cdiff[ 0 ]*k0[ i ]
+ rkck::cdiff[ 2 ]*k2[ i ]
+ rkck::cdiff[ 3 ]*k3[ i ]
+ rkck::cdiff[ 4 ]*k4[ i ]
+ rkck::cdiff[ 5 ]*k5[ i ]
);
}
const timespec stop = clock_tick();
const double total_time = seconds( start, stop );
delete [] y_old;
delete [] y_new;
delete [] y_err;
delete [] k0;
delete [] k1;
delete [] k2;
delete [] k3;
delete [] k4;
delete [] k5;
// Output
cout << "plain\t" << N << "\t" << total_time << endl;
return 0;
}
rkck_params.h :
#ifndef RKCK_PARAMS_H
#define RKCK_PARAMS_H
namespace rkck
{
// C.f. $c_i$ in Ch. 16.2 of NR in C++, 2nd ed.
const double c[ 6 ]
= { 37.0/378.0,
0.0,
250.0/621.0,
125.0/594,
0.0,
512.0/1771.0 };
// C.f. $( c_i - c_i^* )$ in Ch. 16.2 of NR in C++, 2nd ed.
const double cdiff[ 6 ]
= { c[ 0 ] - 2825.0/27648.0,
c[ 1 ] - 0.0,
c[ 2 ] - 18575.0/48384.0,
c[ 3 ] - 13525.0/55296.0,
c[ 4 ] - 277.0/14336.0,
c[ 5 ] - 1.0/4.0 };
}
#endif
util.h :
#ifndef UTIL_H
#define UTIL_H
#include <time.h>
#include <utility>
inline timespec clock_tick()
{
timespec tick;
clock_gettime( CLOCK_REALTIME, &tick );
return tick;
}
// \cite{www.guyrutenberg.com/2007/09/22/profiling-code-using-clock_gettime}
inline double seconds( const timespec& earlier, const timespec& later )
{
double seconds_diff = -1.0;
double nano_diff = -1.0;
if ( later.tv_nsec < earlier.tv_nsec )
{
seconds_diff = later.tv_sec - earlier.tv_sec - 1;
nano_diff = ( 1.0e9 + later.tv_nsec - earlier.tv_nsec )*1.0e-9;
}
else
{
seconds_diff = later.tv_sec - earlier.tv_sec;
nano_diff = ( later.tv_nsec - earlier.tv_nsec )*1.0e-9;
}
return seconds_diff + nano_diff;
}
#endif
最佳答案
在 vector 版本中,您的数据被初始化为零。在 new 版本中它是未初始化的,因此可能会完成不同的工作。
您是否以不同的顺序多次运行?
关于c++ - vector<double> 比 double* : why? 快,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6698831/
我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为
我的瘦服务器配置了nginx,我的ROR应用程序正在它们上运行。在我发布代码更新时运行thinrestart会给我的应用程序带来一些停机时间。我试图弄清楚如何优雅地重启正在运行的Thin实例,但找不到好的解决方案。有没有人能做到这一点? 最佳答案 #Restartjustthethinserverdescribedbythatconfigsudothin-C/etc/thin/mysite.ymlrestartNginx将继续运行并代理请求。如果您将Nginx设置为使用多个上游服务器,例如server{listen80;server
让我们计算MRI范围内的类别:defcount_classesObjectSpace.count_objects[:T_CLASS]endk=count_classes用类方法定义类:classAdefself.foonilendend然后运行:putscount_classes-k#=>3请解释一下,为什么是三个? 最佳答案 查看MRI代码,每次你创建一个Class时,在Ruby中它是Class类型的对象,ruby会自动为这个新类创建“元类”类,这是另一个单例类型的Class对象。C函数调用(class.c)是:rb_define
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request
我使用Nokogiri(Rubygem)css搜索寻找某些在我的html里面。看起来Nokogiri的css搜索不喜欢正则表达式。我想切换到Nokogiri的xpath搜索,因为这似乎支持搜索字符串中的正则表达式。如何在xpath搜索中实现下面提到的(伪)css搜索?require'rubygems'require'nokogiri'value=Nokogiri::HTML.parse(ABBlaCD3"HTML_END#my_blockisgivenmy_bl="1"#my_eqcorrespondstothisregexmy_eq="\/[0-9]+\/"#FIXMEThefoll
如何将send与+=一起使用?a=20;a.send"+=",10undefinedmethod`+='for20:Fixnuma=20;a+=10=>30 最佳答案 恐怕你不能。+=不是方法,而是语法糖。参见http://www.ruby-doc.org/docs/ProgrammingRuby/html/tut_expressions.html它说Incommonwithmanyotherlanguages,Rubyhasasyntacticshortcut:a=a+2maybewrittenasa+=2.你能做的最好的事情是:
我对如何计算通过{%assignvar=0%}赋值的变量加一完全感到困惑。这应该是最简单的任务。到目前为止,这是我尝试过的:{%assignamount=0%}{%forvariantinproduct.variants%}{%assignamount=amount+1%}{%endfor%}Amount:{{amount}}结果总是0。也许我忽略了一些明显的东西。也许有更好的方法。我想要存档的只是获取运行的迭代次数。 最佳答案 因为{{incrementamount}}将输出您的变量值并且不会影响{%assign%}定义的变量,我
我在一个我想在formtasticGem中覆盖的方法中找到了这个。该方法如下所示:defto_htmlinput_wrappingdohidden_field_html是什么意思?在第三行做什么?我知道它对数组有什么作用,但在这里我不知道。 最佳答案 你可以这样读:hidden_field_htmllabel_with_nested_checkbox是连接到hidden_field_html末尾的参数-为了“清晰”,他们将其分成两行 关于ruby-on-rails-没有参数的`
我已经看到了一些其他的问题,尝试了他们的建议,但没有一个对我有用。我已经使用Rails大约一年了,刚刚开始一个新的Rails项目,突然遇到了问题。我卸载并尝试重新安装所有Ruby和Rails。Ruby很好,但Rails不行。当我输入railss时,我得到了can'tfindgemrailties。我当前的Ruby版本是ruby2.2.2p95(2015-04-13修订版50295)[x86_64-darwin15],尽管我一直在尝试通过rbenv设置ruby2.3.0。如果我尝试rails-v查看我正在运行的版本,我会得到同样的错误。我使用的是MacOSXElCapitan版本10
考虑一下:现在这些情况:#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2我需要用其他字符串输出URL。我如何保证&符号不会被转义?由于我无法控制的原因,我无法发送&。求助!把我的头发拉到这里:\编辑:为了澄清,我实际上有一个像这样的数组:@images=[{:id=>"fooid",:url=>"http://