単純なデータファイル「matrix.dat」からデータを読み取っています。例:
1 2 3
4 5 6
7 8 9
ファイルを読み、データ ポイントを 2D 配列に保存します。
else /// Read data from file.
{
// Check matrix is square and find number of columns/rows.
n = CheckSquare(matrixData); /// n = dimension of square matrix
fprintf(stdout, "n = %d\n", n); /// TESTING ///
if(n != 0) /// Matrix is square.
{
int i, j; /// i = rows, j = columns.
double MATRIX[n - 1][n - 1]; /// Declare 2D array of size n x n.
// Loop through file "matrix.dat" and store data into 2D array "MATRIX".
for(i = 0; i < n; i++) /// Loop rows.
{
for(j = 0; j < n; j++) /// Loop columns.
{
fscanf(matrixData, "%lf", &MATRIX[i][j]); /// Store data point as matrix element.
fprintf(stdout, "[%d][%d] = %lf\n", i, j, MATRIX[i][j]); ///TESTING ///
}
}
// Calculate the determinant of matrix "MATRIX".
///det = Determinant(n, MATRIX); /// COMMENT OUT ///
///fprintf(stdout, "Determinant = %lf\n", det); /// COMMENT OUT ///
for(i = 0; i < n; i++) /// Loop rows.
{
for(j = 0; j < n; j++) /// Loop columns.
{
fprintf(stdout, "[%d][%d] = %lf\n", i, j, MATRIX[i][j]);
}
}
}
テスト目的でマトリックスを 2 回出力していることがわかります。ファイルを読み取ってデータを保存しているときに1回、最初のforループが終了した後にもう一度。
2 つの for ループの間で 2D 配列 'MATRIX' を操作していないため、まったく同じ結果が出力されるはずです。
ただし、これは出力されるものです (上記のように「matrix.dat」ファイルを使用する場合):
n = 3
[0][0] = 1.000000
[0][1] = 2.000000
[0][2] = 3.000000
[1][0] = 4.000000
[1][1] = 5.000000
[1][2] = 6.000000
[2][0] = 7.000000
[2][1] = 8.000000
[2][2] = 9.000000
[0][0] = 1.000000
[0][1] = 2.000000
[0][2] = 4.000000
[1][0] = 4.000000
[1][1] = 5.000000
[1][2] = 5.000000
[2][0] = 5.000000
[2][1] = 8.000000
[2][2] = 9.000000
どんな助けでも大歓迎です。
念のため、これは「CheckSquare」関数です。
// Checks if matrix is square and returns the dimension if TRUE.
// Otherwise returns 0.
int CheckSquare(FILE* m)
{
int dim; /// Dimension of matrix.
int dataNum = 0; /// Holds number of data points in file "matrixData".
double temp; /// Temporary variable to hold double data.
// Check matrix is square and find number of columns/rows.
while(fscanf(m, "%lf", &temp) != EOF) /// Data can still be read from file "matrixData".
{
dataNum++; /// Adds to number of data points.
}
rewind(m); /// Sets the position indicator to the beginning of the file "matrixData".
dim = sqrt(dataNum); /// Number of columns and rows if 'dataNum' is perfect square.
if(dim*dim == dataNum) /// Matrix is square.
{
return(dim);
}
else
{
return(0);
}
}