當前位置: 首頁>>代碼示例>>Java>>正文


Java Index類代碼示例

本文整理匯總了Java中javolution.util.Index的典型用法代碼示例。如果您正苦於以下問題:Java Index類的具體用法?Java Index怎麽用?Java Index使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


Index類屬於javolution.util包,在下文中一共展示了Index類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: plus

import javolution.util.Index; //導入依賴的package包/類
private SparseVector<F> plus(SparseVector<F> that) {
    if (this._dimension != that._dimension) throw new DimensionException();
    SparseVector<F> V = SparseVector.newInstance(_dimension, _zero);
    V._elements.putAll(this._elements);
    for (FastMap.Entry<Index, F> e = that._elements.head(), n = that._elements.tail();
            (e = e.getNext()) != n;) {
        Index index = e.getKey();
        FastMap.Entry<Index, F> entry = V._elements.getEntry(index);
        if (entry == null) {
            V._elements.put(index, e.getValue());
        } else {
            entry.setValue(entry.getValue().plus(e.getValue()));
        }
    }
    return V;
}
 
開發者ID:jgaltidor,項目名稱:VarJ,代碼行數:17,代碼來源:SparseVector.java

示例2: getRow

import javolution.util.Index; //導入依賴的package包/類
@Override
public SparseVector<F> getRow(int i) {
    if (!_transposed)
        return _rows.get(i);
    // Else transposed.
    int n = _rows.size();
    int m = _n;
    if ((i < 0) || (i >= m))
        throw new DimensionException();
    SparseVector<F> V = SparseVector.newInstance(n, _zero);
    for (int j = 0; j < n; j++) {
        SparseVector<F> row = _rows.get(j);
        F e = row._elements.get(Index.valueOf(i));
        if (e != null) {
            V._elements.put(Index.valueOf(j), e);
        }
    }
    return V;
}
 
開發者ID:jgaltidor,項目名稱:VarJ,代碼行數:20,代碼來源:SparseMatrix.java

示例3: getColumn

import javolution.util.Index; //導入依賴的package包/類
@Override
public SparseVector<F> getColumn(int j) {
    if (_transposed)
        return _rows.get(j);
    int m = _rows.size();
    if ((j < 0) || (j >= _n))
        throw new DimensionException();
    SparseVector<F> V = SparseVector.newInstance(_n, _zero);
    for (int i = 0; i < m; i++) {
        SparseVector<F> row = _rows.get(i);
        F e = row._elements.get(Index.valueOf(j));
        if (e != null) {
            V._elements.put(Index.valueOf(i), e);
        }
    }
    return V;
}
 
開發者ID:jgaltidor,項目名稱:VarJ,代碼行數:18,代碼來源:SparseMatrix.java

示例4: times

import javolution.util.Index; //導入依賴的package包/類
@Override
public SparseMatrix<F> times(Matrix<F> that) {
    final int m = this.getNumberOfRows();
    final int n = this.getNumberOfColumns();
    final int p = that.getNumberOfColumns();
    if (that.getNumberOfRows() != n)
        throw new DimensionException();
    // Creates a mxp matrix in transposed form (p columns vectors of size m)
    FastTable<SparseVector<F>> rows = this.getRows();
    SparseMatrix<F> M = SparseMatrix.newInstance(m, _zero, true);   
    for (int j = 0; j < p; j++) { 
        Vector<F> thatColj = that.getColumn(j);
        SparseVector<F> column = SparseVector.newInstance(m, _zero);
        M._rows.add(column); // M is transposed.
        for (int i = 0; i < m; i++) {
            F e = rows.get(i).times(thatColj);
            if (!_zero.equals(e)) {
                column._elements.put(Index.valueOf(i), e);
            }
        }
    }
    return M;
}
 
開發者ID:jgaltidor,項目名稱:VarJ,代碼行數:24,代碼來源:SparseMatrix.java

示例5: inverse

import javolution.util.Index; //導入依賴的package包/類
@Override
public SparseMatrix<F> inverse() {
    if (!isSquare())
        throw new DimensionException("Matrix not square");
    F detInv = this.determinant().inverse();
    SparseMatrix<F> A = this.adjoint();
    // Multiply adjoint elements with 1 / determinant.
    for (int i = 0, m = A._rows.size(); i < m; i++) {
        SparseVector<F> row = A._rows.get(i);
        for (FastMap.Entry<Index, F> e = row._elements.head(), end = row._elements
                .tail(); (e = e.getNext()) != end;) {
            F element = e.getValue();
            e.setValue(detInv.times(element));
        }
    }
    return A;
}
 
