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

org.biojava.nbio.structure.io.cif.MetalBondConsumerImpl Maven / Gradle / Ivy

The newest version!
package org.biojava.nbio.structure.io.cif;

import org.biojava.nbio.structure.chem.MetalBondDistance;
import org.rcsb.cif.model.Category;
import org.rcsb.cif.model.StrColumn;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * Created by andreas on 6/9/16.
 */
public class MetalBondConsumerImpl implements MetalBondConsumer {
    private final Map> definitions = new HashMap<>();

    @Override
    public void prepare() {
        definitions.clear();
    }

    @Override
    public void finish() {
        // minimize memory consumption
        for (List d : definitions.values()){
            ((ArrayList) d).trimToSize();
        }
    }

    @Override
    public void consume(Category category) {
        StrColumn atomType1 = (StrColumn) category.getColumn("atom_type_1");
        StrColumn atomType2 = (StrColumn) category.getColumn("atom_type_2");
        StrColumn lowerLimit = (StrColumn) category.getColumn("lower_limit");
        StrColumn upperLimit = (StrColumn) category.getColumn("upper_limit");
        for (int i = 0; i < category.getRowCount(); i++) {
            MetalBondDistance d = new MetalBondDistance();

            d.setAtomType1(atomType1.get(i));
            d.setAtomType2(atomType2.get(i));
            d.setLowerLimit(Float.parseFloat(lowerLimit.get(i)));
            d.setUpperLimit(Float.parseFloat(upperLimit.get(i)));

            List defs = definitions.computeIfAbsent(d.getAtomType1(), k -> new ArrayList<>());
            defs.add(d);
        }
    }

    @Override
    public Map> getContainer(){
        return definitions;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy