forked from Steelangel/CarBoNpy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCarBoN_plot.py
122 lines (100 loc) · 4.36 KB
/
CarBoN_plot.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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
#!/usr/bin/python
#title :CarBon_plot.py
#description :Plots Saved CarBoN Data
#author :Ethan Deneault1
#date :20161220
#version :0.1
#usage :python CarBoN_plot.py
#notes :
#python_version :3.5.1
#=============================================================================
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.ticker as ticker
import datainput
#import matplotlib._color_data
#import matplotlib.cm as cmx
#from sys import exit
file_format, species_file, reactions_file, output_file, model_type, density, Tinit, start_time, end_time, outfile = datainput.settings()
##############################################################################
# The following is used to specify the data file to be plotted
# write its path as "output/filename.dat"
##############################################################################
#file = str('' + outfile + '')
infile = np.load( outfile )
##############################################################################
# The following will take care of the plot's setup
##############################################################################
totmass = 1.11 ### Total of C+O+Si
plottitle = 'C/O = 1/100 C/Si = 1/10'
print(infile.files)
y = infile['y'] / totmass
speciesidx = infile['speciesidx'][()] #extracts dictionary from array?
speciesmass = infile['speciesmass'][()]
abundance = infile['abundance']
time = 365.25 * (infile['time']) #-(99/365.25))
#print(speciesidx)
#print(y[-1,11])
##############################################################################
# The following tests for mass conservation. Total must = 1.
##############################################################################
total = 0
for name, index in speciesidx.items():
if index != 99:
total += speciesmass[name] * y[:,index]
#exit()
##############################################################################
# The following is the figure Plotting
##############################################################################
fig = plt.figure(figsize=(10, 10))
ax1 = fig.add_subplot(111)
ax1.plot(time, y[:, 1], label = '$\mathrm{C}$', linewidth = 2.0)
ax1.plot(time, y[:, 2], '-.', label = '$\mathrm{O}$', linewidth = 2.0)
ax1.plot(time, y[:, 3], label = '$\mathrm{C_2}$', linewidth = 2.0)
ax1.plot(time, y[:, 4], label = '$\mathrm{CO}$', linewidth = 2.0)
ax1.plot(time, y[:, 5], '--', label = '$\mathrm{C_3}$', linewidth = 2.0)
#ax1.plot(time, y[:, 13], '--', label = '$\mathrm{SiO}$', linewidth = 2.0)
#ax1.plot(time, y[:, 15], '-.', label = '$\mathrm{(SiC)_2}$', linewidth = 2.0)
#ax1.plot(time, y[:, 16], '-.', label = '$\mathrm{(SiO)_2}$', linewidth = 2.0)
#ax1.plot(time,total,label='Test',color='black')
#for name,index in speciesidx.items():
# if index in [4,5,6,7]:
# ax1.plot(time,y[:,index],label=name,linewidth=2.0,color=colors[index-4])
# if index in [12,13,14,15,16]:
# ax1.plot(time,y[:,index],'--',label=name,linewidth=2.0,color=colors[index-12])
# if index in [12]:
# ax1.plot(time,y[:,index],':',label=name,linewidth=2.0,color=colors[index-12])
# if index in [17,18,19,20]:
# ax1.plot(time,y[:,index],ls='dashdot',label=name,linewidth=2.0)
plt.subplots_adjust(left = 0.1, right = 0.84,
top = 0.9, bottom = 0.1, wspace = 0.5)
ax1.set_ylim([1e-26, 1e2])
#ax1.set_xlim([100,300])
ax1.set_xlim([69, 1760])
ax1.set_yscale('log')
ax1.set_xlabel('t-t0 (days)')
ax1.xaxis.set_major_locator(ticker.MultipleLocator(100))
ax1.set_ylabel('Abundance')
ax1.legend(loc='center left', bbox_to_anchor = (1, 0.5))
ax1.set_title(plottitle)
plt.show()
####################################################
#ax1.plot(time,total,label='Test')
#ax1.set_ylim([5e-11,2.01e10])
#ax1.set_xlim([73,1826])
#ax1.set_xlim([550,600])
#ax1.set_yscale('log')
#ax1.set_xlabel('Time (days)')
#ax1.set_ylabel('Abundance')
#ax1.legend(loc='center left', bbox_to_anchor=(1, 0.5))
#
#ax2=fig.add_subplot(122)
#labels = [' ','O','C','C2','C3','C4','C5','C6','CO',' ']
#ax2.set_xticklabels(labels)
#ax2.plot(abundance,marker="o",linestyle="None")
#ax2.set_xlim([-1,numspecies])
#ax2.set_yscale('log')
#ax2.set_title('Final Abundance')
#ax2.set_ylabel('Abundance')
#plt.subplots_adjust(left=0.1, right=0.94, top=0.9, bottom=0.1,wspace=0.5)
#plt.show()