import os
import p4.func
import pickle
import math
import numpy
import glob
from p4.p4exceptions import P4Error
[docs]
class McmcCheckPointReader(object):
"""Read in and display mcmc_checkPoint files.
Three options--
To read in a specific checkpoint file, specify the file name by
fName=whatever
To read in the most recent (by os.path.getmtime()) checkpoint
file, say last=True
If you specify neither of the above, it will read in all the
checkPoint files that it finds.
Where it looks is determined by theGlob, which by default is '*',
ie everything in the current directory. If you want to look
somewhere else, you can specify eg::
theGlob='SomeWhereElse/*'
or, if it is unambiguous, just::
theGlob='S*/*'
So you might say::
cpr = McmcCheckPointReader(theGlob='*_0.*')
to get all the checkpoints from the first run, run 0. Then, you
can tell the cpr object to do various things. Eg::
cpr.writeProposalAcceptances()
But perhaps the most powerful thing about it is that it allows
easy access to the checkpointed Mcmc objects, in the list mm. Eg
to get the first one, ask for::
m = cpr.mm[0]
and m is an Mcmc object, complete with all its records of
proposals and acceptances and so on. And the TreePartitions
object. No data, tho, of course.
(Sorry! -- Lazy documentation. See the source code for more that it can do.)
"""
def __init__(self, fName=None, theGlob='*', last=False, verbose=True):
self.mm = []
if not fName:
#fList = [fName for fName in os.listdir(os.getcwd()) if fName.startswith("mcmc_checkPoint")]
#fList = glob.glob(theGlob)
# print "Full glob = %s" % fList
fList = [fName for fName in glob.glob(theGlob) if
os.path.basename(fName).startswith("mcmc_checkPoint")]
# print fList
if not fList:
raise P4Error("No checkpoints found in this directory.")
if last:
# Find the most recent
mostRecent = os.path.getmtime(fList[0])
mostRecentFileName = fList[0]
if len(fList) > 1:
for fName in fList[1:]:
mtime = os.path.getmtime(fName)
if mtime > mostRecent:
mostRecent = mtime
mostRecentFileName = fName
f = open(mostRecentFileName, 'rb')
m = pickle.load(f)
f.close()
self.mm.append(m)
else:
# get all the files
for fName in fList:
f = open(fName, 'rb')
m = pickle.load(f)
f.close()
self.mm.append(m)
self.mm = p4.func.sortListOfObjectsOn2Attributes(
self.mm, "gen", 'runNum')
else:
# get the file by name
f = open(fName, 'rb')
m = pickle.load(f)
f.close()
self.mm.append(m)
if verbose:
self.dump()
[docs]
def read(self, fName):
f = open(fName, 'rb')
m = pickle.load(f)
f.close()
self.mm.append(m)
[docs]
def dump(self, extras=False):
print("McmcCheckPoints (%i checkPoints read)" % len(self.mm))
if extras:
print("%12s %12s %12s %12s %12s %12s %12s" % (
" ", "index", "run", "gen+1", "cpInterval", "sampInterv", "nSamps"))
print("%12s %12s %12s %12s %12s %12s %12s" % (
" ", "-----", "---", "-----", "----------", "----------", "------"))
for i in range(len(self.mm)):
m = self.mm[i]
assert m.checkPointInterval % m.sampleInterval == 0
if m.simTemp:
thisNSamps = m.treePartitions.nTrees
else:
thisNSamps = int(m.checkPointInterval / m.sampleInterval)
assert thisNSamps == m.treePartitions.nTrees
# print " %2i run %2i, gen+1 %11i" % (i, m.runNum, m.gen+1)
print("%12s %12s %12s %12s %12s %12s %12s" % (
" ", i, m.runNum, m.gen + 1, m.checkPointInterval, m.sampleInterval, thisNSamps))
else:
print("%12s %12s %12s %12s %12s" % (
" ", "index", "run", "gen+1", "nSamps"))
print("%12s %12s %12s %12s %12s" % (
" ", "-----", "---", "-----", "------"))
for i in range(len(self.mm)):
m = self.mm[i]
if hasattr(m, "simTemp") and m.simTemp:
thisNSamps = m.treePartitions.nTrees
else:
# assert m.checkPointInterval % m.sampleInterval == 0 # needed?
thisNSamps = int(m.checkPointInterval / m.sampleInterval)
assert thisNSamps == m.treePartitions.nTrees
# print(f"got thisNSamps {thisNSamps}, nTrees {m.treePartitions.nTrees}")
# print " %2i run %2i, gen+1 %11i" % (i, m.runNum, m.gen+1)
print("%12s %12s %12s %12s %12s" % (
" ", i, m.runNum, m.gen + 1, thisNSamps))
[docs]
def compareSplits(self, mNum1, mNum2, verbose=True, minimumProportion=0.1):
"""Do the TreePartitions.compareSplits() method between two checkpoints
Args:
mNum1, mNum2 (int): indices to Mcmc checkpoints in self
Returns:
a tuple of asdoss and the maximum difference in split supports
"""
# Should we be only looking at splits within the 95% ci of the topologies?
m1 = self.mm[mNum1]
m2 = self.mm[mNum2]
tp1 = m1.treePartitions
tp2 = m2.treePartitions
if verbose:
print("\nMcmcCheckPointReader.compareSplits(%i,%i)" % (mNum1, mNum2))
print("%12s %12s %12s %12s %12s" % ("mNum", "runNum", "start", "gen+1", "nTrees"))
for i in range(5):
print(" ---------", end=' ')
print()
for mNum in [mNum1, mNum2]:
print(" %10i " % mNum, end=' ')
m = self.mm[mNum]
print(" %10i " % m.runNum, end=' ')
print(" %10i " % (m.startMinusOne + 1), end=' ')
print(" %10i " % (m.gen + 1), end=' ')
# for i in m.splitCompares:
# print i
print(" %10i " % m.treePartitions.nTrees)
asdos, maxDiff, meanDiff = p4.func._compareSplitsBetweenTwoTreePartitions(
tp1, tp2, minimumProportion, verbose=verbose)
asdos2, maxDiff2, meanDiff2= p4.func._compareSplitsBetweenTwoTreePartitions(
tp2, tp1, minimumProportion, verbose=False)
if math.fabs(asdos - asdos2) > 0.000001:
print("Reciprocal assdos differs: %s %s" % (asdos, asdos2))
if asdos == None and verbose:
print("No splits > %s" % minimumProportion)
return asdos, maxDiff, meanDiff
[docs]
def compareSplitsAll(self, precision=3, linewidth=120):
"""Do func.compareSplitsBetweenTreePartitions() for all pairs
Output is verbose. Shows
- average standard deviation of split frequencies (or supports), like MrBayes
- maximum difference between split supports from each pair of checkpoints, like PhyloBayes
Returns:
None
"""
tpp = [m.treePartitions for m in self.mm]
p4.func.compareSplitsBetweenTreePartitions(tpp, precision=precision, linewidth=linewidth)
[docs]
def writeProposalAcceptances(self):
for m in self.mm:
m.writeProposalAcceptances()
[docs]
def writeSwapMatrices(self):
for m in self.mm:
if m.nChains > 1:
m.writeSwapMatrix()
[docs]
def writeSwapVectors(self):
for m in self.mm:
if m.nChains > 1:
m.writeSwapVector()
[docs]
def writeProposalProbs(self):
for m in self.mm:
m.writeProposalProbs()