當前位置: 首頁>>代碼示例>>Golang>>正文


Golang Rand.Intn方法代碼示例

本文整理匯總了Golang中math/rand.Rand.Intn方法的典型用法代碼示例。如果您正苦於以下問題:Golang Rand.Intn方法的具體用法?Golang Rand.Intn怎麽用?Golang Rand.Intn使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在math/rand.Rand的用法示例。


在下文中一共展示了Rand.Intn方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1: testRandomSimplex

func testRandomSimplex(t *testing.T, nTest int, pZero float64, maxN int, rnd *rand.Rand) {
	// Try a bunch of random LPs
	for i := 0; i < nTest; i++ {
		n := rnd.Intn(maxN) + 2 // n must be at least two.
		m := rnd.Intn(n-1) + 1  // m must be between 1 and n
		if m == 0 || n == 0 {
			continue
		}
		randValue := func() float64 {
			//var pZero float64
			v := rnd.Float64()
			if v < pZero {
				return 0
			}
			return rnd.NormFloat64()
		}
		a := mat64.NewDense(m, n, nil)
		for i := 0; i < m; i++ {
			for j := 0; j < n; j++ {
				a.Set(i, j, randValue())
			}
		}
		b := make([]float64, m)
		for i := range b {
			b[i] = randValue()
		}

		c := make([]float64, n)
		for i := range c {
			c[i] = randValue()
		}

		testSimplex(t, nil, c, a, b, convergenceTol)
	}
}
開發者ID:sbinet,項目名稱:gonum-optimize,代碼行數:35,代碼來源:simplex_test.go

示例2: makedata

func makedata(minsize int, dice *rand.Rand) string {
	b := make([]rune, minsize+dice.Intn(minsize))
	for i := range b {
		b[i] = letters[dice.Intn(len(letters))]
	}
	return string(b)
}
開發者ID:mdmarek,項目名稱:grid,代碼行數:7,代碼來源:datamaker.go

示例3: throw

func throw(g *rand.Rand, edge_amount, throws_amount int) int {
	var result int = 0
	for i := 0; i < throws_amount; i++ {
		result += g.Intn(edge_amount) + 1
	}
	return result
}
開發者ID:apanasenko,項目名稱:MonsterQuest,代碼行數:7,代碼來源:dice.go

示例4: randomMemory

func randomMemory(rng *rand.Rand) *MemoryRegion {
	var mr *MemoryRegion
	var err error
	options := 3
	if tmpfsBuf != nil && hugeBuf != nil {
		options += 2
	}
	switch rng.Intn(options) {
	case 0:
		mr, err = AllocateMemory(4096)
	case 1:
		mr, err = AllocateMemory(65536)
	case 2:
		mr, err = AllocateMemory(1048576)
	case 3:
		mr, err = RegisterMemory(tmpfsBuf.Bytes())
	case 4:
		mr, err = RegisterMemory(hugeBuf.Bytes())
	default:
		panic("invalid mode")
	}
	if err != nil {
		panic(err)
	}
	return mr
}
開發者ID:hpdvanwyk,項目名稱:ib,代碼行數:26,代碼來源:conn_test.go

示例5: RandomString

// There are lots of ways of doing this faster, but this is good
// enough.
func RandomString(rng *rand.Rand, size int) string {
	out := make([]byte, size)
	for i := 0; i < size; i++ {
		out[i] = alphabet[rng.Intn(size)]
	}
	return string(out)
}
開發者ID:WIZARD-CXY,項目名稱:golang-devops-stuff,代碼行數:9,代碼來源:random.go

示例6: Shuffle

// iterate through the deck, and swap values with
// a random card from another location in the deck
func (sd *StandardDeck) Shuffle(r *rand.Rand) {
	s := sd.Size()
	for k := range sd.cards {
		i := r.Intn(s)
		sd.cards[k], sd.cards[i] = sd.cards[i], sd.cards[k]
	}
}
開發者ID:stensonb,項目名稱:blackjack,代碼行數:9,代碼來源:standarddeck.go

示例7: GenerateSlice

func (c *STChain) GenerateSlice(max int, r *rand.Rand) []string {
	var s []string
	var p STPrefix

	for i := 0; i < max; i++ {
		suffix := c.Chain[p]
		if suffix.Count == 0 {
			return s
		}

		j := r.Intn(suffix.Count)

		for word, freq := range suffix.Words {
			j -= freq
			if j < 0 {
				if word == 0 {
					return s
				}

				p.shift(word)
				s = append(s, c.Strings[word])
			}
		}
	}

	return s
}
開發者ID:Nightgunner5,項目名稱:markov,代碼行數:27,代碼來源:stringtable_markov.go

