本文整理汇总了Java中org.openscience.cdk.interfaces.IAtomContainer.getAtom方法的典型用法代码示例。如果您正苦于以下问题:Java IAtomContainer.getAtom方法的具体用法?Java IAtomContainer.getAtom怎么用?Java IAtomContainer.getAtom使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类org.openscience.cdk.interfaces.IAtomContainer
的用法示例。
在下文中一共展示了IAtomContainer.getAtom方法的11个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: determineCarbonAtomStatistics
import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
public static void determineCarbonAtomStatistics(IAtomContainer mol, ICandidate candidate, java.util.Vector<Integer> aromaticAtomIndexes) {
int numberC = 0;
int numberAliphaticCH = 0;
int numberAromaticCH = 0;
for(int i = 0; i < mol.getAtomCount(); i++) {
IAtom atom = mol.getAtom(i);
if(atom.getSymbol().equals("C")) {
numberC++;
int hydrogens = atom.getImplicitHydrogenCount();
if(aromaticAtomIndexes.contains(i)) numberAromaticCH += hydrogens;
else numberAliphaticCH += hydrogens;
}
}
candidate.setProperty("#C", numberC);
candidate.setProperty("#aliphaticCH", numberAliphaticCH);
candidate.setProperty("#aromaticCH", numberAromaticCH);
}
示例2: extractSubstructure
import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
private static IAtomContainer extractSubstructure(
IAtomContainer atomContainer,
int... atomIndices
) throws CloneNotSupportedException {
IAtomContainer substructure = (IAtomContainer) atomContainer.clone();
int numberOfAtoms = substructure.getAtomCount();
IAtom[] atoms = new IAtom[numberOfAtoms];
for (int atomIndex = 0; atomIndex < numberOfAtoms; atomIndex++) {
atoms[atomIndex] = substructure.getAtom(atomIndex);
}
Arrays.sort(atomIndices);
for (int index = 0; index < numberOfAtoms; index++) {
if (Arrays.binarySearch(atomIndices, index) < 0) {
IAtom atom = atoms[index];
substructure.removeAtomAndConnectedElectronContainers(atom);
}
}
return substructure;
}
示例3: negativeCOOHPOOHSOOHDetection
import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
private void negativeCOOHPOOHSOOHDetection(HashMap<Integer, Vector<PotentialPharmacophorePoint>> PPPAssignment,
IAtomContainer mol) {
// Search for COOH, POOH, and SOOH groups
final PotentialPharmacophorePoint ppp = new PotentialPharmacophorePoint("N", "no pattern",
"carbon, sulfur, or phosphorus atom of COOH, SOOH, or POOH");
for (int i = 0; i < mol.getAtomCount(); i++) {
final IAtom a = mol.getAtom(i);
if (a.getAtomicNumber().equals(6) || a.getAtomicNumber().equals(15) || a.getAtomicNumber().equals(16)) {
// Possible starting point of group
// Check neighbor
if (this.isCOOHPOOHSOOHGroup(a, mol)) {
if (!PPPAssignment.containsKey(mol.getAtomNumber(a))) {
final Vector<PotentialPharmacophorePoint> temp = new Vector<PotentialPharmacophorePoint>();
temp.add(ppp);
PPPAssignment.put(mol.getAtomNumber(a), temp);
} else {
PPPAssignment.get(mol.getAtomNumber(a)).add(ppp);
}
}
}
}
}
示例4: process
import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
@Override
void process(IAtomContainer mol) {
long t0 = System.nanoTime();
int[] prev = new int[mol.getAtomCount()];
int[] next = new int[mol.getAtomCount()];
for (int i = 0; i < mol.getAtomCount(); i++) {
next[i] = prev[i] = mol.getAtom(i).getAtomicNumber();
}
for (int rep = 0; rep < mol.getAtomCount(); rep++) {
for (int j = 0; j < mol.getAtomCount(); j++) {
IAtom atom = mol.getAtom(j);
for (IBond bond : mol.getConnectedBondsList(atom)) {
IAtom nbr = bond.getConnectedAtom(atom);
next[j] += prev[mol.getAtomNumber(nbr)];
}
}
System.arraycopy(next, 0, prev, 0, next.length);
}
long t1 = System.nanoTime();
tRun += t1 - t0;
for (int aNext : next) check += aNext;
}
示例5: determineSulfurAtomStatistics
import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
public static void determineSulfurAtomStatistics(IAtomContainer mol, ICandidate candidate, java.util.Vector<Integer> aromaticAtomIndexes) {
int numberS = 0;
int numberSH = 0;
int numberSOO = 0;
int numberSOOO = 0;
int numberSOOOO = 0;
int numberSnoH = 0;
for(int i = 0; i < mol.getAtomCount(); i++) {
IAtom atom = mol.getAtom(i);
if(atom.getSymbol().equals("S")) {
numberS++;
int hydrogens = atom.getImplicitHydrogenCount();
int oxygens = countOxygens(mol.getConnectedAtomsList(atom));
if(oxygens == 4) numberSOOOO++;
else if(oxygens == 3) numberSOOO++;
else if(oxygens == 2) numberSOO++;
else if(hydrogens == 1) numberSH++;
else if(hydrogens == 0) numberSnoH++;
else System.err.println("Somthing wrong with S and " + candidate.getProperty("Identifier"));
}
}
candidate.setProperty("#S", numberS);
candidate.setProperty("#SH", numberSH);
candidate.setProperty("#SO2", numberSOO);
candidate.setProperty("#SO3", numberSOOO);
candidate.setProperty("#SO4", numberSOOOO);
candidate.setProperty("#S(noH)", numberSnoH);
}
示例6: determineNitrogenAtomStatistics
import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
public static void determineNitrogenAtomStatistics(IAtomContainer mol, ICandidate candidate, java.util.Vector<Integer> aromaticAtomIndexes) {
int numberN = 0;
int numberNH = 0;
int numberNHH = 0;
int aromaticNH = 0;
int aromaticN = 0;
for(int i = 0; i < mol.getAtomCount(); i++) {
IAtom atom = mol.getAtom(i);
if(atom.getSymbol().equals("N")) {
numberN++;
int hydrogens = atom.getImplicitHydrogenCount();
if(aromaticAtomIndexes.contains(i)) {
if(hydrogens == 0) aromaticN++;
else if(hydrogens == 1) aromaticNH++;
else System.err.println("Somthing wrong with aromatic N and " + candidate.getProperty("Identifier"));
}
else {
if(hydrogens == 0) continue;
else if(hydrogens == 1) numberNH++;
else if(hydrogens == 2) numberNHH++;
else System.err.println("Somthing wrong with aliphatic N and " + candidate.getProperty("Identifier"));
}
}
}
candidate.setProperty("#N", numberN);
candidate.setProperty("#NHonly", numberNH);
candidate.setProperty("#NH2", numberNHH);
candidate.setProperty("#aromaticNH", aromaticNH);
candidate.setProperty("#aromaticN", aromaticN);
}
示例7: getFingerprint
import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
@Override
public List<IFeature> getFingerprint(IAtomContainer ac) {
final int[][] admat = AdjacencyMatrix.getMatrix(ac);
final int[][] shortest_path = PathTools.computeFloydAPSP(admat);
final List<PathFeature> allShortestPaths = new ArrayList<PathFeature>();
for (int i = 0; i < ac.getAtomCount(); i++) {
final Atom start = (Atom) ac.getAtom(i);
// we may skip the other half of the matrix because we generate a
// canonical features afterwards
for (int j = i; j < ac.getAtomCount(); j++) {
if (i == j) {
continue;
}
final Atom end = (Atom) ac.getAtom(j);
if (shortest_path[i][j] <= super.getSearchDepth()) {
final List<PathFeature> allShortestPathsIndex = getAllShortestPath(ac, start, end,
shortest_path[i][j]);
allShortestPaths.addAll(allShortestPathsIndex);
}
}
}
final ArrayList<IFeature> fingerprint = new ArrayList<IFeature>();
for (int i = 0; i < allShortestPaths.size(); i++) {
final String string = allShortestPaths.get(i).toString();
final NumericStringFeature feature = new NumericStringFeature(string, 1.0);
fingerprint.add(feature);
}
return fingerprint;
}
示例8: getBondRefs
import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
public static BondRef[] getBondRefs(IAtomContainer mol) {
final int numAtoms = mol.getAtomCount();
final int numBonds = mol.getBondCount();
BondRef[] bonds = new BondRef[numBonds];
final Map<IAtom, AtomRef> atomCache = new IdentityHashMap<>(mol.getAtomCount());
for (int i = 0; i < numAtoms; i++) {
final IAtom atom = mol.getAtom(i);
final AtomRef atomrf = new AtomRef(i,
atom,
new ArrayList<BondRef>());
atomCache.put(atomrf.atom, atomrf);
}
for (int i = 0; i < numBonds; i++) {
final IBond bond = mol.getBond(i);
AtomRef beg = atomCache.get(bond.getAtom(0));
AtomRef end = atomCache.get(bond.getAtom(1));
final BondRef bondref = new BondRef(bond, i, beg, end);
beg.bonds.add(bondref);
end.bonds.add(bondref);
bonds[i] = bondref;
}
return bonds;
}
示例9: getAtomRefs
import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
public static AtomRef[] getAtomRefs(IAtomContainer mol) {
final int numAtoms = mol.getAtomCount();
final int numBonds = mol.getBondCount();
AtomRef[] atoms = new AtomRef[numAtoms];
final Map<IAtom, AtomRef> atomCache = new IdentityHashMap<>(mol.getAtomCount());
for (int i = 0; i < numAtoms; i++) {
final IAtom atom = mol.getAtom(i);
final AtomRef atomrf = new AtomRef(i,
atom,
new ArrayList<BondRef>());
atomCache.put(atomrf.atom, atomrf);
atoms[i] = atomrf;
}
for (int i = 0; i < numBonds; i++) {
final IBond bond = mol.getBond(i);
AtomRef beg = atomCache.get(bond.getAtom(0));
AtomRef end = atomCache.get(bond.getAtom(1));
final BondRef bondref = new BondRef(bond, i, beg, end);
beg.bonds.add(bondref);
end.bonds.add(bondref);
}
return atoms;
}
示例10: dfs
import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
private int dfs(IAtomContainer mol, int[][] adjlist, int src, int prev) {
check++;
IAtom atm = mol.getAtom(src);
atm.setFlag(CDKConstants.VISITED, true);
for (int dst : adjlist[src]) {
if (dst == prev)
continue;
IAtom nbr = mol.getAtom(dst);
if (!nbr.getFlag(CDKConstants.VISITED))
dfs(mol, adjlist, dst, src);
}
return 0;
}
示例11: getFingerprint3Point
import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
/**
* generates all possible patterns between three atoms
*
* @param ac
* @param matrix
* @param distanceCutoff
* @param typer
* @return
*/
public List<IFeature> getFingerprint3Point(IAtomContainer ac, int[][] matrix, int distanceCutoff,
ExtendedAtomAndBondTyper typer) {
final ArrayList<IFeature> features = new ArrayList<IFeature>();
for (int i = 0; i < matrix.length; i++) {
for (int j = 0; j < matrix.length; j++) {
if (i == j) {
continue;
}
if (matrix[i][j] > distanceCutoff) {
continue;
}
for (int k = 0; k < matrix.length; k++) {
if ((i == k) || (j == k)) {
continue;
}
if (matrix[j][k] > distanceCutoff) {
continue;
}
if (matrix[k][i] > distanceCutoff) {
continue;
}
final StringBuffer sb = new StringBuffer();
final IAtom atomA = ac.getAtom(i);
final IAtom atomB = ac.getAtom(j);
final IAtom atomC = ac.getAtom(k);
try {
sb.append(typer.getAtomLabel(atomA));
sb.append("-");
sb.append(matrix[i][j]);
sb.append("-");
sb.append(typer.getAtomLabel(atomB));
sb.append("-");
sb.append(matrix[j][k]);
sb.append("-");
sb.append(typer.getAtomLabel(atomC));
sb.append("-");
sb.append(matrix[k][i]);
} catch (final MoltyperException e) {
e.printStackTrace();
}
final NumericStringFeature feature = new NumericStringFeature(sb.toString(), 1.0);
features.add(feature);
}
}
}
return features;
}