Ошибка: неконстантное выражение не может быть сужено от типа 'npy_intp' до 'int'
Я пытаюсь запустить следующую модель, но она не работает во время компиляции:
import numpy as np
import pymc3 as pm
def sample_data(G=1, K=2):
# mean proportion ([0,1]) for each g
p_g = np.random.beta(2, 2, size=G)
# concentration around each p_g
c_g = np.random.lognormal(mean=0.5, sigma=1, size=G)
# reparameterization for standard Beta(a,b)
a_g = c_g * p_g / np.sqrt(p_g**2 + (1.-p_g)**2)
b_g = c_g*(1.-p_g) / np.sqrt(p_g**2 + (1.-p_g)**2)
# for each p_g, sample K proportions
p_gk = np.random.beta(a_g[:, np.newaxis], b_g[:, np.newaxis], size=(G, K))
return p_gk
# Data size
G = 3
K = 5
# obtain a G x K array of proportions p_gk in [0,1]
data = sample_data(G, K)
with pm.Model() as m:
# Parameters
p_g = pm.Beta('p_g', 1., 1., shape=G)
sd_g = pm.HalfNormal('sd_g', sd=1., shape=G)
# Observed proportions
p_gk = pm.Beta('p_gk', mu=p_g, sd=sd_g, shape=(G, K), observed=data)
trace = pm.sample(2000)
с этими ошибками:
Exception: ("Compilation failed (return status=1):
/Users/mfansler/.theano/compiledir_Darwin-17.6.0-x86_64-i386-64bit-i386-3.6.3-64/tmpr58gulp2/mod.cpp:400:27:
error: non-constant-expression cannot be narrowed from type 'npy_intp' (aka 'long') to 'int' in initializer list [-Wc++11-narrowing].
int init_totals[2] = {V3_n0, V3_n1};.
^~~~~.
/Users/mfansler/.theano/compiledir_Darwin-17.6.0-x86_64-i386-64bit-i386-3.6.3-64/tmpr58gulp2/mod.cpp:400:27:
note: insert an explicit cast to silence this issue.
int init_totals[2] = {V3_n0, V3_n1};.
^~~~~.
static_cast<int>( ).
/Users/mfansler/.theano/compiledir_Darwin-17.6.0-x86_64-i386-64bit-i386-3.6.3-64/tmpr58gulp2/mod.cpp:400:34:
error: non-constant-expression cannot be narrowed from type 'npy_intp' (aka 'long') to 'int' in initializer list [-Wc++11-narrowing].
int init_totals[2] = {V3_n0, V3_n1};.
^~~~~.
/Users/mfansler/.theano/compiledir_Darwin-17.6.0-x86_64-i386-64bit-i386-3.6.3-64/tmpr58gulp2/mod.cpp:400:34:
note: insert an explicit cast to silence this issue.
int init_totals[2] = {V3_n0, V3_n1};.
^~~~~.
static_cast<int>( ).
/Users/mfansler/.theano/compiledir_Darwin-17.6.0-x86_64-i386-64bit-i386-3.6.3-64/tmpr58gulp2/mod.cpp:412:9:
error: non-constant-expression cannot be narrowed from type 'ssize_t' (aka 'long') to 'int' in initializer list [-Wc++11-narrowing].
V3_stride0, V3_stride1, .
^~~~~~~~~~.
/Users/mfansler/.theano/compiledir_Darwin-17.6.0-x86_64-i386-64bit-i386-3.6.3-64/tmpr58gulp2/mod.cpp:412:9:
note: insert an explicit cast to silence this issue.
V3_stride0, V3_stride1, .
^~~~~~~~~~.
static_cast<int>( ).
/Users/mfansler/.theano/compiledir_Darwin-17.6.0-x86_64-i386-64bit-i386-3.6.3-64/tmpr58gulp2/mod.cpp:412:21:
error: non-constant-expression cannot be narrowed from type 'ssize_t' (aka 'long') to 'int' in initializer list [-Wc++11-narrowing].
V3_stride0, V3_stride1, .
^~~~~~~~~~.
/Users/mfansler/.theano/compiledir_Darwin-17.6.0-x86_64-i386-64bit-i386-3.6.3-64/tmpr58gulp2/mod.cpp:412:21:
note: insert an explicit cast to silence this issue.
V3_stride0, V3_stride1, .
^~~~~~~~~~.
static_cast<int>( ).
/Users/mfansler/.theano/compiledir_Darwin-17.6.0-x86_64-i386-64bit-i386-3.6.3-64/tmpr58gulp2/mod.cpp:413:1:
error: non-constant-expression cannot be narrowed from type 'ssize_t' (aka 'long') to 'int' in initializer list [-Wc++11-narrowing].
V1_stride0, V1_stride1.
^~~~~~~~~~.
/Users/mfansler/.theano/compiledir_Darwin-17.6.0-x86_64-i386-64bit-i386-3.6.3-64/tmpr58gulp2/mod.cpp:413:1:
note: insert an explicit cast to silence this issue.
V1_stride0, V1_stride1.
^~~~~~~~~~.
static_cast<int>( ).
/Users/mfansler/.theano/compiledir_Darwin-17.6.0-x86_64-i386-64bit-i386-3.6.3-64/tmpr58gulp2/mod.cpp:413:13:
error: non-constant-expression cannot be narrowed from type 'ssize_t' (aka 'long') to 'int' in initializer list [-Wc++11-narrowing].
V1_stride0, V1_stride1.
^~~~~~~~~~.
/Users/mfansler/.theano/compiledir_Darwin-17.6.0-x86_64-i386-64bit-i386-3.6.3-64/tmpr58gulp2/mod.cpp:413:13:
note: insert an explicit cast to silence this issue.
V1_stride0, V1_stride1.
^~~~~~~~~~.
static_cast<int>( ).
6 errors generated.. ", '[Elemwise{log,no_inplace}(TensorConstant{[[0.297343..76841722]]})]')
Я новичок в PyMC3. Я не вижу этих ошибок при запуске существующих примеров PyMC3. Я подозреваю, что я вижу это, потому что я использую многомерный формат (т.е. (G,K)
), поскольку я не видел других, использующих этот формат (возможно, я навязываю свое знакомство со Стэном).
Как правило, мне сложно понять, как реализовать многоуровневые модели, имеющие несколько измерений.
Любая идея, что вызывает ошибки, которые я вижу?
Версии
- питон 3.6.3
- numpy 1.14.5
- Theano 1.0.2
- pymc3 3.4.1
- Mac OS 10.13.5
Обновить
Я установил те же версии пакета (через conda
) на узле HPC (CentOS 7) и смог запустить модифицированную версию модели, предложенную @colcarroll. Тем не менее, на моей машине с OS X я все еще вижу ошибки компиляции Theano, указанные выше, даже с изменениями модели. Это возможно clang
проблема? Можно ли указать компилятор для использования Theano?
2 ответа
Одним из обходных путей является подавление ошибок компиляции:
import theano
theano.config.gcc.cxxflags = "-Wno-c++11-narrowing"
Степень, в которой эти ошибки имеют значение для правильности программы, неясна. Они не возникают при компиляции в CentOS 7 (даже при явной проверке их с помощью -Wc++11-narrowing
). Результаты выборки на Mac OS X с подавленными ошибками и CentOS без были сопоставимы.
Я все еще предпочел бы увидеть ответ, который объясняет основную проблему.
Да. Вы должны быть более четкими в отношении форм для более высоких измерений. Библиотека делает немного "умным", но если вы предоставите shape
аргумент, он будет использовать это.
Ваш пример здесь синтаксически исправлен настройкой
with pm.Model() as m:
# Parameters
p_g = pm.Beta('p_g', 1., 1., shape=(G, 1))
sd_g = pm.HalfNormal('sd_g', sd=1, shape=(G, 1))
# Observed proportions
p_gk = pm.Beta('p_gk', mu=p_g.dot(np.ones((1,K))), sd=sd_g.dot(np.ones((1, K))), shape=(G, K), observed=data)
trace = pm.sample()
Обратите внимание, что работает m.check_test_point()
покажу что p_gk
имеет 0 вероятностей. Это потому что sd_g
слишком широкий, и PyMC3 пытается инициализировать его на уровне 0,8, что не поддерживается mu, sd
параметризованное бета-распределение.
настройка sd_g = pm.HalfNormal('sd_g', sd=0.1, shape=(G, 1))
позволяет вам также брать образцы из модели, хотя это может быть не так, как вы предполагали ранее!