当前位置: 首页>>代码示例>>Java>>正文


Java IAtomContainer.addAtom方法代码示例

本文整理汇总了Java中org.openscience.cdk.interfaces.IAtomContainer.addAtom方法的典型用法代码示例。如果您正苦于以下问题:Java IAtomContainer.addAtom方法的具体用法?Java IAtomContainer.addAtom怎么用?Java IAtomContainer.addAtom使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在org.openscience.cdk.interfaces.IAtomContainer的用法示例。


在下文中一共展示了IAtomContainer.addAtom方法的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: getStructureAsAromaticIAtomContainer

import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
public IAtomContainer getStructureAsAromaticIAtomContainer() {
	IChemObjectBuilder builder = DefaultChemObjectBuilder.getInstance();
	IAtomContainer fragmentStructure = builder.newInstance(IAtomContainer.class);
	
	for(int i = 0; i < this.bondsBitArray.getSize(); i++) {
		if(this.bondsBitArray.get(i)) {
			IBond curBond = this.precursorMolecule.getStructureAsIAtomContainer().getBond(i);
			if(this.precursorMolecule.isAromaticBond(i)) curBond.setIsAromatic(true);
			for(IAtom atom : curBond.atoms()) {
				atom.setImplicitHydrogenCount(0);
				if(this.precursorMolecule.isAromaticBond(i)) atom.setIsAromatic(true);
				fragmentStructure.addAtom(atom);
			}
			fragmentStructure.addBond(curBond);
		}
	}
//	loss of hydrogens
//	MoleculeFunctions.prepareAtomContainer(fragmentStructure);
	
	return fragmentStructure;
}
 
开发者ID:c-ruttkies,项目名称:MetFragRelaunched,代码行数:22,代码来源:DefaultBitArrayFragment.java

示例2: getStructureAsIAtomContainer

import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
public IAtomContainer getStructureAsIAtomContainer() {
	IChemObjectBuilder builder = DefaultChemObjectBuilder.getInstance();
	IAtomContainer fragmentStructure = builder.newInstance(IAtomContainer.class);
	
	for(int i = 0; i < this.bondsBitArray.getSize(); i++) {
		if(this.bondsBitArray.get(i)) {
			IBond curBond = this.precursorMolecule.getStructureAsIAtomContainer().getBond(i);
			for(IAtom atom : curBond.atoms()) {
				fragmentStructure.addAtom(atom);
			}
			fragmentStructure.addBond(curBond);
		}
	}
//	loss of hydrogens
//	MoleculeFunctions.prepareAtomContainer(fragmentStructure);
	
	return fragmentStructure;
}
 
开发者ID:c-ruttkies,项目名称:MetFragRelaunched,代码行数:19,代码来源:DefaultBitArrayFragment.java

示例3: computeIterationForAtom

import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
private ECFPFeature computeIterationForAtom(IAtom atom) throws FingerPrinterException, MoltyperException{
	ECFPFeature oldFeature = featuresOfLastIteration.get(atom);
       IAtomContainer newSubstructure = oldFeature.getNonDeepCloneOfSubstructure();
	List<BondOrderIdentifierTupel> connectivity = new ArrayList<BondOrderIdentifierTupel>();

	for(IAtom connectedAtom: molecule.getConnectedAtomsList(atom)){
		int identifierOfConnectedAtom = featuresOfLastIteration.get(connectedAtom).hashCode();
		//System.out.println("iterate "+connectedAtom.getAtomTypeName()+",id="+identifierOfConnectedAtom+",id="+featuresOfLastIteration.get(connectedAtom).featureToString(true));
		connectivity.add(new BondOrderIdentifierTupel(this.getBondOrder(molecule.getBond(atom,connectedAtom)),identifierOfConnectedAtom));
           IAtomContainer structure = this.featuresOfLastIteration.get(connectedAtom).representedSubstructure();
		for(IAtom a: structure.atoms()){
			if(!newSubstructure.contains(a))
				newSubstructure.addAtom(a);
		}
		for(IBond b: structure.bonds()){
			if(!newSubstructure.contains(b))
				newSubstructure.addBond(b);
		}
	}
	
	ECFPFeature newFeature = new ECFPFeature(this, molecule, atom, newSubstructure, this.iteration,oldFeature.hashCode(), connectivity);
	return newFeature;
}
 
开发者ID:fortiema,项目名称:jCompoundMapper,代码行数:24,代码来源:Encoding2DECFP.java

示例4: computeInitialIteration

import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
private void computeInitialIteration() throws MoltyperException, FingerPrinterException{
	for (IAtom atom : this.molecule.atoms()) {
           IAtomContainer substructure = new AtomContainer();
		substructure.addAtom(atom);
		ECFPVariantFeature ecfpFeature = new ECFPVariantFeature(this, molecule, atom, substructure,
												this.generateExtensionBondList(atom), this.currentIteration,this.getAtomLabel(atom).hashCode(),null);
		this.hashedAtomLabels.put(atom, ecfpFeature.hashCode());
		this.featuresOfLastIteration.put(atom, ecfpFeature);
		this.completeFeatures.add(ecfpFeature);
	}
}
 
