Я только начал с OpenMP, используя C ++.Мой последовательный код на C ++ выглядит примерно так:
#include <iostream>
#include <string>
#include <sstream>
#include <vector>
#include <fstream>
#include <stdlib.h>
int main(int argc, char* argv[]) {
string line;
std::ifstream inputfile(argv[1]);
if(inputfile.is_open()) {
while(getline(inputfile, line)) {
// Line gets processed and written into an output file
}
}
}
Поскольку каждая строка в значительной степени обрабатывается независимо, я пытался использовать OpenMP для распараллеливания этого, потому что входной файл имеет порядок гигабайт.Я предполагаю, что сначала мне нужно получить количество строк во входном файле, а затем распараллелить код таким образом.Может ли кто-нибудь помочь мне здесь?
#include <iostream>
#include <string>
#include <sstream>
#include <vector>
#include <fstream>
#include <stdlib.h>
#ifdef _OPENMP
#include <omp.h>
#endif
int main(int argc, char* argv[]) {
string line;
std::ifstream inputfile(argv[1]);
if(inputfile.is_open()) {
//Calculate number of lines in file?
//Set an output filename and open an ofstream
#pragma omp parallel num_threads(8)
{
#pragma omp for schedule(dynamic, 1000)
for(int i = 0; i < lines_in_file; i++) {
//What do I do here? I cannot just read any line because it requires random access
}
}
}
}
РЕДАКТИРОВАТЬ:
Важные вещи
- Каждая строкаобрабатывается независимо
- Порядок результатов не имеет значения