forked from rdpeng/ProgrammingAssignment2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
cachematrix.R
31 lines (26 loc) · 890 Bytes
/
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
## This function create a special matrix that can cache it's inverse.
makeCacheMatrix <- function(x = matrix()) {
m<-NULL
set<-function(y){
x<<-y
m<<-NULL
}
get<-function()x #get matrix
setinv<-function(inv) m<<-inv # Set inverse of matrix
getinv<-function() m # get inverse of matrix
list(set=set, get=get, setinv=setinv, getinv=getinv )
}
## This function computes the inverse of the special matrix returned by makeCacheMatrix above,
## If the inverse already existed, then retrieve it from the cache
cacheSolve <- function(x, ...) {
## Return a matrix that is the inverse of 'x'
m<-x$getinv()
if(!is.null(m)) {
message("getting cached inverse matrix")
return(m)
}
data<- x$get()
m<- solve(data,...) #get inverse
x$setinv(m)
m
}