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