當前位置: 首頁>>代碼示例>>Java>>正文


Java MolBond.getType方法代碼示例

本文整理匯總了Java中chemaxon.struc.MolBond.getType方法的典型用法代碼示例。如果您正苦於以下問題:Java MolBond.getType方法的具體用法?Java MolBond.getType怎麽用?Java MolBond.getType使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在chemaxon.struc.MolBond的用法示例。


在下文中一共展示了MolBond.getType方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: isAlphaAminoAcidNitrogenAtom

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
private boolean isAlphaAminoAcidNitrogenAtom(MolAtom atom) {
    if (atom.getAtno() == 7) {
        int bondCount = atom.getBondCount();

        for (int i = 0; i < bondCount; i++) {
            MolBond bond = atom.getBond(i);
            MolAtom otherAtom = bond.getOtherAtom(atom);

            if (bond.getType() == 1 && otherAtom.getAtno() == 6) {
                int carbonBondCount = otherAtom.getBondCount();
                for (int j = 0; j < carbonBondCount; j++) {
                    MolBond carbonBond = otherAtom.getBond(j);
                    MolAtom neighborAtom = carbonBond.getOtherAtom(otherAtom);
                    if (carbonBond.getType() == 1 && neighborAtom.getAtno() == 6 && isCarbonylCarbonAtom(neighborAtom)) {
                        return true;
                    }
                }
            }
        }
    }
    return false;
}
 
開發者ID:PistoiaHELM,項目名稱:HELMNotationToolkit,代碼行數:23,代碼來源:PeptideStructureParser.java

示例2: isAmideBond

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
private boolean isAmideBond(MolBond bond) {
    MolAtom atom1 = bond.getAtom1();
    MolAtom atom2 = bond.getAtom2();

    if (bond.getType() == 1) {
        boolean found = false;
        if (isCarbonylCarbonAtom(atom1) && isAminoNitrogenAtom(atom2)) {
            found = true;
        } else if  (isCarbonylCarbonAtom(atom2) && isAminoNitrogenAtom(atom1)) {
            found = true;
        }
        
        if (found && !isPreservedAmideBond(bond)) {
            return true;
        }
    }

    return false;
}
 
開發者ID:PistoiaHELM,項目名稱:HELMNotationToolkit,代碼行數:20,代碼來源:PeptideStructureParser.java

示例3: isCarbonylCarbonAtom

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
private boolean isCarbonylCarbonAtom(MolAtom atom) {
    if (atom.getAtno() == 6) {
        int bondCount = atom.getBondCount();
        int hcount = atom.getImplicitHcount();

        if (bondCount + hcount == 3) {
            for (int i = 0; i < bondCount; i++) {
                MolBond bond = atom.getBond(i);
                MolAtom otherAtom = bond.getOtherAtom(atom);
                if (bond.getType() == 2 && otherAtom.getAtno() == 8) {
                    return true;
                }
            }
        }
    }
    return false;
}
 
開發者ID:PistoiaHELM,項目名稱:HELMNotationToolkit,代碼行數:18,代碼來源:PeptideStructureParser.java

示例4: if

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
protected void genParityPath 
    (LinkedList<MolBond> path, Set<MolAtom> visited, 
     int parity, MolAtom a, MolAtom end) {

    if (a == end) {
        MolPath newpath = new MolPath (path.toArray(new MolBond[0]), rank);
        paths.add(newpath);
    }
    else if (path.size() <= maxdepth) {
        visited.add(a);
        for (int i = 0; i < a.getBondCount(); ++i) {
            MolBond b = a.getBond(i);
            MolAtom xa = b.getOtherAtom(a);
            if (visited.contains(xa) || xa.getCharge() != 0) {
            }
            else if (parity + 1 == b.getType()) {
                path.push(b);
                genParityPath (path, visited, 1-parity, xa, end);
                path.pop();
            }
        }
        visited.remove(a);
    }
}
 
開發者ID:ncats,項目名稱:lychi,代碼行數:25,代碼來源:NCGCTautomerGenerator.java

示例5: mustHaveSingle

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
protected boolean mustHaveSingle (int ai) {
if (avisit[ai] != 0) {
    if ((types[ai] & TAU_DON) != 0)
	return true;
}

MolAtom atom = atoms[ai];
for (int i = 0; i < atom.getBondCount(); ++i) {
    MolBond bond = atom.getBond(i);
    if (bond.getType() == 2 && bvisit[mol.indexOf(bond)] != 0) {
	return true;
    }
}

return false;
   }
 
開發者ID:ncats,項目名稱:lychi,代碼行數:17,代碼來源:SayleDelanyTautomerGenerator.java

