初めてのポスターで、私の問題を完全に解決したものは見つかりませんでした。PythonのCount-in-Cellsを使用した3Dスターフィールドでのクラスタリング
私はマスタープロジェクトの銀河植民地化のためのシミュレーションに取り組んでいます。私がしようとしていることは、シミュレーションが終了した後に残された無彩色の星の空白を見て、過去の統計的な変動のクラスタリングの動作があるかどうかを調べることです。モンテカルロの数値問題であるので、相関関数は実際には適切ではないので、銀河団を見るために通常使用されるcount-in-cells法を使用しています。
だから私は私がやりたいことはボックス内の星の数をカウントし、平均は可能との統計を何をすべきかを比較するために様々なサイズの使用ボックスでcartesians
data = np.genfromtxt('counts.csv') # positions of uncolonsed stars
x = data[:,0]
y = data[:,1]
z = data[:,2]
で働いています結果。
方向は、バブルプロットhereなどの3Dヒストグラムを見ています。私はこれを試してみて、それは私のすべてのデータをビニングしているようには見えません。なぜキューブの「フロア」に「バブル」がありますか?しかし、屋根の多くは何もありません:
あなたがプロットされた生のスターフィールドを見るとこれは明らかに間違っている:
高いz値のビンが任意のデータを保持していないように見えます。これはおそらくかなり簡単な問題ですが、私は私よりもPythonで優れた新鮮な目と心が必要です。
これはどのように修正することができますか?また、1箱あたりのポイント数、つまりビンごとの数を数える方法を探したいと思います。
私は少し暗いですが、申し訳ありませんが、私は細かい仲間が私を提供することができますあなたの助けに感謝します。
ありがとうございました!
リンクされた答えのコードは、多分私はちょうど彼らがやろうとしているのか理解していない、私には過度に複雑に見えます。任意の次元のヒストグラムを計算するには 'numpy.histogramdd'を使います。 – Goyo
サンプル上でKDEを実行し、ボリュームレンダリングで可視化することができます。たとえば、[here](http://stackoverflow.com/questions/25286811/how-to-plot-a-3d-density-map-in-python-with-matplotlib)を参照してください。 –
KDEの治療は本当に良いようです、Vlasに感謝します。私に残されているのは、1ビンあたりのポイント数をカウントすることだけです。なぜscipy.statsに混乱した。binned_statistic_ddに次のようなエラーが出ています:TypeError:binned_statistic_dd()は少なくとも2つの引数をとります(5が与えられます) – Skippeh