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

smile.math.SparseArray Maven / Gradle / Ivy

The newest version!
/*******************************************************************************
 * Copyright (c) 2010 Haifeng Li
 *   
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *  
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *******************************************************************************/

package smile.math;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

/**
 * Sparse array of double values.
 * @author Haifeng Li
 *
 */
public class SparseArray implements Iterable {
    /**
     * The entry in a sparse array of double values.
     */
    public class Entry {

        /**
         * The index of entry.
         */
        public int i;
        /**
         * The value of entry.
         */
        public double x;

        /**
         * Constructor.
         * @param i the index of entry.
         * @param x the value of entry.
         */
        public Entry(int i, double x) {
            this.i = i;
            this.x = x;
        }
    }
    
    private List array;
    
    /**
     * Constructor.
     */
    public SparseArray() {
        this(10);
    }
    
    /**
     * Constructor.
     * @param initialCapacity the number of rows in the matrix.
     * @param ncols the number of columns in the matrix.
     * @param size the number of nonzero entries in the matrix.
     */
    private SparseArray(int initialCapacity) {
        array = new ArrayList(initialCapacity);
    }

    /**
     * Returns the number of nonzero entries.
     * @return the number of nonzero entries
     */
    public int size() {
        return array.size();
    }

    /**
     * Returns true if the array is empty.
     * @return true if the array is empty.
     */
    public boolean isEmpty() {
        return array.isEmpty();
    }
    
    /**
     * Returns an iterator of nonzero entries.
     * @return an iterator of nonzero entries
     */
    public Iterator iterator() {
        return array.iterator();
    }
    
    /**
     * Returns the value of i-th entry.
     * @param i the index of entry.
     * @return the value of entry, 0.0 if the index doesn't exist in the array.
     */
    public double get(int i) {
        for (Entry e : array) {
            if (e.i == i) {
                return e.x;
            }
        }

        return 0.0;
    }

    /**
     * Sets or add an entry.
     * @param i the index of entry.
     * @param x the value of entry.
     * @return true if a new entry added, false if an existing entry updated.
     */
    public boolean set(int i, double x) {
        if (x == 0.0) {
            remove(i);
            return false;
        }
        
        Iterator it = array.iterator();
        for (int k = 0; it.hasNext(); k++) {
            Entry e = it.next();
            if (e.i == i) {
                e.x = x;
                return false;
            } else if (e.i > i) {
                array.add(k, new Entry(i, x));
                return true;
            }
        }
        
        array.add(new Entry(i, x));
        return true;
    }

    /**
     * Append an entry to the array, optimizing for the case where the index is greater than all existing indices in the array.
     * @param i the index of entry.
     * @param x the value of entry.
     */
    public void append(int i, double x) {
        if (x != 0.0) {
            array.add(new Entry(i, x));
        }
    }
    
    /**
     * Removes an entry.
     * @param i the index of entry.
     */
    public void remove(int i) {
        Iterator it = array.iterator();
        while (it.hasNext()) {
            Entry e = it.next();
            if (e.i == i) {
                it.remove();
                break;
            }
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy