mirror of
				https://github.com/gonum/gonum.git
				synced 2025-10-26 08:40:26 +08:00 
			
		
		
		
	cgo,native: fix optimal work length return
This commit is contained in:
		| @@ -894,18 +894,18 @@ func (impl Implementation) Dgeqr2(m, n int, a []float64, lda int, tau, work []fl | ||||
| // | ||||
| // The C interface does not support providing temporary storage. To provide compatibility | ||||
| // with native, lwork == -1 will not run Dgeqrf but will instead write the minimum | ||||
| // work necessary to work[0]. If len(work) < lwork, Dgeqrf will panic. | ||||
| // work necessary to work[0]. If len(work) < max(1, lwork), Dgeqrf will panic. | ||||
| // | ||||
| // tau must have length at least min(m,n), and this function will panic otherwise. | ||||
| func (impl Implementation) Dgeqrf(m, n int, a []float64, lda int, tau, work []float64, lwork int) { | ||||
| 	if len(work) < max(1, lwork) { | ||||
| 		panic(shortWork) | ||||
| 	} | ||||
| 	if lwork == -1 { | ||||
| 		work[0] = float64(n) | ||||
| 		return | ||||
| 	} | ||||
| 	checkMatrix(m, n, a, lda) | ||||
| 	if len(work) < lwork { | ||||
| 		panic(shortWork) | ||||
| 	} | ||||
| 	if lwork < n { | ||||
| 		panic(badWork) | ||||
| 	} | ||||
|   | ||||
| @@ -14,7 +14,7 @@ import ( | ||||
| // parameters at entry and exit. | ||||
| // | ||||
| // work is temporary storage, and lwork specifies the usable memory length. | ||||
| // At minimum, lwork >= m and this function will panic otherwise. | ||||
| // At minimum, lwork >= max(1, m) and this function will panic otherwise. | ||||
| // Dgeqrf is a blocked QR factorization, but the block size is limited | ||||
| // by the temporary space available. If lwork == -1, instead of performing Dgeqrf, | ||||
| // the optimal work length will be stored into work[0]. | ||||
| @@ -25,14 +25,14 @@ func (impl Implementation) Dgeqrf(m, n int, a []float64, lda int, tau, work []fl | ||||
| 	nb := impl.Ilaenv(1, "DGEQRF", " ", m, n, -1, -1) | ||||
| 	lworkopt := n * max(nb, 1) | ||||
| 	lworkopt = max(n, lworkopt) | ||||
| 	if len(work) < max(1, lwork) { | ||||
| 		panic(shortWork) | ||||
| 	} | ||||
| 	if lwork == -1 { | ||||
| 		work[0] = float64(lworkopt) | ||||
| 		return | ||||
| 	} | ||||
| 	checkMatrix(m, n, a, lda) | ||||
| 	if len(work) < lwork { | ||||
| 		panic(shortWork) | ||||
| 	} | ||||
| 	if lwork < n { | ||||
| 		panic(badWork) | ||||
| 	} | ||||
| @@ -41,6 +41,7 @@ func (impl Implementation) Dgeqrf(m, n int, a []float64, lda int, tau, work []fl | ||||
| 		panic(badTau) | ||||
| 	} | ||||
| 	if k == 0 { | ||||
| 		work[0] = float64(lworkopt) | ||||
| 		return | ||||
| 	} | ||||
| 	nbmin := 2 // Minimal block size. | ||||
| @@ -93,4 +94,5 @@ func (impl Implementation) Dgeqrf(m, n int, a []float64, lda int, tau, work []fl | ||||
| 	if i < k { | ||||
| 		impl.Dgeqr2(m-i, n-i, a[i*lda+i:], lda, tau[i:], work) | ||||
| 	} | ||||
| 	work[0] = float64(lworkopt) | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 kortschak
					kortschak