멀티쓰레딩 예제 실행시간 수정 질문
222
작성한 질문수 86
random_device seed;
mt19937 engine(seed());
uniform_int_distribution <> uniformDist(1, 10);
const auto sta2 = chrono::steady_clock::now(); //시간 재는중
for (long long i = 0; i < n_data; i++)
{
v0.push_back(uniformDist(engine));
v1.push_back(uniformDist(engine));
}
const chrono::duration<double> dur2 = chrono::steady_clock::now() - sta2; //시간 재는 중
cout << dur2.count() << endl;
말씀하신 부분을 다음과 같이 해서 시간을 측정해보니 143.15초가 나왔습니다.
for문을 이용해 vector에 값을 넣는 것에만 2~3분이 걸린 것입니다.
구글링 해본 결과 시간 복잡도 계산에 for문 기준으로 1억번 계산하는데 1초라는 내용을 알 수 있었습니다
for문안에 2억번 계산이 이루어지니까 산술적으로 2초가 걸립니다. 하지만
단순 값을 넣는 것이 아닌 완전 랜덤 숫자를 넣는 것이니까 2초보다는 조금 더 걸리겠지 라는 생각을 해봐도
시간이 지나치게 소요된다는 생각이 들었습니다. 교수님이 예제를 보여주실 때는 거의 순식간에 결과를 알 수 있었는데
이러한 차이가 어디서 오는건지 궁금합니다.
답변 3
1
교수님 debug 모드가 아닌 release 모드로 실행하니 실행속도가 확 줄어들었습니다. 전에 말씀해주셨던
debug 모드와 release 모드의 차이 때문인것 같습니다. 앞선 질문들에 답변해주셔서 감사합니다.
0
또한 for문을 작동시키는데 걸리는 시간을 줄이고 싶습니다. for문을 연산할 때 내부적으로 쓰레드 하나가 혼자서 담당하는 것인가요?
멀티 쓰레드처럼 여러 쓰레드를 이용해서 빠르게 계산을 할 수는 없는건가요?
변수가 메모리에 저장되는 것을 알려주는 강의가 어떤강의였죠
1
464
1
메모리 주소 10진수로 출력
1
653
1
클래스 템플릿 특수화에서 boolalpha로 표현된 리턴값에 대해 질문이 있습니다.
1
498
1
여러가지 리턴 타입에 관한 강의가 어떤 걸까요?
1
534
1
메모리 주소에 관한 질분
0
679
1
인터페이스 클래스에서 reportError의 매개변수에 대해 궁금한 것이 있습니다.
0
549
1
형변환 오버로딩에서 const 관련 질문이 있습니다.
0
443
1
Digit 뒤에 reference를 사용하는 이유
0
510
1
4.2 전역 변수, 정적 변수, 내부 연결, 외부 연결
0
322
1
dat파일이...
0
538
1
TODO:대입 연산자 오버로딩에 대한 소스코드입니다.
0
643
1
복사 생성자 관련 질문이 있습니다.
0
454
1
수업 중 궁금한점이 있습니다.
1
389
1
라이브러리자체가 이해가 되지 않습니다.
0
561
1
마지막 예제 질문
0
302
1
증감연산자 위치에 따른 수행 순서 질문입니다.
0
374
1
단항 연산자 오버로딩에서 return 부분에 질문이 있습니다.
1
410
1
friend함수 관련 질문이 있습니다.
0
311
1
operator+ 정의부분에서 궁금한 것이 있습니다.
0
447
1
3분 17초 질문
0
350
1
함수에 값을 대입한다는 개념이 이해가 되지 않습니다.
0
447
1
int getvalue() const에서 const는 왜 뒤에 붙는건가요?
0
443
2
const Something &st에서 const를 빼면 안되나요?
0
300
1
friend함수는 다른 클래스의 멤버함수로 쓸 수 없나요??
1
492
1





