當前位置: 首頁>>代碼示例>>Python>>正文


Python BigWigFile.get_as_array方法代碼示例

本文整理匯總了Python中bx.bbi.bigwig_file.BigWigFile.get_as_array方法的典型用法代碼示例。如果您正苦於以下問題:Python BigWigFile.get_as_array方法的具體用法?Python BigWigFile.get_as_array怎麽用?Python BigWigFile.get_as_array使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在bx.bbi.bigwig_file.BigWigFile的用法示例。


在下文中一共展示了BigWigFile.get_as_array方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: main

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
def main():
	usage="%prog [options]"
	parser = OptionParser(usage,version="%prog " + __version__)
	
	parser.add_option("-i","--bwfile1",action="store",type="string",dest="BigWig_File1",help="BigWig files")
	parser.add_option("-j","--bwfile2",action="store",type="string",dest="BigWig_File2",help="BigWig files")
	parser.add_option("-a","--action",action="store",type="string",dest="action",help='After pairwise align two bigwig files, perform the follow actions (Only select one keyword):"Add" = add signals. "Average" = average signals. "Division"= divide bigwig2 from bigwig1. Add 1 to both bigwig. "Max" = pick the signal that is larger. "Min" = pick the signal that is smaller. "Product" = multiply signals. "Subtract" = subtract signals in 2nd bigwig file from the corresponiding ones in the 1st bigwig file. "geometricMean" = take the geometric mean of signals.')
	parser.add_option("-o","--output",action="store",type="string",dest="output_wig",help="Output wig file")
	parser.add_option("-s","--chromSize",action="store",type="string",dest="chromSize",help="Chromosome size file. Tab or space separated text file with 2 columns: first column is chromosome name, second column is size of the chromosome.")
	parser.add_option("-c","--chunk",action="store",type="int",dest="chunk_size",default=100000,help="Chromosome chunk size. Each chomosome will be cut into samll chunks of this size. Decrease chunk size will save more RAM. default=%default (bp)")
	(options,args)=parser.parse_args()
	
	if not (options.BigWig_File1 and options.BigWig_File2  and options.output_wig and options.chromSize):
		parser.print_help()
		sys.exit(0)
	OUT=open(options.output_wig,'w')
	bw1 = BigWigFile( file=open(options.BigWig_File1) )
	bw2 = BigWigFile( file=open(options.BigWig_File2) )
	chrom_sizes = load_chromsize(options.chromSize)
	for chr_name, chr_size in chrom_sizes.items():		#iterate each chrom
		print >>sys.stderr, "Processing " + chr_name + " ..."
		OUT.write('variableStep chrom='+chr_name+'\n')
		for interval in BED.tillingBed(chrName = chr_name,chrSize = chr_size,stepSize = options.chunk_size):
			coord = interval[1]
			bw_signal1 = bw1.get_as_array(chr_name,interval[1],interval[2])
			bw_signal2 = bw2.get_as_array(chr_name,interval[1],interval[2])
			if all_nan(bw_signal1) and all_nan(bw_signal2):
				continue
			bw_signal1 = replace_nan( bw_signal1 )
			bw_signal2 = replace_nan( bw_signal2 )
		
			call_back = getattr(twoList,options.action)
			for v in call_back(bw_signal1,bw_signal2):
				coord +=1
				if v != 0: print >>OUT, "%d\t%.2f" % (coord,v)
開發者ID:ivangrub,項目名稱:scripts,代碼行數:37,代碼來源:BigWig_overlay.py

示例2: get_mean_phastcons

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
def get_mean_phastcons(bedtool, phastcons_location, sample_size = 1000):
    
    """
    
    Get means phastcons scores for all intervals in a bed tool
    bedtool - bedtool to extract data from
    phastcons_location - location of phastcons file
    
    """
    
    with open(phastcons_location) as bw_file:
        bw = BigWigFile(bw_file)
    
        data = []
        
        for bedline in bedtool.random_subset(min(len(bedtool), sample_size)):
            conservation_values = bw.get_as_array(bedline.chrom, bedline.start, bedline.stop)
            try:
                if len(conservation_values) > 0:
                    mean_phastcons = np.mean(conservation_values)
                else:
                    mean_phastcons = 0
                data.append(mean_phastcons)
            except TypeError:
                pass
    return data
