-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathperf_pysal.py
57 lines (47 loc) · 1.61 KB
/
perf_pysal.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
import sys
import libpysal as lps
import numpy as np
import geopandas as gpd
import esda
import time
"""
Usage:
python3 perf_pysal.py FILE_PATH VARIABLE_NAME PERMUTATIONS CPU_THREADS
python3 perf_pysal.py ./data/natregimes.shp HR60 999 1
"""
data_path = sys.argv[1]
var_name = sys.argv[2]
perms = int(sys.argv[3])
cpu_threads = int(sys.argv[4])
np.random.seed(12345)
# prepare the data and weights
gdf = gpd.read_file(data_path)
x = gdf[var_name]
try:
import numba
print(f"Numba version installed: {numba.__version__}")
except:
print("Numba not installed")
w_start_time = time.time()
if data_path == './data/Chicago_parcels_points.shp':
w = lps.weights.KNN.from_dataframe(gdf, k=10)
#w = lps.weights.KNN.from_shapefile(data_path, k=10)
w_run_time1 = time.time() - w_start_time
else:
w = lps.weights.Queen.from_dataframe(gdf)
#w = lps.weights.Queen.from_shapefile(data_path)
w_run_time1 = time.time() - w_start_time
# remove islands
if len(w.islands) > 0:
print("Remove islands...")
df_noi = gdf[~gdf.index.isin(w.islands)]
w = lps.weights.w_subset(w, df_noi.index.tolist())
x = df_noi[var_name]
w.transform = 'r'
w_run_time2 = time.time() - w_start_time
print("Weights creation took {0} seconds, with transform and remove islands it took {1} seconds".format(w_run_time1, w_run_time2))
# function to execute and time
start_time = time.time()
li = esda.moran.Moran_Local(x, w, permutations=perms, n_jobs=cpu_threads, keep_simulations=False)
run_time = time.time() - start_time
print("{0} {1} {2}: {3} seconds".format(data_path, perms, cpu_threads, run_time))