開發者ID:jgaltidor,項目名稱:VarJ,代碼行數:18,代碼來源:SparseMatrix.java

示例6: determinant

import javolution.util.Index; //導入依賴的package包/類
@Override
public F determinant() {
    if (!isSquare())
        throw new DimensionException("Matrix not square");
    if (_n == 1)
        return this.get(0, 0);
    // Expansion by minors (also known as Laplacian)
    // This algorithm is division free but too slow for dense matrix.
    SparseVector<F> row0 = this.getRow(0);
    F det = null;
    for (FastMap.Entry<Index, F> e = row0._elements.head(), end = row0._elements
            .tail(); (e = e.getNext()) != end;) {
        int i = e.getKey().intValue();
        F d = e.getValue().times(cofactor(0, i));
        if (i % 2 != 0) {
            d = d.opposite();
        }
        det = (det == null) ? d : det.plus(d);
    }
    return det == null ? _zero : det;
}
 
開發者ID:jgaltidor,項目名稱:VarJ,代碼行數:22,代碼來源:SparseMatrix.java

示例7: adjoint

import javolution.util.Index; //導入依賴的package包/類
@Override
public SparseMatrix<F> adjoint() {
    SparseMatrix<F> M = SparseMatrix.newInstance(_n, _zero, _transposed);
    int m = _rows.size();
    for (int i = 0; i < m; i++) {
        SparseVector<F> row = SparseVector.newInstance(_n, _zero);
        M._rows.add(row);
        for (int j = 0; j < _n; j++) {
            F cofactor = _transposed ? cofactor(j, i) : cofactor(i, j);
            if (!_zero.equals(cofactor)) {
                row._elements
                        .put(Index.valueOf(j),
                                ((i + j) % 2 == 0) ? cofactor : cofactor
                                        .opposite());
            }
        }
    }
    return M.transpose();
}
 
開發者ID:jgaltidor,項目名稱:VarJ,代碼行數:20,代碼來源:SparseMatrix.java

示例8: vectorization

import javolution.util.Index; //導入依賴的package包/類
@Override
public SparseVector<F> vectorization() {
    SparseVector<F> V = SparseVector.newInstance(_n
            * this.getNumberOfRows(), _zero);
    int offset = 0;
    for (int j = 0, n = this.getNumberOfColumns(); j < n; j++) {
        SparseVector<F> column = this.getColumn(j);
        for (FastMap.Entry<Index, F> e = column._elements.head(), end = column._elements
                .tail(); (e = e.getNext()) != end;) {
            V._elements.put(Index.valueOf(e.getKey().intValue() + offset),
                    e.getValue());
        }
        offset += this.getNumberOfRows();
    }
    return V;
}
 
開發者ID:jgaltidor,項目名稱:VarJ,代碼行數:17,代碼來源:SparseMatrix.java

示例9: initializeRealtimeClasses

import javolution.util.Index; //導入依賴的package包/類
/** Initializes all real-time classes. */
public static synchronized boolean initializeRealtimeClasses() {
	Initializer initializer = new Initializer(OSGiServices.class.getClassLoader());
	initializer.loadClass(MathLib.class);
	initializer.loadClass(Text.class);
	initializer.loadClass(TypeFormat.class);
	initializer.loadClass(Struct.class);
	initializer.loadClass(FastBitSet.class);
	initializer.loadClass(FastSortedMap.class);
	initializer.loadClass(FastSortedSet.class);
	initializer.loadClass(FastSortedTable.class);
	initializer.loadClass(Index.class); // Preallocates.
	initializer.loadClass(Reducers.class);
	initializer.loadClass(Equalities.class);
	initializer.loadClass(XMLStreamReaderImpl.class);
	initializer.loadClass(XMLStreamWriterImpl.class);
	return initializer.initializeLoadedClasses();
}
 
開發者ID:OpenNTF,項目名稱:org.openntf.domino,代碼行數:19,代碼來源:OSGiServices.java

示例10: writeReference

import javolution.util.Index; //導入依賴的package包/類
/**
 * Writes a reference to the specified object into the specified XML
 * element. The default implementation writes the reference into the 
 * reference attribute and for the first occurences an identifier 
 * (counter starting at 1) is written into the identifier attribute. 
 * 
 * @param  obj the object for which the reference is written.
 * @param  xml the output XML element.
 * @return <code>true</code> if a reference is written;
 *         <code>false</code> if a new identifier is written.
 */