開發者ID:LeiLiSysBio,項目名稱:clipper,代碼行數:28,代碼來源:CLIP_analysis.py

示例3: get_mean_phastcons

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
def get_mean_phastcons(bedtool, phastcons_location):
    
    """
    
    Get means phastcons scores for all intervals in a bed tool
    bedtool - bedtool to extract data from
    phastcons_location - location of phastcons file
    
    """
    
    f = open(phastcons_location, 'r')
    bw = BigWigFile(file=f)

    #if bedtool
    data = np.ndarray(len(bedtool))  
    for i, bedline in enumerate(bedtool):
              
        conservation_values = bw.get_as_array(bedline.chrom, bedline.start, bedline.stop)
        
        if len(conservation_values) > 0:
            mean_phastcons = np.mean(conservation_values)
        else:
            mean_phastcons = 0
        data[i] = mean_phastcons
        
    return data
開發者ID:Jill-Moore,項目名稱:clipper,代碼行數:28,代碼來源:CLIP_analysis.py

示例4: findInsertions

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
def findInsertions(bwFile, bedData, interval, x):

    if interval =='start':
        sL = int(bedData[x][1])-options.l
        sR = int(bedData[x][1])+options.r
    elif interval == 'end':
        sL = int(bedData[x][2])-options.l
        sR = int(bedData[x][2])+options.r
    else:
        sL = int(bedData[x][1])-options.l
        sR = int(bedData[x][2])+options.r
    
    # get signal data
    f = open(bwFile, "rb")
    bigwig_class = BigWigFile(f)
    try: signal = bigwig_class.get_as_array(bedData[x][0],sL,sR)
    except OverflowError: signal = np.array([np.nan]*(sR-sL))
    f.close()
    
    if signal is not None:
        if np.sum(np.isfinite(signal)) > 0:
            out = np.nanmean(signal)
        else: out = 0
    else: out = 0
    
    out = signal
    return out
開發者ID:sjkdenny,項目名稱:atac_tools,代碼行數:29,代碼來源:find_value_in_bw_peak_specific.py

示例5: summarize

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
    def summarize(self, interval, bins=None, method='summarize',
                  function='mean'):

        # We may be dividing by zero in some cases, which raises a warning in
        # NumPy based on the IEEE 754 standard (see
        # http://docs.scipy.org/doc/numpy/reference/generated/
        #       numpy.seterr.html)
        #
        # That's OK -- we're expecting that to happen sometimes. So temporarily
        # disable this error reporting for the duration of this method.
        orig = np.geterr()['invalid']
        np.seterr(invalid='ignore')

        if (bins is None) or (method == 'get_as_array'):
            bw = BigWigFile(open(self.fn))
            s = bw.get_as_array(
                interval.chrom,
                interval.start,
                interval.stop,)
            if s is None:
                s = np.zeros((interval.stop - interval.start,))
            else:
                s[np.isnan(s)] = 0

        elif method == 'ucsc_summarize':
            if function in ['mean', 'min', 'max', 'std', 'coverage']:
                return self.ucsc_summarize(interval, bins, function=function)
            else:
                raise ValueError('function "%s" not supported by UCSC\'s'
                                 'bigWigSummary')

        else:
            bw = BigWigFile(open(self.fn))
            s = bw.summarize(
                interval.chrom,
                interval.start,
                interval.stop, bins)
            if s is None:
                s = np.zeros((bins,))
            else:
                if function == 'sum':
                    s = s.sum_data
                if function == 'mean':
                    s = s.sum_data / s.valid_count
                    s[np.isnan(s)] = 0
                if function == 'min':
                    s = s.min_val
                    s[np.isinf(s)] = 0
                if function == 'max':
                    s = s.max_val
                    s[np.isinf(s)] = 0
                if function == 'std':
                    s = (s.sum_squares / s.valid_count)
                    s[np.isnan(s)] = 0

        # Reset NumPy error reporting
        np.seterr(divide=orig)
        return s
