![JAR search and dependency download from the Maven repository](/logo.png)
org.ejml.dense.row.RandomMatrices_ZDRM Maven / Gradle / Ivy
/*
* Copyright (c) 2020, Peter Abeles. All Rights Reserved.
*
* This file is part of Efficient Java Matrix Library (EJML).
*
* 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 org.ejml.dense.row;
import org.ejml.data.ZMatrixD1;
import org.ejml.data.ZMatrixRMaj;
import java.util.Random;
/**
* Contains a list of functions for creating random row complex matrices and vectors with different structures.
*
* @author Peter Abeles
*/
public class RandomMatrices_ZDRM {
/**
*
* Returns a matrix where all the elements are selected independently from
* a uniform distribution between -1 and 1 inclusive.
*
*
* @param numRow Number of rows in the new matrix.
* @param numCol Number of columns in the new matrix.
* @param rand Random number generator used to fill the matrix.
* @return The randomly generated matrix.
*/
public static ZMatrixRMaj rectangle( int numRow, int numCol, Random rand ) {
return rectangle(numRow, numCol, -1, 1, rand);
}
/**
*
* Returns a matrix where all the elements are selected independently from
* a uniform distribution between 'min' and 'max' inclusive.
*
*
* @param numRow Number of rows in the new matrix.
* @param numCol Number of columns in the new matrix.
* @param min The minimum value each element can be.
* @param max The maximum value each element can be.
* @param rand Random number generator used to fill the matrix.
* @return The randomly generated matrix.
*/
public static ZMatrixRMaj rectangle( int numRow, int numCol, double min, double max, Random rand ) {
ZMatrixRMaj mat = new ZMatrixRMaj(numRow, numCol);
fillUniform(mat, min, max, rand);
return mat;
}
/**
*
* Sets each element in the matrix to a value drawn from an uniform distribution from 0 to 1 inclusive.
*
*
* @param mat The matrix who is to be randomized. Modified.
* @param rand Random number generator used to fill the matrix.
*/
public static void fillUniform( ZMatrixRMaj mat, Random rand ) {
fillUniform(mat, 0, 1, rand);
}
/**
*
* Sets each element in the matrix to a value drawn from an uniform distribution from 'min' to 'max' inclusive.
*
*
* @param min The minimum value each element can be.
* @param max The maximum value each element can be.
* @param mat The matrix who is to be randomized. Modified.
* @param rand Random number generator used to fill the matrix.
*/
public static void fillUniform( ZMatrixD1 mat, double min, double max, Random rand ) {
double d[] = mat.getData();
int size = mat.getDataLength();
double r = max - min;
for (int i = 0; i < size; i++) {
d[i] = r*rand.nextDouble() + min;
}
}
/**
* Creates a random symmetric positive definite matrix.
*
* @param width The width of the square matrix it returns.
* @param rand Random number generator used to make the matrix.
* @return The random symmetric positive definite matrix.
*/
public static ZMatrixRMaj hermitianPosDef( int width, Random rand ) {
// This is not formally proven to work. It just seems to work.
ZMatrixRMaj a = RandomMatrices_ZDRM.rectangle(width, 1, rand);
ZMatrixRMaj b = new ZMatrixRMaj(1, width);
ZMatrixRMaj c = new ZMatrixRMaj(width, width);
CommonOps_ZDRM.transposeConjugate(a, b);
CommonOps_ZDRM.mult(a, b, c);
for (int i = 0; i < width; i++) {
c.data[2*(i*width + i)] += 1;
}
return c;
}
/**
* Creates a random Hermitian matrix with elements from min to max value.
*
* @param length Width and height of the matrix.
* @param min Minimum value an element can have.
* @param max Maximum value an element can have.
* @param rand Random number generator.
* @return A symmetric matrix.
*/
public static ZMatrixRMaj hermitian( int length, double min, double max, Random rand ) {
ZMatrixRMaj A = new ZMatrixRMaj(length, length);
fillHermitian(A, min, max, rand);
return A;
}
/**
* Assigns the provided square matrix to be a random Hermitian matrix with elements from min to max value.
*
* @param A The matrix that is to be modified. Must be square. Modified.
* @param min Minimum value an element can have.
* @param max Maximum value an element can have.
* @param rand Random number generator.
*/
public static void fillHermitian( ZMatrixRMaj A, double min, double max, Random rand ) {
if (A.numRows != A.numCols)
throw new IllegalArgumentException("A must be a square matrix");
double range = max - min;
int length = A.numRows;
for (int i = 0; i < length; i++) {
A.set(i, i, rand.nextDouble()*range + min, 0);
for (int j = i + 1; j < length; j++) {
double real = rand.nextDouble()*range + min;
double imaginary = rand.nextDouble()*range + min;
A.set(i, j, real, imaginary);
A.set(j, i, real, -imaginary);
}
}
}
// /**
// * Creates an upper triangular matrix whose values are selected from a uniform distribution. If hessenberg
// * is greater than zero then a hessenberg matrix of the specified degree is created instead.
// *
// * @param dimen Number of rows and columns in the matrix..
// * @param hessenberg 0 for triangular matrix and > 0 for hessenberg matrix.
// * @param min minimum value an element can be.
// * @param max maximum value an element can be.
// * @param rand random number generator used.
// * @return The randomly generated matrix.
// */
// public static ZMatrixRMaj createUpperTriangle( int dimen , int hessenberg , double min , double max , Random rand )
// {
// if( hessenberg < 0 )
// throw new RuntimeException("hessenberg must be more than or equal to 0");
//
// double range = max-min;
//
// ZMatrixRMaj A = new ZMatrixRMaj(dimen,dimen);
//
// for( int i = 0; i < dimen; i++ ) {
// int start = i <= hessenberg ? 0 : i-hessenberg;
//
// for( int j = start; j < dimen; j++ ) {
// double real = rand.nextDouble()*range + min;
// double imaginary = rand.nextDouble()*range + min;
//
// A.set(i,j, real, imaginary);
// }
//
// }
//
// return A;
// }
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy