-
Notifications
You must be signed in to change notification settings - Fork 44
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[API] Add function for parsing hubbard.dat style files #933
base: develop
Are you sure you want to change the base?
Conversation
… the config structure accordingly
Please wait my signal before merging even if everything is OK. |
namespace sirius { | ||
|
||
static std::vector<std::string> | ||
split(std::string str, std::string token) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Check if this function can help
https://github.com/electronic-structure/SIRIUS/blob/develop/src/core/string_tools.hpp#L32
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yes it will. I will use it.
parse_atom_string(std::string& at_str__) -> std::tuple<std::string, int, int> | ||
{ | ||
std::vector<std::string> split_str_ = split(at_str__, "_"); | ||
int n_ = -1; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
why underscore in local variables? it is not needed
// a bit pedantic.... | ||
n_ = std::stoi(split_str_[1]); | ||
|
||
switch (split_str_[1][1]) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
there is a code repetition with https://github.com/electronic-structure/SIRIUS/blob/develop/src/unit_cell/atom_type.cpp#L412
better solution: introduce a pure function that returns l by charachter label. It can be defined for example in atom_type.hpp
@@ -196,6 +196,11 @@ class Hubbard | |||
} | |||
}; | |||
|
|||
extern void |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this are normal functions on the c++ side. No raw pointers as arguments
} | ||
|
||
void | ||
add_hubbard_atom_pair(Simulation_context& ctx__, int* const atom_pair__, int* const translation__, int* const n__, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
no pointers as arguments
} | ||
|
||
void | ||
parse_hubbard_file(Simulation_context& ctx__, const std::string& data_file__) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
our convention is T const& arg
} | ||
|
||
if ((split_string[0] == "U") || (split_string[0] == "u")) { | ||
const double U_ = std::stod(split_string[2]); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
local variables should not have underscore
const double V_ = std::stoi(split_string[5]); | ||
int translation1[3] = {0, 0, 0}; | ||
int atom_pair_[2]; | ||
int translation2[3] = {0, 0, 0}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this should be r3::vector T;
Actually there is a lot more work coming for this. |
I need to finish this PR.... Will see what I can do next week. |
Add the possibility to parse QE hubbard.dat file directly with SIRIUS. It is useful for cp2k.