Stata random number generator in C(++)

烈酒焚心 提交于 2019-12-11 03:54:59

问题


I am rewriting (and parallelising) some Stata simulations in C++.

For testing purposes I would like to use Stata's random numbers.

So far my approach has been to generate the numbers in Stata, dump them to a CSV file (100s MB), and then read that in my C++ program. This is slow and inelegant.

Ideally I would like to generate the same uniforms with C++ code.

I have read that Stata uses the KISS algorithm (cite http://blog.stata.com/tag/random-numbers/). I found a C implementation at http://www0.cs.ucl.ac.uk/staff/d.jones/GoodPracticeRNG.pdf . But there are several variations of KISS, and there seems still a little work to make this take a single Stata style seed, and produce uniform numbers (the Stata blog suggests we take the binary expansion of the 32 bit int produced and return 0.binary_expansion).

Has anyone already written C/C++ code that will replicate numbers returned from Stata's uniform()?

Edit: the KISS seed computed using Stata's "set seed" seem to depend on an secret function. Cite = http://hsphsun3.harvard.edu/cgi-bin/lwgate/STATALIST/archives/statalist.1210/date/article-1132.html


回答1:


I eventually discovered it is possible to call C/C++ code from within Stata, by means of a plugin.

In particular it is possible to use C++11's Mersenne Twister RNG from within Stata.

Code (cpprandom.cpp) and a demonstration (cpprandom.do) is on my github account. You need the files stplugin.c and stplugin.h from the Stata plugin website (and a modern C++ compiler, of course).



来源:https://stackoverflow.com/questions/29419165/stata-random-number-generator-in-c

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!