示例8: NextCall

func (ss *SessionScenario) NextCall(rg *rand.Rand) (*Call, error) {
	for {
		if i := rg.Intn(ss.SessionAmount); i >= 0 {
			select {
			case st := <-ss._sessions[i].StepLock:
				switch st {
				case STEP1:
					if ss._sessions[i]._calls[st].GenParam != nil {
						ss._sessions[i]._calls[st].Method, ss._sessions[i]._calls[st].Type, ss._sessions[i]._calls[st].URL, ss._sessions[i]._calls[st].Body = ss._sessions[i]._calls[st].GenParam()
					}
					// execute session call for the first time
					return ss._sessions[i]._calls[st], nil
				default:
					// choose a non-initialized call randomly
					ss._sessions[i].StepLock <- REST
					q := rg.Float32() * ss._sessions[i]._totalWeight
					for j := STEP1 + 1; j < ss._sessions[i]._count; j++ {
						if q <= ss._sessions[i]._calls[j].RandomWeight {
							if ss._sessions[i]._calls[j].GenParam != nil {
								ss._sessions[i]._calls[j].Method, ss._sessions[i]._calls[j].Type, ss._sessions[i]._calls[j].URL, ss._sessions[i]._calls[j].Body = ss._sessions[i]._calls[j].GenParam()
							}
							return ss._sessions[i]._calls[j], nil
						}
					}
				}
			default:
				continue
			}
		}
	}

	log.Fatal("what? should never reach here")
	return nil, errors.New("all sessions are being initialized")
}
開發者ID:chenchaoyi,項目名稱:hammer2,代碼行數:34,代碼來源:session_scenario.go

示例9: PickRule

func (self *LSystem) PickRule(name string, random *rand.Rand) int {

	// Sum up the weights of all rules with this name:
	var sum int = 0
	for _, rule := range self.Rules {
		if rule.Name != name {
			continue
		}
		weight := rule.Weight
		sum += weight
	}

	// Choose a rule at random:
	n := random.Intn(sum)
	for i, rule := range self.Rules {
		if rule.Name != name {
			continue
		}
		weight := rule.Weight
		if n < weight {
			return i
		}
		n -= weight
	}

	fmt.Println("Error.")
	return -1
}
開發者ID:prideout,項目名稱:lsystem,代碼行數:28,代碼來源:lsystem.go

示例10: Apply

// Apply partially mixed crossover.
func (c CrossPMX) Apply(p1 Individual, p2 Individual, rng *rand.Rand) (Individual, Individual) {
	var (
		nbGenes = len(p1.Genome)
		o1      = makeIndividual(nbGenes, rng)
		o2      = makeIndividual(nbGenes, rng)
	)
	copy(o1.Genome, p1.Genome)
	copy(o2.Genome, p2.Genome)
	// Choose a random crossover point p such that 0 < p < (nbGenes - 1)
	var (
		p = rng.Intn(nbGenes-2) + 1
		a int
		b int
	)
	// Paste the father's genome up to the crossover point
	for i := 0; i < p; i++ {
		// Find where the second parent's gene is in the first offspring's genome
		a = getIndex(p2.Genome[i], o1.Genome)
		// Swap the genes
		o1.Genome[a], o1.Genome[i] = o1.Genome[i], p2.Genome[i]
		// Find where the first parent's gene is in the second offspring's genome
		b = getIndex(p1.Genome[i], o2.Genome)
		// Swap the genes
		o2.Genome[b], o2.Genome[i] = o2.Genome[i], p1.Genome[i]
	}
	return o1, o2
}
開發者ID:MaxHalford,項目名稱:gago,代碼行數:28,代碼來源:crossover.go

示例11: randCoord

func randCoord(r *rand.Rand) []int {
	var coord []int = make([]int, 3)
	coord[0] = r.Intn(S_MAP)
	coord[1] = r.Intn(S_MAP)
	coord[2] = r.Intn(S_MAP)
	return coord
}
開發者ID:jinseokYeom,項目名稱:GoDWIB,代碼行數:7,代碼來源:GoDWIB.go

示例12: replaceLabels