开发者ID:fortiema,项目名称:jCompoundMapper,代码行数:12,代码来源:Encoding2DECFPVariant.java

示例5: computeInitialIdentifiers

import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
private void computeInitialIdentifiers() throws FingerPrinterException, MoltyperException{
	for(IAtom atom: molecule.atoms()){
           IAtomContainer substructure = new AtomContainer();
		substructure.addAtom(atom);
		for(IBond bond: molecule.getConnectedBondsList(atom)){
			substructure.addBond(bond);
		}
		//System.out.println("initial "+this.getAtomLabel(atom)+",id="+this.getAtomLabel(atom).hashCode());
		ECFPFeature ecfpFeature = new ECFPFeature(this, molecule, atom, substructure,this.iteration,this.getAtomLabel(atom).hashCode(), null);
		this.featuresOfLastIteration.put(atom, ecfpFeature);
		completeFeatures.add(ecfpFeature);
	}
}
 
开发者ID:fortiema,项目名称:jCompoundMapper,代码行数:14,代码来源:Encoding2DECFP.java

示例6: getNonDeepCloneOfSubstructure

import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
public IAtomContainer getNonDeepCloneOfSubstructure(){
       IAtomContainer clone = new AtomContainer();
	for(IBond bond: this.substructure.bonds())
		clone.addBond(bond);
	
	for(IAtom atom: this.substructure.atoms())
		clone.addAtom(atom);
	
	return clone;
}
 
开发者ID:fortiema,项目名称:jCompoundMapper,代码行数:11,代码来源:ECFPFeature.java

示例7: sproutHydrogen

import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
private IAtom sproutHydrogen(IAtomContainer mol, IAtom focus)
{
  IAtom hydrogen = mol.getBuilder().newAtom();
  hydrogen.setAtomicNumber(1);
  hydrogen.setSymbol("H");
  hydrogen.setImplicitHydrogenCount(0);
  mol.addAtom(hydrogen);
  mol.addBond(mol.indexOf(focus), mol.getAtomCount() - 1, IBond.Order.SINGLE);
  return hydrogen;
}
 
开发者ID:cdk,项目名称:depict,代码行数:11,代码来源:DepictController.java

示例8: computeIterationForAtom

import org.openscience.cdk.interfaces.IAtomContainer; //导入方法依赖的package包/类
private ECFPVariantFeature computeIterationForAtom(IAtom atom) throws FingerPrinterException, MoltyperException {
	final ECFPVariantFeature oldFeature = this.featuresOfLastIteration.get(atom);
	final IAtomContainer newSubstructure = oldFeature.getNonDeepCloneOfSubstructure();
	final int numDanglingBonds = oldFeature.numberOfDanglingBonds();

	final List<BondOrderIdentifierTupel> connections = new ArrayList<BondOrderIdentifierTupel>(numDanglingBonds);
	final Map<IBond, DanglingBond> newConnectionCandidates = new HashMap<IBond, DanglingBond>();

	for (int i = 0; i < numDanglingBonds; i++) {
		final DanglingBond connection = oldFeature.getDanglingBond(i);
		final IAtom connectedAtom = connection.getBond().getAtom(connection.getConnectedAtomPosition());
		final int identifierOfConnectedAtom = this.hashedAtomLabels.get(connectedAtom);
		newSubstructure.addAtom(connectedAtom);
		newSubstructure.addBond(connection.getBond());
		final BondOrderIdentifierTupel boIDtupel=Encoding2DECFP.getNewBondOrderIdentifierTupel(this.getBondOrder(connection.getBond()), identifierOfConnectedAtom);
		connections.add(boIDtupel);

		final ArrayList<DanglingBond> newConnections = this.getConnectionsOfAtom(connection.getBond(), connectedAtom);
		for (final DanglingBond dbond : newConnections) {
			if (!newConnectionCandidates.containsKey(dbond.getBond())) {
				newConnectionCandidates.put(dbond.getBond(), dbond);
			}
		}
	}

	final Iterator<DanglingBond> iter = newConnectionCandidates.values().iterator();
	
	while (iter.hasNext()) {
		final DanglingBond bondToCheck = iter.next();
		if (newSubstructure.contains(bondToCheck.getConnectedAtom())) {
			if (!newSubstructure.contains(bondToCheck.getBond())) {
				newSubstructure.addBond(bondToCheck.getBond());
			}
			iter.remove();
		}
	}
	
	final DanglingBond[] newDanglingBonds = newConnectionCandidates.values().toArray(
			new DanglingBond[newConnectionCandidates.size()]);
	
	final ECFPVariantFeature newFeature = new ECFPVariantFeature(this, molecule, atom, newSubstructure, newDanglingBonds,
			this.currentIteration,oldFeature.hashCode(), connections);
	
	this.featuresOfLastIteration.put(atom, newFeature);
	return newFeature;
}
 
开发者ID:fortiema,项目名称:jCompoundMapper,代码行数:47,代码来源:Encoding2DECFPVariant.java


注:本文中的org.openscience.cdk.interfaces.IAtomContainer.addAtom方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。