/*
* Copyright 2011-2014, by Vladimir Kostyukov and Contributors.
*
* This file is part of la4j project (http://la4j.org)
*
* 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.
*
* Contributor(s): -
*
*/
package org.la4j.matrix;
import org.la4j.Matrices;
import org.la4j.iterator.MatrixIterator;
import org.la4j.iterator.VectorIterator;
import org.la4j.Matrix;
import org.la4j.matrix.sparse.CRSMatrix;
import org.la4j.operation.MatrixMatrixOperation;
import org.la4j.operation.MatrixOperation;
import org.la4j.operation.MatrixVectorOperation;
import org.la4j.Vector;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;
import java.util.Random;
public abstract class RowMajorSparseMatrix extends SparseMatrix {
public RowMajorSparseMatrix(int rows, int columns) {
super(rows, columns);
}
public RowMajorSparseMatrix(int rows, int columns, int cardinality) {
super(rows, columns, cardinality);
}
/**
* Creates a zero {@link RowMajorSparseMatrix} of the given shape:
* {@code rows} x {@code columns}.
*/
public static RowMajorSparseMatrix zero(int rows, int columns) {
return CRSMatrix.zero(rows, columns);
}
/**
* Creates a zero {@link RowMajorSparseMatrix} of the given shape:
* {@code rows} x {@code columns} with the given {@code capacity}.
*/
public static RowMajorSparseMatrix zero(int rows, int columns, int capacity) {
return CRSMatrix.zero(rows, columns, capacity);
}
/**
* Creates a diagonal {@link RowMajorSparseMatrix} of the given {@code size} whose
* diagonal elements are equal to {@code diagonal}.
*/
public static RowMajorSparseMatrix diagonal(int size, double diagonal) {
return CRSMatrix.diagonal(size, diagonal);
}
/**
* Creates an identity {@link RowMajorSparseMatrix} of the given {@code size}.
*/
public static RowMajorSparseMatrix identity(int size) {
return CRSMatrix.identity(size);
}
/**
* Creates a random {@link RowMajorSparseMatrix} of the given shape:
* {@code rows} x {@code columns}.
*/
public static RowMajorSparseMatrix random(int rows, int columns, double density, Random random) {
return CRSMatrix.random(rows, columns, density, random);
}
/**
* Creates a random symmetric {@link RowMajorSparseMatrix} of the given {@code size}.
*/
public static RowMajorSparseMatrix randomSymmetric(int size, double density, Random random) {
return CRSMatrix.randomSymmetric(size, density, random);
}
/**
* Creates a new {@link RowMajorSparseMatrix} from the given 1D {@code array} with
* compressing (copying) the underlying array.
*/
public static RowMajorSparseMatrix from1DArray(int rows, int columns, double[] array) {
return CRSMatrix.from1DArray(rows, columns, array);
}
/**
* Creates a new {@link RowMajorSparseMatrix} from the given 2D {@code array} with
* compressing (copying) the underlying array.
*/
public static RowMajorSparseMatrix from2DArray(double[][] array) {
return CRSMatrix.from2DArray(array);
}
/**
* Creates a block {@link RowMajorSparseMatrix} of the given blocks {@code a},
* {@code b}, {@code c} and {@code d}.
*/
public static RowMajorSparseMatrix block(Matrix a, Matrix b, Matrix c, Matrix d) {
return CRSMatrix.block(a, b, c, d);
}
/**
* Parses {@link RowMajorSparseMatrix} from the given CSV string.
*
* @param csv the CSV string representing a matrix
*
* @return a parsed matrix
*/
public static RowMajorSparseMatrix fromCSV(String csv) {
return Matrix.fromCSV(csv).to(Matrices.SPARSE_ROW_MAJOR);
}
/**
* Parses {@link RowMajorSparseMatrix} from the given Matrix Market string.
*
* @param mm the string in Matrix Market format
*
* @return a parsed matrix
*/
public static RowMajorSparseMatrix fromMatrixMarket(String mm) {
return Matrix.fromMatrixMarket(mm).to(Matrices.SPARSE_ROW_MAJOR);
}
@Override
public boolean isRowMajor() {
return true;
}
@Override
public Matrix transpose() {
Matrix result = ColumnMajorSparseMatrix.zero(columns, rows);
MatrixIterator it = nonZeroRowMajorIterator();
while (it.hasNext()) {
double x = it.next();
int i = it.rowIndex();
int j = it.columnIndex();
result.set(j, i, x);
}
return result;
}
@Override
public Matrix rotate() {
Matrix result = ColumnMajorSparseMatrix.zero(columns, rows);
Iterator<Integer> nzRows = iteratorOfNonZeroRows();
List<Integer> reversedNzRows = new LinkedList<Integer>();
while (nzRows.hasNext()) {
reversedNzRows.add(0, nzRows.next());
}
for (int i: reversedNzRows) {
VectorIterator it = nonZeroIteratorOfRow(i);
while (it.hasNext()) {
double x = it.next();
int j = it.index();
result.set(j, rows - 1 - i, x);
}
}
return result;
}
public abstract Iterator<Integer> iteratorOfNonZeroRows();
@Override
public <T> T apply(MatrixOperation<T> operation) {
operation.ensureApplicableTo(this);
return operation.apply(this);
}
@Override
public <T> T apply(MatrixMatrixOperation<T> operation, Matrix that) {
return that.apply(operation.partiallyApply(this));
}
@Override
public <T> T apply(MatrixVectorOperation<T> operation, Vector that) {
return that.apply(operation.partiallyApply(this));
}
}