修訂. | 1d212f2664a62d7de0b1737c0a60848e4fd778bd |
---|---|
大小 | 29,823 bytes |
時間 | 2008-11-13 04:28:13 |
作者 | iselllo |
Log Message | I added a code which now properly calculates the mean coordination number in the system (the previous calculation in
|
#! /usr/bin/env python
import scipy as s
import numpy as n
import pylab as p
#from rpy import r
import distance_calc as d_calc
import igraph as ig
import calc_rad as c_rad
#import g2_calc as g2
from scipy import stats #I need this module for the linear fit
n_part=5000
density=0.01
box_vol=n_part/density
part_diam=1. # particle diameter
part_vol=s.pi/6.*part_diam**3.
tot_vol=n_part*part_vol
cluster_look = 50 # specific particle (and corresponding cluster) you want to track
#Again, I prefer to give the number of particles and the density as input parameters
# and work out the box size accordingly
collisions =1 #whether I should take statistics about the collisions or not.
ini_config=0
fin_config=3000 #for large data post-processing I need to declare an initial and final
#configuration I want to read and post-process
by=1000 #this tells how many configurations there are in the file I am reading
figure=0 #whether I sould print many figures or not
n_config=(fin_config-ini_config)/by # total number of configurations, which are numbered from 0 to n_config-1
my_selection=s.arange(ini_config,fin_config,by)
box_size=(n_part/density)**(1./3.)
print "the box size is, ", box_size
threshold=1.04 #threshold to consider to particles as directly connected
save_size_save =1 #tells whether I want to save the coordinates of a cluster of a specific size
size_save=98
t_step=1. #here meant as the time-separation between adjacent configurations
fold=0
gyration = 1 #parameter controlling whether I want to calculate the radius of gyration
#time=s.linspace(0.,((n_config-1)*t_step),n_config) #I define the time along the simulation
time=p.load("../1/time.dat")
delta_t=(time[2]-time[1])*by
time=time[my_selection] #I adapt the time to the initial and final configuration
p.save("time_red.dat",time)
#some physical parameters of the system
T=0.1 #temperature
beta=0.1 #damping coefficient
v_0=0. #initial particle mean velocity
n_s_ini=2 #element in the time-sequence corresponding
# to the chosen reference time for calculating the velocity autocorrelation
#function
s_ini=(n_s_ini)*t_step #I define a specific time I will need for the calculation
# of the autocorrelation function
#print 'the time chosen for the velocity correlation function is, ', s_ini
#print 'and the corresponding time on the array is, ', time[n_s_ini]
Len=box_size
print 'Len is, ', Len
calculate=1
if (calculate == 1):
# energy_1000=p.load("tot_energy.dat")
# p.plot(energy_1000[:,0], energy_1000[:,1] ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('energy')
# #p.legend(('beta=1e-2,100 part','beta=1e-1, 100 part', 'beta=1e-1, 200 part'))
# p.title('energy evolution')
# p.grid(True)
# p.savefig('energy_2000_particles.pdf')
# p.hold(False)
# print "the std of the energy for a system with 2000 particles is, ", s.std(energy_1000[config_ini:n_config,1])
# print "the mean of the energy for a system with 2000 particles is, ", s.mean(energy_1000[config_ini:n_config,1])
# print "the ratio of the two is,", s.std(energy_1000[config_ini:n_config,1])\
# /s.mean(energy_1000[config_ini:n_config,1])
# print "and the theoretical value is, ", s.sqrt(2./3.)*(1./s.sqrt(n_part))
# tot_config=p.load("total_configuration.dat")
# tot_config=tot_config[(ini_config*n_part*3):(fin_config*n_part*3)]
#I cut the array with the total number
#of configurations for large arrays
# print "the length of tot_config is, ", len(tot_config)
# tot_config=s.reshape(tot_config,(n_config,3*n_part))
# print "tot_config at line 10 is, ", tot_config[10,:]
# #Now I save some "raw" data for detailed analysis
# i=71
# test_arr=tot_config[i,:]
# test_arr=s.reshape(test_arr,(n_part,3))
# p.save("test_71_raw.dat",test_arr)
#Now I want to "fold" particle positions in order to be sure that they are inside
# my box.
#f[:,:,k]=where((Vsum<=V[k+1]) & (Vsum>=V[k]), (V[k+1]-Vsum)/(V[k+1]-V[k]),\
#f[:,:,k] )
#f[:,:,k]=where((Vsum<=V[k]) & (Vsum>=V[k-1]),(Vsum-V[k-1])/(V[k]-V[k-1]),\
#f[:,:,k])
# if (fold ==1):
# #In the case commented below, the box goes from [-L/2,L/2] but that is proba
# #bly not the case in Espresso
# #Len=box_size/2.
# # and then I do the following
# #tot_config=s.where((tot_config>Len) & (s.remainder(tot_config,(2.*Len))<Len),\
# #s.remainder(tot_config,Len),tot_config)
# #tot_config=s.where((tot_config>Len) & (s.remainder(tot_config,(2.*Len))>=Len),\
# #(s.remainder(tot_config,Len)-Len),tot_config)
# #tot_config=s.where((tot_config< -Len) &(s.remainder(tot_config,(-2.*Len))< -Len)\
# #(s.remainder(tot_config,-Len)+Len),tot_config)
# #tot_config=s.where((tot_config< -Len) &(s.remainder(tot_config,(-2.*Len))>=-Len)\
# #s.remainder(tot_config,-Len),tot_config)
# #Now the case when the box is [0,L], so Len is actually the box size
# p.save("tot_config_unfolded.dat",tot_config)
# Len=box_size
# tot_config=s.where(tot_config>Len,s.remainder(tot_config,Len),tot_config)
# tot_config=s.where(tot_config<0.,(s.remainder(tot_config,-Len)+Len),tot_config)
# print "the max of tot_config is", tot_config.max()
# print "the min of tot_config is", tot_config.min()
# p.save("tot_config_my_folding.dat",tot_config)
# x_0=tot_config[0,0] #initial x position of all my particles
# x_col=s.arange(n_part)*3
# print "x_col is, ", x_col
# #Now I plot the motion of particle number 1; I follow the three components
# p.plot(time,tot_config[:,0] ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('x position particle 1 ')
# #p.legend(('beta=1e-2,100 part','beta=1e-1, 100 part', 'beta=1e-1, 200 part'))
# p.title('x_1 vs time')
# p.grid(True)
# p.savefig('x_position_particle_1.pdf')
# p.hold(False)
# # p.save("mean_square_disp.dat", var_x_arr)
# p.plot(time,tot_config[:,1] ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('y position particle 1 ')
# #p.legend(('beta=1e-2,100 part','beta=1e-1, 100 part', 'beta=1e-1, 200 part'))
# p.title('y_1 vs time')
# p.grid(True)
# p.savefig('y_position_particle_1.pdf')
# p.hold(False)
# # p.save("mean_square_disp.dat", var_x_arr)
# p.plot(time,tot_config[:,2] ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('z position particle 1 ')
# #p.legend(('beta=1e-2,100 part','beta=1e-1, 100 part', 'beta=1e-1, 200 part'))
# p.title('z_1 vs time')
# p.grid(True)
# p.savefig('z_position_particle_1.pdf')
# p.hold(False)
# # p.save("mean_square_disp.dat", var_x_arr)
#x_arr=s.zeros((n_part))
#y_arr=s.zeros((n_part))
#z_arr=s.zeros((n_part))
# for i in xrange(0,n_part):
# x_arr[:,i]=tot_config[:,3*i]
# y_arr[:,i]=tot_config[:,(3*i+1)]
# z_arr[:,i]=tot_config[:,(3*i+2)]
# print "the x coordinates are, ", x_arr
# #Now a test: I try to calculate the radius of gyration
# #with a particular distance (suggestion by Yannis)
# mean_x_arr=s.zeros(n_config)
# mean_x_arr=x_arr.mean(axis=1)
# mean_y_arr=s.zeros(n_config)
# mean_y_arr=y_arr.mean(axis=1)
# mean_z_arr=s.zeros(n_config)
# mean_z_arr=z_arr.mean(axis=1)
# var_x_arr2=s.zeros(n_config)
# var_y_arr2=s.zeros(n_config)
# var_y_arr2=s.zeros(n_config)
# for i in xrange(0,n_config):
# for j in xrange(0,n_part):
# var_x_arr2[i]=var_x_arr2[i]+((x_arr[i,j]-mean_x_arr[i])- \
# Len*n.round((x_arr[i,j]-mean_x_arr[i])/Len))**2.
# var_x_arr2=var_x_arr2/n_part
# print 'var_x_arr2 is, ', var_x_arr2
# p.save( "test_config_before_manipulation.dat",x_arr[600,:])
# max_x_dist=s.zeros(n_config)
# #for i in xrange(0, n_config):
# #mean_x_arr[i]=s.mean(x_arr[i,:])
# #var_x_arr[i]=s.var(x_arr[i,:])
# mean_x_arr[:]=s.mean(x_arr,axis=1)
# var_x_arr[:]=s.var(x_arr,axis=1)
# max_x_dist[:]=x_arr.max(axis=1)-x_arr.min(axis=1)
# print "mean_x_arr is, ", mean_x_arr
# print "var_x_arr is, ", var_x_arr
# if (fold==1):
# p.plot(time, max_x_dist ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('x-dimension of aggregate ')
# p.title('x-maximum stretch vs time [folded]')
# p.grid(True)
# p.savefig('max_x_distance_folded.pdf')
# p.hold(False)
# p.save("max_x_distance_folded.dat", max_x_dist)
# elif (fold==0):
# p.plot(time, max_x_dist ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('x-dimension of aggregate ')
# p.title('x-maximum stretch vs time[unfolded]')
# p.grid(True)
# p.savefig('max_x_distance_unfolded.pdf')
# p.hold(False)
# p.save("max_x_distance_unfolded.dat", max_x_dist)
# p.plot(time, var_x_arr ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('mean square displacement ')
# #p.legend(('beta=1e-2,100 part','beta=1e-1, 100 part', 'beta=1e-1, 200 part'))
# p.title('VAR(x) vs time')
# p.grid(True)
# p.savefig('mean_square_disp.pdf')
# p.hold(False)
# p.save("mean_square_disp.dat", var_x_arr)
# p.plot(time, s.sqrt(var_x_arr) ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('mean square displacement ')
# #p.legend(('beta=1e-2,100 part','beta=1e-1, 100 part', 'beta=1e-1, 200 part'))
# p.title('std(x) vs time')
# p.grid(True)
# p.savefig('std_of_x_position.pdf')
# p.hold(False)
# p.save("std_of_x_position.dat", s.sqrt(var_x_arr))
# p.plot(time, mean_x_arr ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('mean x position ')
# #p.legend(('beta=1e-2,100 part','beta=1e-1, 100 part', 'beta=1e-1, 200 part'))
# p.title('mean(x) vs time')
# p.grid(True)
# p.savefig('mean_x_position.pdf')
# p.hold(False)
# p.save("mean_x_position.dat", mean_x_arr)
# #I now calculate the radius of gyration
# if (gyration ==1):
# mean_y_arr=s.zeros(n_config)
# mean_z_arr=s.zeros(n_config)
# var_y_arr[:]=s.var(y_arr,axis=1)
# var_z_arr[:]=s.var(z_arr,axis=1)
# mean_y_arr[:]=s.mean(y_arr,axis=1)
# mean_z_arr[:]=s.mean(z_arr,axis=1)
# r_gyr=s.sqrt(var_x_arr+var_y_arr+var_z_arr)
# p.save("r_gyr_my_post_processing.dat",r_gyr)
# p.plot(time, r_gyr ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('Radius of gyration')
# p.title('Radius of gyration vs time')
# p.grid(True)
# p.savefig('radius of gyration.pdf')
# p.hold(False)
# #Now I want to calculate the distance of the centre of
# #mass of my aggregate from the origin
# dist_origin=s.sqrt(mean_x_arr**2.+mean_y_arr**2.+mean_z_arr**2.)
# p.plot(time, dist_origin ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('Mean distance from origin')
# p.title('Mean distance vs time')
# p.grid(True)
# p.savefig('mean_distance_from_origin.pdf')
# p.hold(False)
# #Now some plots of the std's along the other 2 directions
# p.plot(time, s.sqrt(var_y_arr) ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('mean square displacement ')
# p.title('std(y) vs time')
# p.grid(True)
# p.savefig('std_of_y_position.pdf')
# p.hold(False)
# p.save("std_of_y_position.dat", s.sqrt(var_y_arr))
# p.plot(time, s.sqrt(var_z_arr) ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('mean square displacement ')
# p.title('std(z) vs time')
# p.grid(True)
# p.savefig('std_of_z_position.pdf')
# p.hold(False)
# p.save("std_of_z_position.dat", s.sqrt(var_z_arr))
# p.plot(time, mean_y_arr ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('mean y position ')
# p.title('mean(y) vs time')
# p.grid(True)
# p.savefig('mean_y_position.pdf')
# p.hold(False)
# p.save("mean_y_position.dat", mean_y_arr)
# p.plot(time, mean_z_arr ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('mean z position ')
# p.title('mean(z) vs time')
# p.grid(True)
# p.savefig('mean_z_position.pdf')
# p.hold(False)
# p.save("mean_z_position.dat", mean_z_arr)
# #Now some comparative plots:
# p.plot(time, mean_x_arr,time, mean_y_arr,time, mean_z_arr,linewidth=2.)
# p.xlabel('time')
# p.ylabel('mean position')
# p.legend(('mean x','mean y','mean z',))
# p.title('Evolution mean position')
# p.grid(True)
# p.savefig('mean_position_comparison.pdf')
# p.hold(False)
# p.plot(time, var_x_arr,time, var_y_arr,time, var_z_arr,linewidth=2.)
# p.xlabel('time')
# p.ylabel('mean square displacement')
# p.legend(('var x','var y','var z',))
# p.title('Evolution mean square displacement')
# p.grid(True)
# p.savefig('mean_square_displacement_comparison.pdf')
# p.hold(False)
# p.plot(time, s.sqrt(var_x_arr),time, s.sqrt(var_y_arr),time,\
# s.sqrt(var_z_arr),linewidth=2.)
# p.xlabel('time')
# p.ylabel('std of displacement')
# p.legend(('std x','std y','std z',))
# p.title('Evolution std of displacement')
# p.grid(True)
# p.savefig('std_displacement_comparison.pdf')
# p.hold(False)
# # Now I compare my calculations with the one made
# # by espresso:
# r_gyr_esp=p.load("rgyr.dat")
# p.plot(time, r_gyr, r_gyr_esp[:,0], r_gyr_esp[:,1],linewidth=2.)
# p.xlabel('time')
# p.ylabel('Radius of gyration')
# p.legend(('my_postprocessing','espresso'))
# p.title('Radius of gyration vs time')
# p.grid(True)
# p.savefig('radius_of_gyration_comparison.pdf')
# p.hold(False)
# # Now I do pretty much the same thing with the velocity
# tot_config_vel=p.load("total_configuration_vel.dat")
# if (gyration ==1):
# r_gyr=s.zeros(n_config)
# y_arr=s.zeros((n_config,n_part))
# z_arr=s.zeros((n_config,n_part))
# var_y_arr=s.zeros(n_config)
# var_z_arr=s.zeros(n_config)
# for i in xrange(0,n_part):
# y_arr[:,i]=tot_config[:,(3*i+1)]
# z_arr[:,i]=tot_config[:,(3*i+2)]
# var_y_arr[:]=s.var(y_arr,axis=1)
# var_z_arr[:]=s.var(z_arr,axis=1)
# print "the length of tot_config is, ", len(tot_config)
# tot_config_vel=s.reshape(tot_config_vel,(n_config,3*n_part))
# #print "tot_config at line 10 is, ", tot_config[10,:]
# v_0=tot_config_vel[0,0] #initial x position of all my particles
# v_arr=s.zeros((n_config,n_part))
# print 'OK creating v_arr'
# v_col=s.arange(n_part)*3
# #print "x_col is, ", x_col
# for i in xrange(0,n_part):
# v_arr[:,i]=tot_config_vel[:,3*i]
# mean_v_arr=s.zeros(n_config)
# var_v_arr=s.zeros(n_config)
# # for i in xrange(0, n_config):
# # mean_v_arr[i]=s.mean(v_arr[i,:])
# #var_v_arr[i]=s.var(v_arr[i,:])
# mean_v_arr[:]=s.mean(v_arr,axis=1)
# var_v_arr[:]=s.var(v_arr,axis=1)
# #print "mean_v_arr is, ", mean_v_arr
# #print "var_v_arr is, ", var_v_arr
# #time=s.linspace(0.,(n_config*t_step),n_config)
# p.plot(time, var_v_arr ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('velocity variance')
# #p.legend(('beta=1e-2,100 part','beta=1e-1, 100 part', 'beta=1e-1, 200 part'))
# p.title('VAR(v) vs time')
# p.grid(True)
# p.savefig('velocity_variance.pdf')
# p.hold(False)
# p.save("velocity_variance.dat", var_v_arr)
# #Now I want to calculate the autocorrelation function.
# #First, I need to fix an intial time. I choose something which is well past the
# #ballistic regime
# #Now I start calculating the velocity autocorrelation function
# vel_autocor=s.zeros(n_config)
# for i in xrange(0, n_config):
# vel_autocor[i]=s.mean(v_arr[i]*v_arr[n_s_ini])
# p.plot(time, vel_autocor ,linewidth=2.)
# p.xlabel('time')
# p.ylabel('<v(s)v(t)> ')
# #p.legend(('beta=1e-2,100 part','beta=1e-1, 100 part', 'beta=1e-1, 200 part'))
# p.title('Velocity correlation')
# p.grid(True)
# p.savefig('velocity_correlation_numerics.pdf')
# p.hold(False)
# p.save("velocity_autocorrelation.dat", vel_autocor)
# #Now I try reconstructing the structure of the aggregate.
# #first a test case
# my_conf=tot_config[919,:]
# print 'my_conf is, ', my_conf
# #Now I want to reconstruct the structure of the aggregate in 3D
# # I choose particle zero as a reference
# x_test=s.zeros(3)
# y_test=s.zeros(3)
# z_test=s.zeros(3)
# for i in xrange(0,3):
# x_test[i]=my_conf[3*i]
# y_test[i]=my_conf[3*i+1]
# z_test[i]=my_conf[3*i+2]
# print "x_test is, ", x_test
# print "y_test is, ", y_test
# print "z_test is, ", z_test
# #OK reading the files
# pos_0=s.zeros(3) #I initialized the positions of the three particles
# pos_1=s.zeros(3)
# pos_2=s.zeros(3)
# pos_1[0]=r_ij[0] #Now I have given the x-position of particles 1 and 2 wrt particle 0
# pos_2[0]=r_ij[1]
# #Now I do the same for the y coord!
# count_int=0
# for i in xrange(0,(n_part-1)):
# for j in xrange((i+1),n_part):
# r_ij[count_int]=y_test[i]-y_test[j]
# r_ij[count_int]=r_ij[count_int]-Len*n.round(r_ij[count_int]/Len)
# r_ij[count_int]=-r_ij[count_int] #I have better reverse the signs now.
# print 'i and j are, ', (i+1), (j+1)
# count_int=count_int+1
# print 'r_ij is, ', r_ij
# pos_1[1]=r_ij[0] #Now I have given the x-position of particles 1 and 2 wrt particle 0
# pos_2[1]=r_ij[1]
# #Now I do the same for the z coord!
# count_int=0
# for i in xrange(0,(n_part-1)):
# for j in xrange((i+1),n_part):
# r_ij[count_int]=z_test[i]-z_test[j]
# r_ij[count_int]=r_ij[count_int]-Len*n.round(r_ij[count_int]/Len)
# r_ij[count_int]=-r_ij[count_int] #I have better reverse the signs now.
# print 'i and j are, ', (i+1), (j+1)
# count_int=count_int+1
# print 'r_ij is, ', r_ij
# pos_1[2]=r_ij[0] #Now I have given the x-position of particles 1 and 2 wrt particle 0
# pos_2[2]=r_ij[1]
# print 'pos_0 is,', pos_0
# print 'pos_1 is,', pos_1
# print 'pos_2 is,', pos_2
# #now I can calculate the radius of gyration!
# x_test[0]=pos_0[0]
# x_test[1]=pos_1[0]
# x_test[2]=pos_2[0]
# y_test[0]=pos_0[1]
# y_test[1]=pos_1[1]
# y_test[2]=pos_2[1]
# z_test[0]=pos_0[2]
# z_test[1]=pos_1[2]
# z_test[2]=pos_2[2]
# R_g=s.sqrt(s.var(x_test)+s.var(y_test)+s.var(z_test))
# print "the correct radius of gyration is, ", R_g
#############################################################
#############################################################
#Now I start counting the number of aggregates in each saved configuration
#First I re-build the configuration of the system with the "correct" x_arr,y_arr,z_arr
# I turned the following bit into a comment since I am using the original coord as
#returned by Espresso to start with
# #I re-use the tot_config array for this purpose
# for i in xrange(0,n_part):
# tot_config[:,3*i]=x_arr[:,i]
# tot_config[:,(3*i+1)]=y_arr[:,i]
# tot_config[:,(3*i+2)]=z_arr[:,i]
#p.save("test_calculating_graph.dat",tot_config[71:73,:])
#Now a function to count the collisions
#despite the name, it counts only the number of collisions which took place; it does not know anything
#about the direct calculation of the kernel.
def kernel_calc(A):
d = {}
for r in A:
t = tuple(r)
d[t] = d.get(t,0) + 1
# The dict d now has the counts of the unique rows of A.
B = n.array(d.keys()) # The unique rows of A
C = n.array(d.values()) # The counts of the unique rows
return B,C
#The following function actually takes care of calculating the elements of the kernel matrix from the
#statistics on the collisions.
def kernel_entries_normalized(B2, dist, C2, box_vol, delta_t):
dim=s.shape(B2)
print "dim is, ", dim
n_i=s.zeros(dim[0])
n_j=s.zeros(dim[0])
for i in xrange(len(B2[:,0])):
n_i[i]=len(s.where(dist==B2[i,0])[0])
n_j[i]=len(s.where(dist==B2[i,1])[0])
n_i=n_i/box_vol
n_j=n_j/box_vol
kernel_list=C2/(n_i*n_j*delta_t*box_vol) #I do not get the whole kernel matrix,
#but only the matrix elements for the collisions which actually took place
return kernel_list
#Now a function to calculate the radius of gyration
def calc_radius(x_arr,y_arr,z_arr,Len):
#here x_arr is one-dimensional corresponding to a single configuration
r_0j=s.zeros((len(x_arr)-1))
for j in xrange(1,len(x_arr)): #so, particle zero is now the reference particle
r_0j[j-1]=x_arr[0]-x_arr[j]
r_0j[j-1]=-(r_0j[j-1]-Len*n.round(r_0j[j-1]/Len))
#r_ij[count_int]=-r_ij[count_int] #I have better reverse the signs now.
#print 'i and j are, ', (i+1), (j+1)
#Now I re-define the x_arr in order to be able to take tha variance correctly
x_arr[0]=0.
x_arr[1:n_part]=r_0j
#var_x_arr[:]=s.var(r_0j, axis=1)
var_x_arr=s.var(x_arr)
for j in xrange(1,len(y_arr)): #so, particle zero is now the reference particle
r_0j[j-1]=y_arr[0]-y_arr[j]
r_0j[j-1]=-(r_0j[j-1]-Len*n.round(r_0j[j-1]/Len))
#r_ij[count_int]=-r_ij[count_int] #I have better reverse the signs now.
#print 'i and j are, ', (i+1), (j+1)
#Now I re-define the x_arr in order to be able to take tha variance correctly
y_arr[0]=0.
y_arr[1:n_part]=r_0j
#var_x_arr[:]=s.var(r_0j, axis=1)
var_y_arr=s.var(y_arr)
for j in xrange(1,len(z_arr)): #so, particle zero is now the reference particle
r_0j[j-1]=z_arr[0]-z_arr[j]
r_0j[j-1]=-(r_0j[j-1]-Len*n.round(r_0j[j-1]/Len))
#r_ij[count_int]=-r_ij[count_int] #I have better reverse the signs now.
#print 'i and j are, ', (i+1), (j+1)
#Now I re-define the x_arr in order to be able to take tha variance correctly
z_arr[0]=0.
z_arr[1:n_part]=r_0j
#var_x_arr[:]=s.var(r_0j, axis=1)
var_z_arr=s.var(z_arr)
radius=s.sqrt(var_x_arr+var_y_arr+var_z_arr)
return radius
#Now a function to calculate the positions of the particles in a single cluster
def calc_coord_single(x_arr,y_arr,z_arr,Len):
position_array=s.zeros((len(x_arr),3))
#here x_arr is one-dimensional corresponding to a single configuration
r_0j=s.zeros((len(x_arr)-1))
for j in xrange(1,len(x_arr)): #so, particle zero is now the reference particle
r_0j[j-1]=x_arr[0]-x_arr[j]
r_0j[j-1]=-(r_0j[j-1]-Len*n.round(r_0j[j-1]/Len))
#r_ij[count_int]=-r_ij[count_int] #I have better reverse the signs now.
#print 'i and j are, ', (i+1), (j+1)
#Now I re-define the x_arr in order to be able to take tha variance correctly
x_arr[0]=0.
x_arr[1:n_part]=r_0j
#var_x_arr[:]=s.var(r_0j, axis=1)
#var_x_arr=s.var(x_arr)
position_array[:,0]=x_arr
for j in xrange(1,len(y_arr)): #so, particle zero is now the reference particle
r_0j[j-1]=y_arr[0]-y_arr[j]
r_0j[j-1]=-(r_0j[j-1]-Len*n.round(r_0j[j-1]/Len))
#r_ij[count_int]=-r_ij[count_int] #I have better reverse the signs now.
#print 'i and j are, ', (i+1), (j+1)
#Now I re-define the x_arr in order to be able to take tha variance correctly
y_arr[0]=0.
y_arr[1:n_part]=r_0j
#var_x_arr[:]=s.var(r_0j, axis=1)
#var_y_arr=s.var(y_arr)
position_array[:,1]=y_arr
for j in xrange(1,len(z_arr)): #so, particle zero is now the reference particle
r_0j[j-1]=z_arr[0]-z_arr[j]
r_0j[j-1]=-(r_0j[j-1]-Len*n.round(r_0j[j-1]/Len))
#r_ij[count_int]=-r_ij[count_int] #I have better reverse the signs now.
#print 'i and j are, ', (i+1), (j+1)
#Now I re-define the x_arr in order to be able to take tha variance correctly
z_arr[0]=0.
z_arr[1:n_part]=r_0j
#var_x_arr[:]=s.var(r_0j, axis=1)
#var_z_arr=s.var(z_arr)
position_array[:,2]=z_arr
# radius=s.sqrt(var_x_arr+var_y_arr+var_z_arr)
return position_array
#Now I try loading the R script
#r.source("cluster_functions.R")
#I now calculate the number of clusters in each configuration
n_clusters=s.zeros(n_config)
mean_dist_part_single_cluster=s.zeros(n_config)
overall_coord_number=s.zeros(n_config)
v_aver=s.zeros(n_config)
size_single_cluster=s.zeros(n_config)
r_gyr_single_cluster=s.zeros(n_config)
coord_number_single_cluster=s.zeros(n_config)
correct_coord_number=s.zeros(n_config)
# min_dist=s.zeros(n_config)
dist_mat=s.zeros((n_part,n_part))
for i in xrange(0,n_config):
read_pos="../1/read_pos_%1d"%my_selection[i]
print "read_pos is, ", read_pos
#cluster_name="cluster_dist%05d"%my_selection[i]
test_arr=p.load(read_pos)
#test_arr=s.reshape(test_arr,(n_part,3))
# if (i==14):
# p.save("test_14.dat",test_arr)
#dist_mat=r.distance(test_arr)
x_pos=test_arr[:,0]
y_pos=test_arr[:,1]
z_pos=test_arr[:,2]
dist_mat=d_calc.distance_calc(x_pos,y_pos,z_pos, box_size)
# if (i==71):
# p.save("distance_matrix_71.dat",dist_mat)
# p.save("x_pos_71.dat",x_pos)
#clust_struc= (r.mycluster2(dist_mat,threshold)) #a cumbersome
#way to make sure I have an array even when clust_struct is a single
#number (i.e. I have only a cluster)
# print'clust_struct is, ', clust_struc
# n_clusters[i]=r.mycluster(dist_mat,threshold)
# > Lorenzo,
# > > if your graph is `g` then
# > > degree(g)
# > > gives the number of direct neighbors of each vertex (or particle).
# Just to translate it to Python: g.degree() gives the number of direct
# neighbors of each vertex. If your graph is directed, you may only want
# to count only the outgoing or the incoming edges: g.degree(igraph.OUT)
# or g.degree(igraph.IN)
# > > So
# > > mean(degree(g))
# In Python: sum(g.degree()) / float(g.vcount())
# > > (and to turn an adjacency matrix `am` into an igraph object `g` just
# > > use "g <- graph.adjacency(am)")
# In Python: g = Graph.Adjacency(matrix)
# e.g. g = Graph.Adjacency([[0,1,0],[1,0,1],[0,1,0]])
cluster_obj=ig.Graph.Adjacency((dist_mat <= threshold).tolist(),\
ig.ADJ_UNDIRECTED)
# Now I start the calculation of the coordination number
coord_list=cluster_obj.degree() #Now I have a list with the number of 1rst
#neughbors of each particle
#coord_arr=s.zeros(len(coord_list))
# Lorenzo, i'm not sure why you would like to use adjacency matrices,
# igraph graphs are much better in most cases, espacially if the graph
# is large. Here is how to calculate the mean degree per connected
# component in R, assuming your graph is 'g':
# comps <- decompose.graph(g)
# sapply(comps, function(x) mean(degree(x)))
# Gabor
# In Python: starting with your graph, you obtain a VertexClustering
# object somehow (I assume you already have it). Now, cl[0] gives the
# vertex IDs in the first component, cl[1] gives the vertex IDs in the
# second and so on. If the original graph is called g, then
# g.degree(cl[0]) gives the degrees of those vertices, so the average
# degrees in each connected component are as follows (I'm simply
# iterating over the components in a for loop):
# cl=g.components()
# for idx, component in enumerate(cl):
# degrees = g.degree(component)
# print "Component #%d: %s" % (idx, sum(degrees)/float(len(degrees)))
# -- T.
#I need to get an array out of the list of the list of 1st neighbors
#for l in xrange(len(coord_list)):
#coord_arr[l]=coord_list[l]
#print "coord_list is, ", coord_list
coord_arr=s.asarray(coord_list)-2 #Important! I need this correction!
cluster_obj.simplify()
clustering=cluster_obj.clusters()
#n_clusters[i]=p.load("nc_temp.dat")
n_clusters[i]=len(clustering)
print "the total number of clusters and my_config are,", n_clusters[i], my_selection[i]
my_cluster=clustering.sizes()
#Now I create the array which will contain all the cluster sizes by changing the previous
#list into a scipy array.
my_cluster=s.asarray(my_cluster)
#Now I re-organize the particles in my configuration
#by putting together those which are in the same
#cluster
clust_struc=clustering.membership
clust_struc=s.asarray(clust_struc)
#if (i==0):
# print "clust_struc[4727] and my_selection[i] are, ", clust_struc[4727], my_selection[i]
# print "clust_struc[29] and my_selection[i] are, ", clust_struc[29], my_selection[i]
part_in_clust=s.argsort(clust_struc)
if (i ==0 ):
#cluster_record_old=part_in_clust
part_in_clust_old=s.copy(part_in_clust)
len_my_cluster_old=len(my_cluster)
my_cluster_old=s.copy(my_cluster)
coord_number_dist=s.zeros(len(my_cluster)) #this will contain the distribution of
#the coordination numbers
my_sum=s.cumsum(my_cluster)
f=s.arange(1) #simply 0 but as an array!
my_lim=s.concatenate((f,my_sum))
if (i==0):
my_lim_old=my_lim
for m in xrange(0,len(my_cluster)):
#if (abs(my_lim[m]-my_lim[m+1])<2):
# r_gyr_dist[m]=0.0 # r_gyr_dist has already been initialized to zero!
if (abs(my_lim[m]-my_lim[m+1])>=2):
x_pos2=x_pos[part_in_clust[my_lim[m]:my_lim[m+1]]]
y_pos2=y_pos[part_in_clust[my_lim[m]:my_lim[m+1]]]
z_pos2=z_pos[part_in_clust[my_lim[m]:my_lim[m+1]]]
coord_clust=coord_arr[part_in_clust[my_lim[m]:my_lim[m+1]]]
#print "coord_clust is, ", coord_clust
coord_number_dist[m]=s.mean(coord_clust)
correct_coord_number[i]=coord_number_dist.mean() #i.e. : associate to each cluster a coordination number and
#then take the average on the set of coordination numbers
# (one per cluster)
p.save("coordination_numbers_averaged.dat", correct_coord_number )
print "So far so good"