All Downloads are FREE. Search and download functionalities are using the official Maven repository.

signature.chemistry.AtomSignature Maven / Gradle / Ivy

The newest version!
package signature.chemistry;

import signature.AbstractVertexSignature;
import signature.chemistry.Molecule.BondOrder;

public class AtomSignature extends AbstractVertexSignature {
    
    private Molecule molecule;
    
    public AtomSignature(Molecule molecule, int atomNumber) {
        super();
        this.molecule = molecule;
        this.createMaximumHeight(atomNumber, molecule.getAtomCount());
    }
    
    public AtomSignature(Molecule molecule, int atomNumber, int height) {
        super();
        this.molecule = molecule;
        this.create(atomNumber, molecule.getAtomCount(), height);
    }
    
    public AtomSignature(Molecule molecule, int atomNumber, 
            int height, AbstractVertexSignature.InvariantType invariantType) {
        super(invariantType);
        this.molecule = molecule;
        this.create(atomNumber, molecule.getAtomCount(), height);
    }
    
    public int getIntLabel(int vertexIndex) {
        String symbol = getVertexSymbol(vertexIndex);
        
        // not exactly comprehensive...
        if (symbol.equals("H")) {
            return 1;
        } else if (symbol.equals("C")) {
            return 12;
        } else if (symbol.equals("O")) {
            return 16;
        } else {
            return -1;
        }
    }

    @Override
    public int[] getConnected(int vertexIndex) {
        return this.molecule.getConnected(vertexIndex);
    }

    @Override
    public String getEdgeLabel(int vertexIndex, int otherVertexIndex) {
        BondOrder bondOrder = 
            molecule.getBondOrder(vertexIndex, otherVertexIndex);
        switch (bondOrder) {
            case SINGLE: return "";
            case DOUBLE: return "=";
            case TRIPLE: return "#";
            case AROMATIC: return "p";
            default: return "";
        }
    }

    @Override
    public String getVertexSymbol(int vertexIndex) {
        return this.molecule.getSymbolFor(vertexIndex);
    }

    @Override
    protected int convertEdgeLabelToColor(String label) {
        if (label.equals("-")) {
            return 1;
        } else if (label.equals("=")) {
            return 2;
        } else if (label.equals("#")) {
            return 3;
        }
        return 1;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy