- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
作为一个学习 Haskell 的 Java 人,我已经习惯了思考一切的新方法,但我花了半天时间尝试用简单的 RNG 实现一些东西,但一无所获。在 Java 中,我可以创建一个静态 RNG 并使用 Classname.random.nextInt(10) 调用它,它会满足以下条件:
到目前为止,在 Haskell 中,我面临着经典的程序员困境——我可以拥有 2/3。我仍在学习并且对 Monad 完全一无所知,除了它们可能能够在这方面帮助我。
我最近的尝试是这样的:
getRn :: (RandomGen g) => Int -> Int -> Rand g Int
getRn lo hi= getRandomR (lo,hi)
--编辑:修剪我的问题,这样它就不会那么冗长,用摘要代替,然后我最终做了什么:
在创建了一堆随机城市(对于 TSP)之后,我使用一个函数 createEdges
将它们映射到它们上面,该函数获取一个城市并将其连接到其余城市:M.mapWithKey (\x y -> (x,(createEdges y [1..3] makeCountry)))
问题:
我想用随机的东西替换 [1..3]。 IE。我想在纯代码上映射随机性 (IO)。这给我造成了无穷无尽的困惑(请参阅下面人们试图回答我的尝试,以更好地了解我的困惑)。事实上,我什至不确定我是否正确地解释了问题。
我遇到了这种类型的错误:Couldn't match expected type [Int] with actual type IO [Int]
解决方案:
因此,在发现我想做的事情在功能环境中是根本错误的之后,我决定改变我的方法。我没有生成城市列表然后应用随机性来连接它们,而是创建了一个 [[Int]],其中每个内部列表代表随机边缘。从而在流程开始时创建我的随机性,而不是试图将随机性映射到纯代码上。
(我将最终结果发布为我自己的答案,但现在还不允许我接受我自己的答案。一旦我达到了那个阈值,我就会回来接受)
最佳答案
如果您愿意,您可以在没有任何 monad 或 IO 的情况下使用随机数。您只需要知道,由于涉及到状态(随机数生成器的内部状态),因此您必须接受该状态。
在我看来,最简单的框架是 Sytem.Random .
使用这个你的 getRn
函数看起来像这样:
getRn :: (RandomGen g) => Int -> Int -> g -> (Int, g)
getRn lo hi g = randomR (lo,hi) g
在这里你可以将 g
视为我上面提到的 state - 你把它放进去然后你会像这样(在 ghci 中)得到另一个回来:
> let init = mkStdGen 11
> let (myNr, nextGen) = getRn 1 6 init
> myNr
6
> let (myNr, nextGen') = getRn 1 6 nextGen
> myNr
4
我认为你可以从使用这个开始 - 围绕 gen
进行线程化,稍后当你得到所有 monad 的东西时回来并使其更容易编写/阅读。
我不知道你的数据的定义,但这里有一个使用这种技术的简单例子:
module StackOQuestion where
import System.Random
getRn :: (RandomGen g) => Int -> Int -> g -> (Int, g)
getRn lo hi = randomR (lo,hi)
getRnList :: (RandomGen g) => (g -> (a, g)) -> Int -> g -> ([a], g)
getRnList f n g
| n <= 0 = ([], g)
| otherwise = let (ls, g') = getRnList f (n-1) g
(a, g'') = f g'
in (a:ls, g'')
type City = (Int, Int)
randomCity :: (RandomGen g) => g -> (City, g)
randomCity g =
let (f, g') = getRn 1 6 g
(s, g'') = getRn 1 6 g'
in ((f, s), g'')
randomCities :: (RandomGen g) => (Int, Int) -> g -> ([City], g)
randomCities (minC, maxC) g =
let (count, g') = getRn minC maxC g
in getRnList randomCity count g'
你可以这样测试它:
> let init = mkStdGen 23
> randomCities (2,6) init
([(4,3),(1,2)],394128088 652912057)
如您所见,这会创建两个 Cities(此处仅表示为整数对)- 对于 init
的其他值,您将得到其他答案。
如果你以正确的方式看这里,你可以看到那里已经有一个 state-monad 的开始(g -> ('a, g)
部分) ;)
PS:mkStdGen
有点像您从 Java 和 co 了解到的随机初始化(您通常将系统时钟的滴答计数放入其中的部分)- 我选择 11,因为它是快速输入 ;) - 当然,如果你坚持使用 11,你总是会得到相同的数字 - 所以你需要用 IO 中的东西初始化它 - 但你可以将这个包推送到 main
并保留pure 否则如果你只是通过 g
around
关于haskell - Haskell RNG 和状态,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24502918/
我开发了一个 RNG 算法并生成随机数,现在我想测试生成的输出的随机性。我从 nist(sts) 下载了一个测试套件。有一个选项可以提供输入二进制文件来测试随机性。但我不知道如何生成这些二进制文件。我
因此,我编写了一个函数(以及一个 RNG 函数,上述函数调用该函数)来将随机数量的星号打印到控制台窗口,直到达到 90 个空格。星号代表汽车的运动,90个空格是轨道的长度。下面我包含的代码打印随机数量
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
我正在尝试为我的模拟器重现一些行为。 我有一个百分比支票,从 30% 到 70% 不等。问题是它不是严格随机的。这是我提取的实时数据: https://docs.google.com/spreadsh
这个问题在这里已经有了答案: How to generate a random integer in the range [0,n] from a stream of random bits wit
我目前正在实现一个代表 52 张牌的牌组的 Deck 类。它使用 boost Random 库来洗牌代表卡片的整数。 #include #include #include "constants.h
在本文的最后一个示例 (http://www.daniweb.com/software-development/cpp/threads/1769/c-random-numbers) 中,作者声称这是一
我想使用 在我的 C++ 应用程序中使用多个 RNG .播种它们的最佳方法是什么?我担心当使用来自单个 RNG 的随机数为每个 RNG 播种时,来自不同 RNG 的随机数会过于相关。 最佳答案 如果
现在我正在使用 Mersenne Twister RNG 并执行 Fisher-Yates 洗牌算法 100 次: std::vector shufCards; for(int i =
我正在开发一款纸牌游戏,我需要洗牌算法来做得很好,并且每次游戏运行时都不同,并且没有可预测的纸牌序列。 我正在使用 Mersenne twister 算法,但它仍然需要一个种子,所以实际上,虽然它产生
我可以使用两种方法中的一种来创建具有两个重要特征的伪随机数序列 - (1) 它可以在不同的机器上重现,并且 (2) 该序列从不重复范围内的数字,直到所有数字都被发出. 我的问题是 - 这些方法中的任何
我有一段冗长而复杂的源代码,它使用带有修复种子的随机数生成器。 这段代码是一个模拟器,这个模拟器的参数就是这个RNG给出的随机值。当我在同一台机器上执行代码时,无论我尝试多少次,输出都是一样的。但是当
我在想这个问题。我听说全局变量不好,它们会损害代码的可维护性、可用性、可重用性等。但在这种情况下,我还能做什么呢?也就是说,我有一个“伪随机数生成器”(PRNG),正如人们所知,它们涉及一种内部状态,
回复 this question我运行了以下 VBA 实验: Sub Test() Dim i As Long, A As Variant Dim count1 As Long, co
我知道我可以用例如设置 RNGversion RNGversion("3.5.2") 但是是否可以查询我当前使用的 R 版本? 编辑: 我的问题是版本 3.6.0 发生了一些变化,这在 RNGkind
我今天刚开始学习JavaScript,这个很简单的问题给我带来了麻烦。这只是较大代码段的一部分,但我将其隔离以尝试修复它。这是: document.write(blarg()); func
我制作了一个随机数生成器,如果有人在没有数字的情况下使用它,它会崩溃如何确保用户输入是否是字符串,它不会崩溃,而是说“无效参数”? static int random; static String s
好吧,我正在编写一个与 cpu 对抗的程序,但每次它都会先失败然后致命,我会分解我的代码,以便让你们更容易提供帮助。 进口: import javax.swing.JOptionPane; impor
我的问题是http://rcpp-devel.r-forge.r-project.narkive.com/qJMEsvOK/setting-the-r-random-seed-from-rcpp的后续
作为一个学习 Haskell 的 Java 人,我已经习惯了思考一切的新方法,但我花了半天时间尝试用简单的 RNG 实现一些东西,但一无所获。在 Java 中,我可以创建一个静态 RNG 并使用 Cl
我是一名优秀的程序员,十分优秀!