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

com.actelion.research.chem.mcs.ListWithIntVec Maven / Gradle / Ivy

There is a newer version: 2024.11.2
Show newest version
package com.actelion.research.chem.mcs;

import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;

import com.actelion.research.util.datamodel.IntArray;
import com.actelion.research.util.datamodel.IntVec;

/*
* Copyright (c) 1997 - 2016
* Actelion Pharmaceuticals Ltd.
* Gewerbestrasse 16
* CH-4123 Allschwil, Switzerland
*
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this
*    list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
*    this list of conditions and the following disclaimer in the documentation
*    and/or other materials provided with the distribution.
* 3. Neither the name of the the copyright holder nor the
*    names of its contributors may be used to endorse or promote products
*    derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
*/
public class ListWithIntVec {
	
	private IntVec iv;
	
	private IntArray arr;
	
	private int positionInContainer;
	
	
	public ListWithIntVec() {
	}
	
	public ListWithIntVec(int size) {
		this(size, -1);
	}
	
	/**
	 * 
	 * @param size of the integer array
	 * @param positionInContainer
	 */
	public ListWithIntVec(int size, int positionInContainer) {
		iv = new IntVec(size);
		arr = new IntArray();
		
		this.positionInContainer=positionInContainer;
	}
	
	public ListWithIntVec(ListWithIntVec liv) {
		
		iv = new IntVec(liv.iv);
		
		arr = new IntArray(liv.arr);
	}
	
	public void copyIntoThis(ListWithIntVec liv){
		
		iv.set(0);
		
		System.arraycopy(liv.iv.get(), 0, iv.get(), 0, iv.get().length);
		
		arr.reset();
		
		for (int i = 0; i < liv.arr.length(); i++) {
			arr.add(liv.arr.get(i));
		}
		
	}
	
	/**
	 * Dont't forget to calculate the hash!
	 * @param index
	 * @return false if the bit is already set, true otherwise. 
	 */
	public boolean addBit(int index){
		
		if(iv.isBitSet(index)){
			return false;
		}
		
		iv.setBit(index);
		
		arr.add(index);
		
		return true;
	}
	
	public void addAllBits(ListWithIntVec liv) {
		final int size = liv.size();
		
		for (int i = 0; i < size; i++) {
			addBit(liv.get(i));
		}
		
		calculateHash();
	}
	
	public boolean isOverlap(ListWithIntVec liv) {
		boolean overlap=false;
		
		final int size = liv.size();
		
		for (int i = 0; i < size; i++) {
			if(isBitSet(liv.get(i))){
				overlap=true;
				break;
			}
		}
		
		return overlap;
	}

	
	public boolean equals(Object o) {
		
		IntVec iv2 = ((ListWithIntVec)o).iv;
		
		return iv.equals(iv2);
	}
	
	public boolean isBitSet(int index){
		return iv.isBitSet(index);
	}
	
	public int getBitsSet(){
		
		return iv.getBitsSet();
	}
	
	public int sizeBits(){
		
		return iv.sizeBits();
	}
	
	
	public void calculateHash(){
		iv.calculateHashCode();
	}
	
	public int hashCode(){
		return iv.hashCode();
	}
	
	public int get(int index){
		return arr.get(index);
	}
	
	/**
	 * 
	 * @return number of bits set
	 */
	public int size(){
		return arr.length();
	}
	
	public int getLengthIntVec(){
		return iv.size();
	}
	
	
	public void reset(){
		iv.set(0);
		arr.reset();
	}
	
	/**
	 * The array part of the object.
	 * @return
	 */
    public String toStringArray() {
    	
        StringBuilder sb = new StringBuilder();
        
        for (int i = 0; i < arr.length(); i++) {
        	sb.append(arr.get(i));
            if(i < arr.length()-1){
            	sb.append(" ");
            }
        }
        
        return sb.toString();
    }
	
    public String toString() {
    	
        StringBuilder sb = new StringBuilder();
        
        int si = iv.sizeBits();
        List li = new ArrayList();
        for (int i = 0; i < si; i++) {
        	if(iv.isBitSet(i))
        		li.add(i);
        }
        
        for (int i = 0; i < li.size(); i++) {
        	sb.append(li.get(i));
            if(i




© 2015 - 2024 Weber Informatics LLC | Privacy Policy