This repository was archived by the owner on Jun 10, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMigrationResultsDialog.cpp
More file actions
119 lines (87 loc) · 3.79 KB
/
Copy pathMigrationResultsDialog.cpp
File metadata and controls
119 lines (87 loc) · 3.79 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
// MigrationResultsDialog.cpp : implementation file
//
#include "stdafx.h"
#include "LatticeRelaxation.h"
#include "MigrationResultsDialog.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// MigrationResultsDialog dialog
MigrationResultsDialog::MigrationResultsDialog(CWnd* pParent /*=NULL*/)
: CDialog(MigrationResultsDialog::IDD, pParent)
{
//{{AFX_DATA_INIT(MigrationResultsDialog)
m_migrationEnergy = 0.0;
m_numberOfSteps = 0;
//}}AFX_DATA_INIT
}
void MigrationResultsDialog::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(MigrationResultsDialog)
DDX_Control(pDX, IDC_MIGRATION_STEPS_LIST, m_migrationStepsList);
DDX_Text(pDX, IDC_ENERGY_OF_MIGRATION_EDIT, m_migrationEnergy);
DDX_Text(pDX, IDC_NUMBER_OF_MIGRATION_STEPS_EDIT, m_numberOfSteps);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(MigrationResultsDialog, CDialog)
//{{AFX_MSG_MAP(MigrationResultsDialog)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// MigrationResultsDialog message handlers
BOOL MigrationResultsDialog::OnInitDialog()
{
CDialog::OnInitDialog();
m_migrationStepsList.SetExtendedStyle(
m_migrationStepsList.GetExtendedStyle()|LVS_EX_GRIDLINES|LVS_EX_FULLROWSELECT );
m_migrationStepsList.InsertColumn(0,"Step");
m_migrationStepsList.SetColumnWidth(0,50);
m_migrationStepsList.InsertColumn(1,"Migrating atom coordinates, a0");
m_migrationStepsList.SetColumnWidth(1,190);
m_migrationStepsList.InsertColumn(2,"Energy after relaxation, eV");
m_migrationStepsList.SetColumnWidth(2,190);
m_migrationStepsList.InsertColumn(3,"Delta Energy, eV");
m_migrationStepsList.SetColumnWidth(3,142);
std::vector<MigrationStepResults>::iterator stepsIterator;
std::vector<MigrationStepResults> steps = migrationResults.migrationStepResults;
int numberOfSteps = 0;
double minEnergy = 0.0;
double maxEnergy = 0.0;
for (stepsIterator = steps.begin(); stepsIterator != steps.end(); stepsIterator++) {
MigrationStepResults relaxationResults = *stepsIterator;
CString formatString;
formatString.Format("%d",numberOfSteps);
m_migrationStepsList.InsertItem(numberOfSteps,formatString);
m_migrationStepsList.SetItemText(numberOfSteps,0,formatString);
formatString.Format("(%f, %f, %f)",relaxationResults.migratingAtomCoordinates.x / 2.86,relaxationResults.migratingAtomCoordinates.y / 2.86,relaxationResults.migratingAtomCoordinates.z / 2.86);
m_migrationStepsList.SetItemText(numberOfSteps,1,formatString);
formatString.Format("%f",relaxationResults.complexEnergyAfterRelaxation);
m_migrationStepsList.SetItemText(numberOfSteps,2,formatString);
formatString.Format("%f",relaxationResults.relaxationEnergy);
m_migrationStepsList.SetItemText(numberOfSteps,3,formatString);
if ((relaxationResults.complexEnergyAfterRelaxation > maxEnergy) || (maxEnergy == 0.0)) {
maxEnergy = relaxationResults.complexEnergyAfterRelaxation;
}
if ((relaxationResults.complexEnergyAfterRelaxation < minEnergy) || (minEnergy == 0.0)) {
minEnergy = relaxationResults.complexEnergyAfterRelaxation;
}
numberOfSteps++;
}
numberOfSteps = 0;
for (stepsIterator = steps.begin(); stepsIterator != steps.end(); stepsIterator++) {
MigrationStepResults relaxationResults = *stepsIterator;
CString formatString;
formatString.Format("%f",relaxationResults.complexEnergyAfterRelaxation - minEnergy);
m_migrationStepsList.SetItemText(numberOfSteps,3,formatString);
numberOfSteps++;
}
m_migrationEnergy = maxEnergy - minEnergy;
m_numberOfSteps = numberOfSteps;
UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}