本文整理汇总了C++中Molecule::edgeEnd方法的典型用法代码示例。如果您正苦于以下问题:C++ Molecule::edgeEnd方法的具体用法?C++ Molecule::edgeEnd怎么用?C++ Molecule::edgeEnd使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Molecule
的用法示例。
在下文中一共展示了Molecule::edgeEnd方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: _normalizeMolecule
void MoleculeInChI::_normalizeMolecule(Molecule &mol)
{
QS_DEF(Array<int>, ignored);
ignored.clear_resize(mol.vertexEnd());
ignored.zerofill();
for (int i = mol.vertexBegin(); i < mol.vertexEnd(); i = mol.vertexNext(i))
if (mol.convertableToImplicitHydrogen(i))
ignored[i] = 1;
for (int i = mol.edgeBegin(); i != mol.edgeEnd(); i = mol.edgeNext(i))
if (mol.getBondTopology(i) == TOPOLOGY_RING)
mol.cis_trans.setParity(i, 0);
MoleculeAutomorphismSearch of;
of.detect_invalid_cistrans_bonds = true;
of.detect_invalid_stereocenters = true;
of.find_canonical_ordering = false;
of.ignored_vertices = ignored.ptr();
of.process(mol);
for (int i = mol.edgeBegin(); i != mol.edgeEnd(); i = mol.edgeNext(i))
if (mol.cis_trans.getParity(i) != 0 && of.invalidCisTransBond(i))
mol.cis_trans.setParity(i, 0);
for (int i = mol.vertexBegin(); i != mol.vertexEnd(); i = mol.vertexNext(i))
if (mol.stereocenters.getType(i) > MoleculeStereocenters::ATOM_ANY && of.invalidStereocenter(i))
mol.stereocenters.remove(i);
}
示例2: _markComplicatedStereocentersAsValid
void MoleculeAutomorphismSearch::_markComplicatedStereocentersAsValid (Molecule &mol)
{
// If there is more then 1 unknown stereocenter in the biconnected
// component then validity of such stereocenters cannot be found
// with current methods. For example C[[email protected]]1C[[email protected]@H](C)C[[email protected]](C)C1
// can lead to CC1C[[email protected]](C)C[[email protected]@H](C)C1 or CC1C[[email protected]@H](C)C[[email protected]](C)C1,
// but canonical codes are different for such molecules.
QS_DEF(Array<int>, single_bond_bridge_mark);
single_bond_bridge_mark.resize(mol.edgeEnd());
single_bond_bridge_mark.fill(1);
SpanningTree sp_tree(mol, 0);
sp_tree.markAllEdgesInCycles(single_bond_bridge_mark.ptr(), 0);
for (int i = mol.edgeBegin(); i != mol.edgeEnd(); i++)
if (mol.getBondOrder(i) != BOND_SINGLE)
single_bond_bridge_mark[i] = 0;
Filter edge_filter(single_bond_bridge_mark.ptr(), Filter::NEQ, 1);
GraphDecomposer decomposer(mol);
decomposer.decompose(0, &edge_filter);
const Array<int> &decomposition = decomposer.getDecomposition();
QS_DEF(Array<int>, undef_stereo_in_component);
undef_stereo_in_component.clear();
for (int v = mol.vertexBegin(); v != mol.vertexEnd(); v = mol.vertexNext(v))
{
int comp = decomposition[v];
if (comp < 0)
continue;
while (undef_stereo_in_component.size() <= comp)
undef_stereo_in_component.push(0);
if (_stereocenter_state[v] == _UNDEF)
undef_stereo_in_component[comp]++;
}
// Mark stereocenters as valid if there are more then 1
// undefined stereocenter in the component
for (int v = mol.vertexBegin(); v != mol.vertexEnd(); v = mol.vertexNext(v))
{
int comp = decomposition[v];
if (comp < 0)
continue;
if (_stereocenter_state[v] == _UNDEF && undef_stereo_in_component[comp] > 1)
_stereocenter_state[v] = _VALID;
}
}
示例3: aromatizeBonds
bool MoleculeAromatizer::aromatizeBonds (Molecule &mol, const AromaticityOptions &options)
{
MoleculeAromatizer aromatizer(mol, options);
aromatizer.precalculatePiLabels();
aromatizer.aromatize();
bool aromatic_bond_found = false;
for (int e_idx = mol.edgeBegin(); e_idx < mol.edgeEnd(); e_idx = mol.edgeNext(e_idx))
if (aromatizer.isBondAromatic(e_idx))
{
mol.setBondOrder(e_idx, BOND_AROMATIC, true);
aromatic_bond_found = true;
}
// Aromatize RGroups
int n_rgroups = mol.rgroups.getRGroupCount();
for (int i = 1; i <= n_rgroups; i++)
{
PtrPool<BaseMolecule> &frags = mol.rgroups.getRGroup(i).fragments;
for (int j = frags.begin(); j != frags.end(); j = frags.next(j))
{
Molecule &fragment = frags[j]->asMolecule();
aromatic_bond_found |= MoleculeAromatizer::aromatizeBonds(fragment, options);
}
}
return aromatic_bond_found;
}
示例4: _hasStereo
bool MoleculeAutomorphismSearch::_hasStereo (Molecule &mol)
{
for (int i = mol.edgeBegin(); i != mol.edgeEnd(); i = mol.edgeNext(i))
if (mol.cis_trans.getParity(i) != 0)
return true;
if (mol.stereocenters.size() != 0)
return true;
return false;
}
示例5: saveMoleculeIntoInchi
void IndigoInchi::saveMoleculeIntoInchi (Molecule &mol, Array<char> &inchi)
{
inchi_Input input;
QS_DEF(Array<inchi_Atom>, atoms);
QS_DEF(Array<inchi_Stereo0D>, stereo);
// Check if structure has aromatic bonds
bool has_aromatic = false;
for (int e = mol.edgeBegin(); e != mol.edgeEnd(); e = mol.edgeNext(e))
if (mol.getBondOrder(e) == BOND_AROMATIC)
{
has_aromatic = true;
break;
}
Molecule *target = &mol;
Obj<Molecule> dearom;
if (has_aromatic)
{
dearom.create();
dearom->clone(mol, 0, 0);
try
{
dearom->dearomatize();
}
catch (DearomatizationsGroups::Error &)
{
}
target = dearom.get();
}
generateInchiInput(*target, input, atoms, stereo);
inchi_Output output;
int ret = GetINCHI(&input, &output);
if (output.szMessage)
warning.readString(output.szMessage, true);
if (output.szLog)
log.readString(output.szLog, true);
if (output.szAuxInfo)
auxInfo.readString(output.szAuxInfo, true);
if (ret != inchi_Ret_OKAY && ret != inchi_Ret_WARNING)
{
// Construct error before dispoing inchi output to preserve error message
IndigoError error("Indigo-InChI: InChI generation failed: %s. Code: %d.", output.szMessage, ret);
FreeINCHI(&output);
throw error;
}
inchi.readString(output.szInChI, true);
FreeINCHI(&output);
}
示例6: _initQuery
void MangoExact::_initQuery (Molecule &query)
{
int i;
MoleculeAromatizer::aromatizeBonds(query, AromaticityOptions::BASIC);
if (_flags & MoleculeExactMatcher::CONDITION_STEREO)
{
for (i = query.edgeBegin(); i != query.edgeEnd(); i = query.edgeNext(i))
if (query.getEdgeTopology(i) == TOPOLOGY_RING)
query.cis_trans.setParity(i, 0);
}
}
示例7: _getFirstApproximation
void MoleculeAutomorphismSearch::_getFirstApproximation (Molecule &mol)
{
_stereocenter_state.clear_resize(mol.vertexEnd());
_cistrans_bond_state.clear_resize(mol.edgeEnd());
const MoleculeStereocenters &stereocenters = mol.stereocenters;
for (int i = 0; i < _stereocenter_state.size(); i++)
_stereocenter_state[i] = _NO_STEREO;
for (int i = stereocenters.begin(); i != stereocenters.end(); i = stereocenters.next(i))
{
int atom_index = stereocenters.getAtomIndex(i);
_stereocenter_state[atom_index] = _UNDEF;
}
for (int i = 0; i < _cistrans_bond_state.size(); i++)
_cistrans_bond_state[i] = _NO_STEREO;
for (int i = mol.edgeBegin(); i != mol.edgeEnd(); i = mol.edgeNext(i))
if (mol.cis_trans.getParity(i))
_cistrans_bond_state[i] = _UNDEF;
_cistrans_stereo_bond_parity.clear_resize(mol.edgeEnd());
_cistrans_stereo_bond_parity.zerofill();
_treat_undef_as = _INVALID;
_target_stereocenter = -1;
_target_bond = -1;
// Approximation orbits cannot be used on this step because
// of existance of check_automorphism method. But order from
// first refinment can be used here.
_approximation_orbits.fffill();
profTimerStart(t0, "mol_auto.first_search");
AutomorphismSearch::process(mol);
profTimerStop(t0);
getCanonicallyOrderedOrbits(_approximation_orbits);
_findCisTransStereoBondParirties(mol);
}
示例8: _calcConnectivity
void MoleculePiSystemsMatcher::_calcConnectivity (Molecule &mol, Array<int> &conn)
{
conn.clear_resize(mol.vertexEnd());
conn.zerofill();
for (int e = mol.edgeBegin(); e != mol.edgeEnd(); e = mol.edgeNext(e))
{
int bond_order = mol.getBondOrder(e);
const Edge &edge = mol.getEdge(e);
conn[edge.beg] += bond_order;
conn[edge.end] += bond_order;
}
for (int v = mol.vertexBegin(); v != mol.vertexEnd(); v = mol.vertexNext(v))
if (!mol.isPseudoAtom(v) && !mol.isRSite(v))
conn[v] += mol.getImplicitH(v);
}
示例9: _findInvalidStereoCisTrans
bool MoleculeAutomorphismSearch::_findInvalidStereoCisTrans (Molecule &mol)
{
_treat_undef_as = _VALID;
QS_DEF(Array<int>, invalid_stereo);
invalid_stereo.clear();
bool invalid_found = false;
for (int i = mol.edgeBegin(); i != mol.edgeEnd(); i = mol.edgeNext(i))
{
if (_cistrans_bond_state[i] != _UNDEF || mol.cis_trans.getParity(i) == 0)
continue;
if (ignored_vertices != 0)
{
const Edge &edge = mol.getEdge(i);
if (ignored_vertices[edge.beg] || ignored_vertices[edge.end])
continue;
}
_cistrans_bond_state[i] = _INVALID;
if (_checkCisTransInvalid(mol, i))
// Stereobond is invalid
invalid_stereo.push(i);
_cistrans_bond_state[i] = _UNDEF;
}
// Mark invalid stereocenters
for (int i = 0; i < invalid_stereo.size(); i++)
{
int bond_index = invalid_stereo[i];
_cistrans_bond_state[bond_index] = _INVALID;
invalid_found = true;
}
return invalid_found;
}
示例10: _findCisTransStereoBondParirties
void MoleculeAutomorphismSearch::_findCisTransStereoBondParirties (Molecule &mol)
{
const MoleculeStereocenters &stereocenters = mol.stereocenters;
// Mark edges that connects two stereocenters and that common parity can be detected
for (int i = mol.edgeBegin(); i != mol.edgeEnd(); i = mol.edgeNext(i))
{
const Edge &edge = mol.getEdge(i);
if (!stereocenters.exists(edge.beg) || !stereocenters.exists(edge.end))
continue;
if (stereocenters.getGroup(edge.beg) != stereocenters.getGroup(edge.end))
continue;
if (stereocenters.getType(edge.beg) != stereocenters.getType(edge.end))
continue;
// Both stereocenters exists and groups are the same
int orb_beg = _approximation_orbits[edge.beg];
int orb_end = _approximation_orbits[edge.end];
_approximation_orbits[edge.beg] = -2; // Some value different from -1 and other orbits
_approximation_orbits[edge.end] = -2;
int parity_beg, parity_end;
if (_validStereocenterByAtom(edge.beg, _approximation_orbits, &parity_beg) == _VALID &&
_validStereocenterByAtom(edge.end, _approximation_orbits, &parity_end) == _VALID)
{
// 1 - means that both stereocenters have the same parity
_cistrans_stereo_bond_parity[i] = -parity_beg * parity_end;
}
// Restore orbits
_approximation_orbits[edge.beg] = orb_beg;
_approximation_orbits[edge.end] = orb_end;
}
}
示例11: saveMolecule
void CmfSaver::saveMolecule (Molecule &mol)
{
/* Walk molecule */
DfsWalk walk(mol);
QS_DEF(Array<int>, mapping);
if (_ext_encoder != 0)
_ext_encoder->start();
walk.walk();
/* Get walking sequence */
const Array<DfsWalk::SeqElem> &v_seq = walk.getSequence();
/* Calculate mapping to the encoded molecule */
walk.calcMapping(mapping);
QS_DEF(Array<int>, branch_counters);
QS_DEF(Array<int>, cycle_numbers);
branch_counters.clear_resize(mol.vertexEnd());
branch_counters.zerofill();
cycle_numbers.clear();
_atom_sequence.clear();
QS_DEF(Array<int>, bond_mapping);
bond_mapping.clear_resize(mol.edgeEnd());
bond_mapping.fffill();
int bond_index = 0;
/* Encode first atom */
if (v_seq.size() > 0)
{
_encodeAtom(mol, v_seq[0].idx, mapping.ptr());
_atom_sequence.push(v_seq[0].idx);
int j, openings = walk.numOpenings(v_seq[0].idx);
for (j = 0; j < openings; j++)
{
cycle_numbers.push(v_seq[0].idx);
_encodeCycleNumer(j);
}
}
/* Main cycle */
int i, j, k;
for (i = 1; i < v_seq.size(); i++)
{
int v_idx = v_seq[i].idx;
int e_idx = v_seq[i].parent_edge;
int v_prev_idx = v_seq[i].parent_vertex;
bool write_atom = true;
if (v_prev_idx >= 0)
{
if (walk.numBranches(v_prev_idx) > 1)
if (branch_counters[v_prev_idx] > 0)
_encode(CMF_CLOSE_BRACKET);
int branches = walk.numBranches(v_prev_idx);
if (branches > 1)
if (branch_counters[v_prev_idx] < branches - 1)
_encode(CMF_OPEN_BRACKET);
branch_counters[v_prev_idx]++;
if (branch_counters[v_prev_idx] > branches)
throw Error("unexpected branch");
_encodeBond(mol, e_idx, mapping.ptr());
bond_mapping[e_idx] = bond_index++;
if (save_bond_dirs)
{
int dir = mol.getBondDirection(e_idx);
if (dir != 0)
{
if (dir == BOND_UP)
dir = CMF_BOND_UP;
else if (dir == BOND_DOWN)
dir = CMF_BOND_DOWN;
else
dir = CMF_BOND_EITHER;
const Edge &edge = mol.getEdge(e_idx);
if (edge.beg == v_prev_idx && edge.end == v_idx)
;
else if (edge.beg == v_idx && edge.end == v_prev_idx)
_encode(CMF_BOND_SWAP_ENDS);
else
throw Error("internal");
_encode(dir);
}
//.........这里部分代码省略.........
示例12: generateInchiInput
void IndigoInchi::generateInchiInput (Molecule &mol, inchi_Input &input,
Array<inchi_Atom> &atoms, Array<inchi_Stereo0D> &stereo)
{
QS_DEF(Array<int>, mapping);
mapping.clear_resize(mol.vertexEnd());
mapping.fffill();
int index = 0;
for (int v = mol.vertexBegin(); v != mol.vertexEnd(); v = mol.vertexNext(v))
mapping[v] = index++;
atoms.clear_resize(index);
atoms.zerofill();
stereo.clear();
for (int v = mol.vertexBegin(); v != mol.vertexEnd(); v = mol.vertexNext(v))
{
inchi_Atom &atom = atoms[mapping[v]];
int atom_number = mol.getAtomNumber(v);
if (atom_number == ELEM_PSEUDO)
throw IndigoError("Molecule with pseudoatom (%s) cannot be converted into InChI", mol.getPseudoAtom(v));
if (atom_number == ELEM_RSITE)
throw IndigoError("Molecule with RGroups cannot be converted into InChI");
strncpy(atom.elname, Element::toString(atom_number), ATOM_EL_LEN);
Vec3f &c = mol.getAtomXyz(v);
atom.x = c.x;
atom.y = c.y;
atom.z = c.z;
// connectivity
const Vertex &vtx = mol.getVertex(v);
int nei_idx = 0;
for (int nei = vtx.neiBegin(); nei != vtx.neiEnd(); nei = vtx.neiNext(nei))
{
int v_nei = vtx.neiVertex(nei);
atom.neighbor[nei_idx] = mapping[v_nei];
int edge_idx = vtx.neiEdge(nei);
atom.bond_type[nei_idx] = getInchiBondType(mol.getBondOrder(edge_idx));
int bond_stereo = INCHI_BOND_STEREO_NONE;
if (mol.cis_trans.isIgnored(edge_idx))
bond_stereo = INCHI_BOND_STEREO_DOUBLE_EITHER;
else
{
int dir = mol.getBondDirection2(v, v_nei);
if (mol.getBondDirection2(v, v_nei) == BOND_EITHER)
bond_stereo = INCHI_BOND_STEREO_SINGLE_1EITHER;
else if (mol.getBondDirection2(v_nei, v) == BOND_EITHER)
bond_stereo = INCHI_BOND_STEREO_SINGLE_2EITHER;
}
atom.bond_stereo[nei_idx] = bond_stereo;
nei_idx++;
}
atom.num_bonds = vtx.degree();
// Other properties
atom.isotopic_mass = mol.getAtomIsotope(v);
atom.radical = mol.getAtomRadical(v);
atom.charge = mol.getAtomCharge(v);
// Hydrogens
int hcount = -1;
if (Molecule::shouldWriteHCount(mol, v) || mol.isExplicitValenceSet(v) || mol.isImplicitHSet(v))
{
if (mol.getAtomAromaticity(v) == ATOM_AROMATIC &&
atom_number == ELEM_C && atom.charge == 0 && atom.radical == 0)
{
// Do not set number of implicit hydrogens here as InChI throws an exception on
// the molecule B1=CB=c2cc3B=CC=c3cc12
;
}
else
// set -1 to tell InChI add implicit hydrogens automatically
hcount = mol.getImplicitH_NoThrow(v, -1);
}
atom.num_iso_H[0] = hcount;
}
// Process cis-trans bonds
for (int e = mol.edgeBegin(); e != mol.edgeEnd(); e = mol.edgeNext(e))
{
if (mol.cis_trans.getParity(e) == 0)
continue;
int subst[4];
mol.cis_trans.getSubstituents_All(e, subst);
const Edge &edge = mol.getEdge(e);
inchi_Stereo0D &st = stereo.push();
// Write it as
// #0 - #1 = #2 - #3
st.neighbor[0] = mapping[subst[0]];
st.neighbor[1] = mapping[edge.beg];
st.neighbor[2] = mapping[edge.end];
st.neighbor[3] = mapping[subst[2]];
if (mol.cis_trans.getParity(e) == MoleculeCisTrans::CIS)
st.parity = INCHI_PARITY_ODD;
//.........这里部分代码省略.........
示例13: process
void MoleculeAutomorphismSearch::process (Molecule &mol)
{
_initialize(mol);
if (detect_invalid_stereocenters || detect_invalid_cistrans_bonds)
{
// Mark stereocenters that are valid
_markValidOrInvalidStereo(true, _approximation_orbits, NULL);
_markValidOrInvalidStereo(false, _approximation_orbits, NULL);
// Temposrary solution: mark unknown stereocenters as valid if
// number of them is more then 1 in each component
_markComplicatedStereocentersAsValid(mol);
// Find invalid stereocenters and bonds iteratively
// For each component
const int *ignored_vertices_saved = ignored_vertices;
GraphDecomposer decomposer(mol);
int ncomp = decomposer.decompose();
QS_DEF(Array<int>, ignored_vertices_arr);
ignored_vertices_arr.resize(mol.vertexEnd());
ignored_vertices = ignored_vertices_arr.ptr();
for (int comp = 0; comp < ncomp; comp++)
{
// Copy existing ignores vertices
if (ignored_vertices_saved != 0)
ignored_vertices_arr.copy(ignored_vertices_saved, mol.vertexEnd());
else
ignored_vertices_arr.zerofill();
for (int i = mol.vertexBegin(); i != mol.vertexEnd(); i = mol.vertexNext(i))
{
if (decomposer.getComponent(i) != comp)
ignored_vertices_arr[i] = 1;
}
while (_findInvalidStereo(mol))
;
}
ignored_vertices = ignored_vertices_saved;
}
// Mark all other stereocenters and stereobonds as valid
const MoleculeStereocenters &stereocenters = mol.stereocenters;
for (int i = stereocenters.begin(); i != stereocenters.end(); i = stereocenters.next(i))
{
int atom_index = stereocenters.getAtomIndex(i);
if (_stereocenter_state[atom_index] == _UNDEF)
_stereocenter_state[atom_index] = _VALID;
}
for (int i = mol.edgeBegin(); i != mol.edgeEnd(); i = mol.edgeNext(i))
if (_cistrans_bond_state[i] == _UNDEF && mol.cis_trans.getParity(i) != 0)
_cistrans_bond_state[i] = _VALID;
// Find final orbits and canonical ordering with found
// valid and invalid stereocenters and bonds
_target_stereocenter = -1;
_target_bond = -1;
_fixed_atom = -1;
// Find possible cis-trans bonds
_findAllPossibleCisTrans(mol);
if (find_canonical_ordering)
{
profTimerStart(t0, "mol_auto.final_search");
AutomorphismSearch::process(mol);
profTimerStop(t0);
}
}
示例14: clear
TautomerSuperStructure::TautomerSuperStructure (Molecule &mol) :
CP_INIT,
TL_CP_GET(_atomsEmitBond),
TL_CP_GET(_atomsAcceptBond),
TL_CP_GET(_isBondAttachedArray),
TL_CP_GET(_mapping),
TL_CP_GET(_inv_mapping),
TL_CP_GET(_edge_mapping),
TL_CP_GET(_total_h)
{
int i;
_inside_ctor = true;
clone(mol, &_inv_mapping, &_mapping);
_edge_mapping.clear_resize(edgeEnd());
_edge_mapping.fffill();
for (i = mol.edgeBegin(); i != mol.edgeEnd(); i = mol.edgeNext(i))
{
const Edge &edge = mol.getEdge(i);
_edge_mapping[findEdgeIndex(_inv_mapping[edge.beg],
_inv_mapping[edge.end])] = i;
}
// Collect atom properties
_collectAtomProperties();
// Detect distances from _atomsEmitBond elements to _atomsAcceptBond elements
QS_DEF(Array<int>, distancesMatrix);
distancesMatrix.resize(_atomsEmitBond.size() * _atomsAcceptBond.size());
for (int i = 0; i < _atomsEmitBond.size(); i++)
{
int *result = distancesMatrix.ptr() + _atomsAcceptBond.size() * i;
_findMinDistance(_atomsEmitBond[i], 6, _atomsAcceptBond, result);
}
QS_DEF(Array<int>, attachedBonds);
attachedBonds.clear();
for (int i = 0; i < _atomsEmitBond.size(); i++)
for (int j = 0; j < _atomsAcceptBond.size(); j++)
{
int v1 = _atomsEmitBond[i];
int v2 = _atomsAcceptBond[j];
if (findEdgeIndex(v1, v2) != -1)
continue;
// Check new loop size: 5 or 6
int size = distancesMatrix[_atomsAcceptBond.size() * i + j];
if (size != 4 && size != 5)
continue;
attachedBonds.push(addEdge(v1, v2));
}
_isBondAttachedArray.resize(edgeEnd());
_isBondAttachedArray.zerofill();
for (int i = 0; i < attachedBonds.size(); i++)
_isBondAttachedArray[attachedBonds[i]] = true;
_inside_ctor = false;
}
TautomerSuperStructure::~TautomerSuperStructure ()
{
}
void TautomerSuperStructure::clear ()
{
if (_inside_ctor)
Molecule::clear();
else
throw Exception("clear(): not supported");
}
int TautomerSuperStructure::getBondOrder (int idx)
{
if (!_inside_ctor && _isBondAttachedArray[idx])
return -1;
return Molecule::getBondOrder(idx);
}
int TautomerSuperStructure::getBondTopology (int idx)
{
if (!_inside_ctor &&_isBondAttachedArray[idx])
return -1;
return Molecule::getBondTopology(idx);
}
bool TautomerSuperStructure::possibleBondOrder (int idx, int order)
{
if (!_inside_ctor &&_isBondAttachedArray[idx])
return order == 0 || order == BOND_SINGLE;
return Molecule::possibleBondOrder(idx, order);
}
//.........这里部分代码省略.........
示例15: _writeMolecule
void CrfSaver::_writeMolecule (Molecule &molecule)
{
Obj<CmfSaver> saver;
int i;
if (_encoder.get() != 0)
saver.create(_encoder.ref());
else
saver.create(_output);
QS_DEF(Array<int>, atom_flags);
QS_DEF(Array<int>, bond_flags);
if (_atom_stereo_flags != 0)
{
atom_flags.clear_resize(molecule.vertexEnd());
atom_flags.zerofill();
for (i = molecule.vertexBegin(); i != molecule.vertexEnd(); i = molecule.vertexNext(i))
if (_atom_stereo_flags[i] == STEREO_RETAINS)
atom_flags[i] = 1;
else if (_atom_stereo_flags[i] == STEREO_INVERTS)
atom_flags[i] = 2;
saver->atom_flags = atom_flags.ptr();
}
if (_bond_rc_flags != 0)
{
bond_flags.clear_resize(molecule.edgeEnd());
bond_flags.zerofill();
for (i = molecule.edgeBegin(); i != molecule.edgeEnd(); i = molecule.edgeNext(i))
{
if (_bond_rc_flags[i] & RC_UNCHANGED)
bond_flags[i] |= 1;
if (_bond_rc_flags[i] & RC_MADE_OR_BROKEN)
bond_flags[i] |= 2;
if (_bond_rc_flags[i] & RC_ORDER_CHANGED)
bond_flags[i] |= 4;
}
saver->bond_flags = bond_flags.ptr();
}
saver->save_bond_dirs = save_bond_dirs;
saver->save_highlighting = save_highlighting;
saver->save_mapping = save_mapping;
saver->saveMolecule(molecule);
if (_aam != 0)
_writeAam(_aam, saver->getAtomSequence());
if (xyz_output != 0)
{
if (xyz_output == &_output && _encoder.get() != 0)
_encoder->finish();
saver->saveXyz(*xyz_output);
if (xyz_output == &_output && _encoder.get() != 0)
_encoder->start();
}
}