示例6: mustHaveDouble

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
protected boolean mustHaveDouble (int ai) {
if ((types[ai] & TAU_DON) == 0 && avisit[ai] != 0) {
    int doub = 0, avail = 0;
    MolAtom atom = atoms[ai];
    for (int i = 0; i < atom.getBondCount(); ++i) {
	MolBond bond = atom.getBond(i);
	if (bvisit[mol.indexOf(bond)] != 0) {
	    if (bond.getType() == 2)
		++doub;
	}
	else {
	    ++avail;
	}
    }
    return avail== 1 && doub == 0;
}
return false;
   }
 
開發者ID:ncats,項目名稱:lychi,代碼行數:19,代碼來源:SayleDelanyTautomerGenerator.java

示例7: resetEZ

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
public static void resetEZ (Molecule mol) {
MolBond[] bonds = mol.getBondArray();
for (int i = 0; i < bonds.length; ++i) {
    MolBond b = bonds[i];
    int type = b.getType();
    if (type == 2) {
	b.setFlags(0, MolBond.CTUMASK);
    }
    else if (type == 1) {
	int flags = b.getFlags() & MolBond.STEREO1_MASK;
	if (flags  == (MolBond.UP | MolBond.DOWN)) {
	    // WAVY flag... 
	    b.setFlags(0, MolBond.STEREO1_MASK);
	}
    }
}
   }
 
開發者ID:ncats,項目名稱:lychi,代碼行數:18,代碼來源:ChemUtil.java

示例8: isQueryMol

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
public static boolean isQueryMol (Molecule mol) {
    mol.ungroupSgroups();
    for (MolAtom atom : mol.getAtomArray()) {
        switch (atom.getAtno()) {
        case MolAtom.LIST:
        case MolAtom.NOTLIST:
        case MolAtom.ANY:
        case MolAtom.RGROUP:
            return true;
        }
    }

    for (MolBond bond : mol.getBondArray()) {
        switch (bond.getType()) {
        case 1: case 2: case 3: case MolBond.AROMATIC:
            break;

        default:
            return true;
        }
    }
    return false;
}
 
開發者ID:ncats,項目名稱:lychi,代碼行數:24,代碼來源:LyChIStandardizer.java

示例9: isAlphaAminoAcidCarbonylCarbonAtom

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
private boolean isAlphaAminoAcidCarbonylCarbonAtom(MolAtom atom) {
    if (atom.getAtno() == 6) {
        int bondCount = atom.getBondCount();
        boolean foundOxygen = false;
        boolean foundAlphaNitrogen = false;
        for (int i = 0; i < bondCount; i++) {
            MolBond bond = atom.getBond(i);
            MolAtom otherAtom = bond.getOtherAtom(atom);
            if (bond.getType() == 2 && otherAtom.getAtno() == 8) {
                foundOxygen = true;
            } else if (bond.getType() == 1 && otherAtom.getAtno() == 6) {
                int carbonBondCount = otherAtom.getBondCount();

                for (int j = 0; j < carbonBondCount; j++) {
                    MolBond carbonBond = otherAtom.getBond(j);
                    MolAtom neighborAtom = carbonBond.getOtherAtom(otherAtom);
                    if (carbonBond.getType() == 1 && neighborAtom.getAtno() == 7) {
                        foundAlphaNitrogen = true;
                        break;
                    }
                }
            }
        }
        if (foundOxygen && foundAlphaNitrogen) {
            return true;
        }
    }
    return false;
}
 
開發者ID:PistoiaHELM,項目名稱:HELMNotationToolkit,代碼行數:30,代碼來源:PeptideStructureParser.java

示例10: isDisulfideBond

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
private boolean isDisulfideBond(MolBond bond) {
    MolAtom atom1 = bond.getAtom1();
    MolAtom atom2 = bond.getAtom2();
    if (bond.getType() == 1) {
        if (isDisulfideSulfurAtom(atom1) && isDisulfideSulfurAtom(atom2)) {
            return true;
        }
    }
    return false;
}
 
開發者ID:PistoiaHELM,項目名稱:HELMNotationToolkit,代碼行數:11,代碼來源:PeptideStructureParser.java

示例11: isKekulized

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
protected static boolean isKekulized (Molecule m) {
for (MolBond b : m.getBondArray()) {
    if (b.getType() == MolBond.AROMATIC) {
	return false;
    }
}
return true;
   }
 
開發者ID:ncats,項目名稱:lychi,代碼行數:9,代碼來源:SayleDelanyTautomerGenerator.java

