0

我有一个非常基本的程序,只有函数和变量并执行一些计算。构建部分很好。只有 cout、加法、乘法等非常基本的东西。

在 linux 上,程序在 eclipse cdt 上运行良好,(运行大约 3-4 秒)

当程序在visual studio 2010 c++上的windows 7上运行时,程序在带有MinGW的windows 7 eclipse c++上运行时花了163秒,很多

这里发生了什么??!!?!

编辑:我们不要称它为 c++,这里只是很多 C 函数,这是来自 main() 的代码

    foutput1 = fopen(FILENAME1, "w");
foutput2 = fopen(FILENAME2, "w");
solveSystem();
OutputStepToFile();
iter++;
do
{
    temporalExternalChange(tim);
    do
    {
        solveSystem();
        iter++;
    } while (iter<T_FOUT);
    iter = 0;
    OutputStepToFile();
    tim+=dt*T_FOUT;
    if (fmod(tim,T_PRINT)<=0.0){cout << "\nt=" << tim << "ms";};
} while(tim<T_TOTAL);

SolveSystem() 是以下(部分),它只是对某些变量进行计算的函数:

      void solveSystem()
      {

fsGCcGMPformation();        // !cGMP formation
falp1AdAct_IP3form();       // !Norepinephrine receptor
fIVoCC();                   // !Voltage dependent calcium current I_CaL
fIKv();                     // !Delayed rectifier current I_K
fIBKCa();                   // !Calcium-activated potassium 
    ...
    ...
    ...
fVoltageChange();
performODEstep();
}

OutputStepToFile() 函数只是使用 C 风格的文件输出

   void OutputStepToFile()
   {
    fprintf(foutput1,"%g %g %g %g %g %g %g %g ",V_m, tim, Ca_i, Na_i, K_i, Cl_i, Ca_u, Ca_r);                                                       // 1
    fprintf(foutput1,"%g %g %g %g %g %g %g ",d_L, f_L, BKCa_a, KvD_a, KvD_i_slow, KvD_i_fast, KCNQ_a);      // 8
    fprintf(foutput1,"%g %g %g %g ",P_SOC, R_01, R_10, R_11);   // 15
    fprintf(foutput1,"%g %g %g %g %g %g %g %g %g\n", h_IP3, RS_G, RS_PG, G, IP3, PIP2, DAG, V_cGMP, cGMP);  // 22

    // Store Ca,K,Cl,Na ion channels
    fprintf(foutput2,"%g %g %g %g %g %g %g %g %g ", I_CaL,  I_CaT,  I_BKCa, I_KvD, I_KCNQ, I_K2P, I_Kir, I_KATP, I_CaCC);
    // Store ROCs/SOCs
    fprintf(foutput2,"%g %g %g %g %g %g %g ",   INa_NSC, IK_NSC, ICa_NSC, I_NSC, I_SOCNa, I_SOCCa, I_SOC);
    // store SR dynamic currents, co-transporters, pumps and exchangers
    fprintf(foutput2,"%g %g %g %g %g %g %g %g ",    I_up, I_tr, I_rel, I_IP3, I_PMCA, I_NaK, I_NCX, I_NaKCl_Cl);
    fprintf(foutput2,"%g %g %g %g %g %g\n",     I_stim, V_cGMPbar,  I_Catotm,   I_Natotm,   I_Cltotm,   I_Ktotm);
   }
4

2 回答 2

3

找出程序花费所有时间的唯一可靠方法是对其进行分析。这将向您显示每个方法/功能所花费的时间,并且您应该能够追踪延迟。如果由于某种原因您不能使用分析器,您可以尝试在代码的关键阶段插入一些计时调用来隔离问题的位置。

也就是说,我的猜测是在您程序的 I/O 部分(coutprintf...)。计算应在两种架构上编译为类似的代码,除非您使用外部库,否则它们不应受到移植过程的影响。另一方面,I/O 调用可能会受到标准库的差异以及每个操作系统如何处理缓冲和 I/O 的影响。可以想象,可能还有一些库函数在 Windows 上没有很好地实现。

一条重要的信息是您的程序在这 160 多秒内的行为方式。它是在 100% 烧毁 CPU,还是在等待某事发生?

于 2012-08-25T19:29:49.163 回答
1

由于某种原因,solveSystem() 内部调用的函数之一可能表现不同。我建议,您首先注释掉solveSystem() 中的所有函数。检查在 VC++ 上是否仍需要 160 多秒。依次启用solveSystem()中的函数。

于 2012-08-25T19:15:58.263 回答