forked from rdpeng/ProgrammingAssignment2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcachematrix.R
34 lines (31 loc) · 1.01 KB
/
cachematrix.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
## This function creates a special "matrix" object that can cache its inverse.
## sample is the matrix object that user will submit on the console
makeCacheMatrix <- function(sample = matrix()) {
invsample <- NULL
set <- function(x) {
Sample <<- x
invsample <<- NULL
}
get <- function() sample
setInverse <- function(inverse) inv <<- inverse
getInverse <- function() invsample
list(set = set,
get = get,
setInverse = setInverse,
getInverse = getInverse)
}
## This function computes the inverse of the special "matrix" created by
## makeCacheMatrix above. If the inverse has already been calculated (and the
## matrix has not changed), then it should retrieve the inverse from the cache.
cacheSolve <- function(sample, ...) {
## Return a matrix that is the inverse of 'sample'
inv <- sample$getInverse()
if (!is.null(inv)) {
message("getting cached data")
return(invsample)
}
mat <- sample$get()
invsample <- solve(mat, ...)
sample$setInverse(invsample)
invsample
}