Package org.nuiton.math.matrix
Class DoubleSparseArrayVector
java.lang.Object
org.nuiton.math.matrix.DoubleSparseArrayVector
- All Implemented Interfaces:
SparseVector,Vector
Permet de stocker des données à une position lineaire et de la redemander.
Cette classe ne gére que les données lineaire. L'avantage de cette classe est
de ne conserver que les elements differents de la valeur par defaut, ce qui
minimize la taille du tableau necessaire a conserver les données.
On permet que la matrice est plus de
Integer.MAX_VALUE cellules mais
on ne permet pas que la matrice est plus que Integer.MAX_VALUE valeur
différente que le default value.
Created: 6 octobre 2005 01:29:23 CEST- Version:
- $Revision$ Last update: $Date$ by : $Author$
- Author:
- Benjamin POUSSIN <poussin@codelutin.com>
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected intcurrent number of assigned valueprotected longmaximum number of element, maximum pos valueprotected doublela valeur par defautprotected long[]contient la position de l'element, le tableau est triéprotected double[] -
Constructor Summary
ConstructorsConstructorDescriptionDoubleSparseArrayVector(long capacity) DoubleSparseArrayVector(long capacity, double defaultValue) -
Method Summary
Modifier and TypeMethodDescriptionprotected voidaddElementAt(int index, long element, double value) protected voidcheckPos(long pos) protected voidensureCapacity(int mincap) booleanprotected intfindIndex(long pos) retourne la position dans le tableau position de la position lineairevoidlong[]Return an orderer array of position assigned, this array can be longer than realy assigned value, you must used getNumberOfAssignedValue to know number of significant position in arraydouble[]Return an array in same order that getAssignedPosition.doubleValue to used if not un assigned valuegetInfo()return information on this vector.doubleDeprecated.doubleRetourne la valeur la plus utilise dans le vectorlongReturne number of assigned value, assigned value is value stored in memorydoublegetValue(long pos) inthashCode()voidinit(long capacity) Init vector, before this method call, vector is in indetermined state.booleanPermet de savoir si map est implanté par ce vector.booleanPermet de savoir si paste est implanté par ce vector.iterator()Retourne un objet Inc pret a etre utilisé pour boucler sur tous les element de la matrice.Retourne un objet Inc pret a etre utilisé pour boucler sur tous les element different de 0 de la matrice.voidmap(MapFunction f) on applique sur chaque donnée existante et sur defaultvoidOn recopie tous les attributs pour que le vector ressemble exactement a celui passé en argumentprotected voidremoveElementAt(int index) voidsetValue(long pos, double value) longsize()Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.nuiton.math.matrix.Vector
add, forEach, isImplementedAdd, isImplementedMinus, minus
-
Field Details
-
defaultValue
protected double defaultValuela valeur par defaut -
capacity
protected long capacitymaximum number of element, maximum pos value -
assignedSize
protected int assignedSizecurrent number of assigned value -
position
protected long[] positioncontient la position de l'element, le tableau est trié -
values
protected double[] values
-
-
Constructor Details
-
DoubleSparseArrayVector
public DoubleSparseArrayVector() -
DoubleSparseArrayVector
public DoubleSparseArrayVector(long capacity) -
DoubleSparseArrayVector
public DoubleSparseArrayVector(long capacity, double defaultValue)
-
-
Method Details
-
init
public void init(long capacity) Description copied from interface:VectorInit vector, before this method call, vector is in indetermined state. multiple call to init method must be permit. Only first call must do some work, extra call must do nothing -
getInfo
Description copied from interface:Vectorreturn information on this vector. This information depends on implementation example: - size - max occurence number - ... -
getDefaultValue
public double getDefaultValue()Description copied from interface:SparseVectorValue to used if not un assigned value- Specified by:
getDefaultValuein interfaceSparseVector- Returns:
-
getAssignedPosition
public long[] getAssignedPosition()Description copied from interface:SparseVectorReturn an orderer array of position assigned, this array can be longer than realy assigned value, you must used getNumberOfAssignedValue to know number of significant position in array- Specified by:
getAssignedPositionin interfaceSparseVector- Returns:
-
getAssignedValue
public double[] getAssignedValue()Description copied from interface:SparseVectorReturn an array in same order that getAssignedPosition. This array contains values. This array can be longer than realy assigned value, you must used getNumberOfAssignedValue to know number of significant position in array- Specified by:
getAssignedValuein interfaceSparseVector- Returns:
-
getNumberOfAssignedValue
public long getNumberOfAssignedValue()Description copied from interface:VectorReturne number of assigned value, assigned value is value stored in memory- Specified by:
getNumberOfAssignedValuein interfaceVector
-
size
public long size() -
getMaxOccurence
Deprecated.- Specified by:
getMaxOccurencein interfaceVector
-
getMaxOccurrence
public double getMaxOccurrence()Description copied from interface:VectorRetourne la valeur la plus utilise dans le vector- Specified by:
getMaxOccurrencein interfaceVector- Returns:
-
checkPos
protected void checkPos(long pos) -
getValue
public double getValue(long pos) -
setValue
public void setValue(long pos, double value) -
equals
-
hashCode
public int hashCode() -
findIndex
protected int findIndex(long pos) retourne la position dans le tableau position de la position lineaire- Parameters:
pos-- Returns:
- la position ou < 0 donnant la position de l'element s'il etait present
-
ensureCapacity
protected void ensureCapacity(int mincap) -
addElementAt
protected void addElementAt(int index, long element, double value) -
removeElementAt
protected void removeElementAt(int index) -
isImplementedPaste
Description copied from interface:VectorPermet de savoir si paste est implanté par ce vector.- Specified by:
isImplementedPastein interfaceVector- Parameters:
v- vector to test- Returns:
trueif operation is supported
-
isImplementedMap
public boolean isImplementedMap()Description copied from interface:VectorPermet de savoir si map est implanté par ce vector.- Specified by:
isImplementedMapin interfaceVector- Returns:
trueif operation is supported
-
paste
On recopie tous les attributs pour que le vector ressemble exactement a celui passé en argument -
map
on applique sur chaque donnée existante et sur default -
iterator
Description copied from interface:VectorRetourne un objet Inc pret a etre utilisé pour boucler sur tous les element de la matrice. -
iteratorNotZero
Description copied from interface:VectorRetourne un objet Inc pret a etre utilisé pour boucler sur tous les element different de 0 de la matrice.- Specified by:
iteratorNotZeroin interfaceVector- Returns:
- un objet Inc pret à être utilisé
-
forEachNotZero
- Specified by:
forEachNotZeroin interfaceVector
-