func replaceLabels(l *lexer, r *rand.Rand) string {
	var buf bytes.Buffer
	var labelCounter uint
	var remLabels []uint

	for i := l.nextItem(); i.typ != itemEOF; i = l.nextItem() {
		switch i.typ {
		case itemText:
			buf.WriteString(i.val)
		case itemLabel:
			buf.WriteString("label")
			buf.WriteString(strconv.Itoa(int(labelCounter)))
			remLabels = append(remLabels, labelCounter)
			labelCounter++
		case itemNewLine:
			buf.WriteString("\n")

			// randomly put a label here, if any
			if len(remLabels) > 0 && r.Intn(8) == 0 {
				buf.WriteString("label")
				buf.WriteString(strconv.Itoa(int(remLabels[0])))
				buf.WriteString(":\n")
				remLabels = remLabels[1:]
			}
		}
	}

	for _, l := range remLabels {
		buf.WriteString("label")
		buf.WriteString(strconv.Itoa(int(l)))
		buf.WriteString(":\n")
	}

	return buf.String()
}
開發者ID:yblein,項目名稱:tavor-isa,代碼行數:35,代碼來源:post.go

示例13: randomColor

// randomColor returns a random RGB color from a random seed.
func randomColor(seed *rand.Rand) color.RGBA {
	return color.RGBA{
		uint8(seed.Intn(255)),
		uint8(seed.Intn(255)),
		uint8(seed.Intn(255)),
		0xff} // No alpha.
}
開發者ID:karlek,項目名稱:vanilj,代碼行數:8,代碼來源:fractal.go

示例14: ensureExits

// ensureExits makes sure there is an outside exit on two sides
// of the room. The corners are left alone.
func (rms *rooms) ensureExits(random *rand.Rand, rm *room) {
	var top, bot, left, right []*cell
	xmax, ymax := rm.w, rm.h
	for x := rm.x + 1; x < rm.x+rm.w-1; x++ {
		u := rms.cells[x][rm.y]
		if u.isWall {
			top = append(top, u)
		}
		u = rms.cells[x][rm.y+rm.h-1]
		if u.isWall {
			bot = append(bot, u)
		}
	}
	for y := rm.y + 1; y < rm.y+rm.h-1; y++ {
		u := rms.cells[rm.x][y]
		if u.isWall {
			left = append(left, u)
		}
		u = rms.cells[rm.x+rm.w-1][y]
		if u.isWall {
			right = append(right, u)
		}
	}

	// randomize which sides get exits.
	if random.Intn(2) == 0 {
		rms.ensureExit(random, top, xmax-2)
		rms.ensureExit(random, left, ymax-2)
	} else {
		rms.ensureExit(random, bot, xmax-2)
		rms.ensureExit(random, right, ymax-2)
	}
}
開發者ID:krattai,項目名稱:monoflow,代碼行數:35,代碼來源:rooms.go

示例15: run

func (s *sim) run(t *testing.T, rng *rand.Rand) {
	dbg(s.graph.Graph().Map())

	step := 0
	for len(s.pending) > 0 {
		if step > 1000000 {
			t.Fatal("non-convergence")
		}
		step++

		// Maybe add or remove a link
		if rng.Intn(100) == 0 {
			e := s.graph.RandomEdge(rng)
			if s.graph.Contains(e) {
				s.graph.Remove(e)

				// Check that the graph did not become
				// disconnected.
				if s.graph.Graph().Connected() {
					dbg("Disconnecting", e)
					s.disconnect(e)
				} else {
					s.graph.Add(e)
				}
			} else {
				dbg("Connecting", e)
				s.graph.Add(e)
				s.link(e)
			}
		}

		// Propagate an update
		i := rng.Intn(len(s.pending))
		l := s.pending[i]
		s.pending[i] = s.pending[len(s.pending)-1]
		s.pending = s.pending[:len(s.pending)-1]

		if l.closed {
			continue
		}

		for prop, updates := range l.sender.Outgoing() {
			dbg(l.sender.c.id, "->", l.receiver.c.id, ":", updates)
			l.receiver.Incoming(l.receiver.c.ConnectivityPropagation(), updates)
			l.sender.Delivered(prop, updates)
		}
	}

	var expect map[NodeID]interface{}
	var expectNode NodeID
	for _, node := range s.graph.Nodes {
		c := s.cs[node]
		if expect == nil {
			expect = c.Dump()
			expectNode = node
		} else {
			require.Equal(t, expect, c.Dump(), "mismatch %s %s", expectNode, node)
		}
	}
}
開發者ID:squaremo,項目名稱:monotreme,代碼行數:60,代碼來源:connectivity_test.go


注:本文中的math/rand.Rand.Intn方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。