Initial commit of fibonacci_http_go
This commit is contained in:
parent
6a88aeb484
commit
d840abd759
23 changed files with 299 additions and 518 deletions
76
internal/fibonacci/fib.go
Normal file
76
internal/fibonacci/fib.go
Normal file
|
|
@ -0,0 +1,76 @@
|
|||
package fibonacci
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"fmt"
|
||||
"math/big"
|
||||
)
|
||||
|
||||
// Fibonacci calculates Fibonacci number.
|
||||
// This function generated correct values from 0 to 93 sequence number.
|
||||
// For bigger values use FibonacciBig function.
|
||||
func Fibonacci(n uint) uint64 {
|
||||
if n <= 1 {
|
||||
return uint64(n)
|
||||
}
|
||||
|
||||
var n2, n1 uint64 = 0, 1
|
||||
|
||||
for i := uint(2); i < n; i++ {
|
||||
n2, n1 = n1, n1+n2
|
||||
}
|
||||
|
||||
return n2 + n1
|
||||
}
|
||||
|
||||
// FibonacciBig calculates Fibonacci number using bit.Int.
|
||||
// For the sequence numbers below 94, it is recommended to use Fibonacci function as it is more efficient.
|
||||
func FibonacciBig(n uint) *big.Int {
|
||||
if n <= 1 {
|
||||
return big.NewInt(int64(n))
|
||||
}
|
||||
|
||||
var n2, n1 = big.NewInt(0), big.NewInt(1)
|
||||
|
||||
for i := uint(1); i < n; i++ {
|
||||
n2.Add(n2, n1)
|
||||
n1, n2 = n2, n1
|
||||
}
|
||||
|
||||
return n1
|
||||
}
|
||||
|
||||
func FibonacciFromString(str string) (*big.Int, error) {
|
||||
|
||||
n := new(big.Int)
|
||||
n, ok := n.SetString(str, 10)
|
||||
|
||||
if !ok {
|
||||
return nil, errors.New("ConvertError")
|
||||
}
|
||||
|
||||
if n.Sign() != 1 {
|
||||
return big.NewInt(int64(n.Int64())), nil
|
||||
}
|
||||
|
||||
// Initialize two big ints with the first two numbers in the sequence.
|
||||
a := big.NewInt(0)
|
||||
b := big.NewInt(1)
|
||||
|
||||
// Loop while a is smaller than 1e100.
|
||||
for i := int64(1); i <= n.Int64(); i++ {
|
||||
// Compute the next Fibonacci number, storing it in a.
|
||||
a.Add(a, b)
|
||||
// Swap a and b so that b is the next number in the sequence.
|
||||
a, b = b, a
|
||||
}
|
||||
|
||||
fmt.Println(a) // 100-digit Fibonacci number
|
||||
|
||||
// Test a for primality.
|
||||
// (ProbablyPrimes' argument sets the number of Miller-Rabin
|
||||
// rounds to be performed. 20 is a good value.)
|
||||
fmt.Println(a.ProbablyPrime(20))
|
||||
|
||||
return a, nil
|
||||
}
|
||||
57
internal/fibonacci/fib_test.go
Normal file
57
internal/fibonacci/fib_test.go
Normal file
|
|
@ -0,0 +1,57 @@
|
|||
package fibonacci
|
||||
|
||||
import "testing"
|
||||
|
||||
func BenchmarkFibonacci_10(b *testing.B) {
|
||||
for i := 0; i < b.N; i++ {
|
||||
Fibonacci(10)
|
||||
}
|
||||
}
|
||||
|
||||
func BenchmarkFibonacci_20(b *testing.B) {
|
||||
for i := 0; i < b.N; i++ {
|
||||
Fibonacci(20)
|
||||
}
|
||||
}
|
||||
|
||||
func BenchmarkFibonacciBig_10(b *testing.B) {
|
||||
for i := 0; i < b.N; i++ {
|
||||
FibonacciBig(10)
|
||||
}
|
||||
}
|
||||
|
||||
func BenchmarkFibonacciBig_20(b *testing.B) {
|
||||
for i := 0; i < b.N; i++ {
|
||||
FibonacciBig(20)
|
||||
}
|
||||
}
|
||||
|
||||
func TestFibonacci(t *testing.T) {
|
||||
data := []struct {
|
||||
n uint
|
||||
want uint64
|
||||
}{
|
||||
{0, 0}, {1, 1}, {2, 1}, {3, 2}, {4, 3}, {5, 5}, {6, 8}, {10, 55}, {42, 267914296},
|
||||
}
|
||||
|
||||
for _, d := range data {
|
||||
if got := Fibonacci(d.n); got != d.want {
|
||||
t.Errorf("Invalid Fibonacci value for N: %d, got: %d, want: %d", d.n, got, d.want)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func TestFibonacciBig(t *testing.T) {
|
||||
data := []struct {
|
||||
n uint
|
||||
want int64
|
||||
}{
|
||||
{0, 0}, {1, 1}, {2, 1}, {3, 2}, {4, 3}, {5, 5}, {6, 8}, {10, 55}, {42, 267914296},
|
||||
}
|
||||
|
||||
for _, d := range data {
|
||||
if got := FibonacciBig(d.n); got.Int64() != d.want {
|
||||
t.Errorf("Invalid Fibonacci value for N: %d, got: %d, want: %d", d.n, got, d.want)
|
||||
}
|
||||
}
|
||||
}
|
||||
39
internal/http/server.go
Normal file
39
internal/http/server.go
Normal file
|
|
@ -0,0 +1,39 @@
|
|||
package http
|
||||
|
||||
import (
|
||||
"apps/internal/fibonacci"
|
||||
"fmt"
|
||||
"net/http"
|
||||
|
||||
//"github.com/chenjiandongx/ginprom"
|
||||
"github.com/gin-gonic/gin"
|
||||
//"github.com/prometheus/client_golang/prometheus/promhttp"
|
||||
)
|
||||
|
||||
func StartServer() error {
|
||||
r := gin.Default()
|
||||
|
||||
//r.Use(ginprom.PromMiddleware(nil))
|
||||
|
||||
r.GET("/fibonacci", CalculateFibonacci)
|
||||
//r.GET("/metrics", gin.WrapH(promhttp.Handler()))
|
||||
|
||||
return r.Run(":9090")
|
||||
}
|
||||
|
||||
func CalculateFibonacci(c *gin.Context) {
|
||||
|
||||
numberstr := c.Query("number")
|
||||
|
||||
result, err := fibonacci.FibonacciFromString(numberstr)
|
||||
|
||||
if err != nil {
|
||||
c.AbortWithStatus(http.StatusBadRequest)
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
c.JSON(200, gin.H{
|
||||
"result": fmt.Sprint(result),
|
||||
})
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue