The Amazing Rob Pike :D On Tue, Sep 22, 2020 at 12:13 PM Rob Pike <r...@golang.org> wrote:
> I'm not going to debug you program for you - you'll learn more doing it > yourself, but I glanced at it and saw immediately that you're missing an > easy optimization. Raising a number to an integer power can be done much > faster by repeated squaring according to the bit pattern of the exponent. > I'll leave that cryptic comment alone to let you puzzle it out yourself. > (Don't look it up; it's much more fun to figure out.) > > -rob > > > On Tue, Sep 22, 2020 at 3:11 AM Hau Phan <haupc....@gmail.com> wrote: > >> i can't find get n-th root in document of go big package so i decided to >> do it myself using newton's method. i found a solution at >> https://www.geeksforgeeks.org/n-th-root-number/ and start to implement >> in go. but my code only work fine for base 2. other base result gone too >> far from correct. >> >> Anyone could show me where am i wrong. >> >> Here's my code >> >> ```go >> package main >> >> import ( >> "fmt" >> "math/big" >> "math/rand" >> ) >> >> // PowFloat return x^n >> func PowFloat(x *big.Float, n int64) *big.Float { >> result := new(big.Float).SetInt64(1) >> for i := 0; i < int(n); i++ { >> result.Mul(result, x) >> } >> return result >> } >> >> // GetNthRoothFloat get nth root of a using newton's method >> func GetNthRoothFloat(a *big.Float, n int64) *big.Float { >> N := new(big.Float).SetInt64(n) >> xPre := new(big.Float).SetInt64(int64(rand.Intn(10) + 1)) >> eps := new(big.Float).SetFloat64(0.00000000001) >> delX := new(big.Float).SetInt64(2147483647) >> xK := new(big.Float).SetInt64(0) >> >> for delX.Cmp(eps) > 0 { >> t1 := new(big.Float).Sub(N, new(big.Float).SetFloat64(1.0)) // t1 = n-1 >> t1 = t1.Mul(t1, xPre) // t1 = (N-1) >> * xPre >> t2 := new(big.Float).Quo(a, PowFloat(xPre, n-1)) // t2 = a/( >> xPre^(n-1) ) >> t3 := new(big.Float).Add(t1, t2) // t3 = t1 + >> t2 >> xK.Quo(t3, N) >> delX = new(big.Float).Sub(xK, xPre) >> delX.Abs(delX) >> xPre = xK.Copy(xK) >> } >> return xK >> } >> >> func main() { >> t := new(big.Float).SetInt64(64) >> fmt.Println(GetNthRoothFloat(t, 3)) >> } >> ``` >> >> -- >> You received this message because you are subscribed to the Google Groups >> "golang-nuts" group. >> To unsubscribe from this group and stop receiving emails from it, send an >> email to golang-nuts+unsubscr...@googlegroups.com. >> To view this discussion on the web visit >> https://groups.google.com/d/msgid/golang-nuts/5a38a7fe-426b-4f94-905e-79b42dcaa611n%40googlegroups.com >> <https://groups.google.com/d/msgid/golang-nuts/5a38a7fe-426b-4f94-905e-79b42dcaa611n%40googlegroups.com?utm_medium=email&utm_source=footer> >> . >> > -- > You received this message because you are subscribed to the Google Groups > "golang-nuts" group. > To unsubscribe from this group and stop receiving emails from it, send an > email to golang-nuts+unsubscr...@googlegroups.com. > To view this discussion on the web visit > https://groups.google.com/d/msgid/golang-nuts/CAOXNBZQrjBjT-dDEK1Atu7R32aT1mgTsSAYhXAF7hXmj35BjuQ%40mail.gmail.com > <https://groups.google.com/d/msgid/golang-nuts/CAOXNBZQrjBjT-dDEK1Atu7R32aT1mgTsSAYhXAF7hXmj35BjuQ%40mail.gmail.com?utm_medium=email&utm_source=footer> > . > -- You received this message because you are subscribed to the Google Groups "golang-nuts" group. To unsubscribe from this group and stop receiving emails from it, send an email to golang-nuts+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/golang-nuts/CAG9C_MeG0P%3DSy5732WvW-EfsreSObQve%3DLsEUms%3DdWdRenvZ4Q%40mail.gmail.com.