我编写了一个C++(Rcpp)函数来从仅包含数字的文件中读取和填充多维矩阵。当我在Linux上运行它时,它运行良好,并且运行速度非常快。但是,在具有相同规格的Windows计算机上,相同的代码要慢得多(大约200倍)。任何人都可以发现问题吗?

void read_ed0moins_lut_(const char *filename, float downward_irradiance_table_as_output[NBWL][NTHETAS][NO3][NTAUCLD][NALB]) {

    std::ifstream infile;
    infile.open(filename);
    float tmp;
    for (int theta = 0; theta < NTHETAS; theta++) {
        for (int ozone = 0; ozone < NO3; ozone++) {
            for (int taucl = 0; taucl < NTAUCLD; taucl++) {
                for (int albedo = 0; albedo < NALB; albedo++) {
                    for (int wavelength = 0; wavelength < NBWL; wavelength++) {
                        infile >> tmp; // This line is very slow on Windows
                        downward_irradiance_table_as_output[wavelength][theta][ozone][taucl][albedo] = tmp;
                    }
                }
            }
        }
    }

    // Close file
    infile.close();
}

最佳答案

这里有一些想法:

  • 在 Release模式下构建(启用优化,启用-O2标志)
  • 启用ifstream缓冲:

  •     std::ifstream infile(filename);
        char buffer[65536];
        infile.rdbuf()->pubsetbuf(buffer, sizeof(buffer));
    
  • 按循环顺序排列数组的尺寸:
    downward_irradiance_table_as_output[NTHETAS][NO3][NTAUCLD][NALB][NBWL]
    这样您就可以遍历row-major-order,这对缓存更友好。
  • 10-02 09:25