public boolean writeReference(Object obj, XMLFormat.OutputElement xml)
        throws XMLStreamException {
    Index id = (Index) _objectToId.get(obj);
    if (id == null) { // New identifier.
        id = Index.of(_counter++);
        _objectToId.put(obj, id);
        _tmp.clear().append(id.intValue());
        if (_idURI == null) {
            xml.getStreamWriter().writeAttribute(_idName, _tmp);
        } else {
            xml.getStreamWriter().writeAttribute(_idURI, _idName, _tmp);
        }
        return false;
    }
    _tmp.clear().append(id.intValue());
    if (_refURI == null) {
        xml._writer.writeAttribute(_refName, _tmp);
    } else {
        xml._writer.writeAttribute(_refURI, _refName, _tmp);
    }
    return true;
}
 
開發者ID:OpenNTF,項目名稱:org.openntf.domino,代碼行數:34,代碼來源:XMLReferenceResolver.java

示例11: valueOf

import javolution.util.Index; //導入依賴的package包/類
/**
 * Returns a sparse vector equivalent to the specified vector but with 
 * the zero elements removed using the specified object equality comparator.
 * This method can be used to clean up sparse vectors (to remove elements
 * close to zero).
 * 
 * @param that the vector to convert.
 * @param zero the zero element for the sparse vector to return.
 * @param comparator the comparator used to determinate zero equality. 
 * @return a sparse vector with zero elements removed.
 */
public static <F extends Field<F>> SparseVector<F> valueOf(
        Vector<F> that, F zero, FastComparator<? super F> comparator) {
    if (that instanceof SparseVector) 
        return SparseVector.valueOf((SparseVector<F>) that, zero, comparator);
    int n = that.getDimension();
    SparseVector<F> V = SparseVector.newInstance(n, zero);
    for (int i=0; i < n; i++) {
        F element = that.get(i);
        if (!comparator.areEqual(zero, element)) {
            V._elements.put(Index.valueOf(i), element);
        }
    }
    return V;
}
 
開發者ID:jgaltidor,項目名稱:VarJ,代碼行數:26,代碼來源:SparseVector.java

示例12: get

import javolution.util.Index; //導入依賴的package包/類
@Override
public F get(int i) {
    if ((i < 0) || (i >= _dimension))
        throw new IndexOutOfBoundsException();
    F element = _elements.get(Index.valueOf(i));
    return (element == null) ? _zero : element;
}
 
開發者ID:jgaltidor,項目名稱:VarJ,代碼行數:8,代碼來源:SparseVector.java

示例13: opposite

import javolution.util.Index; //導入依賴的package包/類
@Override
public SparseVector<F> opposite() {
    SparseVector<F> V = SparseVector.newInstance(_dimension, _zero);
    for (FastMap.Entry<Index, F> e = _elements.head(), n = _elements.tail(); (e = e
            .getNext()) != n;) {
        V._elements.put(e.getKey(), e.getValue().opposite());
    }
    return V;
}
 
開發者ID:jgaltidor,項目名稱:VarJ,代碼行數:10,代碼來源:SparseVector.java

示例14: times

import javolution.util.Index; //導入依賴的package包/類
@Override
public SparseVector<F> times(F k) {
    SparseVector<F> V = SparseVector.newInstance(_dimension, _zero);
    for (FastMap.Entry<Index, F> e = _elements.head(), n = _elements.tail(); (e = e
            .getNext()) != n;) {
        V._elements.put(e.getKey(), e.getValue().times(k));
    }
    return V;
}
 
開發者ID:jgaltidor,項目名稱:VarJ,代碼行數:10,代碼來源:SparseVector.java

示例15: copy

import javolution.util.Index; //導入依賴的package包/類
@SuppressWarnings("unchecked")
@Override
public SparseVector<F> copy() {
    SparseVector<F> V = SparseVector.newInstance(_dimension, (F)_zero.copy());
    for (Map.Entry<Index, F> e : _elements.entrySet()) {
        V._elements.put(e.getKey(), (F) e.getValue().copy());            
    }
    return V;
}
 
開發者ID:jgaltidor,項目名稱:VarJ,代碼行數:10,代碼來源:SparseVector.java


注:本文中的javolution.util.Index類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。