Created
November 22, 2020 16:52
-
-
Save dionsaputra/5f3445dbee17633fc8919a6fbb9414e5 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
fun inverse(matrix: Matrix): Matrix? { | |
require(matrix.rows == matrix.cols) | |
// check matrix invertible | |
if (determinant(matrix).equalsDelta(0.0)) return null | |
// copy matrix | |
val inverse = Matrix.diagonal(matrix.rows, 1.0, 0.0) | |
val temp = Matrix( | |
matrix.rows, | |
matrix.cols, | |
matrix.elements.map { it.toDouble() } | |
) | |
for (r in 0 until matrix.rows) { | |
for (c in 0 until matrix.cols) temp[r,c] = matrix[r,c] | |
} | |
for (fdRow in 0 until matrix.rows) { | |
// find focus-diagonal | |
while (fdCol < matrix.cols | |
&& temp[fdRow, fdCol].equalsDelta(0.0)) fdCol++ | |
// matrix not invertible if all row is zero | |
if (fdCol == matrix.cols) return null | |
// multiply with 1/fd | |
val scalingFactor = 1 / temp[fdRow, fdCol] | |
for (c in 0 until matrix.cols) { | |
temp[fdRow, c] *= scalingFactor | |
inverse[fdRow, c] *= scalingFactor | |
} | |
// subtract with k*R | |
for (r in 0 until matrix.rows) { | |
if (r == fdRow) continue | |
val subFactor = temp[r, fdCol] | |
for (c in 0 until matrix.cols) { | |
temp[r, c] -= subFactor * temp[fdRow, c] | |
inverse[r, c] -= subFactor * inverse[fdRow, c] | |
} | |
} | |
} | |
return inverse | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment