File: example10.cpp

package info (click to toggle)
rdkit 202503.6-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 222,000 kB
  • sloc: cpp: 411,111; python: 78,482; ansic: 26,181; java: 8,285; javascript: 4,404; sql: 2,393; yacc: 1,626; lex: 1,267; cs: 1,090; makefile: 581; xml: 229; fortran: 183; sh: 121
file content (41 lines) | stat: -rw-r--r-- 1,200 bytes parent folder | download | duplicates (2)
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
//
// Generating depictions - example10.cpp

#include <iostream>
#include <Geometry/point.h>
#include <GraphMol/SmilesParse/SmilesParse.h>
#include <GraphMol/GraphMol.h>
#include <GraphMol/MolOps.h>
#include <GraphMol/Depictor/RDDepictor.h>
#include <GraphMol/Substruct/SubstructMatch.h>

using namespace RDKit;

int main(int argc, char **argv) {
  auto mol = "c1nccc2n1ccc2"_smiles;
  RDDepict::compute2DCoords(*mol);

#ifdef RDK_BUILD_COORDGEN_SUPPORT
  RDDepict::preferCoordGen = true;
#else
  std::cout << "CoordGen support not available" << std::endl;
#endif

  RDDepict::compute2DCoords(*mol, nullptr, true);

  std::shared_ptr<RDKit::ROMol> templ(RDKit::SmilesToMol("c1nccc2n1ccc2"));
  RDDepict::compute2DCoords(*templ);
  std::shared_ptr<RDKit::ROMol> mol1(RDKit::SmilesToMol("c1cccc2ncn3cccc3c21"));

  MatchVectType matchVect;
  if (SubstructMatch(*mol1, *templ, matchVect)) {
    RDKit::Conformer &conf = templ->getConformer();
    RDGeom::INT_POINT2D_MAP coordMap;
    for (auto mv : matchVect) {
      RDGeom::Point3D pt3 = conf.getAtomPos(mv.first);
      RDGeom::Point2D pt2(pt3.x, pt3.y);
      coordMap[mv.second] = pt2;
    }
    RDDepict::compute2DCoords(*mol1, &coordMap);
  }
}