示例12: adjustEZStereo

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
public static void adjustEZStereo (Molecule mol) {
for (MolBond b : mol.getBondArray()) {
    if (b.getType() == 2) {
	MolAtom a1 = b.getCTAtom1();
	MolAtom a4 = b.getCTAtom4();
	if (a1 != null && a4 != null 
	    && (a1.getX() != 0. || a1.getY() != 0.)
	    && (a4.getX() != 0. || a4.getY() != 0.)) {
	    b.setStereo2Flags(a1, a4, b.calcStereo2(a1, a4));
	}
    }
}
   }
 
開發者ID:ncats,項目名稱:lychi,代碼行數:14,代碼來源:ChemUtil.java

示例13: getLabel

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
public String getLabel (MolBond b) {
int type = b.getType();
switch (type) {
case 1: return "";
case 2: return "=";
case 3: return "#";
case MolBond.AROMATIC: return ":";
default: return "?";
}
   }
 
開發者ID:ncats,項目名稱:lychi,代碼行數:11,代碼來源:Deprotonator.java

示例14: transform

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
void transform (Molecule mol, int[] hit) {
    if (debug) {
        System.out.println("Hit: "+smirks);
        for(int j=0; j < hit.length; j++) {
            System.out.print(" " + (hit[j]+1)+":"
                             +source.getAtom(j).getAtomMap());
        }
        System.out.println();
    }

    if (target.getAtomCount() == 0) {
        // delete this subgraph
        for (int j = 0; j < hit.length; ++j) {
            mol.removeNode(hit[j]);
        }
    }
    else {
        MolAtom[] M = new MolAtom[mol.getAtomCount()];

        // update atom
        for (int j = 0; j < hit.length; ++j) {
            MolAtom src = target.getAtom(map[j]);
            MolAtom dst = mol.getAtom(hit[j]);
            //System.out.println("updating atom " + (hit[j]+1));
            copy (dst, src);
            M[hit[j]] = src;
        }
                
        // now update the bond
        for (MolBond b1 : mol.getBondArray()) {
            MolAtom a1 = b1.getAtom1();
            MolAtom a2 = b1.getAtom2();
            int i1 = mol.indexOf(a1);
            int i2 = mol.indexOf(a2);

            if (M[i1] != null && M[i2] != null) {
                for (int j = 0; j < M[i1].getBondCount(); ++j) {
                    MolBond b2 = M[i1].getBond(j);
                    if (b2.getOtherAtom(M[i1]) == M[i2]) {
                        int type = b2.getType();
                        switch (type) {
                        case MolBond.SINGLE_OR_AROMATIC:
                            b1.setType(1);
                            break;

                        case MolBond.DOUBLE_OR_AROMATIC:
                            b1.setType(2);
                            break;

                        case 1: case 2: case 3:
                            b1.setType(type);
                            break;
                        }

                        if (debug) {
                            System.out.println
                                ("updating bond " + (i1+1)
                                 + "-"+(i2+1) + " to " 
                                 + b1.getType());
                        }
                    }
                }
            }
        }

        M = null;
    }
}
 
開發者ID:ncats,項目名稱:lychi,代碼行數:69,代碼來源:SMIRKS.java

示例15: postprocessing

import chemaxon.struc.MolBond; //導入方法依賴的package包/類
void postprocessing (Molecule mol, boolean chargeBalance) {
    if (chargeBalance) chargeBalance (mol);
    if (mol.getAtomCount() > 0) {
        /*
         * this is needed because of tests/standardizer_case10.smi
         */
        try {
            String smiles = mol.toFormat("cxsmiles:u");
            if (DEBUG) {
                logger.log(Level.INFO, "Before final molecule cleaning: "
                           +smiles);
            }

            Molecule newmol = MolImporter.importMol(smiles);
            newmol.dearomatize();

            boolean hasArom = false;
            for (MolBond b : newmol.getBondArray()) {
                if (b.getType() == MolBond.AROMATIC) {
                    hasArom = true;
                    break;
                }
            }

            if (hasArom) {
                logger.log(Level.WARNING, mol.getName()
                           +": can't kekulize aromatized form: "+smiles);
                // leave mol as-is
            }
            else {
                if (DEBUG) {
                    logger.info("Final molecule clean-up\n"
                                +newmol.toFormat("mol"));
                }
                newmol.clonecopy(mol);
            }
        }
        catch (Exception ex) {
            logger.log(Level.SEVERE, 
                       "Can't cleanup molecule properly", ex);
        }
    }
}
 
開發者ID:ncats,項目名稱:lychi,代碼行數:44,代碼來源:LyChIStandardizer.java


注:本文中的chemaxon.struc.MolBond.getType方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。