開發者ID:bakerwm,項目名稱:metaseq,代碼行數:60,代碼來源:filetype_adapters.py

示例6: BigWigWrapper

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
class BigWigWrapper(object):

    """A wrapper for bx-python BigWig file"""

    def __init__(self, filepath):
        self.bw = BigWigFile(open(filepath))

    def __getitem__(self, iv):
        return self.bw.get_as_array(iv.chrom, iv.start, iv.end)
開發者ID:guma44,項目名稱:MetaProfile,代碼行數:11,代碼來源:Signal.py

示例7: profile_bwfile

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
def profile_bwfile(inbed,bwfile):
	'''retrieve signal from bigwig file for each entry in input bed file'''
	bw = BigWigFile( file=open( bwfile ) )
	
	for line in open(inbed):
		bw_signal=[]
		try:
			if line.startswith('#'):continue
			if line.startswith('track'):continue
			if line.startswith('browser'):continue
			if not line.strip():
				continue
			else:
				line = line.rstrip('\r\n')
				fields = line.split()
				chrom = fields[0]
				start = int(fields[1])
				end = int(fields[2])
		except:
			print >>sys.stderr,"Must be  chrom [space] start [space] end: " + line,
			continue		
		bw_signal.extend(bw.get_as_array(chrom,start,end))
		print chrom +'\t'+ str(start) +'\t'+ str(end) + '\t' + ','.join(str(i) for i in bw_signal)		
開發者ID:ivangrub,項目名稱:scripts,代碼行數:25,代碼來源:BigWig_extract_signal.py

示例8: findInsertions

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
def findInsertions(bwFile, bedData, x):
    if options.tn5 is not None:
        bwFile = options.b + options.tn5 + "." + bedData[x][0] + ".Scores.bw"

    sL = int(bedData[x][1]) - options.l
    sR = int(bedData[x][2]) + options.r

    # get signal data
    f = open(bwFile, "rb")
    bw = BigWigFile(f)
    try:
        signal = bw.get_as_array(bedData[x][0], sL, sR)
    except OverflowError:
        signal = np.array([np.nan] * (sR - sL))
    f.close()

    out = signal
    try:
        if bedData[x][3] == "-":
            out = out[::-1]
    except IndexError:
        pass
    return out
開發者ID:sjkdenny,項目名稱:atac_tools,代碼行數:25,代碼來源:find_footprint_matrix.py

