5#ifndef GEMMI_SMCIF_HPP_
6#define GEMMI_SMCIF_HPP_
25 {
"length_a",
"length_b",
"length_c",
26 "angle_alpha",
"angle_beta",
"angle_gamma"});
30 st.cell.set(as_number(c[0]), as_number(c[1]), as_number(c[2]),
31 as_number(c[3]), as_number(c[4]), as_number(c[5]));
33 for (
const char* tag : {
"_space_group_name_H-M_alt",
34 "_symmetry_space_group_name_H-M"})
35 if (
const std::string* val = block.
find_value(tag)) {
36 st.spacegroup_hm = as_string(*val);
77 std::vector<SmallStructure::Site>::iterator
aniso_site =
st.sites.begin();
78 for (
auto row : block.
find(
"_atom_site_aniso_",
79 {
"label",
"U_11",
"U_22",
"U_33",
80 "U_12",
"U_13",
"U_23"})) {
97 for (
auto row : block.
find(
"_atom_type_",
99 "scat_dispersion_real",
100 "scat_dispersion_imag"})) {
106 st.atom_types.push_back(atom_type);
110 st.setup_cell_images();
118 if (
st.cell.is_crystal()) {
126 if (!
st.spacegroup_hm.empty())
128 if (
st.wavelength != 0)
142 site.type_symbol.empty() ?
site.element_and_charge_symbol()
149 site.disorder_group == 0 ?
"." : std::to_string(
site.disorder_group)
155 if (
site.aniso.nonzero()) {
161 "label",
"U_11",
"U_22",
"U_33",
"U_12",
"U_13",
"U_23"});
163 if (
site.aniso.nonzero())
double as_number(const std::string &s, double nan=NAN)
std::string as_string(const std::string &value)
bool is_null(const std::string &value)
std::string quote(std::string v)
int string_to_int(const char *p, bool checked, size_t length=0)
void split_element_and_charge(const std::string &label, T *dest)
SmallStructure make_small_structure_from_block(const cif::Block &block_)
cif::Block make_cif_block_from_small_structure(const SmallStructure &st)
GEMMI_DLL int GEMMI_DLL int std::string to_str(double d)
constexpr double u_to_b()
Column find_values(const std::string &tag)
Table find(const std::string &prefix, const std::vector< std::string > &tags)
void set_pair(const std::string &tag, const std::string &value)
Loop & init_loop(const std::string &prefix, std::vector< std::string > tags)
const std::string * find_value(const std::string &tag) const