Penguin Data-set Convex HullΒΆ
Data is from the PalmerPenguin dataset created by Dr. Kristen Gorman and the Palmer Station, Antarctica LTER.
data:image/s3,"s3://crabby-images/c5808/c58086444762dc74b547de6a3b1dd5e734d7c103" alt="../../_images/convex_hull_3.png"
import csv
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.patches as mpatches
import s3dlib.surface as s3d
#.. Penguin Data-set Convex Hull
# 1. Define data to examine .........................................
with open('data/palmerpenguins.csv') as csv_file:
csv_reader = csv.reader(csv_file, delimiter=',')
line_count = 0
all_data = []
for row in csv_reader:
line_count += 1
if line_count ==1 :
heading = row
else: all_data.append(row)
heading = heading[2:6]
nptemp = np.array(all_data)[:,2:6].T.astype(float)
pgtype = np.array(all_data)[:,0]
x,y,z = 2,0,3 #.. fields to be plotted
X = np.array( [ nptemp[x], nptemp[y], nptemp[z] ] )
# 2 & 3. Setup surfaces and plot ....................................
rgbC = [ [0.988,0.471,0.031], [0.549,0.000,0.925], [0.063,0.478,0.471] ]
names = [ 'Adelie', 'Chinstrap', 'Gentoo' ]
handles = [None]*3
fig = plt.figure(figsize=(6, 4.5))
ax = plt.axes(projection='3d')
ax.set( xlim=(170,240), ylim=(35,65),zlim=(2500,6500),
xlabel=heading[x], ylabel=heading[y], zlabel=heading[z] )
for i in range(3) :
data = X.T[pgtype == names[i]]
colors = [rgbC[i]]
dataT = data.T
handles[i] = mpatches.Patch(color=rgbC[i], label=names[i])
# .........................................
surface = s3d.Surface3DCollection.chull(data,color=rgbC[i])
surface.evert().triangulate(4)
surface.shade()
# .........................................
ax.add_collection3d(surface)
ax.legend(handles=handles)
ax.set_title('Palmer Penguins', fontsize='x-large' )
ax.view_init(elev=25, azim=125)
fig.tight_layout()
plt.show()