From d7c421fde5dc896b52209247b6c95b9d172d76ad Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jean-S=C3=A9bastien?= Date: Sun, 19 Dec 2021 15:13:49 +0100 Subject: [PATCH] Add alerts --- src/EXECS/LiebLin_DSF_tester.cc | 2 +- src/SCAN/General_Scan.cc | 14 +++++++++++++- 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/src/EXECS/LiebLin_DSF_tester.cc b/src/EXECS/LiebLin_DSF_tester.cc index 8846ca2..da6ce46 100644 --- a/src/EXECS/LiebLin_DSF_tester.cc +++ b/src/EXECS/LiebLin_DSF_tester.cc @@ -78,7 +78,7 @@ int main(int argc, char* argv[]) cout << setprecision(16) << "estate.E - spstate.E = " << estate.E - spstate.E << "\tME = " << real(exp(ln_Psi_ME(spstate, estate))) << endl; - //cout << "Another try ? (1 == yes, 0 == no)" << endl; + cout << "Another try ? (1 == yes, 0 == no)" << endl; again = 1; cin >> again; } while (again != 0); diff --git a/src/SCAN/General_Scan.cc b/src/SCAN/General_Scan.cc index b64206e..ae27290 100644 --- a/src/SCAN/General_Scan.cc +++ b/src/SCAN/General_Scan.cc @@ -537,6 +537,7 @@ namespace ABACUS { Vect threads_to_do; int il_to_do = paused_thread_data.lowest_il_with_nthreads_neq_0; // for resaving threads in case we're out of time + DP current_threshold = exp(-paused_thread_data.logscale * il_to_do); { #pragma omp critical threads_to_do = paused_thread_data.Extract_Next_Scan_Threads(); @@ -568,6 +569,7 @@ namespace ABACUS { ScanState.Set_to_Label(threads_to_do[ithread].label, BaseScanState.Ix2); + Tstate ScanStateBeingDescended = ScanState; // STARTING Descend_and_Compute block: int type_required = threads_to_do[ithread].type; @@ -657,6 +659,16 @@ namespace ABACUS { // << "\t" << setw(16) << std::fixed << setprecision(8) // << data_value/exp(-paused_thread_data.logscale * il_to_do) << endl; + // Uncomment below if alerts for unexpectedly high data_value (as compared to threshold) are desired + // if (fabs(data_value) > 10.0* current_threshold) { + // cout << "\nAlert: data_value > 10* threshold, " << data_value << "\t" << current_threshold << endl; + // cout << " for state " << ScanState.label << " descendent of type " << type_required + // << " of state " << ScanStateBeingDescended.label << endl; + // cout << AveragingState.Ix2 << endl; + // cout << ScanStateBeingDescended.Ix2 << endl; + // cout << ScanState.Ix2 << endl; + // } + } // if (ScanState.conv) else { if (nconv0++ < 1000) @@ -753,7 +765,7 @@ namespace ABACUS { } // for idesc - // FINISHED Descend_and_Compute block + // FINISHED Descend_and_Compute block scan_info_this_ithread.TT += omp_get_wtime() - start_time_this_ithread;