rand_test.go 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. package otherutils
  2. import (
  3. "fmt"
  4. "testing"
  5. )
  6. func TestRandChoiceByWeighted(t *testing.T) {
  7. items := [][]int64{
  8. {1, 1000},
  9. {2, 1000},
  10. {3, 500},
  11. {4, 10},
  12. }
  13. frequencies := make(map[int64]int64)
  14. for i := 0; i < 10000; i++ {
  15. selected := RandChoiceByWeighted(items)
  16. //fmt.Println(selected)
  17. frequencies[selected]++
  18. }
  19. fmt.Println("Frequencies of selection after 10000 trials:")
  20. for k, v := range frequencies {
  21. fmt.Printf("%d: %d\n", k, v)
  22. }
  23. }
  24. func TestRandOneNum(t *testing.T) {
  25. for i := 0; i < 10; i++ {
  26. got := RandOneNum(0, 5)
  27. fmt.Println(got)
  28. }
  29. }
  30. func TestWeightedTable_RandOneItem(t *testing.T) {
  31. items := [][]int64{
  32. {1, 1000},
  33. {2, 1000},
  34. {3, 500},
  35. {4, 0},
  36. {5, 0},
  37. }
  38. weightedTable := SetWeightedTable(items, func(item []int64) int64 {
  39. return item[1]
  40. })
  41. res := make(map[int64]int64)
  42. for i := 0; i < 100000; i++ {
  43. item, _ := weightedTable.RandOneItem(false)
  44. if _, ok := res[item[0]]; ok {
  45. res[item[0]]++
  46. } else {
  47. res[item[0]] = 1
  48. }
  49. }
  50. fmt.Println(res)
  51. var num int64
  52. for _, n := range res {
  53. num += n
  54. }
  55. fmt.Println(num)
  56. }