示例9: enumerate

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
 or left_or_right == 'r' and strand == '-'):
 # 5' site
 if (chrom, coordinate) in annotated_5p:
     fivep_splice_site_counts = (
             annotated_fivep_splice_site_counts
         )
     line_counts = annotated_line_counts
 else:
     fivep_splice_site_counts = (
             unannotated_fivep_splice_site_counts
         )
     line_counts = unannotated_line_counts
 if strand == '+':
     bwvals = bw.get_as_array(
                 chrom,
                 coordinate - args.extension,
                 coordinate + args.extension
             )
     if bwvals is None:
         continue
     for i, j in enumerate(
                     xrange(-args.extension, args.extension)
                 ):
         if not math.isnan(bwvals[i]):
             fivep_splice_site_counts[j] += bwvals[i]
             line_counts[j] += 1
 elif strand == '-':
     bwvals = bw.get_as_array(
                 chrom,
                 coordinate - (args.extension - 1),
                 coordinate + (args.extension + 1)
開發者ID:foundjem,項目名稱:runs,代碼行數:33,代碼來源:phylop.py

示例10: BigWigFile

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
Create a site profile vector showing the average signal accumulated from a
bigwig file around the center of each interval from a BED file.

Output is the average signal value at that relative position across the 
intervals.

usage: %prog bigwig_file.bw padding < bed_file.bed 
"""

import sys
from numpy import *

from bx.intervals.io import GenomicIntervalReader
from bx.bbi.bigwig_file import BigWigFile

bw = BigWigFile( open( sys.argv[1] ) )
padding = int( sys.argv[2] )
totals = zeros( padding*2, dtype=float64 )
valid = zeros( padding*2, dtype=int32 )

for interval in GenomicIntervalReader( sys.stdin ):
    center = floor( ( interval.start + interval.end ) / 2 )
    values = bw.get_as_array( interval.chrom, center - padding, center + padding )
    # Determine which positions had data and mask the rest for totalling
    invalid = isnan( values )
    values[ invalid ] = 0
    totals += values
    valid += ( ~ invalid )

savetxt( sys.stdout, totals/valid )
開發者ID:mikel-egana-aranguren,項目名稱:SADI-Galaxy-Docker,代碼行數:32,代碼來源:bed_bigwig_profile.py

示例11: BedReader

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
	if args.inFile2 is not None:
		inFile2 = BedReader(open(args.inFile2))
else:	
	raise Exception("Unrecognized format!");



for locus in scanThese:
	if args.verbose>0:
		print("Scanning %s"%(locus[GENOMEDATA.NAME]))
	stF = max(locus[GENOMEDATA.ST] - padding,0);
	enF = locus[GENOMEDATA.EN] + padding + inclusive;
	try:
		if (locus[GENOMEDATA.STR]=="-" and args.inFile2 is not None):
			if args.format=="BIGWIG" or args.format=="BW" or args.format=="BIGBED" or args.format=="BB":
				values = inFile2.get_as_array( locus[GENOMEDATA.CHR], stF, enF )
		else:
			if args.format=="BIGWIG" or args.format=="BW" or args.format=="BIGBED" or args.format=="BB":
				values = inFile1.get_as_array( locus[GENOMEDATA.CHR], stF, enF )
	except OverflowError as e:
		sys.stderr.write("OverflowError at '%s'; st=%d, en=%d\n"%(locus[GENOMEDATA.NAME],locus[GENOMEDATA.ST],locus[GENOMEDATA.EN]));
		raise(e);
	if values is None and args.correctChr>0:
		#try again adding chr or taking it away
		if locus[GENOMEDATA.CHR][:3]=="chr":
			 locus[GENOMEDATA.CHR] =  locus[GENOMEDATA.CHR][3:]
		else:
			 locus[GENOMEDATA.CHR]="chr"+ locus[GENOMEDATA.CHR];
		try:
			if (locus[GENOMEDATA.STR]=="-" and args.inFile2 is not None):
				if args.format=="BIGWIG" or args.format=="BW" or args.format=="BIGBED" or args.format=="BB":
開發者ID:Carldeboer,項目名稱:BigWig-Tools,代碼行數:33,代碼來源:aggregateGenomeData.py

示例12: main

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
def main(args):
    bw_file = BigWigFile( open(args.bigWigFile) )
    bw_file.get_as_array(chrom, st, end)
開發者ID:samesense,項目名稱:pol2_states,代碼行數:5,代碼來源:getBigWigTot.py

示例13: BigWigFile

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
inFile.close();

chromSizesFile = MYUTILS.smartGZOpen(args.chrsFile,'r');
chromSizes = {};
for line in chromSizesFile:
	if line is None or line == "" or line[0]=="#": continue
	data=line.rstrip().split("\t");
	chromSizes[data[0]]=int(data[1]);

curBW = BigWigFile(open(args.inBW))

outStream = MYUTILS.smartGZOpen("%s.wig.gz"%(args.outFPre),"w");
outStream.write("track type=wiggle_0\n")

for chr in transChrs:
	values = curBW.get_as_array( chr, 0, chromSizes[oldToNew[chr]] )
	#print(chr);
	if values is not None:
		sys.stderr.write("Adding %s -> %s\n"%(chr, oldToNew[chr]));
		outStream.write("fixedStep chrom=%s start=1 step=1\n"%(oldToNew[chr]))
		outStream.write("\n".join(map(str,values)));
		outStream.write("\n");

toBW = subprocess.Popen(["wigToBigWig","%s.wig.gz"%(args.outFPre),args.chrsFile,"%s.bw"%(args.outFPre)])
temp = toBW.communicate()
if temp[0] is not None:
	sys.stderr.write("wigToBigWig: %s"%(temp[0]));
if temp[1] is not None:
	sys.stderr.write("wigToBigWig: %s"%(temp[1]));
if temp[0] is None and temp[1] is None and os.path.isfile("%s.bw"%(args.outFPre)): # if no errors, delete the original
	os.remove("%s.wig.gz"%(args.outFPre))
開發者ID:Carldeboer,項目名稱:BigWig-Tools,代碼行數:33,代碼來源:swapChromsomeNamesInBW.py

示例14: range

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
wSize = options.w
wSmooth = np.ones(wSize)
step = options.s

#### SCRIPT #####
# split genome into chunks
for i in range(0,len(gSizes)):
    # break chrs into pieces
    chrN = gSizes[i][0]
    chrLen = int(gSizes[i][1])
    sVals = np.arange(1,int(gSizes[i][1]),chunkSize)
    
    # read in bigWig
    for j in range(0,len(sVals)):
        # get data, pass if not available
        signal = bw.get_as_array(chrN,sVals[j],sVals[j]+chunkSize+padLen)
        try: signal.any()
        except: continue
        
        # smooth data
        print chrN, sVals[j]
        signal[np.isnan(signal)] = 0
        convM = np.convolve(signal,wSmooth,'same')
            
        # save data
        sList = np.arange(sVals[j],sVals[j]+chunkSize+padLen,step)
        eList = sList+step
        chrList = np.array([chrN]*len(sList))
        meanSig = convM[range(step/2,chunkSize+padLen,step)]
        
        # save out
開發者ID:sjkdenny,項目名稱:atac_tools,代碼行數:33,代碼來源:py_smooth_bigwig.py

示例15: BigWigFile

# 需要導入模塊: from bx.bbi.bigwig_file import BigWigFile [as 別名]
# 或者: from bx.bbi.bigwig_file.BigWigFile import get_as_array [as 別名]
curBW = BigWigFile(open(args.inBW))

outStream = MYUTILS.smartGZOpen("%s.wig.gz"%(args.outFPre),"w");
outStream.write("track type=wiggle_0\n")


for chr in chromSizes.keys():
	last = 0;
	final = chromSizes[chr];
	sys.stderr.write("Outputting data for %s:\n"%(chr));
	while last!=final: # this breaks it up into chunks so that I'm not piping entire (human) chromosomes at once
		if args.verbose>0: sys.stderr.write("  Section %i - %i:\n"%(last,curLast));
		curLast = np.min([last+args.chunks,final]);
		curEnd = np.min([curLast+additionalFlankSize, final]);
		curSt = np.max([last-additionalFlankSize,0]);
		values = curBW.get_as_array( chr, curSt, curEnd )
	#print(chr);
		if values is not None:
			for f in allFunctions:
				values = applyFunction(values,f);
			values = values[(last - curSt):(curLast-last + (last-curSt))];# set them only to the middle part of this data so that the additionalFlankSize regions are not output.
			#print(values.shape);
			if last==0:
				outStream.write("fixedStep chrom=%s start=1 step=1\n"%(chr))
			outStream.write("\n".join(map(str,values)));
			outStream.write("\n");
			outStream.flush();
		last=curLast;

outStream.close();
開發者ID:Carldeboer,項目名稱:BigWig-Tools,代碼行數:32,代碼來源:transformBigWig.py


注:本文中的bx.bbi.bigwig_file.BigWigFile.get_as_array方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。