aboutsummaryrefslogtreecommitdiffstats
path: root/mass_profile
diff options
context:
space:
mode:
authorAaron LI <aaronly.me@gmail.com>2016-06-07 19:51:40 +0800
committerAaron LI <aaronly.me@gmail.com>2016-06-07 19:51:40 +0800
commit43692e5f1d9ac09eb67bd1555b71f24ec8d86bf4 (patch)
treee63872222e9c0342e23900d9f36c2c619e4b20ee /mass_profile
parent78fbb8a3027d1e3476ab31e99c3d1c7cb698e0bf (diff)
downloadchandra-acis-analysis-43692e5f1d9ac09eb67bd1555b71f24ec8d86bf4.tar.bz2
Add previous uncommited analyze_lxfx.py
Diffstat (limited to 'mass_profile')
-rwxr-xr-xmass_profile/analyze_lxfx.py83
1 files changed, 54 insertions, 29 deletions
diff --git a/mass_profile/analyze_lxfx.py b/mass_profile/analyze_lxfx.py
index c3d4030..62859ff 100755
--- a/mass_profile/analyze_lxfx.py
+++ b/mass_profile/analyze_lxfx.py
@@ -1,32 +1,57 @@
-#!/usr/bin/env python
+#!/usr/bin/env python3
+#
+# Calculate the mean and standard deviation of the (Monte Carlo)
+# Lx and Fx data
+#
+# Junhua GU
+# Weitian LI
+# 2016-06-07
+#
import sys
-import math
-import numpy
-
-lx1_array=[]
-lx2_array=[]
-lx3_array=[]
-for i in open('summary_lx.dat'):
- x1,x2,x3=i.split()
- x1=float(x1)
- x2=float(x2)
- x3=float(x3)
- lx1_array.append(x1)
- lx2_array.append(x2)
- lx3_array.append(x3)
-
-
-lx1_array=numpy.array(lx1_array)
-lx2_array=numpy.array(lx2_array)
-lx3_array=numpy.array(lx3_array)
-
-
-f=open('lx_result.txt','w')
-f.write("Lx(bolo)= %4.2E +/- %4.2E erg/s\n"%(lx1_array[0],lx1_array.std()))
-print("Lx(bolo)= %4.2E +/- %4.2E erg/s"%(lx1_array[0],lx1_array.std()))
-f.write("Lx(0.7-7)= %4.2E +/- %4.2E erg/s\n"%(lx2_array[0],lx2_array.std()))
-print("Lx(0.7-7)= %4.2E +/- %4.2E erg/s"%(lx2_array[0],lx2_array.std()))
-f.write("Lx(0.1-2.4)= %4.2E +/- %4.2E erg/s\n"%(lx3_array[0],lx3_array.std()))
-print("Lx(0.1-2.4)= %4.2E +/- %4.2E erg/s"%(lx3_array[0],lx3_array.std()))
+import argparse
+import numpy as np
+
+def read_bands(bands):
+ """
+ Read energy bands list, each band per line.
+ """
+ bands = map(str.split, open(bands).readlines())
+ bands = ["-".join(b) for b in bands]
+ return bands
+
+
+def output(name, bands, means, sigmas, outfile=sys.stdout):
+ if outfile is not sys.stdout:
+ outfile = open(outfile, "w")
+ for b, m, s in zip(bands, means, sigmas):
+ print("%s(%s)= %4.2E +/- %4.2E erg/s" % (name, b, m, s),
+ file=outfile)
+ if outfile is not sys.stdout:
+ outfile.close()
+
+
+def main():
+ parser = argparse.ArgumentParser(
+ description="Analyze Lx/Fx results")
+ parser.add_argument("name", help="Lx or Fx")
+ parser.add_argument("infile", help="input data file")
+ parser.add_argument("outfile", help="output results file")
+ parser.add_argument("bands", help="energy bands of the input data columns")
+ args = parser.parse_args()
+
+ data = np.loadtxt(args.infile)
+ bands = read_bands(args.bands)
+ if len(bands) != data.shape[1]:
+ raise ValueError("number of energy bands != number of data columns")
+
+ means = np.mean(data, axis=0)
+ sigmas = np.std(data, axis=0)
+ output(name=args.name, bands=bands, means=means, sigmas=sigmas)
+ output(name=args.name, bands=bands, means=means, sigmas=sigmas,
+ outfile=args.outfile)
+
+
+if __name__ == "__main__":
+ main()