草庐IT

PARALLEL_CASE

全部标签

c++ - Matlab/C++ : segmentation fault on parallel computing with C++ Mex persistent objects (cannot convert handle)

本帖引用:[1]http://www.mathworks.com/matlabcentral/newsreader/view_thread/278243“使C++对象在mex调用之间持久化,并且健壮。”[2]MATLABparforandC++classmexwrappers(copyconstructorrequired?)“MATLABparfor和C++类mex包装器(需要复制构造函数?)”我成功地实现了一个Matlab/C++接口(interface),基于[1]上提出的方法。无论如何,我在尝试将系统与Matlab并行计算一起使用时遇到了麻烦。在MEX接口(interface)

c++ - Concurrency::parallel_for (PPL) 创建了太多线程

我正在使用Concurrency::parallel_for()VisualStudio2010的并行模式库(PPL)来处理一组索引任务(通常,索引集远大于可以同时运行的线程数)。每个任务,在进行冗长的计算之前,首先从共享资源管理器请求私有(private)工作存储资源(以防万一:任务特定内存映射文件的View,但我认为如果每个任务的故事情节都是一样的请求从共享堆分配私有(private)内存)。共享资源管理器的使用与Concurrency::critical_section同步问题就在这里开始了:如果第一个线程/任务在临界区中并且第二个任务发出请求,它必须等到第一个任务的请求被处理。

c++ - Visual C++ parallel_for + vector 访问冲突

我正在尝试将循环通过~12,000x12,000单元格矩阵(大约125次)的过程转换为使用并行处理(通过parallel_for)。我正在使用的代码如下。你可以看到for循环被注释掉的地方。当我用for循环运行这段代码时,没有任何问题。当我使用parallel_for运行它(调试)时,它在随机点崩溃,出现“FratarProcess.exe0xC0000005中0x00f3d4ae处的未处理异常:访问冲突写入位置0x0000000。备注:accessMatrix声明为vector>accessMatrix;并在此之前填充。voiddumpMatrix(unsignedshortm){i

c++ - MSVC 并发运行时中的 parallel_for_each 和 parallel_for 有什么区别?

parallel_for_each的形式是:Concurrency::parallel_for_each(start_iterator,end_iterator,function_object);但是parallel_for也是类似的形式:Concurrency::parallel_for(start_value,end_value,function_object);那么在多核编程中使用的Concurrency::parallel_for和Concurrency::parallel_for_each算法有什么区别? 最佳答案 我不知

c++ - "virtual base class in the case of multilevel inheritance"有意义吗

考虑以下显示多级继承的示例代码:案例1:这里类derived1是通过虚拟继承从类base派生的,类derived2是从类派生的直接类derived1。classbase{};classderived1:virtualpublicbase{};classderived2:publicderived1{};Case2:与Case1相同,只是不涉及虚拟继承classbase{};classderived1:publicbase//novirtualinheritance{};classderived2:publicderived1{};假设我在这两种情况下都创建了derived2类的对象。C

c++ - 哪些提升类型用于 switch-case 表达式比较?

以下程序在使用不同的编译器编译时打印“unknown”。为什么会这样?#include"stdio.h"constcharOPTION=(char)(unsignedchar)253;intmain(intargc,char*argv[]){unsignedcharc=253;switch(c){caseOPTION:printf("option\n");break;default:printf("unknown\n");break;}return0;}在查看C++标准(N36902013-05-05)时,我看到了switch的子句:6.4.2Theswitchstatement2Th

java - 小铁杆: Do you know any parallel modified moving average algorithm?

你知道任何并行修正移动平均算法吗?我想快速计算移动平均线而不是sequentialalgorithms.我想使用并行算法,但我仍然没有找到解决方案。我发现最好的算法是顺序算法modifiedmovingaverageformeasuringcomputerperformance:new_avg=alfa(new_time,previous_time)*new_value+(1-alfa(new_time,previous_time))*previous_avgalfa(new_time,previous_time)=1-exp(-(new_time-previous_time)/mov

c++ - 错误 C2196 : case value '?' already used

好的,在代码中使用VisualStudioUltimate2012构建时出现奇怪的错误(可能是ANSI、unicode等问题)...switch(input[index]){case'א'://AlefHebrewcharacterif(/*conditional*/){//Dostuff.}break;case'ב'://BethHebrewcharacterif(/*conditional*/){//Dostuff}break;default:{//Dosomeotherstuff.}break;}第二个case参数生成...ErrorC2196:casevalue'?'alrea

c++ - parallel_for (Inter TBB) 是否存在类似于我们在 std::function 上看到的开销?

在此链接中std::functionvstemplate关于std::function的开销有一个很好的讨论。基本上,要避免传递给std::function构造函数的仿函数的堆分配造成10倍的开销,您必须使用std::ref或std::cref。取自@CassioNeri答案的示例显示了如何通过引用将lambda传递给std::function。floatfoo(std::functionf){return-1.0f*f(3.3f)+666.0f;}foo(std::cref([a,b,c](floatarg){returnarg*0.5f;}));现在,IntelThreadBuil

c++ - 使用 std::string 在 switch-case block 中返回字符串常量

注意:这不是关于使用字符串来选择switch-caseblock中的执行路径。C++中的一个常见模式是使用switch-caseblock将整数常量转换为字符串。这看起来像:charconst*to_string(codescode){switch(code){casecodes::foo:return"foo";casecodes::bar:return"bar";}}但是,我们是在C++中,所以使用std::string更合适:std::stringto_string(codescode){switch(code){casecodes::foo:return"foo";caseco