我正在试着做一个histogram of Poisson random generated variables using Python and C。我想使用Python for plotting和C for generating. This resulted in the following to codes
Python:
import ctypes
import numpy as np
import matplotlib.pyplot as plt
import time
lam = 5.0
n = 1000000
def generate_poisson(lam, n):
array = np.zeros(n, dtype= np.int)
f = ctypes.CDLL('./generate_poisson.so').gen_poisson
f(ctypes.c_double(lam), ctypes.c_int(n), ctypes.c_void_p(array.ctypes.data))
return array
start_time = time.time()
array = generate_poisson(lam,n)
print(time.time() - start_time)
plt.hist(array, bins = [0,1,2,3,4,5,6,7,8,9,10,11,12], density = True)
plt.savefig('fig.png')
print(array)C:
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <math.h>
double get_random() { return ((double)rand() / (double)RAND_MAX); }
int poisson_random(double lam){
int X;
double prod, U, explam;
explam = exp(-lam);
X = 0;
prod = 1.0;
while (1){
U = get_random();
prod *= U;
if (prod > explam){
X+=1;
}
else {
return X;
}
}
}
void gen_poisson(double lam, int n, void * arrayv)
{
int * array = (int *) arrayv;
int index = 0;
srand(time(NULL));
for (int i =0; i<n; i++, index++){
//printf("before %d\n", array[i]);
array[index++] = poisson_random(lam);
//printf("after %d\n", array[i]);
}
}理解这种方法工作的原因,或者至少它看起来工作正常的问题,出现在gen_poisson()中的for循环中。以某种方式使用array[index++]而不是array[index]会得到正确的直方图。但我真的不明白为什么一定要这样。当for循环更改为
for (int i =0; i<2*n; i++){
//printf("before %d\n", array[i]);
array[i++] = poisson_random(lam);
//printf("after %d\n", array[i]);
}有人能解释一下为什么在这种情况下循环必须递增两次吗?我刚开始用C编程,虽然我有一些Python的经验。因此,假设罪魁祸首是我对C的缺乏理解。
发布于 2020-10-26 03:54:04
将gen_poisson更改为:
void gen_poisson(double lam, int n, void * arrayv)
{
long * array = (long *) arrayv;
srand(time(NULL));
for (int i =0; i<n; i++){
array[i] = poisson_random(lam);
}
}解决了问题。正如将数组声明为int *而不是long *时所指出的问题一样。
https://stackoverflow.com/questions/64524071
复制相似问题