diff --git a/.gitignore b/.gitignore index b276be3..e8dfd11 100644 --- a/.gitignore +++ b/.gitignore @@ -9,8 +9,8 @@ dist/* build/* c-concoct/build/* *.egg* -c-concoct/build/* c-concoct/dist/* +c-concoct/vbgmm.c #ignore screen file .screenrc #ignore test folder diff --git a/.travis.yml b/.travis.yml index ebfa979..980ae3f 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,26 +1,21 @@ language: python python: - "2.7" - # does not have headers provided, please ask https://launchpad.net/~pypy/+archive/ppa - # maintainers to fix their pypy-dev package. + - "3.4" + # Since we are using system_site_packages, we are only able to use + # the default python versions, see: + # https://docs.travis-ci.com/user/languages/python/#travis-ci-uses-isolated-virtualenvs # command to install dependencies virtualenv: system_site_packages: true before_install: - #Uses miniconda installation of scientific python packages instead of building from source - #or using old versions supplied by apt-get. Source: https://gist.github.com/dan-blanchard/7045057 - - if [ ${TRAVIS_PYTHON_VERSION:0:1} == "2" ]; then wget http://repo.continuum.io/miniconda/Miniconda-latest-Linux-x86_64.sh -O miniconda.sh; else wget http://repo.continuum.io/miniconda/Miniconda3-3.7.3-Linux-x86_64.sh -O miniconda.sh; fi - - chmod +x miniconda.sh - - ./miniconda.sh -b - - export PATH=/home/travis/miniconda3/bin:/home/travis/miniconda2/bin:$PATH - - conda update --yes conda + - pip install --upgrade pip - sudo apt-get update -qq - sudo apt-get install -qq build-essential libgsl0-dev bedtools mummer - "export DISPLAY=:99.0" - "sh -e /etc/init.d/xvfb start" + - pip install -r requirements.txt install: - - conda install --yes python=$TRAVIS_PYTHON_VERSION cython numpy scipy biopython pandas pip scikit-learn docutils sphinx jinja2 seaborn - - pip install bcbio-gff - python setup.py install # command to run tests script: nosetests diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..ccca028 --- /dev/null +++ b/Dockerfile @@ -0,0 +1,34 @@ +# Docker for CONCOCT (http://github.com/BinPro/CONCOCT) v1.0.0 +# VERSION 1.0.0 +# +# This docker creates and sets up an Ubuntu environment with all +# dependencies for CONCOCT v1.0.0 installed. +# +# To login to the docker with a shared directory from the host do: +# +# docker run -v /my/host/shared/directory:/my/docker/location -i -t alneberg/concoct_1.0.0 /bin/bash +# + +FROM ubuntu:18.04 +COPY . /opt/CONCOCT + +# Get basic ubuntu packages needed +RUN apt-get update -qq +RUN apt-get install -qq wget build-essential libgsl0-dev git zip unzip bedtools python-pip + +RUN pip install --upgrade pip + +# Install python dependencies and fetch and install CONCOCT 1.0.0 +RUN cd /opt/CONCOCT;\ + pip install -r requirements.txt;\ + +# wget --no-check-certificate https://github.com/BinPro/CONCOCT/archive/1.0.0.tar.gz;\ +# tar xf 1.0.0.tar.gz;\ +# cd CONCOCT-1.0.0;\ +# python setup.py install + +RUN cd /opt/CONCOCT/;\ + python setup.py install + +RUN cd /opt/CONCOCT/;\ + nosetests diff --git a/README.md b/README.md index 5eb80f7..624e329 100644 --- a/README.md +++ b/README.md @@ -1,12 +1,8 @@ -## CONCOCT 0.4.2 [![Build Status](https://travis-ci.org/BinPro/CONCOCT.png?branch=master)](https://travis-ci.org/BinPro/CONCOCT) +## CONCOCT 1.0.0 [![Build Status](https://travis-ci.org/BinPro/CONCOCT.png?branch=master)](https://travis-ci.org/BinPro/CONCOCT) -A program for unsupervised binning of metagenomic contigs by using nucleotide composition, +A program for unsupervised binning of metagenomic contigs by using nucleotide composition, coverage data in multiple samples and linkage data from paired end reads. -Warning! This software is to be considered under development. Functionality and the user interface may still change significantly from one version to another. -If you want to use this software, please stay up to date with the list of known issues: -https://github.com/BinPro/CONCOCT/issues - ## Please Cite ## If you use CONCOCT in your publication, please cite: @@ -15,8 +11,37 @@ Johannes Alneberg, Brynjar Smári Bjarnason, Ino de Bruijn, Melanie Schirmer, Jo ## Documentation ## A comprehensive documentation for concoct is hosted on [readthedocs](https://concoct.readthedocs.org). +## Basic Usage ## +Cut contigs into smaller parts +```bash +cut_up_fasta.py original_contigs.fa -c 10000 -o 0 --merge_last -b contigs_10K.bed > contigs_10K.fa +``` + +Generate table with coverage depth information per sample and subcontig. +This step assumes the directory 'mapping' contains sorted and indexed bam files where each sample has been mapped against the original contigs. +```bash +concoct_coverage_table.py contigs_10K.bed mapping/Sample*.sorted.bam > coverage_table.tsv +``` + +Run concoct +```bash +concoct --composition_file contigs_10K.fa --coverage_file coverage_table.tsv -b concoct_output/ +``` + +Merge subcontig clustering into original contig clustering +```bash +merge_cutup_clustering.py concoct_output/clustering_gt1000.csv > concoct_output/clustering_merged.csv +``` + +Extract bins as individual FASTA +```bash +mkdir concoct_output/fasta_bins +extract_fasta_bins.py original_contigs.fa concoct_output/clustering_merged.csv --output_path concoct_output/fasta_bins +``` + ## Support ## -If you are having issues, please let us know. We have a mailing list located at: concoct-support@lists.sourcefourge.net which you can also subscribe to [here](https://lists.sourceforge.net/lists/listinfo/concoct-support). +[![Gitter](https://img.shields.io/badge/gitter-%20join%20chat%20%E2%86%92-4fb99a.svg?style=flat-square)](https://gitter.im/BinPro/CONCOCT) +If you are having trouble running CONCOCT or interpretting any results, please don't hesitate to write a question in our gitter channel. ## Contribute ## diff --git a/bin/concoct b/bin/concoct index c99775a..4236001 100755 --- a/bin/concoct +++ b/bin/concoct @@ -1,16 +1,17 @@ #!/usr/bin/env python -from __future__ import division +from __future__ import print_function import sys import logging import vbgmm +import numpy as np + from concoct.output import Output from concoct.parser import arguments from concoct.input import load_data from concoct.transform import perform_pca -import vbgmm def main(args): # Initialize output handling @@ -22,7 +23,7 @@ def main(args): if len(composition) < 2: logging.error('Not enough contigs pass the threshold filter. Exiting!') sys.exit(-1) - + if cov is not None: joined = composition.join(cov.ix[:,cov_range[0]:cov_range[1]],how="inner") else: @@ -30,16 +31,17 @@ def main(args): # Fix special case in pca_components if args.pca_components == "All": - args.pca_components = joined[args.length_threshold_filter].shape[1] + args.pca_components = joined.shape[1] #PCA on the contigs that have kmer count greater than length_threshold transform_filter, pca = perform_pca( joined, - args.pca_components + args.pca_components, + args.seed ) logging.info('Performed PCA, resulted in %s dimensions' % transform_filter.shape[1]) - + if not args.no_original_data: Output.write_original_data( joined, @@ -59,13 +61,23 @@ def main(args): logging.info('PCA transformed data.') - logging.info('Will call vbgmm with parameters: %s, %s, %s' % (Output.CONCOCT_PATH, args.clusters, args.length_threshold)) + logging.info('Will call vbgmm with parameters: %s, %s, %s, %s' % (Output.CONCOCT_PATH, args.clusters, args.length_threshold, args.threads)) + + N_contigs = transform_filter.shape[0] + assign = np.zeros(N_contigs, dtype=np.int32) + + assign = vbgmm.fit(np.copy(transform_filter,order='C'), int(args.clusters), int(args.seed), int(args.threads)) - vbgmm.fit(Output.CONCOCT_PATH, args.clusters, args.length_threshold,args.seed,args.iterations,args.epsilon,args.converge_out) + + Output.write_assign( + assign, + args.length_threshold, + joined.index, + ) logging.info("CONCOCT Finished") - + if __name__=="__main__": args = arguments() if args.total_percentage_pca == 100: @@ -75,4 +87,4 @@ if __name__=="__main__": results = main(args) - print >> sys.stderr, "CONCOCT Finished, the log shows how it went." + print("CONCOCT Finished, the log shows how it went.", file=sys.stderr) diff --git a/bin/concoct_refine b/bin/concoct_refine new file mode 100755 index 0000000..1cd4122 --- /dev/null +++ b/bin/concoct_refine @@ -0,0 +1,82 @@ +#!/usr/bin/env python +from __future__ import division +DESC="""A script that iterates over concoct results and reruns the concoct algorithm +for clusters where the median SCG presence is at least 2.""" + + +import sys +import logging +import vbgmm +import numpy as np +import argparse +import pandas as p + +from sklearn.decomposition import PCA + +from concoct.transform import perform_pca + +def main(argv): + parser = argparse.ArgumentParser(description=DESC) + + parser.add_argument("cluster_file", help="string specifying cluster file") + + parser.add_argument("original_data", help="string original but transformed data file") + + parser.add_argument("scg_file", help="string specifying scg frequency file") + + parser.add_argument('-e','--expansion_factor',default=2, type=int, + help=("number of clusters to expand by")) + + parser.add_argument('-t','--threads',default=1, type=int, + help=("number of threads to use defaults to one")) + + args = parser.parse_args() + + clusters = p.read_csv(args.cluster_file, header=None, index_col=0) + + original_data = p.read_csv(args.original_data, header=0, index_col=0) + + original_data_matrix = original_data.as_matrix() + + scg_freq = p.read_csv(args.scg_file, header=0, index_col=0) + + scg_freq_matrix = scg_freq.as_matrix() + + med_scgs = np.median(scg_freq_matrix, axis=1) + + clusters_matrix = clusters.as_matrix() + + cluster_freq = np.bincount(clusters_matrix[:,0]) + + K = cluster_freq.shape[0] + new_clusters_matrix = np.copy(clusters_matrix,order='C') + nNewK = K - 1 + for k in range(K): + if med_scgs[k] > 1: + + select = clusters_matrix == k + + slice_k = original_data_matrix[select[:,0],:] + + index_k = np.where(select[:,0])[0] + + pca_object = PCA(n_components=0.90).fit(slice_k) + transform_k = pca_object.transform(slice_k) + + NK = med_scgs[k]*args.expansion_factor + print "Run CONCOCT for " + str(k) + "with " + str(NK) + "clusters" + " using " + str(args.threads) + "threads" + assigns = vbgmm.fit(np.copy(transform_k,order='C'),int(NK),int(args.threads)) + kK = np.max(assigns) + 1 + + + for a in range(1,kK): + index_a = index_k[assigns == a] + new_clusters_matrix[index_a] = nNewK + a + + nNewK = nNewK + kK - 1 + + new_assign_df = p.DataFrame(new_clusters_matrix,index=original_data.index) + new_assign_df.to_csv("clustering_refine.csv") +if __name__ == "__main__": + main(sys.argv[1:]) + diff --git a/c-concoct/Makefile b/c-concoct/Makefile new file mode 100644 index 0000000..7546d39 --- /dev/null +++ b/c-concoct/Makefile @@ -0,0 +1,16 @@ +CC = gcc +CFLAGS = -std=c99 -g -I/usr/local/include/ +EFLAGS = +EFILE = test_vbgmmfit +LIBS = -lgomp -lpthread -lm -lgsl -lgslcblas -L/usr/local/lib +OBJS = c_vbgmm_fit.o test_vbgmm_fit.o + +$(EFILE) : $(OBJS) + @echo "linking..." + $(CC) $(EFLAGS) -o $(EFILE) $(OBJS) $(LIBS) + +$(OBJS) : c_vbgmm_fit.c c_vbgmm_fit.h + $(CC) $(CFLAGS) -c $*.c + +clean: + rm -rf *.o test_vbgmmfit diff --git a/c-concoct/c_vbgmm_fit.c b/c-concoct/c_vbgmm_fit.c new file mode 100644 index 0000000..c5a9a1a --- /dev/null +++ b/c-concoct/c_vbgmm_fit.c @@ -0,0 +1,1306 @@ +/* C functions for running vbgmm from Cython*/ + +/*System includes*/ +#include +#include +#include +#include +#include +#include + +/*GSL includes*/ +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +/*User includes*/ +#include "c_vbgmm_fit.h" + +void c_vbgmm_fit (double* adX, int nN, int nD, int nK, int seed, int* anAssign, int nThreads) +{ + int debug = 0; + int bAssign = 0; + driverMP(adX, nN, nD, anAssign, nK, seed, DEF_MAX_ITER, DEF_EPSILON, debug, bAssign, nThreads); + + return; +} + +int driverMP(double *adX, int nN, int nD, int *anAssign, int nKStart, unsigned long lSeed, + int nMaxIter, double dEpsilon, int debug, int bAssign, int nThreads) +{ + t_Params tParams; + t_Data tData; + gsl_rng *ptGSLRNG = NULL; + const gsl_rng_type *ptGSLRNGType = NULL; + t_VBParams tVBParams; + t_Cluster *ptCluster = NULL; + int i = 0, nK = nKStart, nNthreads = 0; + int nT = 0; + char *szCOutFile = NULL; + + /*initialise GSL RNG*/ + gsl_rng_env_setup(); + + gsl_set_error_handler_off(); + + ptGSLRNGType = gsl_rng_default; + ptGSLRNG = gsl_rng_alloc(ptGSLRNGType); + + /*set OMP thread number*/ + nNthreads = nThreads; + nT = nN / 32 + 1; + printf("%d %d %d\n",nN,nT,nNthreads); + if (nT < nNthreads){ + nNthreads = nT; + } + + omp_set_num_threads(nNthreads); + fprintf(stderr,"Setting %d OMP threads\n",nNthreads); + + /*set clusters params*/ + tParams.nKStart = nKStart; + tParams.nMaxIter = nMaxIter; + tParams.dEpsilon = dEpsilon; + tParams.lSeed = lSeed; + + fprintf(stderr,"Generate input data\n"); + fflush(stderr); + generateInputData(adX, nN, nD, &tData); + + setVBParams(&tVBParams, &tData); + + if(debug>0){ + szCOutFile = (char *) malloc(sizeof(char)*MAX_FILE_NAME_LENGTH); + + sprintf(szCOutFile,"%sr%d.csv",DEF_FILE_STUB,0); + } + + if(bAssign > 0){ + nK = 0; + + for(i = 0; i < nN; i++){ + if(anAssign[i] > nK){ + nK = anAssign[i]; + } + } + } + ptCluster = malloc(sizeof(t_Cluster)); + allocateCluster(ptCluster,nN,nK,nD,&tData,lSeed,nMaxIter,dEpsilon,szCOutFile); + + ptCluster->bAssign = bAssign; + if(bAssign > 0){ + for(i = 0; i < nN; i++){ + ptCluster->anMaxZ[i] = anAssign[i]; + } + } + + ptCluster->ptVBParams = &tVBParams; + + ptCluster->nThread = 0; + + fitEM_MP((void *) ptCluster); + + compressCluster(ptCluster); + + calcCovarMatrices(ptCluster,&tData); + + for(i = 0; i < nN; i++){ + anAssign[i] = ptCluster->anMaxZ[i]; + } + + if(debug>0){ + free(szCOutFile); + } + + /*free up memory in data object*/ + destroyData(&tData); + + /*free up best BIC clusters*/ + + destroyCluster(ptCluster); + free(ptCluster); + + gsl_rng_free(ptGSLRNG); + gsl_matrix_free(tVBParams.ptInvW0); + + return EXIT_SUCCESS; + + memoryError: + fprintf(stderr, "Failed allocating memory in driver\n"); + fflush(stderr); + exit(EXIT_FAILURE); +} + +void generateInputData(double *adX, int nN, int nD, t_Data *ptData) +{ + double **aadX = NULL; + int i = 0, j = 0; + + /*allocate memory for data matrix*/ + aadX = (double **) malloc(nN*sizeof(double*)); + if(!aadX) + goto memoryError; + + for(i = 0; i < nN; i++){ + aadX[i] = (double *) malloc(nD*sizeof(double)); + if(!aadX[i]) + goto memoryError; + } + + for(i = 0; i < nN; i++){ + for(j = 0; j < nD; j++){ + aadX[i][j] = adX[i*nD + j]; + } + } + ptData->nD = nD; + ptData->nN = nN; + ptData->aadX = aadX; + return; + + memoryError: + fprintf(stderr, "Failed allocating memory in readInputData\n"); + fflush(stderr); + exit(EXIT_FAILURE); +} + +void destroyData(t_Data *ptData) +{ + int nN = ptData->nN; + int i = 0; + + for(i = 0; i < nN; i++){ + free(ptData->aadX[i]); + } + free(ptData->aadX); + + return; +} + +void calcSampleVar(t_Data *ptData,double *adVar, double *adMu) +{ + double **aadX = ptData->aadX; + int i = 0, n = 0; + int nD = ptData->nD, nN = ptData->nN; + /*sample means*/ + double dN = (double) nN; + + for(i = 0; i < nD; i++){ + adMu[i] = 0.0; + adVar[i] = 0.0; + } + + for(i = 0; i < nD; i++){ + for(n = 0; n < nN; n++){ + adMu[i] += aadX[n][i]; + adVar[i] += aadX[n][i]*aadX[n][i]; + } + + adMu[i] /= dN; + + adVar[i] = (adVar[i] - dN*adMu[i]*adMu[i])/(dN - 1.0); + } + + return; +} + +void setVBParams(t_VBParams *ptVBParams, t_Data *ptData) +{ + int i = 0, nD = ptData->nD; + double adVar[nD], adMu[nD]; + + ptVBParams->dBeta0 = DEF_BETA0; + ptVBParams->dNu0 = (double) nD; + ptVBParams->ptInvW0 = gsl_matrix_alloc(nD,nD); + + calcSampleVar(ptData,adVar, adMu); + gsl_matrix_set_zero (ptVBParams->ptInvW0); + + for(i = 0; i < nD; i++){ + double dRD = adVar[i]*((double) nD); + + gsl_matrix_set(ptVBParams->ptInvW0,i,i,dRD); + } + + ptVBParams->dLogWishartB = dLogWishartB(ptVBParams->ptInvW0, nD, ptVBParams->dNu0, TRUE); +} + +void allocateCluster(t_Cluster *ptCluster, int nN, int nK, int nD, t_Data *ptData, long lSeed, int nMaxIter, double dEpsilon, char *szCOutFile) +{ + int i = 0, j = 0, k = 0; + + ptCluster->szCOutFile = szCOutFile; + ptCluster->ptVBParams = NULL; + ptCluster->lSeed = lSeed; + ptCluster->nMaxIter = nMaxIter; + ptCluster->dEpsilon = dEpsilon; + ptCluster->ptData = ptData; + + ptCluster->nN = nN; + ptCluster->nK = nK; + ptCluster->nKSize = nK; + ptCluster->nD = nD; + + ptCluster->dVBL = 0.0; + + ptCluster->anMaxZ = (int *) malloc(nN*sizeof(int)); /*destroyed*/ + if(!ptCluster->anMaxZ) + goto memoryError; + + ptCluster->anW = (int *) malloc(nK*sizeof(int)); /*destroyed*/ + if(!ptCluster->anW) + goto memoryError; + + for(i = 0; i < nN; i++){ + ptCluster->anMaxZ[i] = NOT_SET; + } + + for(i = 0; i < nK; i++){ + ptCluster->anW[i] = 0; + } + + ptCluster->aadZ = (double **) malloc(nN*sizeof(double *)); /*destroyed*/ + if(!ptCluster->aadZ) + goto memoryError; + + for(i = 0; i < nN; i++){ + ptCluster->aadZ[i] = (double *) malloc(nK*sizeof(double)); /*destroyed*/ + if(!ptCluster->aadZ[i]) + goto memoryError; + + for(j = 0; j < nK; j++){ + ptCluster->aadZ[i][j] = 0.0; + } + } + + ptCluster->adLDet = (double *) malloc(nK*sizeof(double)); /*all*/ + ptCluster->adPi = (double *) malloc(nK*sizeof(double)); + ptCluster->adBeta = (double *) malloc(nK*sizeof(double)); + ptCluster->adNu = (double *) malloc(nK*sizeof(double)); /*destroyed*/ + + if(!ptCluster->adLDet || !ptCluster->adPi) + goto memoryError; + + if(!ptCluster->adBeta || !ptCluster->adNu) + goto memoryError; + + for(k = 0; k < nK; k++){ + ptCluster->adLDet[k] = 0.0; + ptCluster->adPi[k] = 0.0; + ptCluster->adBeta[k] = 0.0; + ptCluster->adNu[k] = 0.0; + } + + ptCluster->aadMu = (double **) malloc(nK*sizeof(double *)); + if(!ptCluster->aadMu) + goto memoryError; + + ptCluster->aadM = (double **) malloc(nK*sizeof(double *)); + if(!ptCluster->aadM) + goto memoryError; + + for(i = 0; i < nK; i++){ + ptCluster->aadM[i] = (double*) malloc (nD*sizeof(double)); + if(!ptCluster->aadM[i]) + goto memoryError; + + ptCluster->aadMu[i] = (double*) malloc (nD*sizeof(double)); + if(!ptCluster->aadMu[i]) + goto memoryError; + } + + ptCluster->aptSigma = (gsl_matrix **) malloc(nK*sizeof(gsl_matrix *)); + if(!ptCluster->aptSigma) + goto memoryError; + + for(i = 0; i < nK ; i++){ + ptCluster->aptSigma[i] = (gsl_matrix*) gsl_matrix_alloc (nD, nD); + } + + ptCluster->aptCovar = (gsl_matrix **) malloc(nK*sizeof(gsl_matrix *)); + if(!ptCluster->aptCovar) + goto memoryError; + + for(i = 0; i < nK ; i++){ + ptCluster->aptCovar[i] = (gsl_matrix*) gsl_matrix_alloc (nD, nD); + } + + return; + + memoryError: + fprintf(stderr, "Failed allocating memory in allocateCluster\n"); + fflush(stderr); + exit(EXIT_FAILURE); +} + +void destroyCluster(t_Cluster* ptCluster) +{ + int i = 0, nN = ptCluster->nN, nKSize = ptCluster->nKSize; + + if(ptCluster->szCOutFile != NULL){ + free(ptCluster->szCOutFile); + } + + free(ptCluster->anMaxZ); + + free(ptCluster->anW); + + for(i = 0; i < nN; i++){ + free(ptCluster->aadZ[i]); + } + free(ptCluster->aadZ); + + free(ptCluster->adLDet); + free(ptCluster->adPi); + free(ptCluster->adBeta); + free(ptCluster->adNu); + + for(i = 0; i < nKSize; i++){ + free(ptCluster->aadMu[i]); + free(ptCluster->aadM[i]); + } + + free(ptCluster->aadMu); + free(ptCluster->aadM); + + for(i = 0; i < nKSize ; i++){ + gsl_matrix_free(ptCluster->aptSigma[i]); + gsl_matrix_free(ptCluster->aptCovar[i]); + } + free(ptCluster->aptSigma); + free(ptCluster->aptCovar); + return; +} + +void* fitEM_MP(void *pvCluster) +{ + t_Cluster *ptCluster = (t_Cluster *) pvCluster; + gsl_rng *ptGSLRNG = NULL; + const gsl_rng_type *ptGSLRNGType = NULL; + int i = 0, k = 0; + /*initialise GSL RNG*/ + ptGSLRNGType = gsl_rng_default; + ptGSLRNG = gsl_rng_alloc(ptGSLRNGType); + + gsl_rng_set (ptGSLRNG, ptCluster->lSeed); + + if(ptCluster->bAssign == FALSE){ + initKMeans(ptGSLRNG, ptCluster, ptCluster->ptData); + } + else{ + for(i = 0; i < ptCluster->nN; i++){ + for(k = 0; k < ptCluster->nK; k++){ + ptCluster->aadZ[i][k] = 0.0; + } + ptCluster->aadZ[i][ptCluster->anMaxZ[i]] = 1.0; + } + performMStepMP(ptCluster, ptCluster->ptData); + } + + gmmTrainVB_MP(ptCluster, ptCluster->ptData); + + gsl_rng_free(ptGSLRNG); + + return NULL; +} + +void compressCluster(t_Cluster *ptCluster) +{ + int i = 0, k = 0, nNewK = 0, nN = ptCluster->nN; + double **aadNewZ = NULL, dN = (double) nN; + + for(i = 0; i < ptCluster->nK; i++){ + if(ptCluster->adPi[i] > 0.0){ + nNewK++; + } + } + + aadNewZ = (double **) malloc(nN*sizeof(double *)); + if(!aadNewZ) + goto memoryError; + + for(i = 0; i < nN; i++){ + aadNewZ[i] = (double *) malloc(nNewK*sizeof(double)); + if(!aadNewZ[i]) + goto memoryError; + } + + for(i = 0; i < nN; i++){ + int nC = 0; + for(k = 0; k < ptCluster->nK; k++){ + if(ptCluster->adPi[k] > 0.0){ + aadNewZ[i][nC] = ptCluster->aadZ[i][k]; + nC++; + } + } + } + + for(i = 0; i < nN; i++){ + free(ptCluster->aadZ[i]); + } + free(ptCluster->aadZ); + + /*reset Z and K*/ + ptCluster->aadZ = aadNewZ; + ptCluster->nK = nNewK; + + /*recalculate Pi*/ + for(k = 0; k < ptCluster->nK; k++){ + ptCluster->adPi[k] = 0.0; + for(i = 0; i < nN; i++){ + ptCluster->adPi[k] += ptCluster->aadZ[i][k]; + } + ptCluster->adPi[k] /= dN; + } + + /*assign to best clusters*/ + for(i = 0; i < nN; i++){ + double dMaxZ = ptCluster->aadZ[i][0]; + int nMaxK = 0; + for(k = 1; k < ptCluster->nK; k++){ + if(ptCluster->aadZ[i][k] > dMaxZ){ + nMaxK = k; + dMaxZ = ptCluster->aadZ[i][k]; + } + } + ptCluster->anMaxZ[i] = nMaxK; + } + + for(k = 0; k < ptCluster->nK; k++){ + ptCluster->anW[k] = 0; + } + + for(i = 0; i < nN; i++){ + ptCluster->anW[ptCluster->anMaxZ[i]]++; + } + + return; + + memoryError: + fprintf(stderr, "Failed allocating memory in main\n"); + fflush(stderr); + exit(EXIT_FAILURE); +} + +double decomposeMatrix(gsl_matrix *ptSigmaMatrix, int nD) +{ + double dDet = 0.0; + int status; + int l = 0; + + status = gsl_linalg_cholesky_decomp(ptSigmaMatrix); + + if(status == GSL_EDOM){ + fprintf(stderr,"Failed Cholesky decomposition in decomposeMatrix\n"); + fflush(stderr); + exit(EXIT_FAILURE); + } + else{ + for(l = 0; l < nD; l++){ + double dT = gsl_matrix_get(ptSigmaMatrix,l,l); + dDet += 2.0*log(dT); + } + gsl_linalg_cholesky_invert(ptSigmaMatrix); + return dDet; + } +} + +double mstep(int k, double *adMu, double* adM, int nN, int nD, double** aadZ, double** aadX, double *pdBeta, double *pdNu, double *pdLDet, t_VBParams *ptVBParams, gsl_matrix *ptCovarK, gsl_matrix *ptSigmaMatrix) +{ + double dPi = 0.0, dBeta = 0.0, dLDet = 0.0, dNu = 0.0; + int i = 0, j = 0, l = 0, m = 0; + double dF = 0.0; + double **aadCovar = NULL; + double **aadInvWK = NULL; + + aadCovar = (double **) malloc(nD*sizeof(double*)); + if(!aadCovar) + goto memoryError; + + for(i = 0; i < nD; i++){ + aadCovar[i] = (double *) malloc(nD*sizeof(double)); + if(!aadCovar[i]) + goto memoryError; + } + + aadInvWK = (double **) malloc(nD*sizeof(double*)); + if(!aadInvWK) + goto memoryError; + + for(i = 0; i < nD; i++){ + aadInvWK[i] = (double *) malloc(nD*sizeof(double)); + if(!aadInvWK[i]) + goto memoryError; + } + + /*recompute mixture weights and means*/ + for(j = 0; j < nD; j++){ + adMu[j] = 0.0; + for(l = 0; l < nD; l++){ + aadCovar[j][l] = 0.0; + aadInvWK[j][l] = 0.0; + } + } + + for(i = 0; i < nN; i++){ + if(aadZ[i][k] > MIN_Z){ + dPi += aadZ[i][k]; + for(j = 0; j < nD; j++){ + adMu[j] += aadZ[i][k]*aadX[i][j]; + } + } + } + + /*normalise means*/ + if(dPi > MIN_PI){ + /*Equation 10.60*/ + dBeta = ptVBParams->dBeta0 + dPi; + + for(j = 0; j < nD; j++){ + /*Equation 10.61*/ + adM[j] = adMu[j]/dBeta; + adMu[j] /= dPi; + } + + dNu = ptVBParams->dNu0 + dPi; + + /*calculate covariance matrices*/ + for(i = 0; i < nN; i++){ + if(aadZ[i][k] > MIN_Z){ + double adDiff[nD]; + + for(j = 0; j < nD; j++){ + adDiff[j] = aadX[i][j] - adMu[j]; + } + + for(l = 0; l < nD; l++){ + for(m = 0; m <=l ; m++){ + aadCovar[l][m] += aadZ[i][k]*adDiff[l]*adDiff[m]; + } + } + } + } + + for(l = 0; l < nD; l++){ + for(m = l + 1; m < nD; m++){ + aadCovar[l][m] = aadCovar[m][l]; + } + } + + /*save sample covariances for later use*/ + for(l = 0; l < nD; l++){ + for(m = 0; m < nD; m++){ + double dC = aadCovar[l][m] / dPi; + gsl_matrix_set(ptCovarK,l,m,dC); + } + } + + /*Now perform equation 10.62*/ + dF = (ptVBParams->dBeta0*dPi)/dBeta; + for(l = 0; l < nD; l++){ + for(m = 0; m <= l; m++){ + aadInvWK[l][m] = gsl_matrix_get(ptVBParams->ptInvW0, l,m) + aadCovar[l][m] + dF*adMu[l]*adMu[m]; + } + } + + for(l = 0; l < nD; l++){ + for(m = 0; m <= l ; m++){ + aadCovar[l][m] /= dPi; + gsl_matrix_set(ptSigmaMatrix, l, m, aadInvWK[l][m]); + gsl_matrix_set(ptSigmaMatrix, m, l, aadInvWK[l][m]); + } + } + + + /*Implement Equation 10.65*/ + dLDet = ((double) nD)*log(2.0); + + for(l = 0; l < nD; l++){ + double dX = 0.5*(dNu - (double) l); + dLDet += gsl_sf_psi (dX); + } + + dLDet -= decomposeMatrix(ptSigmaMatrix,nD); + } + else{ + /*Equation 10.60*/ + dPi = 0.0; + + dBeta = ptVBParams->dBeta0; + + for(j = 0; j < nD; j++){ + /*Equation 10.61*/ + adM[j] = 0.0; + adMu[j] = 0.0; + } + + dNu = ptVBParams->dNu0; + + for(l = 0; l < nD; l++){ + for(m = 0; m <= l; m++){ + aadInvWK[l][m] = gsl_matrix_get(ptVBParams->ptInvW0, l,m); + } + } + + for(l = 0; l < nD; l++){ + for(m = 0; m <= l ; m++){ + aadInvWK[l][m] = gsl_matrix_get(ptVBParams->ptInvW0, l,m); + } + } + + for(l = 0; l < nD; l++){ + for(m = 0; m <= l ; m++){ + gsl_matrix_set(ptSigmaMatrix, l, m, aadInvWK[l][m]); + gsl_matrix_set(ptSigmaMatrix, m, l, aadInvWK[l][m]); + } + } + + /*Implement Equation 10.65*/ + dLDet = ((double) nD)*log(2.0); + + for(l = 0; l < nD; l++){ + double dX = 0.5*(dNu - (double) l); + dLDet += gsl_sf_psi (dX); + } + + dLDet -= decomposeMatrix(ptSigmaMatrix,nD); + } + + /*free up memory*/ + for(i = 0; i < nD; i++){ + free(aadCovar[i]); + free(aadInvWK[i]); + } + + free(aadCovar); + free(aadInvWK); + + (*pdBeta) = dBeta; + (*pdNu) = dNu; + (*pdLDet) = dLDet; + return dPi; + + memoryError: + fprintf(stderr, "Failed allocating memory in mstep\n"); + fflush(stderr); + exit(EXIT_FAILURE); +} + +void performMStepMP(t_Cluster *ptCluster, t_Data *ptData){ + int k = 0; + int nN = ptData->nN, nK = ptCluster->nK, nD = ptData->nD; + double **aadZ = ptCluster->aadZ,**aadX = ptData->aadX; + double **aadCovar = NULL, **aadInvWK = NULL; + t_VBParams *ptVBParams = ptCluster->ptVBParams; + + /*perform M step*/ +#pragma omp parallel for + for(int k = 0; k < nK; k++){ /*loop components*/ + double dPi = 0.0, dBeta = 0.0, dNu = 0.0, dLDet = 0.0; + + dPi = mstep(k, ptCluster->aadMu[k],ptCluster->aadM[k], nN, nD, aadZ, aadX, &dBeta, &dNu, &dLDet, ptVBParams, ptCluster->aptCovar[k], ptCluster->aptSigma[k]); + + ptCluster->adPi[k] = dPi; + ptCluster->adBeta[k] = dBeta; + ptCluster->adNu[k] = dNu; + ptCluster->adLDet[k] = dLDet; + } + + /*Normalise pi*/ + + if(1){ + double dNP = 0.0; + + for(k = 0; k < nK; k++){ + dNP += ptCluster->adPi[k]; + } + + for(k = 0; k < nK; k++){ + ptCluster->adPi[k] /= dNP; + } + } + + return; + + memoryError: + fprintf(stderr, "Failed allocating memory in performMStep\n"); + fflush(stderr); + exit(EXIT_FAILURE); +} + +void initKMeans(gsl_rng *ptGSLRNG, t_Cluster *ptCluster, t_Data *ptData) +{ + /*very simple initialisation assign each data point to random cluster*/ + int i = 0, k = 0, nN = ptData->nN, nK = ptCluster->nK, nD = ptData->nD; + double **aadMu = ptCluster->aadMu, **aadX = ptData->aadX; + int *anMaxZ = ptCluster->anMaxZ, *anW = ptCluster->anW, nChange = nN; + int nIter = 0, nMaxIter = ptCluster->nMaxIter; + for(i = 0; i < nN; i++){ + int nIK = gsl_rng_uniform_int (ptGSLRNG, nK); + ptCluster->anMaxZ[i] = nIK; + anW[nIK]++; + } + + updateMeans(ptCluster, ptData); + + while(nChange > 0 && nIter < nMaxIter){ + nChange = 0; + /*reassign vectors*/ + for(i = 0; i < nN; i++){ + double dMinDist = DBL_MAX; + int nMinK = NOT_SET; + + for(k = 0; k < nK; k++){ + double dDist = calcDist(aadX[i],aadMu[k],nD); + + if(dDist < dMinDist){ + nMinK = k; + dMinDist = dDist; + } + } + + if(nMinK != anMaxZ[i]){ + int nCurr = anMaxZ[i]; + nChange++; + anW[nCurr]--; + anW[nMinK]++; + anMaxZ[i] = nMinK; + + /*check for empty clusters*/ + if(anW[nCurr] == 0){ + int nRandI = gsl_rng_uniform_int (ptGSLRNG, nN); + int nKI = 0; + /*select at random from non empty clusters*/ + + while(anW[anMaxZ[nRandI]] == 1){ + nRandI = gsl_rng_uniform_int (ptGSLRNG, nN); + } + + nKI = anMaxZ[nRandI]; + anW[nKI]--; + anW[nCurr] = 1; + anMaxZ[nRandI] = nCurr; + } + } + } + //printf("%d %d\n",nIter,nChange); + nIter++; + updateMeans(ptCluster, ptData); + } + + for(i = 0; i < nN; i++){ + for(k = 0; k < nK; k++){ + ptCluster->aadZ[i][k] = 0.0; + } + ptCluster->aadZ[i][anMaxZ[i]] = 1.0; + } + + performMStepMP(ptCluster, ptData); + return; +} + +double eqnA(int nD, gsl_matrix *ptCovarK, gsl_matrix *ptSigmaK, double *adMuK, double *adMK, double dLDetK, double dNuK, double logd2Pi, double dBetaK,double dNK) +{ + int l = 0; + gsl_matrix *ptRes = gsl_matrix_alloc(nD,nD); + gsl_vector *ptDiff = gsl_vector_alloc(nD); + double dT1 = 0.0, dT2 = 0.0, dF = 0.0; + gsl_vector *ptR = gsl_vector_alloc(nD); + double dD = (double) nD; + double dRet = 0.0; + + gsl_blas_dgemm (CblasNoTrans, CblasNoTrans, 1.0,ptCovarK,ptSigmaK,0.0,ptRes); + + for(l = 0; l < nD; l++){ + dT1 += gsl_matrix_get(ptRes,l,l); + } + + for(l = 0; l < nD; l++){ + gsl_vector_set(ptDiff,l,adMuK[l] - adMK[l]); + } + + gsl_blas_dsymv (CblasLower, 1.0, ptSigmaK, ptDiff, 0.0, ptR); + + gsl_blas_ddot (ptDiff, ptR, &dT2); + + dF = dLDetK - dNuK*(dT1 + dT2) - dD*(logd2Pi + (1.0/dBetaK)); + + dRet = 0.5*dNK*dF; + + gsl_matrix_free(ptRes); + gsl_vector_free(ptDiff); + gsl_vector_free(ptR); + + return dRet; +} + +double eqnB(int nD, gsl_matrix *ptInvW0, gsl_matrix *ptSigmaK, double* adMK, double dBeta0, double d2Pi, double dLDetK, double dBetaK, double dNuK, double dNu0) +{ + int l = 0; + double dD = (double) nD; + gsl_matrix *ptRes = gsl_matrix_alloc(nD,nD); + gsl_vector *ptDiff = gsl_vector_alloc(nD); + gsl_vector *ptR = gsl_vector_alloc(nD); + double dT1 = 0.0, dT2 = 0.0, dF = 0.0; + double dRet = 0.0; + + gsl_blas_dgemm (CblasNoTrans, CblasNoTrans, 1.0,ptInvW0,ptSigmaK,0.0,ptRes); + + for(l = 0; l < nD; l++){ + dT1 += gsl_matrix_get(ptRes,l,l); + } + + for(l = 0; l < nD; l++){ + gsl_vector_set(ptDiff,l,adMK[l]); + } + + gsl_blas_dsymv (CblasLower, 1.0, ptSigmaK, ptDiff, 0.0, ptR); + + gsl_blas_ddot (ptDiff, ptR, &dT2); + + dF = dD*log(dBeta0/d2Pi) + dLDetK - ((dD*dBeta0)/dBetaK) - dBeta0*dNuK*dT2 - dNuK*dT1; + + dRet = 0.5*(dF + (dNu0 - dD - 1.0)*dLDetK); + + gsl_matrix_free(ptRes); + gsl_vector_free(ptDiff); + gsl_vector_free(ptR); + + return dRet; +} + + +double calcVBL_MP(t_Cluster* ptCluster) +{ + int nN = ptCluster->nN; + int nK = ptCluster->nK, nD = ptCluster->nD; + double dBishop1 = 0.0, dBishop2 = 0.0, dBishop3 = 0.0, dBishop4 = 0.0, dBishop5 = 0.0; /*Bishop equations 10.71...*/ + double dD = (double) nD; + double** aadMu = ptCluster->aadMu, **aadM = ptCluster->aadM, **aadZ = ptCluster->aadZ; + double* adBeta = ptCluster->adBeta, *adNu = ptCluster->adNu, *adLDet = ptCluster->adLDet, *adPi = ptCluster->adPi; + double adNK[nK], adRet[nK]; + double d2Pi = 2.0*M_PI, logd2Pi = log(d2Pi), dBeta0 = ptCluster->ptVBParams->dBeta0, dNu0 = ptCluster->ptVBParams->dNu0, dRet = 0.0; + double dK = 0.0; + + for(int k = 0; k < nK; k++){ + adNK[k] = 0.0; + } + + /*Equation 10.72*/ + for(int i = 0; i < nN; i++){ + for(int k = 0; k < nK; k++){ + adNK[k] += aadZ[i][k]; + if(adPi[k] > 0.0){ + dBishop2 += aadZ[i][k]*log(adPi[k]); + } + } + } + + + for(int k = 0; k < nK; k++){ + if(adNK[k] > 0.0){ + dK++; + } + } + + /*Equation 10.71*/ +#pragma omp parallel for + for(int k = 0; k < nK; k++){ + if(adNK[k] > 0.0){ + adRet[k] = eqnA(nD, ptCluster->aptCovar[k], ptCluster->aptSigma[k], aadMu[k], aadM[k], adLDet[k], adNu[k], logd2Pi, adBeta[k],adNK[k]); + } + else{ + adRet[k] = 0.0; + } + } + + for(int k = 0; k < nK; k++){ + dBishop1 += adRet[k]; + } + + + /*Equation 10.74*/ +#pragma omp parallel for + for(int k = 0; k < nK; k++){ + if(adNK[k] > 0.0){ + adRet[k] = eqnB(nD, ptCluster->ptVBParams->ptInvW0, ptCluster->aptSigma[k], aadM[k], ptCluster->ptVBParams->dBeta0, d2Pi, adLDet[k], adBeta[k], adNu[k],ptCluster->ptVBParams->dNu0); + } + } + + for(int k = 0; k < nK; k++){ + dBishop3 += adRet[k]; + } + + dBishop3 += dK*ptCluster->ptVBParams->dLogWishartB; + + /*Equation 10.75*/ + for(int i = 0; i < nN; i++){ + for(int k = 0; k < nK; k++){ + if(aadZ[i][k] > 0.0){ + dBishop4 += aadZ[i][k]*log(aadZ[i][k]); + } + } + } + + /*Equation 10.77*/ + for(int k = 0; k < nK; k++){ + if(adNK[k] > 0.0){ + dBishop5 += 0.5*adLDet[k] + 0.5*dD*log(adBeta[k]/d2Pi) - 0.5*dD - dWishartExpectLogDet(ptCluster->aptSigma[k], adNu[k], nD); + } + } + + dRet = dBishop1 + dBishop2 + dBishop3 - dBishop4 - dBishop5; + + return dRet; +} + +void calcZ_MP(t_Cluster* ptCluster, t_Data *ptData){ + double **aadX = ptData->aadX, **aadZ = ptCluster->aadZ; + int nK = ptCluster->nK, nD = ptCluster->nD, nN = ptData->nN; + double dD = (double) nD; + double** aadM = ptCluster->aadM, *adPi = ptCluster->adPi; + +#pragma omp parallel for + for(int i = 0; i < nN; i++){ + double dMinDist = DBL_MAX; + double dTotalZ = 0.0; + double dNTotalZ = 0.0; + double adDist[nK]; + int k = 0, l = 0; + gsl_vector *ptDiff = gsl_vector_alloc(nD); + gsl_vector *ptRes = gsl_vector_alloc(nD); + + + for(k = 0; k < nK; k++){ + if(adPi[k] > 0.){ + /*set vector to data point*/ + for(l = 0; l < nD; l++){ + gsl_vector_set(ptDiff,l,aadX[i][l] - aadM[k][l]); + } + + gsl_blas_dsymv (CblasLower, 1.0, ptCluster->aptSigma[k], ptDiff, 0.0, ptRes); + + gsl_blas_ddot (ptDiff, ptRes, &adDist[k]); + + adDist[k] *= ptCluster->adNu[k]; + + adDist[k] -= ptCluster->adLDet[k]; + + adDist[k] += dD/ptCluster->adBeta[k]; + + if(adDist[k] < dMinDist){ + dMinDist = adDist[k]; + } + } + } + + for(k = 0; k < nK; k++){ + if(adPi[k] > 0.){ + aadZ[i][k] = adPi[k]*exp(-0.5*(adDist[k]-dMinDist)); + dTotalZ += aadZ[i][k]; + } + else{ + aadZ[i][k] = 0.0; + } + } + + for(k = 0; k < nK; k++){ + double dF = aadZ[i][k] / dTotalZ; + if(dF < MIN_Z){ + aadZ[i][k] = 0.0; + } + dNTotalZ += aadZ[i][k]; + } + if(dNTotalZ > 0.){ + for(k = 0; k < nK; k++){ + aadZ[i][k] /= dNTotalZ; + } + } + gsl_vector_free(ptRes); + gsl_vector_free(ptDiff); + } + + return; +} + +void gmmTrainVB_MP(t_Cluster *ptCluster, t_Data *ptData) +{ + int i = 0, k = 0,nIter = 0; + int nN = ptData->nN, nK = ptCluster->nK; + /*change in log-likelihood*/ + double dLastVBL = 0.0, dDelta = DBL_MAX; + double **aadZ = ptCluster->aadZ; + int nMaxIter = ptCluster->nMaxIter; + double dEpsilon = ptCluster->dEpsilon; + FILE *ofp = NULL; + + if(ptCluster->szCOutFile){ + ofp = fopen(ptCluster->szCOutFile,"w"); + if(!ofp){ + fprintf(stderr, "Failed to open file %s in gmmTrainVB\n",ptCluster->szCOutFile); + fflush(stderr); + } + } + + /*calculate data likelihood*/ + calcZ_MP(ptCluster,ptData); + ptCluster->dVBL = calcVBL_MP(ptCluster); + + while(nIter < nMaxIter && dDelta > dEpsilon){ + + /*update parameter estimates*/ + performMStepMP(ptCluster, ptData); + + /*calculate responsibilities*/ + calcZ_MP(ptCluster,ptData); + + dLastVBL = ptCluster->dVBL; + ptCluster->dVBL = calcVBL_MP(ptCluster); + dDelta = fabs(ptCluster->dVBL - dLastVBL); + + fprintf(stderr,"%d,%f,%f\n",nIter, ptCluster->dVBL, dDelta); + fflush(stderr); + if(ofp){ + fprintf(ofp,"%d,%f,%f,",nIter, ptCluster->dVBL, dDelta); + for(k = 0; k < nK-1; k++){ + fprintf(ofp,"%f,",ptCluster->adPi[k]); + } + fprintf(ofp,"%f\n",ptCluster->adPi[nK - 1]); + fflush(ofp); + } + nIter++; + } + + if(ofp){ + fclose(ofp); + } + + /*assign to best clusters*/ + for(i = 0; i < nN; i++){ + double dMaxZ = aadZ[i][0]; + int nMaxK = 0; + for(k = 1; k < nK; k++){ + if(aadZ[i][k] > dMaxZ){ + nMaxK = k; + dMaxZ = aadZ[i][k]; + } + } + ptCluster->anMaxZ[i] = nMaxK; + } + + return; +} + +void calcCovarMatrices(t_Cluster *ptCluster, t_Data *ptData) +{ + int i = 0, j = 0, k = 0, l = 0, m = 0; + int nN = ptData->nN, nK = ptCluster->nK, nD = ptData->nD; + double **aadZ = ptCluster->aadZ,**aadX = ptData->aadX; + double *adPi = ptCluster->adPi, **aadCovar = NULL; + double dN = (double) nN; + + aadCovar = (double **) malloc(nD*sizeof(double*)); + if(!aadCovar) + goto memoryError; + + for(i = 0; i < nD; i++){ + aadCovar[i] = (double *) malloc(nD*sizeof(double)); + if(!aadCovar[i]) + goto memoryError; + } + + + for(k = 0; k < nK; k++){ /*loop components*/ + double* adMu = ptCluster->aadMu[k]; + gsl_matrix *ptSigmaMatrix = ptCluster->aptSigma[k]; + /*recompute mixture weights and means*/ + for(j = 0; j < nD; j++){ + adMu[j] = 0.0; + for(l = 0; l < nD; l++){ + aadCovar[j][l] = 0.0; + } + /*prevents singularities*/ + aadCovar[j][j] = MIN_COVAR; + } + + /* compute weight associated with component k*/ + adPi[k] = 0.0; + for(i = 0; i < nN; i++){ + adPi[k] += aadZ[i][k]; + for(j = 0; j < nD; j++){ + adMu[j] += aadZ[i][k]*aadX[i][j]; + } + } + /*normalise means*/ + for(j = 0; j < nD; j++){ + adMu[j] /= adPi[k]; + } + + /*calculate covariance matrices*/ + for(i = 0; i < nN; i++){ + double adDiff[nD]; + + for(j = 0; j < nD; j++){ + adDiff[j] = aadX[i][j] - adMu[j]; + } + + for(l = 0; l < nD; l++){ + for(m = 0; m <=l ; m++){ + aadCovar[l][m] += aadZ[i][k]*adDiff[l]*adDiff[m]; + } + } + } + + for(l = 0; l < nD; l++){ + for(m = l + 1; m < nD; m++){ + aadCovar[l][m] = aadCovar[m][l]; + } + } + + for(l = 0; l < nD; l++){ + for(m = 0; m < nD; m++){ + aadCovar[l][m] /= adPi[k]; + gsl_matrix_set(ptSigmaMatrix, l, m, aadCovar[l][m]); + } + } + + adPi[k] /= dN; /*normalise weights*/ + } + /*free up memory*/ + for(i = 0; i < nD; i++){ + free(aadCovar[i]); + } + + //gsl_matrix_free(ptSigmaMatrix); + free(aadCovar); + + return; + memoryError: + fprintf(stderr, "Failed allocating memory in performMStep\n"); + fflush(stderr); + exit(EXIT_FAILURE); +} + +/*note assuming you are using inverse W matrix*/ +double dLogWishartB(gsl_matrix *ptInvW, int nD, double dNu, int bInv) +{ + int i = 0; + double dRet = 0.0, dT = 0.0; + double dLogDet = 0.0, dD = (double) nD; + gsl_matrix* ptTemp = gsl_matrix_alloc(nD,nD); + + gsl_matrix_memcpy(ptTemp, ptInvW); + + dLogDet = decomposeMatrix(ptTemp, nD); + + if(bInv == TRUE){ + dRet = 0.5*dNu*dLogDet; + } + else{ + dRet = -0.5*dNu*dLogDet; + } + + dT = 0.5*dNu*dD*log(2.0); + + dT += 0.25*dD*(dD - 1.0)*log(M_PI); + + for(i = 0; i < nD; i++){ + dT += gsl_sf_lngamma(0.5*(dNu - (double) i)); + } + + gsl_matrix_free(ptTemp); + + return dRet - dT; +} + +double dWishartExpectLogDet(gsl_matrix *ptW, double dNu, int nD) +{ + int i = 0; + double dRet = 0.0, dLogDet = 0.0, dD = (double) nD; + gsl_matrix* ptTemp = gsl_matrix_alloc(nD,nD); + + gsl_matrix_memcpy(ptTemp, ptW); + + dLogDet = decomposeMatrix(ptW, nD); + + dRet = dD*log(2.0) + dLogDet; + + for(i = 0; i < nD; i++){ + dRet += gsl_sf_psi(0.5*(dNu - (double) i)); + } + + gsl_matrix_free(ptTemp); + + return dRet; +} + +void updateMeans(t_Cluster *ptCluster, t_Data *ptData) +{ + int i = 0, j = 0, k = 0; + int nN = ptData->nN, nK = ptCluster->nK, nD = ptData->nD; + int *anMaxZ = ptCluster->anMaxZ; + int *anW = ptCluster->anW; + double **aadX = ptData->aadX, **aadMu = ptCluster->aadMu; + + for(k = 0; k < nK; k++){ + + for(j = 0; j < nD; j++){ + aadMu[k][j] = 0.0; + } + } + + for(i = 0; i < nN; i++){ + int nZ = anMaxZ[i]; + + for(j = 0; j < nD; j++){ + aadMu[nZ][j] += aadX[i][j]; + } + } + + for(k = 0; k < nK; k++){ /*loop components*/ + + /*normalise means*/ + if(anW[k] > 0){ + for(j = 0; j < nD; j++){ + aadMu[k][j] /= (double) anW[k]; + } + } + else{ + for(j = 0; j < nD; j++){ + aadMu[k][j] = 0.0; + } + } + } + + return; +} + +double calcDist(double* adX, double *adMu, int nD) +{ + double dDist = 0.0; + int i = 0; + + for(i = 0; i < nD; i++){ + double dV = adX[i] - adMu[i]; + dDist += dV*dV; + } + + return sqrt(dDist); +} diff --git a/c-concoct/c_vbgmm_fit.h b/c-concoct/c_vbgmm_fit.h new file mode 100644 index 0000000..40e7cda --- /dev/null +++ b/c-concoct/c_vbgmm_fit.h @@ -0,0 +1,182 @@ +#ifndef NMGS_H +#define NMGS_H + +typedef struct s_Params +{ + /*seed*/ + unsigned long int lSeed; + /*min change VBL*/ + double dEpsilon; + /*maximum no. iterations*/ + int nMaxIter; + /*initial cluster size*/ + int nKStart; +} t_Params; + + +typedef struct s_Data +{ + int nN; + + int nD; + + double **aadX; +} t_Data; + +typedef struct s_VBParams +{ + /*scale for mean prior*/ + double dBeta0; + + /*Wishart degrees of freedom*/ + double dNu0; + + /*Inverse! of the Wishart scale precision-matrix*/ + gsl_matrix *ptInvW0; + + /*Log Wishart normalisation*/ + double dLogWishartB; + +} t_VBParams; + + +typedef struct s_Cluster +{ + /*output file for convergence if not null*/ + char *szCOutFile; + /*parameters for variational Bayes*/ + t_VBParams *ptVBParams; + /*start seed*/ + unsigned long lSeed; + /* maximum no. iterations*/ + int nMaxIter; + /* min. change in VBL bound*/ + double dEpsilon; + /*thread index*/ + int nThread; + /*pointer to data*/ + t_Data *ptData; + /*number of data points*/ + int nN; + /*size no. of clusters allocated*/ + int nKSize; + /*number of clusters*/ + int nK; + /*number of dimensions*/ + int nD; + /*variational lower bound*/ + double dVBL; + /*Means*/ + double **aadMu; + /*Scaled weight Bishop 10.60*/ + double *adBeta; + /*Scaled means Bishop 10.61*/ + double **aadM; + /*sample covariance matrix for each cluster storing this helps with lower bound calcn*/ + gsl_matrix **aptCovar; + /*Inverse regularised variances Bishop 10.62*/ + gsl_matrix **aptSigma; + /*Bishop 10.63*/ + double *adNu; + /*Responsibilities*/ + double **aadZ; + /*log-Matrix determinants*/ + double *adLDet; + /*mixture weights*/ + double *adPi; + /*assigned cluster for each data point*/ + int *anMaxZ; + /*frequencies for each cluster*/ + int *anW; + /*whether initial assignments provided*/ + int bAssign; +} t_Cluster; + + +#define DELIM ",\n" +#define MAX_LINE_LENGTH 1048576 +#define MAX_FILE_NAME_LENGTH 1024 +#define MAX_WORD_LENGTH 128 +#define DEF_FILE_STUB "debug_out" + +#define TRUE 1 +#define FALSE 0 + +#define NOT_SET -1 + +/*Default parameters*/ +#define DEF_BETA0 1.0e-3 + +#define MIN_Z 1.0e-6 +#define MIN_PI 0.1 /*Unormalised*/ +#define MIN_COVAR 0.001 + +#define N_RTHREADS 10 +#define R_PRIME 1009 + + +#define DEF_EPSILON 1.0e-4 +#define DEF_MAX_ITER 1000 +#define DEF_SEED 1l + +/*user defines*/ + +void c_vbgmm_fit (double* adX, int nN, int nD, int nK, int seed, int* anAssign, int nThreads); + +int driverMP(double *adX, int nN, int nD, int *anAssign, int nKStart, unsigned long lSeed, + int nMaxIter, double dEpsilon, int debug, int bAssign, int nThreads); + +int driver(double *adX, int nN, int nD, int *anAssign, int nKStart, unsigned long lSeed, int nMaxIter, double dEpsilon, int debug, int bAssign); + +void generateInputData(double *adX, int nN, int nD, t_Data *ptData); + +void destroyData(t_Data *ptData); + +void calcSampleVar(t_Data *ptData,double *adVar, double *adMu); + +void setVBParams(t_VBParams *ptVBParams, t_Data *ptData); + +void* fitEM(void *pvCluster); + +void* fitEM_MP(void *pvCluster); + +void* runRThreads(void *pvpDCluster); + +void allocateCluster(t_Cluster *ptCluster, int nN, int nK, int nD, t_Data *ptData, long lSeed, int nMaxIter, double dEpsilon, char *szCOutFile); + +void destroyCluster(t_Cluster* ptCluster); + +void compressCluster(t_Cluster *ptCluster); + +double decomposeMatrix(gsl_matrix *ptSigmaMatrix, int nD); + +void performMStep(t_Cluster *ptCluster, t_Data *ptData); + +void performMStepMP(t_Cluster *ptCluster, t_Data *ptData); + +void initKMeans(gsl_rng *ptGSLRNG, t_Cluster *ptCluster, t_Data *ptData); + +double calcVBL(t_Cluster* ptCluster); + +double calcVBL_MP(t_Cluster* ptCluster); + +void gmmTrainVB(t_Cluster *ptCluster, t_Data *ptData); + +void gmmTrainVB_MP(t_Cluster *ptCluster, t_Data *ptData); + +double dLogWishartB(gsl_matrix *ptInvW, int nD, double dNu, int bInv); + +void updateMeans(t_Cluster *ptCluster, t_Data *ptData); + +double dWishartExpectLogDet(gsl_matrix *ptW, double dNu, int nD); + +void calcZ(t_Cluster* ptCluster, t_Data *ptData); + +void calcZ_MP(t_Cluster* ptCluster, t_Data *ptData); + +void calcCovarMatrices(t_Cluster *ptCluster, t_Data *ptData); + +double calcDist(double* adX, double *adMu, int nD); + + +#endif diff --git a/c-concoct/setup.py b/c-concoct/setup.py new file mode 100644 index 0000000..e660e2d --- /dev/null +++ b/c-concoct/setup.py @@ -0,0 +1,15 @@ +#!/usr/bin/env python + +from distutils.core import setup +from distutils.extension import Extension +from Cython.Distutils import build_ext + +import numpy + +setup( + cmdclass = {'build_ext': build_ext}, + ext_modules = [Extension("vbgmm", + sources=["vbgmm.pyx", "c_vbgmm_fit.c"], + libraries =['gsl', 'gslcblas'], + include_dirs=[numpy.get_include(), '/opt/local/include/'])], +) diff --git a/c-concoct/test/PCA_components_data_gt1000.csv b/c-concoct/test/PCA_components_data_gt1000.csv deleted file mode 100644 index c20ab28..0000000 --- a/c-concoct/test/PCA_components_data_gt1000.csv +++ /dev/null @@ -1,25 +0,0 @@ -2.52801360e-02,6.35446750e-03,3.13917466e-02,2.45080790e-03,-4.10225609e-03,-3.26596508e-03,2.54404039e-02,-2.94336807e-03,6.71810523e-03,1.24634913e-02,1.02380632e-02,2.06566188e-02,1.39890000e-02,1.58931251e-03,-1.71962583e-02,-9.63427336e-03,2.04093805e-02,5.04569386e-03,8.04076310e-03,8.82027865e-04,2.20072148e-03,2.25337464e-02,-1.15116680e-02,1.39212920e-02,4.77093222e-03,2.46338484e-02,-1.19619079e-03,1.41873546e-02,1.13921984e-02,-3.14615688e-02,-8.69022557e-04,1.81262486e-02,1.06166096e-02,1.77021783e-03,1.49708813e-02,2.85358964e-02,-8.63461813e-03,9.14515275e-03,-3.42959371e-03,7.72534850e-03,-4.88825796e-03,2.37699530e-02,3.12427571e-02,-1.25330678e-02,9.99043215e-03,7.86341203e-03,3.39075082e-02,1.49152035e-02,1.03039323e-02,1.78976720e-02,-1.55847168e-02,-3.62688139e-02,-5.13625915e-02,-2.86377133e-02,-2.70196463e-02,2.01502131e-02,-5.42537819e-03,7.76470149e-03,1.70175881e-02,2.72141156e-02,3.41510350e-04,1.11101472e-02,1.46693709e-02,1.29302793e-02,3.94590153e-03,-5.97747570e-03,1.40762122e-02,1.61645193e-02,-3.08054338e-02,9.82607740e-03,1.17713849e-02,2.39147245e-02,-2.11114766e-03,2.97241695e-02,2.78242565e-03,2.20731735e-02,1.53297252e-02,2.21981891e-02,1.08459690e-02,-5.72347221e-02,1.03129098e-02,1.54651678e-02,1.38311704e-02,4.44794477e-02,-5.12696594e-03,3.06966420e-02,1.53188090e-02,9.70648510e-03,2.45809344e-02,-1.26469554e-02,1.66282978e-02,1.46028946e-02,-6.64287955e-04,2.88087455e-02,-4.91853609e-03,-7.37187503e-02,-4.37083939e-02,-4.85665187e-02,-2.45982053e-02,-7.68133603e-03,-1.09276911e-02,-9.61902962e-03,6.71476504e-03,-3.90197568e-02,-8.04652640e-03,-9.98981813e-03,-4.93944749e-02,-1.08954252e-02,-4.75999376e-03,7.68755902e-03,-8.97019809e-04,1.61707642e-02,1.17401597e-02,-7.37496195e-02,-7.19688660e-03,-5.08422640e-03,1.91056846e-02,-2.44458311e-03,-9.13026305e-03,-3.16045254e-02,-6.25392662e-02,1.37704240e-02,1.83167823e-02,-2.20882360e-02,-3.05811538e-02,-3.51928432e-02,1.96691723e-02,2.33937197e-03,6.29008414e-03,-2.86593871e-02,4.58348495e-02,1.89155078e-02,-4.28342059e-02,-2.30458592e-02,-7.95780199e-02,-6.94901890e-03,-1.78239331e-02,-2.35982053e-01,-9.12571957e-02,1.51073371e-01,3.75346611e-01,3.70484301e-01,-1.41802316e-01,3.30524321e-01,-3.66349411e-01,3.14361507e-02,1.31365013e-01,4.85095771e-03,-3.77805975e-01,-1.53403945e-01,-1.56879442e-01,-2.93076945e-01,-1.93336568e-02 --9.24452531e-02,-8.83770959e-02,-8.40385854e-02,-4.69873011e-02,-1.03646156e-01,-8.66107004e-02,-8.99428659e-02,-6.13827071e-02,-6.46582461e-02,-7.17842399e-02,-1.68462087e-02,-4.01580286e-02,-5.06532889e-02,-3.23681029e-02,1.77588144e-02,2.00655661e-03,-1.44751834e-01,-1.21786870e-01,-7.64976678e-02,-8.14575319e-02,-1.38677202e-01,-1.06187136e-01,-5.36962717e-02,-5.35104475e-02,-3.63834619e-02,-3.94435305e-02,-1.08711964e-02,-3.92902410e-02,-4.98782015e-02,2.10577933e-02,-1.55275087e-02,-6.14632677e-02,-3.45450530e-02,-1.11653039e-02,-6.31405244e-02,-5.79425455e-02,-7.52519724e-03,-1.36614312e-02,1.96363172e-02,2.08313600e-02,4.14464304e-02,-2.07662069e-02,-2.53178280e-02,4.48116831e-02,1.48733658e-02,-6.68054217e-02,-4.41499378e-02,-5.35457621e-03,-4.59730205e-02,-1.83512694e-02,-1.62384212e-02,4.24877076e-02,5.72435419e-02,5.03181072e-02,6.19887273e-02,-8.14026388e-03,3.06741927e-02,3.06052301e-02,-1.29971219e-01,-1.12737361e-01,-8.04332067e-02,-1.13982184e-01,-9.64261915e-02,-1.10724380e-01,-3.90880641e-02,-5.81772143e-03,-4.42922854e-02,-6.07824231e-02,-1.45072005e-03,-3.71188768e-02,-9.52261062e-02,-9.00620886e-02,-8.14776584e-02,-9.67610293e-02,-3.56934153e-02,-6.45745686e-02,-6.50960421e-02,-4.82847705e-02,-4.22360504e-02,4.34812549e-02,-1.70359689e-02,-4.85736495e-02,-1.46101622e-02,-4.51903856e-02,-1.16864506e-02,-2.50924091e-02,1.53771237e-02,1.89181247e-02,-3.67373560e-02,4.24237866e-02,4.03290136e-03,-3.08956222e-02,1.42522609e-02,-4.56408201e-02,-1.20384258e-02,6.71525366e-02,5.56396097e-02,7.26330322e-02,2.52099822e-02,1.89456525e-02,4.05126939e-03,2.39826774e-02,6.79846909e-03,5.93076079e-02,4.55519652e-02,3.18085993e-02,8.12094360e-02,6.13321153e-02,2.49689433e-02,-1.21812327e-02,-4.22871388e-03,4.04741027e-02,3.02532303e-02,9.78479135e-02,3.41259820e-02,2.13085011e-02,2.83812339e-02,5.79216733e-02,8.14775398e-02,1.05433459e-01,1.20306707e-01,2.14425705e-02,3.00986969e-02,8.24353775e-02,1.11291700e-01,9.18037523e-02,-5.17366668e-02,1.90719823e-03,3.22299658e-02,8.52381224e-02,1.31426789e-01,4.82689851e-02,7.52849155e-02,8.38339480e-02,1.42721925e-01,6.00143309e-02,7.72851839e-02,7.60688324e-02,5.00700209e-02,2.84948369e-01,2.18302163e-01,2.05146373e-01,-1.16993092e-02,2.17726684e-01,5.80107680e-02,1.78838134e-01,1.12582163e-01,2.21613934e-02,1.69721649e-01,-2.27235445e-01,3.03558212e-02,3.15828876e-01,-1.17850967e-01 -5.91413319e-02,8.38431955e-02,4.46065458e-02,4.75660004e-02,1.03346121e-01,1.05839501e-01,6.21192947e-02,6.86138921e-02,4.20000322e-02,4.86431972e-02,-3.84292826e-03,-9.62074049e-03,4.69042839e-02,4.64357736e-02,-3.19461851e-03,1.84087976e-02,1.15975874e-01,1.00662865e-01,7.29407846e-02,5.33857977e-02,1.34311229e-01,9.07430315e-02,5.44343799e-02,3.05514611e-02,3.72567209e-02,-2.47232618e-03,-1.68419377e-02,1.67401396e-02,2.67761483e-02,-1.82655124e-02,8.96708222e-03,3.61839350e-02,1.63797270e-02,-9.73743399e-03,5.06869964e-02,1.54512747e-02,2.64376320e-03,-3.81485121e-04,-1.17628280e-02,-3.75446148e-02,-3.84842853e-02,-2.78307391e-02,-3.88687213e-02,-7.29583013e-02,-4.23828193e-02,5.54382399e-02,1.35202945e-02,5.52282044e-03,6.39132959e-02,-6.60517959e-03,3.10647729e-02,-2.33950966e-02,-5.74252857e-03,-4.52204309e-02,-6.74200796e-02,-2.16553728e-02,-5.69908541e-02,-4.66119729e-02,1.07296612e-01,9.59728288e-02,9.82368991e-02,1.13309054e-01,7.40411868e-02,6.39118823e-02,5.64727994e-02,3.60231339e-02,2.96313116e-02,5.50281713e-02,-3.04930654e-03,1.05527344e-02,1.55911262e-01,1.30689736e-01,7.30161236e-02,5.59982712e-02,3.66988706e-02,5.48763102e-02,2.90387671e-02,1.72007043e-02,3.88728539e-02,-1.47226186e-02,1.56815574e-02,2.09875934e-02,-1.79268835e-02,9.69873350e-03,1.16315828e-02,-2.45508485e-03,-3.88491558e-02,-4.97961252e-02,3.39007783e-03,-7.58204094e-02,-5.36433340e-02,-2.20378011e-02,-1.19654900e-02,-8.65772313e-03,7.97404446e-03,-1.66399208e-02,-4.34686060e-02,-5.29449206e-02,-2.53676139e-02,-9.82635060e-03,-1.99277595e-02,-1.31049225e-02,-2.58005881e-02,-6.54618620e-02,-3.46695501e-02,-5.06636637e-02,-6.99130951e-02,-7.65292807e-02,-2.52558347e-02,-8.12409423e-03,1.12155804e-02,-6.73152857e-02,-8.47795951e-02,-5.62977055e-02,-5.46237990e-02,-3.01275261e-02,-7.52534223e-02,-5.67883114e-02,-1.01929397e-01,-1.29479326e-01,-1.00776682e-01,-7.60898383e-02,-9.44031507e-02,-1.23682895e-01,-1.44292613e-01,-1.28322752e-01,3.16460784e-04,-3.95840417e-02,-5.20910007e-02,-7.85457930e-02,1.87369293e-01,-7.73911312e-02,-6.09135725e-02,-8.67943988e-02,-1.25543204e-01,-8.80652827e-02,5.41068671e-02,8.40931149e-02,4.51015064e-02,3.22770085e-01,1.04155237e-01,1.18487656e-01,1.44020288e-02,1.84323049e-01,1.94922335e-01,9.91881712e-02,1.18775709e-03,3.16807155e-02,2.58540857e-01,-1.48965151e-01,7.28622049e-02,3.71301899e-01,-8.92696785e-02 --1.07122488e-01,-8.40611215e-02,-4.14528090e-02,-7.14557470e-02,-8.08021613e-02,-8.66126022e-02,-3.42865919e-02,-6.02018621e-02,6.06322982e-03,1.12009967e-02,3.33608817e-02,1.37476778e-02,-3.07525798e-02,-2.51065257e-02,-9.61181979e-02,-5.22392658e-02,-8.26771827e-02,-3.53320712e-02,-4.58864029e-02,-4.93177240e-02,-8.00460194e-02,-7.63389785e-02,-5.76931970e-02,3.82240077e-02,4.52036948e-04,3.32475039e-02,2.08143495e-02,5.29137402e-02,3.23661482e-02,-5.16194441e-02,6.65002579e-05,7.08063674e-03,8.94086516e-02,6.32248227e-02,-1.51895488e-02,5.33034816e-02,4.67732038e-02,8.40261684e-02,1.72716955e-02,2.94135273e-03,2.62587827e-02,4.97471559e-02,8.66507891e-02,-1.63138108e-02,-1.90414601e-02,-4.71551292e-02,3.75637872e-02,-1.19215584e-02,-3.19976553e-02,2.47558608e-02,2.31726798e-02,-4.82158863e-02,-3.50667346e-02,-4.45548153e-02,-4.08256395e-03,1.44021076e-02,-4.08045802e-02,-5.20273078e-02,-5.33438501e-02,-6.00013796e-03,-7.70795108e-02,-5.24292338e-02,-2.89004643e-02,-2.17045650e-02,-7.43878640e-03,-5.56468346e-02,-1.19673087e-02,-1.25070574e-02,-3.27488412e-02,-3.74035851e-02,-1.08746417e-02,-4.94260400e-02,-5.71222286e-02,-1.05935735e-01,-5.45871337e-02,-7.65817836e-03,-6.19367239e-02,-5.10940180e-02,-2.06259179e-02,-7.88933408e-02,-2.74171229e-02,1.16778856e-01,2.16800564e-02,4.95794331e-03,2.33512064e-02,2.94584596e-02,-3.65556218e-02,2.06088462e-02,1.42223159e-02,-2.67967528e-02,5.34594901e-03,6.20056120e-02,5.81168696e-02,3.97774514e-02,1.05562473e-01,-1.95851350e-02,-6.30575739e-02,-2.49247649e-02,-4.43949543e-02,-6.47713315e-02,4.94719886e-02,-4.42534645e-02,6.31435069e-02,6.86099261e-03,7.59942798e-02,7.21580261e-02,-3.82874315e-02,-2.49114437e-02,-2.94882250e-02,3.36107434e-02,-3.37398684e-02,3.94177400e-02,5.29367543e-02,-3.56186935e-02,-1.05074667e-02,4.92426158e-02,2.04058661e-02,-1.00713555e-01,-4.27610685e-02,-4.51532490e-02,-5.10817559e-02,3.53683674e-02,5.60449165e-02,-6.13331255e-02,-4.46774179e-02,-4.03780990e-02,3.39034904e-02,2.71740288e-02,5.59739404e-02,1.75506411e-02,1.03366563e-01,3.70841876e-02,2.87769229e-03,-1.04810941e-01,-5.19645082e-02,-2.04013555e-02,-1.39702329e-01,-1.56259011e-01,-1.18668358e-01,3.15272529e-01,-9.35249209e-02,-9.73786984e-02,-1.31952865e-01,2.47642213e-01,2.90252494e-01,-3.08964482e-01,-3.74817551e-01,1.17772180e-01,-4.33992657e-02,1.55845736e-01,1.81427558e-01,-9.11163164e-02,-1.80249345e-03 -1.16252221e-01,5.08311378e-02,5.20842285e-02,2.76399402e-02,2.88038080e-02,3.33741905e-02,5.51074874e-02,7.51685825e-02,-2.24305839e-02,-3.69750760e-02,-1.93668807e-02,1.84106661e-02,-5.85885686e-02,-8.00244431e-02,-3.98862605e-02,-5.25727883e-02,1.06900290e-01,9.21590664e-02,-3.63465965e-02,4.23959926e-02,4.16492626e-02,5.98033608e-02,5.70126036e-02,2.26288554e-02,-3.82898659e-02,-1.19282546e-03,8.04078946e-02,-3.23744747e-03,1.79001446e-02,5.68440323e-02,4.84515055e-02,-3.73440612e-02,-5.24093513e-02,-3.04123857e-02,-1.02022391e-01,-2.02467341e-02,-3.89332425e-02,-6.55710500e-03,-9.21416586e-02,-8.20806287e-03,3.40844331e-03,3.65518594e-02,-8.56060044e-03,6.46701176e-03,-4.54386862e-03,-4.38042985e-02,2.28345139e-02,-4.26176826e-02,-1.99812406e-01,-1.61884925e-02,-6.41447186e-02,-2.16456790e-02,-1.41557358e-01,-9.80712687e-04,-2.82577109e-02,-1.04113708e-01,7.45791181e-03,-1.25421123e-02,6.66830096e-02,5.00881864e-02,1.49336345e-03,1.26297683e-02,9.79500633e-02,7.96458153e-02,-1.42476831e-01,-1.17560714e-01,-7.39798169e-02,-1.11556480e-01,-1.79181131e-02,-4.12719109e-02,4.65566526e-02,-8.81461907e-02,1.81161112e-02,3.10303898e-02,5.32356851e-02,-9.09520260e-02,-6.95550333e-02,5.84510100e-02,-3.96887542e-02,7.29574059e-04,6.99599410e-02,-5.46760627e-02,-4.37528532e-02,5.47758192e-02,1.41489087e-02,-2.55195334e-02,-5.54754918e-02,-2.58426528e-02,9.41376353e-02,4.60083656e-02,7.83175367e-02,-9.59076208e-03,-5.13958339e-02,2.80815586e-02,-1.83186566e-02,-6.55307589e-03,2.54791989e-02,2.81647237e-03,1.19176353e-01,4.42579933e-02,-2.82494139e-02,-7.57671257e-02,3.54460870e-03,4.87659488e-02,-3.12137196e-02,2.34595085e-02,-2.53057213e-02,-4.72195569e-02,-2.04528116e-01,-5.86031393e-02,-1.05443718e-01,-6.60768688e-02,3.43391484e-02,-1.50857245e-02,1.30105302e-02,5.30287826e-02,-3.74638564e-02,2.90294440e-02,3.47037210e-02,3.96355459e-02,2.53141583e-02,7.79065635e-02,2.46011514e-02,1.07579082e-01,1.69951911e-02,1.05686813e-01,-6.14098570e-02,-6.92715985e-04,2.38089776e-02,-5.33719672e-02,5.49657155e-03,-4.78931968e-02,-3.92656029e-02,9.00434635e-02,3.07985331e-02,1.75870939e-01,5.76709699e-02,4.05644640e-02,9.87222175e-02,-2.50582091e-01,2.06262683e-01,1.23103732e-01,6.16763683e-02,2.73762055e-01,2.18709469e-01,5.86873407e-02,1.88900000e-02,2.33302363e-01,-2.32262501e-02,2.96802986e-01,2.42790886e-01,-1.82647904e-02,3.66862882e-02 --5.09099223e-02,9.75635281e-03,-7.56986060e-02,-3.53798493e-02,-2.17701330e-02,4.87806427e-03,-4.96868323e-02,-2.80511840e-02,4.20237037e-02,1.78716562e-02,-4.72354751e-02,-4.34464198e-02,6.63215356e-02,3.65791182e-02,-6.84709353e-03,-2.60707604e-02,-1.43825260e-01,-2.01024347e-02,-2.49134454e-02,-8.51467514e-02,-6.20744729e-02,-3.82922499e-02,-4.05183054e-02,4.77661143e-02,6.17639125e-02,3.53510494e-02,-3.91023612e-02,8.68359974e-02,4.75203138e-02,-5.24870913e-03,-6.27219148e-02,9.01849439e-02,7.49859041e-02,3.03846515e-02,1.04471192e-02,-2.02337256e-02,-2.83211819e-02,2.98445663e-02,3.64552152e-02,-1.04121198e-01,-5.43922798e-02,5.46224524e-02,4.55777471e-02,-3.16551891e-02,-6.73795580e-02,4.40413818e-02,-4.21182471e-02,1.67411229e-02,7.31678827e-02,-1.93211871e-02,-1.21100857e-04,3.38658328e-02,3.68882158e-02,-8.04730771e-02,-2.33655009e-02,9.19601341e-02,-7.40561485e-02,-1.07702344e-01,-8.90453027e-02,-1.34737261e-01,-1.20599619e-01,-4.52935304e-02,-7.92107299e-02,-1.02063400e-01,1.16554683e-01,-2.27366700e-02,1.10681780e-02,5.05375722e-02,-7.94890205e-02,-8.67503709e-02,9.94886489e-03,-1.68462639e-02,-1.43290787e-01,-1.84712681e-02,-2.55577042e-02,8.57713808e-02,3.87785170e-02,-9.39937742e-03,3.21605727e-02,-2.11994065e-04,-9.61096372e-02,8.14345114e-02,1.47662486e-02,-3.68048393e-02,-3.25964070e-04,2.95262444e-02,-1.13568202e-02,5.31935913e-02,1.88134945e-02,-5.71280912e-02,-7.58125881e-02,4.05941426e-02,1.30841605e-02,4.40026553e-02,7.71305260e-02,6.21491314e-02,-4.92658989e-02,-2.95364820e-03,-1.57572577e-01,-1.58352127e-01,5.83934078e-03,3.29624075e-02,8.37351095e-02,-2.09473472e-02,4.22705921e-02,1.89119279e-02,-1.84197450e-02,-1.52376610e-02,8.84635273e-02,-4.21942946e-02,7.54418989e-02,5.07280804e-02,-5.09175560e-03,-8.49802648e-03,-9.84206070e-02,-5.36576275e-02,3.92938065e-02,-1.45143015e-01,-8.22208437e-02,-5.54562662e-02,-3.17460420e-02,-1.68831203e-02,1.27924863e-02,-1.20714282e-01,7.86687680e-03,-1.04122802e-01,5.32967839e-02,7.57598917e-03,-3.25627316e-02,2.95490187e-04,2.33451319e-02,3.23003852e-02,5.60007115e-02,-1.79097627e-01,-3.55809203e-02,-2.31249096e-01,1.56404264e-01,5.63878202e-02,1.08946030e-01,-4.23667909e-01,1.46733068e-01,8.77154858e-02,1.07923694e-01,1.10319202e-01,7.20694389e-02,1.56131253e-01,1.98339907e-01,1.73858147e-01,6.88170721e-02,1.27584792e-01,1.31717958e-01,-5.53261078e-02,-1.41679626e-02 -1.15153607e-02,-1.01556201e-04,2.51896518e-02,5.51283898e-03,-4.20915894e-02,-8.02099914e-02,5.15729511e-02,7.68124922e-02,2.54091503e-02,-2.10525494e-02,7.30214661e-03,2.50189263e-02,3.16170239e-02,-2.32340014e-02,1.94595589e-03,2.30826792e-02,-6.00082320e-02,-2.46589089e-02,-3.45541972e-02,1.06131834e-02,-1.26993363e-01,2.08235710e-02,4.53852885e-02,6.21798292e-02,3.40464123e-02,6.93714944e-02,-9.15875020e-03,2.40803326e-02,1.61124624e-02,-2.31568444e-02,7.18697411e-02,2.15859555e-02,3.38843190e-02,4.79995279e-02,-6.63239997e-02,-4.89603189e-02,-2.27839758e-03,6.14890597e-02,-6.12833523e-04,3.52764429e-02,-2.07919487e-02,3.61224834e-02,-4.02807718e-02,-4.76612400e-02,2.86844548e-02,-1.59126802e-02,8.02133378e-02,-1.27211755e-02,-1.60431612e-01,3.98690811e-02,-5.18750613e-02,-1.54572422e-02,-2.06661010e-01,3.70418749e-02,-4.25757415e-02,2.00591934e-02,1.14405755e-02,-1.33125284e-02,-9.88505767e-02,-6.08562893e-02,-9.38763461e-02,-1.26281071e-01,8.75203321e-03,5.21476270e-02,-4.48211363e-02,-5.13296708e-02,-1.08050183e-01,-3.41582148e-02,-7.48552343e-02,-4.87478133e-02,-1.91188771e-01,-1.58098844e-01,-6.28879018e-02,-1.46533160e-02,7.22434998e-02,3.17812804e-02,2.17620710e-03,7.07489604e-03,3.67329611e-02,-3.16633930e-03,1.07899220e-01,4.25796738e-02,5.46900699e-02,2.58376551e-02,5.98166475e-02,7.19878067e-02,3.96226162e-03,2.22807419e-02,-1.00713339e-02,-3.84040608e-02,2.52844695e-02,3.44416925e-02,1.27096127e-02,6.99205825e-02,1.97060504e-02,-8.64207827e-02,-1.39792407e-02,-6.23113833e-02,5.67493363e-02,1.22808957e-01,2.08796725e-02,4.70625468e-02,3.51614186e-02,-1.11475887e-01,1.90809144e-02,-1.34663898e-02,3.24542714e-03,3.38093153e-02,-1.09883067e-01,-6.27006221e-02,2.61558477e-02,5.79953265e-03,-2.30012547e-02,-6.20357921e-02,9.41710009e-02,2.56607810e-02,2.59726956e-03,-1.32069083e-02,-3.51909013e-02,-6.37208963e-02,-2.09654134e-01,3.01276911e-02,1.72592955e-02,-4.67603500e-02,-1.77460102e-01,-5.50257732e-02,1.41101458e-02,6.05050999e-02,7.84399172e-02,-4.31358869e-02,-3.06189889e-01,7.35894526e-02,-1.04308299e-01,1.83165823e-02,-2.74869121e-01,2.83162965e-02,-6.43311950e-03,-1.74613661e-01,-1.50555446e-02,-1.37067508e-01,-1.02449579e-01,-8.81124424e-02,-1.65044962e-01,-4.07608058e-02,5.51560456e-02,8.71306889e-02,1.06576580e-01,5.52107306e-02,-2.60652528e-03,-2.57653203e-01,-9.47522274e-02,3.00309406e-01,-7.24488855e-02 -2.22154885e-04,-1.07467248e-02,-7.52743539e-03,-6.39706175e-02,2.71343677e-02,-3.15520248e-02,1.16422368e-02,-8.01163905e-02,-4.66183109e-02,-1.08282013e-02,-4.22513051e-03,-3.83344912e-03,-4.12546343e-03,-5.03371715e-02,-3.02293153e-02,-4.81928227e-02,-1.62533612e-02,-2.56271598e-02,3.60255122e-02,-1.41795947e-02,5.38056243e-02,-1.50944047e-02,-7.22666513e-02,-7.36952610e-02,-3.22673386e-02,-6.77853899e-02,-1.27207355e-02,-5.27468887e-02,-6.50954283e-02,-5.41977697e-02,-9.76188941e-02,-4.46205280e-02,-2.34211056e-02,-6.65195526e-02,9.69144340e-02,-2.65415134e-02,-1.15621073e-01,-5.92104243e-02,4.46075817e-04,-1.25729514e-02,3.22847778e-02,-4.21619594e-03,3.93884954e-02,-1.57497397e-03,-2.56066142e-02,7.60310567e-03,-2.51802290e-02,5.65352204e-02,6.56130201e-02,-6.80138092e-02,-8.21229743e-02,-5.12589640e-02,-3.16002626e-02,-5.09461488e-02,2.72287133e-02,5.70293477e-03,-1.27731595e-03,-9.27839240e-03,5.40705799e-02,9.98050457e-03,8.45641971e-02,1.84231507e-02,-1.75696178e-03,-5.98938721e-02,-1.78450905e-02,2.03731118e-02,7.17763703e-02,8.62102974e-02,-8.20658909e-03,5.57663011e-02,1.10780205e-01,-1.69265377e-02,9.29962667e-02,-3.43150173e-02,-5.75641719e-02,-6.55679299e-02,-7.35767237e-02,1.78083225e-02,-6.14549454e-02,-8.32906765e-02,-4.79849993e-02,-4.92687608e-02,-1.13216790e-01,2.71042004e-02,-8.05011388e-02,-7.56270006e-02,4.56148477e-03,-1.58452436e-02,3.51371958e-02,-5.91169383e-03,-8.63873284e-03,-1.01124999e-01,-4.14074111e-02,-8.87840465e-02,-4.86549874e-02,-1.08106138e-01,-4.25841026e-02,-4.83883215e-02,-9.14167292e-02,-7.66162828e-02,-3.42625252e-02,-7.50485019e-02,-6.10929766e-02,-1.19149191e-01,-4.09524521e-02,-3.48544158e-02,-1.02830380e-01,-7.64584094e-02,1.99381165e-02,8.63272809e-02,-1.63434345e-02,4.70791845e-02,6.48234856e-02,-6.88800383e-02,-1.16896088e-01,-5.19271594e-02,5.16014410e-02,2.17368751e-02,4.50791031e-02,1.77402769e-02,8.81558138e-02,-6.11414706e-03,1.35776424e-03,1.78771280e-02,8.07798071e-02,2.80345654e-02,-4.84919249e-02,-1.51802350e-01,-4.01983925e-02,2.63531223e-02,-2.38204725e-01,-4.55372913e-02,-8.41051142e-02,-2.97607401e-02,1.17328934e-01,-4.71376116e-02,7.12466744e-02,-5.74493665e-02,-1.56256985e-03,-3.09770189e-02,-1.65698662e-01,-2.75255352e-01,-1.58129745e-01,1.14113624e-01,-5.85927781e-02,1.38555550e-01,2.71892755e-02,2.75745462e-01,-2.53870971e-01,-2.21204371e-01,2.89223385e-01,1.10004918e-01,-2.05533386e-01 --3.89372131e-02,-4.64383672e-02,2.13044650e-02,-5.13557135e-03,-1.31438415e-02,-3.82251020e-02,-8.89448154e-02,-3.38204374e-02,-4.44257136e-03,9.40238439e-02,4.11558513e-02,9.21341283e-02,1.18837238e-02,7.01899336e-02,3.84440652e-02,1.07554864e-01,-7.40770313e-02,-1.36493711e-01,4.99702051e-02,5.69034199e-02,-3.84615721e-02,-2.33460439e-02,-4.88986197e-02,-5.49989799e-02,-6.77633948e-02,-7.62372137e-02,-9.82264442e-02,-1.26971363e-01,-1.08072192e-01,-9.68573562e-02,-4.50739816e-02,1.48750732e-02,9.88537901e-03,3.14596172e-02,1.91851480e-01,1.02416455e-01,1.10800556e-01,1.40795666e-02,3.87491361e-02,3.19272212e-02,6.58435114e-04,-3.63670252e-02,7.02101769e-02,4.67769717e-02,8.36357824e-02,9.33955024e-02,5.52642827e-02,1.20893576e-01,1.82312630e-01,1.20490123e-01,7.02367024e-02,5.10249138e-03,-5.51254265e-02,1.04807289e-01,-9.31999538e-03,7.67805999e-03,9.60825870e-02,1.30806590e-01,-5.32394591e-02,5.72405739e-02,1.93434142e-02,-6.40273778e-02,-2.87862378e-02,-2.99093249e-02,2.56984347e-02,7.89420287e-02,1.71841693e-01,1.23561290e-01,1.39322536e-01,2.01800932e-01,-3.28509642e-02,-3.10428713e-02,7.93397769e-02,-1.71502344e-03,2.71980142e-03,1.59870813e-02,5.48304041e-02,2.21397222e-02,3.58028890e-03,2.19173789e-02,6.38827274e-02,-1.40216061e-02,2.75147328e-02,-6.50814124e-03,5.65028207e-02,-3.88464686e-03,1.25241628e-02,-6.23773719e-02,-1.15279314e-01,-2.22639759e-02,3.57452241e-02,-6.95042325e-03,-3.29452655e-02,-4.19217824e-02,-1.35791446e-02,-3.56251177e-02,3.86276618e-02,-4.20724577e-02,9.18070444e-02,4.45796978e-02,6.67590882e-02,5.21064870e-02,-1.23917572e-01,-1.79469070e-01,-1.36988797e-02,1.96668973e-02,2.23618572e-02,1.05625716e-02,2.36898505e-01,2.26517945e-01,9.62056709e-02,-1.90960997e-02,-3.16178422e-02,3.34477852e-02,7.10089990e-02,7.39351863e-02,2.61244864e-02,7.71250700e-02,3.16056563e-02,-1.28706148e-02,-8.36845197e-02,-6.39498584e-03,-4.48520528e-03,4.64708410e-02,-1.22859720e-01,8.83580101e-02,7.34401620e-02,-3.28744086e-02,1.39795965e-02,-3.72649598e-02,-5.00897401e-03,7.57315328e-03,-9.06067627e-03,1.20306990e-01,-1.93338258e-01,1.60173675e-01,2.15640105e-02,-8.05420647e-03,-4.49379748e-02,-1.49639304e-01,1.05850160e-01,8.66857344e-02,6.19931389e-03,1.24896409e-01,1.87795435e-01,-1.50948260e-02,6.48458546e-02,4.97682025e-02,8.32777038e-03,1.57394942e-01,1.41477374e-01,3.22584995e-02,1.09623211e-01 -6.59875535e-02,1.22539073e-02,6.44323488e-02,3.82014902e-02,-4.75785625e-02,-1.52469885e-02,-1.76301077e-02,-1.78018012e-02,6.14200592e-02,1.01914772e-02,3.61007295e-02,9.25699765e-02,-2.81330062e-02,-6.09733380e-03,-2.61457855e-02,-1.03111860e-02,-4.23776428e-03,-1.20730679e-01,2.62336441e-02,-1.73824497e-01,-2.74445839e-03,-1.06855478e-01,-3.28173971e-02,-3.59983866e-02,-1.22188857e-01,-4.11539066e-02,-3.87489737e-02,-5.53976509e-02,-5.33987780e-02,-1.14717133e-01,-1.43152300e-01,8.76153730e-02,-3.76806691e-03,-2.25248755e-02,-1.22188515e-01,1.82613250e-02,-5.87531178e-02,-2.05020413e-02,-2.96506140e-02,8.24853830e-02,4.83490583e-02,2.53262802e-02,1.25046251e-01,7.83458615e-02,1.16493311e-01,-1.03610205e-01,-6.03868318e-02,-1.36422511e-02,1.99598104e-02,-1.20339521e-01,-7.13833707e-02,-8.61621011e-02,-1.40883782e-01,-7.00691509e-02,5.91283916e-02,-8.00383689e-02,-5.81824039e-02,4.22991121e-03,2.49606161e-02,3.93198841e-02,-4.90570688e-02,-8.96818942e-02,-6.67817072e-02,-1.22106117e-01,6.93833919e-02,1.17812205e-02,1.22832154e-01,-1.58532004e-01,-1.74255739e-01,-1.07548539e-01,1.40607665e-01,2.76726177e-01,-1.65819290e-01,8.23277112e-03,6.62641764e-02,-2.53626828e-02,-1.09667473e-02,3.86445268e-02,4.79179454e-03,-1.32780812e-02,2.68554236e-02,-2.91771228e-02,-5.84293023e-02,-2.45231583e-02,-1.12147722e-01,-8.31871455e-02,3.20502385e-02,5.70661256e-02,1.33338144e-02,3.22335131e-02,-8.71010866e-03,-5.21913339e-02,-4.76844574e-02,-2.86272740e-02,-6.60942683e-02,-1.38597037e-01,-4.09446834e-02,1.24610593e-02,-5.81820292e-02,1.73766957e-02,4.81395636e-02,-1.19932345e-02,-6.40166369e-02,-3.10560675e-01,3.70072002e-03,3.93904698e-02,-3.70350813e-02,-6.49990344e-02,-2.54698634e-02,-1.96144091e-01,-6.29644279e-02,-2.12321933e-02,2.40658210e-02,-1.04682752e-01,-6.35066592e-02,-1.48727726e-02,-2.91024491e-02,1.07737385e-01,1.00068895e-01,8.43920807e-02,-1.11793904e-01,2.05808595e-02,2.62477341e-02,8.97163753e-02,8.14694147e-02,-8.11709305e-03,4.20228336e-02,-1.21176393e-01,-5.84602182e-02,-1.13059844e-02,3.64453804e-02,-6.24860163e-02,-5.34866023e-02,2.44418841e-02,-5.23874883e-02,-7.24169242e-02,-9.79836330e-03,-7.53922056e-02,1.66943402e-02,-3.61566735e-02,1.26920807e-02,6.78011042e-02,9.89620989e-03,-6.53983769e-02,7.91711971e-02,-1.27878940e-01,1.20544331e-02,-6.03076156e-02,8.89779388e-02,1.04320221e-01,-2.07153388e-01,1.01243975e-01,8.13076600e-02 --5.82530910e-02,1.14640044e-01,-1.06146945e-01,-4.42963497e-03,1.26050651e-01,1.55111655e-01,7.44881452e-02,8.44134726e-02,-1.18428241e-01,-8.21719524e-02,-1.62079459e-01,-8.51367571e-02,-4.87240971e-02,-4.43405025e-02,2.98074868e-02,-4.87075974e-02,-7.94547823e-02,8.04354479e-02,1.00423307e-01,3.47292041e-02,4.03427593e-02,8.37705273e-02,1.29388326e-01,-1.48615720e-02,2.09874052e-03,-6.10539297e-02,1.26615393e-02,-2.41594273e-02,-4.65949425e-02,3.49006073e-02,1.62617372e-02,-5.79304707e-02,-1.20211177e-01,-4.93736428e-02,5.49175293e-02,-1.03421049e-01,5.84302187e-02,-6.90662852e-02,-8.10775675e-02,-6.91944736e-02,-1.18891137e-01,-4.47157732e-02,-1.16197578e-01,-3.11267070e-02,-6.12353719e-02,-6.31927407e-02,-2.32019095e-02,-2.66505220e-02,1.87737736e-01,5.23155833e-02,-9.25688696e-02,4.46893802e-02,1.50092608e-02,-9.92960033e-04,3.51373475e-04,-1.28100136e-02,-1.23824336e-02,-9.23983322e-02,-1.33510840e-01,-2.06759887e-01,-1.96218773e-01,1.14726242e-01,-1.38058128e-02,-2.91717778e-02,1.65702202e-01,9.76948335e-02,-5.94091078e-02,2.46377590e-03,-2.32566679e-02,-4.70782417e-02,-1.61816665e-01,1.83553389e-02,-1.63814605e-01,-4.25646038e-02,5.54950642e-02,-6.40516788e-02,-3.25834261e-02,-1.17296618e-02,-2.44311738e-02,9.18975780e-02,2.52146041e-02,-1.86033398e-01,-3.44284201e-02,-6.22555323e-02,-6.20071463e-03,-5.65733880e-02,3.29431905e-02,-3.56791128e-02,-5.26931297e-02,4.50748260e-03,-4.94797574e-02,-1.02255904e-01,-9.01477677e-02,-6.13089251e-02,-1.06755606e-01,4.47986071e-02,5.89902527e-02,4.17990956e-02,3.77258547e-02,3.96116780e-02,-5.74814082e-02,-1.61216621e-02,-4.72678697e-02,-3.57296048e-02,-8.66323107e-02,-6.51778517e-02,1.03653403e-02,-2.30388818e-02,6.80163087e-02,-3.34670205e-02,7.88238856e-03,-3.10741683e-03,-3.81692645e-02,6.36964128e-02,-1.06033062e-02,-6.85768235e-02,-6.92263097e-02,3.57283749e-02,2.12158388e-02,3.38870154e-02,-9.13867422e-02,-6.46425156e-02,-5.80884958e-02,-3.60768983e-03,2.82099862e-02,8.23810900e-04,-2.00424912e-01,-4.61518475e-02,-9.96957497e-02,-2.02915153e-02,9.88454377e-02,-1.52130045e-02,-4.66136155e-02,7.04065147e-03,-5.04110076e-02,-1.51381136e-02,-1.67500979e-01,-1.89589498e-01,-1.64336597e-01,-8.49195996e-02,5.04223529e-02,-4.08039099e-02,-1.80166083e-01,5.67618116e-02,1.60796735e-01,-1.33988722e-01,-1.20068516e-02,-8.12583008e-02,-5.64135666e-02,1.41385678e-02,4.57586299e-02,-4.66092289e-02,-2.97838916e-02 -2.70064272e-04,-9.69797941e-03,6.22851599e-02,-8.80984083e-03,8.26611607e-02,-1.29510888e-01,-1.41543126e-02,-6.79054829e-02,9.65511936e-02,-1.60846262e-02,-1.56144782e-02,-6.14706296e-02,-6.46101501e-02,-1.43388772e-02,-4.34616130e-02,-3.86860293e-02,-7.29988081e-02,8.76706749e-02,1.31063233e-01,1.47492750e-01,-1.17198790e-01,-1.16646333e-01,2.88028854e-02,-3.14886546e-02,-4.82436544e-02,-4.80350255e-02,-1.86416895e-02,-1.45175172e-01,9.79204437e-02,-5.89300645e-02,1.02385840e-02,1.06155683e-01,1.34316078e-01,9.38530709e-02,1.20612574e-01,-5.88428699e-02,-2.06542947e-02,8.56752569e-02,-7.83087515e-02,8.24692141e-02,4.72131831e-02,-4.99622286e-02,6.06069897e-02,2.44116980e-02,2.90706864e-02,-8.84508097e-03,5.97671240e-02,-1.08596572e-01,-8.05843351e-02,6.71427814e-03,3.50358377e-02,-8.40770461e-02,-1.05375628e-01,-5.58987826e-02,-3.62191522e-03,-1.05200874e-01,-2.31094800e-02,-7.54365398e-02,-2.97651563e-02,-1.93878109e-01,-1.08068526e-01,9.65412330e-02,4.72919212e-03,8.23620733e-02,1.62685915e-01,1.03519157e-01,8.29097291e-02,9.32985011e-02,2.70739628e-02,4.27969289e-02,-2.57294283e-01,-3.66141653e-02,-4.91320270e-02,3.19779867e-02,9.27922351e-03,-1.19860589e-01,-4.58397176e-02,1.09441181e-02,-6.01565971e-02,-7.00864184e-02,6.80067579e-02,2.98862315e-03,-9.21557334e-02,-7.14638784e-02,-2.61569839e-02,-1.96184904e-02,-3.67783064e-02,1.22182696e-02,-3.17609134e-03,1.00586549e-02,1.18092645e-02,-6.98281754e-03,-2.22679151e-01,1.31417478e-01,6.62980071e-02,-1.00189548e-01,-3.55961703e-02,2.26343271e-02,3.45243543e-02,2.79004011e-02,1.57280112e-02,-8.56269728e-03,-7.25863210e-02,2.81400221e-03,-1.20728516e-02,2.79560942e-02,-3.25968427e-02,-3.18895205e-02,4.90514695e-02,7.24904908e-02,-1.09647956e-01,-1.52810026e-01,-1.29409472e-01,-8.06293903e-02,1.26907385e-02,2.60104790e-02,-1.98833026e-01,1.00162543e-02,-1.95297294e-02,-2.52348623e-02,2.17944250e-02,5.28545493e-02,8.19607879e-03,1.12927719e-02,6.19982090e-02,-6.00527048e-02,1.84198246e-02,-8.72710731e-03,2.69885766e-02,-1.95069455e-01,-1.32168576e-02,4.84608348e-02,-3.16224412e-02,-7.13953090e-02,1.43560754e-01,-2.72289670e-02,8.33996280e-02,5.33787520e-02,8.97828043e-02,2.24115973e-02,-1.58577384e-02,7.11131913e-02,1.47891858e-01,-1.67678010e-02,-2.41474675e-01,4.00082228e-02,-1.94350944e-01,1.03632230e-02,8.21928122e-02,-4.15908721e-03,7.50106733e-02,2.06868076e-02,2.25965030e-02 --2.46790941e-01,-1.68153201e-01,-7.87047376e-02,-1.46738366e-01,3.85447437e-02,-1.67937045e-01,5.43413997e-02,-1.36624988e-01,-4.50684020e-02,-2.91252724e-02,-1.14808598e-03,-4.00859857e-02,-5.09017830e-02,-5.75386419e-02,-8.46203264e-02,-4.97005047e-02,9.75086191e-02,1.80150471e-01,1.66741442e-01,9.84920832e-02,7.23813883e-02,2.75488489e-02,-9.32896797e-02,9.62132903e-02,4.47762407e-02,1.66307525e-01,4.57780441e-02,6.48571091e-02,2.24566342e-02,9.51872129e-03,6.41946968e-02,-4.10162825e-02,7.02322157e-03,5.80239644e-03,3.22194434e-02,7.34840649e-02,-5.45856671e-02,-6.19546902e-03,-1.47110243e-03,7.03826051e-02,1.26175295e-02,1.13687916e-02,2.18206319e-02,1.00689967e-01,-7.90964705e-03,-1.31007069e-01,1.66865878e-03,2.78488214e-02,1.01656519e-01,-2.67096184e-03,-6.53652146e-02,3.25348444e-03,-1.06994800e-01,1.79415387e-02,2.35214945e-02,7.99817784e-02,1.47075640e-02,8.58697007e-02,1.05746918e-02,7.30368127e-02,2.99707217e-02,2.53038898e-01,1.35952203e-01,1.63885682e-01,8.76907155e-02,1.34161823e-01,7.43622707e-02,-8.92348952e-02,1.44508213e-02,9.92373553e-02,1.32643444e-02,1.63284663e-01,-1.77037675e-02,-1.88381609e-01,-1.45746872e-01,-4.05370937e-02,-1.27901292e-02,-7.75916164e-02,-2.67847399e-02,-1.39447121e-01,-3.83669514e-02,-4.59559209e-02,9.61471859e-02,7.46489751e-02,1.51384732e-03,6.90784911e-02,1.77390093e-01,1.16521893e-01,-2.85666215e-02,-4.26838179e-02,5.64268528e-02,3.60547179e-02,4.25739445e-02,2.20400967e-02,-2.37403650e-02,-9.42022807e-02,-4.12866843e-02,-6.95763007e-03,-6.74975201e-02,1.07503299e-01,2.32253564e-03,-4.04359317e-02,4.77326647e-02,6.27677467e-02,2.11213431e-02,1.15166668e-02,2.34184680e-02,6.69434296e-02,1.63878619e-03,-1.24950149e-02,-3.74835295e-02,1.12876257e-01,1.37417985e-02,-2.45003269e-02,2.65904092e-02,-2.59011322e-02,4.07849027e-02,1.18489540e-01,6.67588909e-02,-1.13305101e-04,6.08878467e-02,-2.44773396e-02,7.55499678e-02,-1.13975359e-03,2.46144309e-02,-4.23338416e-02,-5.33038083e-02,1.37712721e-01,-3.60045693e-02,2.27837984e-02,7.53513442e-03,1.20550593e-01,1.66091511e-02,3.48712209e-02,1.24320160e-03,-5.29289277e-02,8.49667215e-03,-3.62719971e-02,5.37352219e-02,-1.11332329e-01,3.25352113e-02,9.77556811e-02,-8.42921130e-02,-5.66816487e-02,1.08650654e-01,4.14358744e-02,7.74022207e-02,8.45799275e-02,4.50830653e-02,5.95117955e-02,-9.85881043e-02,1.16236381e-01,4.22011568e-02 -2.83431406e-02,7.43217190e-02,4.02072932e-02,1.40418880e-02,-7.82761356e-03,1.49296275e-01,3.56211980e-02,1.25944285e-01,7.80549735e-02,2.95520835e-02,-8.58570250e-02,1.26759874e-01,-8.08400876e-03,-2.52482933e-02,-6.72251198e-03,-1.83247347e-02,8.82432728e-02,-7.87133295e-02,7.73931670e-02,2.41758329e-02,6.41509655e-02,1.28157441e-01,1.05656718e-01,-1.13772116e-02,3.86758322e-02,-1.87460099e-02,2.82276172e-02,5.93138357e-02,1.06104015e-01,1.14790523e-01,-7.12026202e-03,9.99015948e-02,1.73045400e-01,-1.64335262e-02,7.62279952e-02,2.07034031e-02,4.74957042e-02,-1.01049810e-02,2.82134369e-02,-9.03568620e-02,9.77822204e-02,1.02153054e-01,1.36531547e-01,1.52627068e-01,9.44054575e-02,1.69139741e-02,2.77514913e-02,2.34903507e-02,1.30822218e-04,2.20073099e-02,5.17033857e-02,2.92223695e-02,-1.53427989e-01,-2.58717251e-03,6.78141847e-02,-6.44450006e-02,-4.41629380e-02,-1.99330690e-02,6.85786854e-02,5.19511187e-02,-1.84732634e-02,4.06522250e-04,3.71620995e-02,3.70895114e-02,9.59931744e-02,1.66817183e-02,1.35633016e-01,-6.98585950e-03,6.54431118e-02,1.13017507e-01,5.81234485e-03,1.61294013e-02,4.26030307e-03,3.02730463e-02,3.99318672e-02,1.87924094e-02,-1.59556661e-02,6.36495124e-02,2.32214300e-02,6.28939205e-02,-3.11471283e-02,-1.97163905e-02,-5.03932667e-02,5.84384263e-02,3.80889226e-02,-3.19563713e-02,-3.96382208e-02,6.85522155e-02,-7.76751055e-03,1.39420774e-01,3.19839133e-02,1.19813973e-01,-2.19605962e-02,1.13210356e-01,9.30372622e-02,1.36211567e-01,2.27446066e-02,1.19636745e-01,5.29824606e-02,-1.55556384e-01,3.84762779e-02,-1.91697771e-02,4.11574760e-02,1.70929442e-01,6.82210434e-02,1.42204180e-01,-4.71934219e-02,-2.39406361e-02,1.70995729e-01,5.40810859e-02,-1.93102068e-02,-6.21445389e-02,6.66712634e-02,2.84871766e-02,-3.19558823e-02,1.35874092e-03,-8.47896679e-02,-1.58946866e-01,-5.94733632e-04,6.87193328e-02,-8.16573843e-03,1.15603781e-01,1.42992275e-01,1.06727171e-01,1.66233371e-01,6.54182580e-02,-1.66376734e-02,-1.08969366e-02,9.76596282e-02,6.74643881e-02,-8.88022412e-02,7.70460555e-02,1.70634157e-01,-5.00518672e-02,1.45571215e-01,-7.74979853e-02,-6.81332963e-02,-1.77826417e-01,-1.15733365e-01,-2.07449906e-02,2.96203182e-02,-4.67161675e-02,-4.97678548e-02,2.45376937e-02,1.44529595e-01,-2.26137560e-02,1.30376529e-01,-4.55972663e-02,-7.40045890e-02,-1.00168969e-01,-1.09887879e-01,1.96700172e-01,-2.57427806e-02 --1.47901526e-01,-1.48207734e-02,-1.09531933e-01,-4.15921637e-02,-9.27165642e-02,7.35379605e-02,8.89445294e-02,6.54919269e-02,-6.58476276e-02,-1.00390148e-01,-4.61475140e-02,-3.43862822e-02,-9.73640077e-02,3.41712835e-02,1.61092903e-02,-7.73520050e-02,-4.12251582e-02,-2.49506643e-01,-7.20604981e-04,-1.13915012e-01,1.40254951e-01,-5.45876244e-02,8.11474145e-02,1.40979722e-01,1.04271784e-01,3.76107398e-03,3.59814225e-02,7.89960801e-02,3.23264693e-02,5.52335362e-02,9.75448601e-02,-7.46365445e-02,4.85376911e-03,-9.54797416e-02,3.82601923e-03,-9.02982051e-02,-4.77337794e-02,-2.56742649e-02,-6.22811383e-02,-2.45460707e-02,1.78750443e-02,-3.10525385e-02,-7.64504504e-02,-6.63176225e-03,6.14046823e-02,-8.10147079e-02,-3.11330128e-02,-9.56915698e-02,-4.09273810e-03,-4.38984384e-02,2.49009759e-02,5.26228074e-02,-5.21955253e-02,-1.39613087e-02,3.16847423e-02,-9.07967596e-02,-6.34031916e-02,-3.73899502e-02,-2.62752980e-02,1.33343441e-01,4.53172916e-02,-3.10021825e-01,1.69577765e-02,-8.58298526e-02,-7.06227242e-02,2.70789936e-02,2.15565184e-01,4.96621056e-02,8.92050637e-02,-4.48548351e-02,1.88915078e-01,6.77139508e-02,1.04723424e-01,-1.62187148e-01,-2.61811895e-02,-7.56474013e-02,-9.94968663e-02,-1.36584461e-01,-2.79753428e-02,3.99812336e-02,3.49021503e-02,-7.44765533e-03,-3.08787534e-03,-7.17395997e-02,-1.06113611e-02,3.31432347e-02,2.04990711e-03,-5.90218125e-02,-1.24244543e-01,-2.09516145e-02,-7.47454146e-03,-3.96767864e-02,-3.95861682e-02,-2.36801395e-02,1.43664480e-02,-2.86160203e-02,1.65144574e-02,3.65886577e-02,6.61733695e-02,6.92926868e-02,5.04969357e-03,1.10270034e-02,9.37786556e-02,1.21769474e-01,8.80574539e-04,-2.10865569e-02,2.42990709e-02,-1.96335683e-02,4.86171747e-02,1.65281117e-01,-5.58298503e-02,-4.63233518e-02,-9.30713344e-02,-1.34299876e-02,6.65235807e-02,-2.93692687e-02,-9.68384607e-02,-3.91413509e-02,-2.07974059e-02,-5.15088334e-02,-1.02728151e-01,-2.94745089e-02,-2.55993488e-02,-1.43863685e-02,-1.25868828e-01,-7.03652121e-02,-1.39483382e-01,3.94105062e-02,-3.67628655e-02,-8.31677426e-02,7.04740595e-02,-1.34444968e-02,-1.10864402e-02,-1.48132876e-02,-3.29811303e-02,-2.09366575e-02,7.00016261e-02,-1.22581062e-01,1.59160725e-02,-1.11478655e-01,-3.20388758e-02,1.13151852e-03,6.78140019e-02,2.02126660e-02,-2.42853482e-01,5.24919839e-02,-1.60470119e-01,8.97709717e-02,-7.94769262e-03,9.91430706e-02,-5.81401550e-02,1.05762846e-01,4.20961258e-02 -1.52088709e-01,-8.02988947e-03,3.22634927e-02,8.26053185e-02,-5.01978067e-02,-7.37257821e-02,-3.63558751e-02,-1.05266911e-01,-2.56343061e-02,8.94990318e-02,-5.59993165e-02,-1.36607427e-01,1.28256226e-01,1.02459215e-01,-1.81978612e-02,1.87083505e-02,-6.10397462e-02,7.23399049e-02,-1.62495960e-01,-6.10089733e-02,4.52636786e-03,-2.01475319e-01,-9.57359749e-02,1.26343223e-01,8.76716474e-02,4.94474772e-02,2.43164784e-02,4.09880552e-02,-4.01296979e-02,-8.14673344e-03,-6.41487775e-02,2.22493419e-02,-4.82351142e-02,-2.70494337e-02,2.24290162e-01,-3.60824034e-02,1.21035231e-01,-2.88921387e-02,-3.59280473e-02,-3.67194594e-02,-5.65964409e-02,3.44226028e-02,-1.11681971e-01,-7.63602965e-02,-1.00104801e-01,2.67038737e-02,6.69889145e-02,-8.13901038e-02,1.19554245e-01,1.58830075e-01,4.79140176e-02,-9.14503978e-03,-2.82735308e-01,-1.96633846e-02,5.10719446e-02,6.64206219e-02,2.24066582e-02,-5.78654849e-02,1.53105396e-01,-8.59506088e-02,7.83411131e-02,4.37076592e-02,-2.33495359e-02,-1.54250700e-01,-8.52682487e-02,-5.02194889e-02,-1.25277687e-01,3.96108861e-02,-5.62605274e-02,-3.44844174e-04,1.73548589e-01,-3.96666301e-02,1.00742371e-01,1.04483599e-01,-2.22903590e-02,-3.38306729e-02,-1.63642135e-01,-1.49754628e-02,-1.95764434e-02,-2.97010731e-02,-1.61638650e-02,5.53289367e-03,-2.74237905e-03,-3.42861748e-02,2.10676387e-02,1.27771264e-03,7.27510179e-03,-9.64196471e-04,-1.46328907e-02,3.03848923e-02,-4.69307787e-02,-1.92802433e-02,-8.24704339e-02,1.05178402e-01,-1.05467196e-01,-6.59880581e-02,2.32418476e-02,-3.14724882e-03,-5.63610034e-02,-1.21717487e-02,-5.18288014e-02,4.24123857e-02,2.28009174e-02,2.52795498e-02,-1.68993391e-02,-6.92499309e-02,-3.74432221e-02,2.20023511e-02,5.36230006e-02,-4.61339639e-03,4.65176900e-04,5.30454465e-02,-6.87779019e-02,1.66665589e-02,6.49283608e-02,-9.34095094e-02,-5.60383680e-02,2.48402519e-02,1.25499944e-02,9.81317120e-02,-2.43620249e-02,3.77493087e-02,-8.82835678e-04,5.33960781e-02,8.42890267e-02,3.59450032e-02,-9.68176354e-02,2.29268342e-01,-1.71658471e-02,-2.91829654e-02,-1.60702954e-01,8.50450313e-02,-1.70079839e-02,-6.61970570e-03,9.30147369e-02,-4.22833391e-02,-3.11558646e-02,-1.40378129e-01,5.08234369e-02,1.12111911e-01,-8.45361708e-03,3.60982427e-02,5.48867207e-02,1.46770080e-02,4.36024771e-02,-3.63733813e-02,1.01635123e-01,-1.58851031e-01,-1.25665912e-02,1.83706185e-01,-8.69464426e-03,1.12476845e-01,4.11402871e-02 --9.78052751e-02,-8.09249776e-02,2.95575787e-03,4.09945583e-02,-4.70989364e-02,-9.92078384e-02,1.25126662e-02,-5.00134842e-02,-6.06662685e-02,3.65835518e-02,-8.19368131e-03,7.57257175e-02,1.93458343e-02,-1.41531161e-02,7.87790592e-02,2.29453066e-02,3.11752500e-02,-2.56345681e-02,-1.20752210e-02,5.39107048e-02,-9.10372167e-02,-2.57868069e-02,-5.22408432e-02,-8.38904895e-02,-3.31429531e-03,-8.42442368e-03,6.62425166e-02,-5.04720263e-02,-4.74725507e-02,1.08777121e-02,-9.90302098e-02,-9.13116381e-03,-7.11747565e-02,2.68209234e-02,9.60377124e-02,-7.29549430e-02,-7.39523486e-02,-8.14510844e-02,-4.15225229e-02,-4.82464775e-02,-4.18531341e-02,9.39868173e-02,9.90839140e-03,2.48222285e-02,4.65616583e-04,-1.64337947e-02,9.18234977e-03,-5.03731975e-02,-1.34000895e-01,6.03928556e-03,-7.61430058e-02,5.08958174e-02,1.92882567e-01,5.02792851e-02,6.42615007e-02,4.43558939e-02,4.82647921e-02,2.75226448e-04,3.89705533e-02,6.17371254e-02,2.46504095e-01,-2.74501278e-02,6.40533085e-02,5.97414533e-02,5.47195287e-02,-7.40895239e-02,-9.71175214e-02,-6.04767341e-02,1.75569346e-01,4.41501894e-03,-7.59450889e-02,-2.61548427e-01,2.24199641e-01,-8.73338203e-03,-3.45050172e-02,-8.20500140e-02,-3.41348353e-02,4.31021160e-02,-6.10981946e-02,1.32319281e-02,-2.23769132e-02,-1.31198440e-01,1.54369365e-02,5.53641160e-03,-5.23044288e-02,-4.04281716e-02,-3.38652186e-02,1.82086044e-04,8.26834656e-02,5.78720083e-02,6.40354158e-02,-3.10609578e-04,-6.72932298e-02,5.03862038e-02,-1.22751003e-01,-5.72335518e-02,-3.54720469e-02,-6.74809860e-03,-4.96765895e-02,-1.61131767e-01,-1.40688661e-02,2.22438790e-02,-3.56865917e-02,-1.63123404e-01,-1.71241816e-01,-4.80030731e-02,4.36287001e-03,5.07049020e-02,-1.32045957e-02,6.57151197e-02,-3.58881269e-02,-1.48931641e-02,7.11902831e-02,-3.74175394e-02,-1.38403710e-02,-1.36885437e-01,-4.54117951e-02,-1.46506695e-01,-4.58285504e-02,-8.78416483e-03,-1.52258754e-01,9.47788318e-02,6.24049516e-02,1.96251651e-02,4.69523081e-02,-2.98436636e-02,-8.52465718e-03,-3.12456255e-02,-1.01846921e-02,4.23218654e-02,1.47407764e-01,-3.63933071e-03,-8.69739058e-02,-1.16434665e-01,1.26502564e-02,-1.64291360e-01,-1.13842532e-02,-1.40553412e-01,-4.91176601e-02,-1.30390275e-01,5.10375064e-02,2.26343613e-02,-5.74766502e-02,2.82231860e-02,5.07867231e-02,-1.67546206e-02,-8.98711473e-02,4.28381814e-02,2.60017838e-01,-1.59919053e-02,-2.45730126e-01,-4.46930113e-02,1.68126607e-02 -9.91667917e-02,-1.72275641e-03,2.73554737e-02,6.29375534e-02,-5.17138898e-02,4.91330832e-02,7.81911462e-02,-9.79754836e-03,-1.83254964e-01,-1.15610121e-01,-6.47230549e-02,-3.10352902e-02,3.25362018e-02,-3.64156300e-02,-2.94025738e-02,2.82118572e-02,-7.56209890e-02,2.88206864e-02,-5.74713884e-02,-5.00185060e-02,-1.13967805e-01,1.07369705e-01,2.59518751e-02,1.51585205e-02,4.93664869e-02,2.20153336e-03,1.59013185e-01,-1.07778394e-02,-1.03656868e-01,-1.57214330e-02,6.57938849e-02,-1.51707485e-01,1.80908048e-02,-5.27266912e-02,-5.30789644e-02,6.29043459e-02,7.47449920e-02,-4.06130662e-02,-7.00551314e-02,2.27210397e-03,1.11935287e-01,8.40276165e-02,8.24051755e-02,-2.70182078e-02,8.55982979e-03,2.87128175e-02,9.76893065e-02,1.39260157e-01,1.00830332e-01,1.26124220e-01,-5.74262901e-02,-6.84197512e-02,3.23837563e-02,-1.46197922e-02,3.14275176e-02,-1.25153416e-02,-5.04038317e-03,3.47528106e-02,5.81499450e-02,-4.83603958e-02,-6.52950355e-02,-4.14890078e-02,1.34413147e-02,-7.11890170e-02,-1.24855997e-02,1.01799698e-01,4.39809905e-02,1.08454790e-01,3.66123057e-02,-4.50242955e-02,-2.74016275e-02,9.77622039e-02,-7.81201913e-02,1.54647017e-01,-3.81166249e-02,-3.59081745e-03,7.34442603e-02,8.81198590e-02,-2.41747257e-02,-8.98774739e-02,-4.16317366e-02,2.31161699e-01,-2.94783892e-02,1.92392040e-01,8.62331266e-03,-4.35237943e-02,1.28457083e-02,7.89999192e-02,1.46596935e-01,4.97070708e-02,7.26555372e-02,7.43776078e-04,5.33452822e-02,4.78959066e-02,-1.34754026e-01,-2.20567040e-02,-6.25173089e-02,-1.68254343e-02,4.37553362e-02,-1.78702832e-02,-1.31958047e-01,-1.15110136e-01,8.20565805e-02,-3.47742889e-02,-2.09701397e-02,1.08648924e-01,-1.77889605e-02,-6.48609313e-02,9.51605105e-02,2.84101630e-02,1.23990429e-01,-5.35532396e-02,1.14749940e-02,-8.63347767e-03,5.73945146e-02,-7.39159832e-02,1.00108990e-02,8.30935969e-02,-2.26135928e-02,-1.31468617e-02,1.85808357e-01,8.15840244e-02,3.78380426e-02,-9.40994780e-03,-4.70697129e-02,5.23409769e-03,-1.64551532e-01,4.48862682e-02,5.90903847e-02,-4.47332634e-02,1.64447612e-01,3.92058357e-02,-6.92410276e-02,-4.60030100e-02,-4.37340797e-02,1.35632288e-01,1.65117671e-01,-1.99053240e-01,9.01682589e-02,-5.31272590e-02,-1.12737751e-01,6.12311367e-03,1.45177834e-01,-1.64769894e-02,-7.66387289e-03,-6.34081609e-02,-5.05529694e-02,1.03752083e-01,1.74752339e-01,-1.60401506e-01,-6.51204306e-02,-5.52766907e-02,1.57479354e-03 --6.88136264e-02,1.16935538e-02,5.86736530e-04,3.57023201e-02,3.15679287e-02,5.06313386e-02,6.72415469e-02,2.99345093e-02,-8.57978385e-02,-6.10021317e-02,-9.55928050e-02,1.41521230e-02,-4.47745382e-02,-3.42645911e-02,3.55599689e-02,-5.34568143e-03,-9.83454641e-02,-2.07195479e-02,1.35543299e-01,1.27872764e-02,4.05434620e-02,1.30405701e-01,2.22600054e-02,6.00486539e-03,1.96629296e-02,2.54633207e-02,2.29255595e-02,-4.34016958e-02,-2.37470816e-02,2.55327449e-02,2.94354704e-03,-2.08055269e-02,-5.77125553e-02,-1.37898622e-02,-8.52041514e-02,-2.73249959e-02,-8.67809510e-02,-7.76779653e-02,3.75894363e-03,-2.31585733e-02,-1.51747034e-02,1.11496403e-01,-1.10151711e-01,8.43744191e-02,5.61794512e-02,1.02601630e-02,4.40845767e-02,9.13095622e-02,-4.92936202e-02,3.76051522e-03,-1.39456659e-01,2.47199126e-02,-2.63796655e-02,6.31670520e-02,7.58352078e-02,4.19429960e-02,1.13338463e-02,-6.20661522e-02,-1.35593639e-01,-1.01054426e-01,-7.85106306e-02,-5.84750791e-02,-9.97260947e-03,3.34539409e-02,3.20576801e-02,5.03418737e-03,1.77749031e-01,2.60796520e-03,4.82706673e-02,8.13695829e-02,-6.69337931e-02,-1.53300546e-01,3.15724053e-02,3.48473834e-02,4.75185525e-02,-4.16801563e-02,5.23612536e-02,2.45697701e-02,3.80629036e-02,-3.33989842e-02,-1.72510793e-02,4.06100434e-02,5.26199674e-03,2.00700987e-01,8.98231970e-03,5.15006814e-02,1.99840473e-03,3.08133268e-02,6.48486909e-02,5.24711113e-02,2.96422788e-02,-3.74626714e-02,8.83186802e-02,-1.11283087e-02,-1.98726250e-02,-4.28214589e-02,-4.78038843e-02,-8.13900262e-03,-9.52259985e-02,-6.85148340e-02,-9.16665315e-02,4.08680883e-03,-1.70936215e-02,-1.07942468e-01,-4.41361643e-02,-1.21752690e-02,2.42918419e-02,-1.26223274e-01,6.08232824e-02,-1.80128059e-02,-3.29699380e-02,5.39898151e-02,1.09526937e-01,-3.24954250e-02,-7.10932560e-02,-8.00059644e-02,5.06298509e-02,-7.78373964e-02,4.38936269e-02,1.29051696e-02,-8.52560698e-02,5.50471294e-02,2.78332948e-02,8.78852350e-03,-2.19176037e-02,-7.06358999e-03,-9.98166380e-02,7.02585313e-02,3.62973662e-02,1.11434175e-01,-2.53742464e-01,-4.78450774e-02,-4.19805905e-02,-1.46725443e-02,-1.39637539e-01,-1.37237784e-01,-3.57264162e-02,1.84336982e-01,4.00377950e-02,3.63969328e-01,1.05796602e-02,8.36837861e-02,2.04931229e-01,-8.40448710e-02,-8.67287895e-02,6.32539943e-02,3.55471195e-02,-2.46673856e-02,-7.09541838e-02,3.19127117e-01,6.49687052e-02,5.67574166e-02,1.09452381e-01 -2.38278143e-02,2.32086663e-02,3.68575087e-02,-5.04500951e-02,2.25713786e-02,-4.89991070e-02,1.35055887e-01,4.08936028e-02,2.64535466e-02,1.88260897e-01,1.40325005e-01,8.11533564e-02,-1.04380511e-02,-5.51127528e-02,-6.02289920e-02,-4.28052014e-03,-2.20547963e-02,-1.59373144e-01,-5.59613987e-02,1.27419537e-01,-5.06636365e-03,8.88498402e-02,1.35045453e-02,4.43182647e-05,2.94822557e-02,1.30412799e-01,2.02189963e-02,1.06870310e-01,-3.23826521e-03,8.34349139e-02,-2.31128150e-02,9.35402051e-02,-2.28031489e-01,-1.14784628e-01,1.79161042e-02,-7.46002729e-02,7.33724719e-02,-1.09125966e-01,-3.54136939e-03,-1.09271374e-02,5.47812156e-02,2.98747164e-02,3.75303634e-02,2.54738452e-02,7.32817281e-02,1.41470969e-02,-8.25549332e-02,-9.08513643e-02,-3.66627501e-02,-2.53470867e-02,-1.32828339e-01,-2.09495103e-02,-2.93688123e-02,-1.04283815e-01,-3.47552374e-02,1.01071365e-01,-3.37555846e-02,-3.67052802e-02,3.80076029e-02,3.31477314e-02,-1.53541669e-01,-3.53486585e-02,-1.07450432e-01,-1.92188814e-02,-1.54079932e-01,1.64488663e-02,7.09918909e-02,3.15456152e-02,-1.48768683e-02,5.88502112e-02,-7.34013184e-02,-5.25430448e-02,1.16976281e-02,8.46325763e-02,-5.30957539e-02,1.11104707e-01,2.77635051e-01,4.14488778e-02,-6.99840990e-03,2.12486033e-02,-8.19275145e-02,-1.21935784e-02,-2.01145115e-02,-5.55889304e-02,-4.18312074e-02,-6.16949881e-02,2.03416883e-01,1.81107684e-01,-1.83305171e-01,-2.62267638e-02,5.37045536e-02,-1.23736204e-02,-5.59839397e-02,-2.69270546e-02,-9.91486305e-02,1.58943050e-02,4.97366294e-02,3.28810273e-02,-4.08399180e-02,-3.72172391e-02,1.12953768e-01,-6.21898218e-02,2.24986781e-02,1.22377696e-01,-1.59217730e-01,-4.46125201e-02,-3.28617083e-02,-6.19052916e-02,-2.88432925e-02,-8.48873376e-03,3.74815573e-02,-4.34740600e-02,-8.51724263e-02,-1.30639620e-02,5.55266505e-03,-1.55931219e-01,-1.15138392e-02,-3.17128059e-02,1.10635776e-01,5.74599175e-02,1.21382521e-01,-7.74688563e-02,2.40458504e-02,-3.49016635e-02,3.93651099e-02,3.05851784e-03,2.03709106e-01,7.05882984e-02,-1.40468877e-01,-1.12152113e-01,-1.07509101e-01,6.09016433e-02,-5.72931092e-02,-2.24671729e-02,-6.34803729e-03,5.71103480e-02,-3.79771715e-02,-5.73207964e-02,-3.10709566e-02,3.90402898e-02,4.55736248e-02,5.63477338e-02,-5.00945332e-02,1.76671976e-02,-2.61652591e-02,-4.55939907e-03,-1.24639136e-01,1.24053568e-02,1.61396262e-01,5.58639176e-03,1.08725914e-01,-7.39928115e-03,-8.15435574e-03 -7.26803702e-02,1.99702860e-02,-8.64527895e-04,2.24616851e-02,-5.85347371e-02,1.45135547e-01,-1.66984541e-01,-5.43854367e-02,6.10160587e-02,-1.72957488e-01,3.90817029e-02,7.91963703e-02,-3.31518547e-02,-1.54588534e-01,2.27820428e-02,1.11065235e-02,-3.08716339e-02,6.32642391e-02,5.29167387e-02,-5.27086380e-02,-2.52980048e-02,-2.82125050e-03,-8.78260503e-02,5.45008878e-02,8.24656115e-02,-5.40300595e-02,-1.66609184e-02,7.99736135e-02,6.55628303e-02,3.56624726e-02,-7.90879771e-02,-4.85869366e-02,-9.26904656e-04,6.55707205e-02,-6.66466586e-02,-3.69190835e-01,-6.98434105e-02,-1.89160606e-02,6.65692056e-02,6.79026318e-02,-1.48599869e-02,4.12935981e-04,2.47895863e-01,-6.03620795e-02,-4.96168147e-02,1.27940215e-01,-6.96671446e-02,-7.25737280e-02,2.24724802e-02,-1.55222715e-01,-2.47094316e-01,6.43347371e-02,4.19778625e-02,4.60109621e-02,-6.77406011e-02,1.02499907e-02,4.12065049e-02,3.48153290e-02,1.81337878e-02,-6.66833906e-02,1.04843038e-01,1.42167009e-01,-1.06590209e-02,-3.30757700e-02,1.83980886e-02,7.93264705e-02,2.32995385e-02,4.22816617e-02,6.37531650e-02,2.43948967e-02,2.84317049e-02,6.33926571e-02,-1.69028965e-02,2.82619891e-02,-5.50590543e-04,-2.13818867e-02,-1.17798374e-01,1.94568933e-02,-1.39266413e-02,-1.40972743e-02,-7.51093825e-02,4.95911657e-03,-3.25455770e-03,-1.70508337e-02,8.19906629e-02,-5.32107584e-02,-9.68727852e-02,-9.84991590e-02,3.23259426e-02,-1.27951138e-01,4.23721438e-03,2.65590201e-02,2.16655852e-02,-1.15788601e-03,-1.17070243e-03,6.70573778e-02,-4.38122356e-03,-4.52723068e-02,-4.45290934e-02,-5.30066210e-02,2.67916759e-02,-8.58397680e-02,2.03473670e-02,6.80633846e-02,3.70524190e-02,-1.71269565e-03,5.04067737e-02,9.49403781e-02,5.34599553e-02,1.00769215e-01,-4.15774979e-02,-1.04728950e-02,-9.45412803e-02,7.14921839e-02,4.48053967e-04,-5.69568530e-02,5.22576882e-02,8.89481058e-02,2.47605545e-02,1.69912198e-02,2.41005506e-02,-2.33175525e-02,-1.25828528e-02,-3.69486551e-02,-8.25778880e-02,3.00264905e-02,5.50411681e-02,8.03146002e-02,-2.29444063e-02,-1.93091015e-02,-2.97188811e-01,-5.99644327e-02,-1.82648786e-03,4.20609166e-02,-9.21072743e-02,7.74091623e-02,8.19237923e-02,-3.72125348e-02,-1.04115935e-01,-2.47194912e-02,5.87689788e-02,1.23383136e-01,1.09506635e-01,5.56416183e-02,1.01572111e-01,-6.09493679e-02,-1.89010085e-01,-5.45509693e-02,6.09480009e-03,-5.73929575e-03,-1.41550844e-01,2.89534906e-02,-4.51323879e-02 -1.16417712e-02,8.25895623e-02,-5.69421076e-02,9.41042883e-03,6.83769337e-03,6.37989270e-02,-2.65899878e-02,4.74673200e-02,-5.76402172e-02,3.26759387e-03,-1.10157479e-02,-4.19946639e-02,8.31535000e-02,7.05189668e-02,-4.38219855e-02,6.96226192e-02,9.07924959e-02,-1.20717478e-01,1.00971389e-01,6.44352907e-02,-3.70949423e-02,6.34040193e-02,-2.65871462e-02,-7.50768647e-02,-1.30100625e-02,-7.26647124e-02,-8.63021241e-02,1.63933743e-02,5.02791089e-02,-1.80837941e-02,7.45572700e-03,-3.46744682e-02,3.66331046e-02,-9.00913556e-02,-8.16101033e-02,7.53676683e-02,-2.78638383e-02,8.93574425e-02,8.41974321e-02,-4.92784338e-03,5.26886071e-02,-1.27887642e-01,-1.91611090e-01,-5.22375159e-02,-5.17349950e-02,5.96801026e-02,6.82096546e-03,1.12543580e-01,7.57415211e-02,-1.40806288e-02,4.93374676e-02,1.61380033e-02,-4.43857171e-02,-4.93276554e-02,1.70207661e-02,4.96691660e-02,-2.50182349e-03,-1.52921544e-02,9.61588616e-02,8.92481333e-02,-9.84673323e-02,7.39327080e-03,4.19620519e-02,4.15291721e-02,-3.69841602e-02,2.44613195e-01,-2.44005056e-01,1.19849124e-01,-4.63425749e-02,9.52366694e-03,-5.10178567e-02,-1.18186474e-01,2.23731381e-02,-2.12045181e-02,-1.39434843e-05,7.16112249e-02,5.18325270e-03,2.80493886e-02,-2.88300623e-02,2.66228148e-02,-3.11449945e-02,-5.90050321e-02,2.65813861e-02,-8.94071676e-03,-4.95834351e-02,-4.92804152e-02,-2.59619281e-02,-1.38547426e-02,-9.46221127e-02,6.99274543e-02,-3.63015172e-02,-7.37007005e-03,-1.16451187e-02,-4.26560909e-03,5.56191374e-02,-6.22312074e-03,1.94770482e-02,2.38300866e-02,-5.79743318e-02,5.31511345e-02,-1.09165161e-01,8.59057539e-02,9.53781806e-03,8.08383902e-03,1.07572648e-01,-8.59706085e-02,2.33576253e-02,4.87319886e-02,1.10624183e-02,-1.05682104e-01,8.11222285e-02,7.36507664e-02,-4.61030908e-02,2.42308937e-02,-1.23885063e-02,2.06479009e-02,5.78573870e-03,5.32387607e-02,-2.38024702e-02,6.74565276e-02,3.26195439e-02,-9.39947968e-03,-4.70485649e-02,5.26116936e-02,8.94049117e-02,5.07996358e-03,5.01958352e-02,-2.07544281e-01,5.73742633e-02,2.41430831e-02,-1.99367532e-01,1.28560408e-02,3.64663424e-02,-1.44414630e-02,7.53543322e-02,-5.03608092e-02,1.39212825e-01,-1.05751200e-01,1.62091797e-02,5.00850279e-02,-3.55006273e-04,1.17004756e-01,8.14305162e-03,4.38290933e-02,-3.06555006e-02,-1.01575810e-01,-1.93159345e-01,3.58165976e-01,7.76262096e-02,1.83172359e-01,-2.71274007e-01,5.50220311e-02,2.59902284e-02 --1.22527221e-01,-2.24342804e-02,-9.73409684e-02,-6.40204400e-02,-1.05770252e-02,1.70875051e-02,9.17181203e-03,2.65083949e-02,-4.13767394e-02,2.54247217e-02,2.87382705e-02,-9.64260205e-03,-3.76371315e-02,6.91192516e-02,-4.05581286e-03,-1.01301161e-01,1.03068993e-01,1.44325420e-01,-8.98924905e-02,-4.05303082e-02,9.85524002e-02,-2.25514316e-02,2.89100142e-02,-1.63428311e-02,-1.66035940e-02,-4.08784537e-02,-4.19726404e-02,-4.89533091e-02,-8.59822232e-02,-3.77349205e-02,3.26433338e-02,-7.12504211e-02,-1.84674806e-02,-1.09618755e-01,2.87497621e-02,9.45038793e-03,7.20553677e-02,1.21245236e-02,-4.54687398e-02,3.50627594e-02,-2.73903922e-02,-2.68076310e-02,3.18040067e-01,-7.50339436e-02,1.28917457e-02,-1.80774002e-02,1.35651450e-02,-6.73856469e-02,1.06685302e-01,8.54736227e-02,2.83624819e-02,-5.80438377e-04,1.65201434e-01,-4.36194696e-02,1.84850714e-02,-6.43684692e-02,-7.22517027e-02,-1.45137877e-01,-8.09430148e-02,5.53098832e-02,-1.40912819e-01,2.45416278e-01,1.30673515e-03,-2.05070361e-02,-2.99406270e-01,-1.50240762e-01,6.41778942e-02,-9.15867222e-03,5.17534360e-02,-9.69986339e-02,6.96591741e-03,-1.05966426e-01,-9.94425235e-02,-5.99145225e-02,-5.48961950e-02,-1.23515463e-02,7.21371730e-02,-5.02075060e-03,7.81388165e-03,-8.31181414e-03,2.46993482e-02,-1.05969422e-01,-4.74348252e-02,-8.31730040e-03,-2.75546072e-02,9.24970563e-02,-5.38850590e-02,2.28234258e-02,-4.00233087e-02,1.41025590e-02,4.19559356e-03,-8.01497386e-02,-6.42066341e-02,-9.29475925e-02,8.70352087e-03,1.03895379e-02,-3.64826005e-02,1.43181791e-02,8.00517712e-02,1.86563369e-02,4.15760497e-02,1.56127566e-02,6.98226262e-03,-1.20952702e-01,3.64065876e-02,5.68419060e-02,5.90938396e-02,-7.01081386e-02,-9.05213479e-02,1.62088304e-01,6.05813483e-02,3.07339564e-02,-1.80307069e-02,-1.24114551e-02,1.16378134e-01,1.08487859e-01,-6.35040488e-02,-1.62041301e-01,-4.52244602e-02,-1.15987336e-02,-5.65909932e-02,3.82428331e-02,3.09476025e-02,1.51627674e-02,-2.51821933e-02,-2.74740611e-02,2.67508083e-02,-1.31882228e-01,-1.55821948e-02,-3.12519944e-02,-2.03332983e-01,-2.94612687e-03,1.49388284e-02,-8.45048015e-02,9.10838194e-02,6.90489956e-03,1.24377534e-01,-1.35865678e-01,7.62428773e-02,1.19564385e-01,-8.16157937e-02,1.11593413e-01,1.17746889e-01,-7.57179436e-02,7.44683580e-02,3.71268934e-03,1.66444508e-01,-6.85545015e-03,1.65213755e-02,3.76779719e-02,-1.18182410e-01,-2.88837965e-02,-1.20703541e-02 -9.18860499e-02,8.48336524e-02,2.13239773e-02,-1.66972782e-02,-1.60170771e-02,6.73053896e-03,7.96404605e-02,-1.90448893e-02,1.20076112e-01,1.53993346e-01,-1.80796121e-02,1.67644067e-02,-2.16231657e-02,-5.69506389e-03,-7.81056872e-03,-5.86162812e-02,4.29917998e-02,1.67354145e-02,7.44729116e-02,-1.07034969e-01,7.16670016e-03,1.16560132e-02,-7.99550168e-02,5.45244865e-02,1.89510861e-01,6.86741987e-02,8.45367751e-02,-3.06910375e-02,-1.49311227e-02,3.45314164e-02,1.86658957e-03,1.12320959e-01,4.43973870e-02,1.79409678e-01,1.23986163e-01,6.64722314e-02,2.36304265e-02,1.72145712e-02,-6.98024323e-02,-3.33502884e-02,-6.04837000e-02,3.91732358e-02,2.86437502e-03,-8.98472178e-02,-4.09802025e-02,-4.71374488e-02,-1.44803095e-01,2.64323728e-02,-7.81659313e-02,2.82240246e-02,5.67475572e-02,1.80990328e-02,1.67614170e-01,2.57590467e-02,-1.05096084e-02,3.68594740e-02,-6.18454527e-02,1.02937970e-01,1.92743313e-01,-4.43852856e-02,-1.70726414e-01,-1.14382570e-01,8.26974964e-02,5.62610826e-02,1.84695613e-01,-1.54412055e-02,3.55394250e-02,3.96608229e-02,1.21250233e-02,-1.58016675e-01,2.95540802e-02,5.20490710e-02,-8.40244076e-02,-5.36873776e-02,3.40729579e-02,-6.47848152e-02,-5.76244135e-02,3.64681415e-03,-2.12206727e-02,2.82935178e-02,5.45596412e-02,-1.09535072e-01,-1.34974810e-01,-9.37979810e-03,6.10629228e-02,6.06858768e-03,3.45369436e-02,8.73226685e-03,9.12227849e-02,-1.26329653e-02,3.73346834e-02,-1.12541374e-01,-9.91047168e-02,-3.14815507e-02,3.71660161e-02,1.21554492e-01,1.37253250e-02,-7.10004687e-03,3.83038809e-02,3.65549750e-02,1.42303908e-01,1.87335010e-02,2.28759982e-02,-8.74533517e-02,-6.07754497e-02,-1.39327506e-02,3.39454209e-03,4.52854201e-02,5.88651261e-02,1.07006491e-01,-7.48372490e-02,7.76894698e-02,1.49092504e-01,6.49554161e-02,-3.89739731e-03,9.95299468e-03,2.59495249e-02,7.28463007e-03,1.45554769e-02,3.92499279e-02,-8.23297462e-03,-2.68248101e-02,-8.32351468e-02,4.79023203e-02,-7.56576142e-02,7.83268626e-02,6.17485689e-04,2.00488249e-01,-6.85224664e-02,1.16581222e-01,-1.29371699e-01,-3.94234911e-02,4.27915029e-02,1.07430144e-01,-2.98317334e-02,1.03572134e-01,-3.11729664e-02,-2.43121696e-02,4.07344563e-03,1.29103070e-01,-6.02189610e-02,5.22711302e-02,-1.27172643e-02,-4.81894802e-02,-1.00203787e-01,-9.52551306e-02,1.13210440e-01,3.22039328e-01,1.79745846e-01,-1.30325845e-02,-1.94277325e-02,-8.82091790e-02,-4.90187941e-02 --1.48835148e-01,-1.86757826e-02,-6.30636999e-02,-2.35545880e-02,-3.12762788e-02,1.60968744e-02,7.16533415e-02,4.71188215e-02,2.73079258e-02,8.92758302e-02,-6.25000233e-02,-1.20401794e-01,-2.85230658e-02,-1.68338757e-02,-7.76512001e-02,1.06783751e-01,6.19503140e-04,-2.56149153e-02,-5.24196893e-02,-6.97270337e-02,-1.39166589e-01,1.04532125e-01,1.08339272e-01,-3.10283968e-02,3.27757966e-02,2.85252071e-02,-2.82673246e-02,2.88951372e-02,-5.74557294e-03,6.00466353e-03,2.52341955e-02,-1.68636897e-02,1.67721242e-02,4.53494433e-02,-7.85092731e-04,8.75383933e-02,-4.27257174e-02,4.99281818e-03,-3.87075457e-02,-5.12261110e-02,-1.03299205e-01,-1.55188705e-01,-3.48497784e-02,4.55416257e-03,-3.74696404e-02,8.10418736e-02,-1.29230038e-01,1.02085908e-01,-1.99340436e-01,-4.76872821e-02,4.54707340e-02,-6.67574041e-02,-1.35641666e-01,-6.56739893e-02,4.12645100e-03,1.27734860e-01,3.14971883e-03,8.93109489e-02,8.53007180e-02,-1.28645499e-01,7.64211550e-02,-3.35991764e-02,-1.71894177e-02,-1.02068487e-01,9.62940540e-02,-1.43250129e-01,6.66158068e-02,1.02505817e-01,-3.31720392e-02,5.11917286e-02,-1.55619620e-01,1.12275214e-01,4.13604624e-02,-1.04420375e-02,-8.96287482e-02,-3.19106802e-02,7.17393838e-02,5.31312923e-02,-1.30864273e-01,-1.53414280e-04,-3.07380344e-02,7.99998425e-02,-1.39224131e-01,-1.47889789e-02,2.71729876e-02,4.58388590e-02,8.51406085e-02,-6.77638767e-02,9.60325809e-02,-9.29023606e-03,-1.60252005e-02,-1.77864137e-01,-2.74767064e-02,-2.75914362e-02,-1.65304327e-02,-7.21290200e-04,5.78165849e-02,-5.66289689e-02,-9.16717984e-03,9.64091981e-03,-4.09909734e-02,-6.23780960e-02,4.77403746e-03,7.15489002e-02,1.35428916e-02,5.94533255e-03,-6.86555545e-02,-3.56978847e-02,-2.06806070e-01,2.97683180e-01,2.89830364e-02,1.22250169e-02,-6.43316314e-03,2.12953615e-03,-8.41225455e-02,7.31883364e-02,6.98187707e-02,1.63289888e-03,-9.88807946e-03,3.37602863e-02,-2.71370561e-02,-5.22574750e-02,-9.47924614e-02,1.59334944e-02,8.43554458e-02,2.34286478e-02,6.95435360e-02,-7.66227566e-02,-1.27606420e-01,-8.17288415e-03,2.22070366e-02,1.74160828e-02,-7.08704427e-02,-4.16638752e-03,2.45549992e-02,-7.46399435e-03,-8.71600180e-03,-4.69222883e-02,6.59483224e-02,1.65332879e-02,4.00395939e-02,-1.62376615e-02,1.63097208e-01,-1.24360717e-02,2.32182701e-01,9.19211081e-02,-4.57052460e-02,-9.19885860e-02,-1.72765795e-01,2.03454162e-02,-2.50372756e-01,2.81683692e-02,4.73717303e-02 diff --git a/c-concoct/test/PCA_transformed_data_gt1000.csv b/c-concoct/test/PCA_transformed_data_gt1000.csv deleted file mode 100644 index 167fa98..0000000 --- a/c-concoct/test/PCA_transformed_data_gt1000.csv +++ /dev/null @@ -1,444 +0,0 @@ -contig,0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24 -contig-309000000,3.44240380e-01,6.25698181e+00,-9.69791467e-01,1.09745763e+00,-9.62334521e-01,9.59070870e-01,-5.37774726e-01,6.43004685e-01,1.13450853e+00,1.05743711e+00,2.81188719e-01,3.88739670e-01,6.41421918e-01,2.09899487e-01,9.61344594e-01,2.01769110e+00,-4.73311432e-01,9.15084857e-01,-8.00987214e-01,7.45311248e-01,3.32595870e-01,-4.74924250e-01,-3.86607057e-01,4.31872005e-01,1.17951580e+00 -contig-4559000000,-5.90970185e+00,-5.94939337e+00,-1.77014553e-01,-6.94379558e-01,-1.69369383e-01,5.30759583e-02,2.87987399e-01,1.64532994e-03,-1.57609667e-01,1.86455620e-02,5.75262354e-02,-1.55380296e-01,2.43746677e-01,-5.22860126e-02,6.67607096e-02,-5.74294349e-02,-4.46737877e-01,4.77527369e-01,-4.43540681e-01,-2.54258765e-01,-3.86221209e-01,-2.29220675e-01,-4.48194648e-01,4.72585251e-02,-4.51862520e-02 -contig-3573000000,1.35921335e+01,-1.44940358e+00,-6.18529778e+00,-6.76195646e-01,-2.35570923e-01,-2.00766373e-01,-4.95655540e-01,7.82804907e-01,-5.38319225e-01,-3.16028920e-01,-5.03687898e-01,3.63242113e-01,7.91144442e-03,-3.19357735e-01,1.39299689e-01,1.12347073e-01,-5.06410232e-01,-2.89603060e-01,2.81345189e-01,-3.13197414e-02,8.60643013e-02,8.00960836e-02,-1.17146121e-01,1.93749770e-02,-6.67367315e-02 -contig-167000000,-7.40407946e+00,-2.90687832e+00,-4.23666808e+00,-4.02181057e-01,-1.91867576e-01,-9.39203950e-02,7.70322630e-01,5.14136833e-01,-6.96611069e-02,1.72913555e-01,2.11542734e-01,-4.13797742e-02,-1.84437778e-01,-7.02689351e-02,2.27162431e-01,2.90769420e-02,-5.39664640e-02,2.36282346e-01,-4.07928088e-01,-1.83877418e-01,-1.70687917e-01,-1.01859018e-01,4.28172766e-02,-6.58994216e-03,-1.85417605e-01 -contig-315000000,1.01510135e+01,-1.59489001e+00,-8.43535597e-01,2.94841428e-01,2.21030411e-01,1.60418248e+00,6.77563777e-01,-1.60668012e+00,3.97672203e-01,7.36840260e-01,8.09439060e-01,-4.26643981e-01,-3.13841206e-01,7.53172662e-01,8.29015925e-02,-6.51125428e-01,8.33424314e-01,4.17602888e-01,-1.11587411e+00,2.34731134e-01,-3.23179767e-01,-7.26306471e-02,5.70930801e-01,3.30105167e-01,-1.96841422e-01 -contig-305000000,4.86698170e-02,6.36554636e+00,-5.84174518e-01,1.11643757e+00,-9.71671118e-01,1.73467833e+00,-6.44071182e-01,-1.92022588e-01,-3.26198817e-01,-1.44526306e-01,-3.23599451e-01,-3.96922451e-02,1.00922131e-01,-6.76642807e-01,-3.99179872e-01,2.46480916e-01,3.43281525e-01,-2.03312481e+00,4.85669791e-02,-3.87819490e-01,-1.16606574e-01,-7.38410311e-02,-1.92105731e-01,2.22767014e-01,-3.91424820e-01 -contig-242000000,2.06331303e+00,-4.27003358e+00,1.02386883e+01,-1.26398683e+00,-9.60313584e-01,1.75310556e+00,-7.18282834e-01,5.34123858e-01,-1.92544296e+00,1.08145494e+00,1.17223393e+00,1.65325134e+00,-5.39638931e-01,4.40886393e-01,5.79292968e-01,3.53581284e-01,1.59228809e+00,-4.74179054e-01,-7.63245877e-02,-1.31800202e+00,-4.83251736e-02,8.70992894e-01,8.50488708e-01,-6.69129280e-01,1.32701012e-01 -contig-9000000,1.41510600e+01,-3.13975592e+00,-4.68564789e+00,-8.45481581e-01,-2.49854913e-01,-9.44257863e-02,-1.15050216e+00,5.95173514e-01,-5.56171338e-01,-5.69338971e-01,-2.78117437e-01,4.34204868e-01,-3.44627117e-01,-5.08493422e-02,2.84339858e-01,-2.41996861e-01,-5.88743191e-01,-1.03618533e-01,1.63781707e-01,-2.47188638e-01,-2.89232425e-01,-1.26553075e-01,-1.73504914e-01,1.14398350e-01,-9.91672273e-02 -contig-286000000,-4.22635250e-01,3.96262222e+00,1.42892905e+00,8.09941732e-02,-3.44052924e-01,1.74368137e-01,-1.32176283e-01,-3.16898688e-01,1.45501915e+00,5.45905885e-01,1.24436679e+00,3.12665175e-01,-9.83748594e-01,8.69742281e-01,-8.95422923e-02,-2.20646959e-01,-8.41302791e-01,1.15201504e-01,-5.90054861e-01,3.79021661e-01,-4.49843857e-01,1.10132193e+00,5.66765360e-03,1.03779048e+00,4.22831058e-01 -contig-17000000,1.27266571e+01,-5.32624976e+00,6.24133261e-01,-9.00854897e-01,-1.12572014e-01,8.58259611e-01,-1.27223867e+00,-2.96415096e-01,-7.84675544e-01,-6.09683672e-01,9.55939603e-01,-1.89654428e-01,-3.93002328e-01,-4.48773436e-02,5.42182773e-01,-4.49563865e-01,-1.11408189e-01,-1.48424231e-01,-4.33477376e-01,-3.36578249e-01,-4.72007183e-01,-1.79489539e-01,-1.40605533e-01,3.92905540e-01,2.19059037e-02 -contig-236000000,-4.73233900e-02,4.96375800e+00,2.28434211e-01,2.62056833e-01,-1.18192182e-01,6.10001803e-01,-3.44573490e-01,-2.83776542e-01,-7.08498904e-01,-2.92959020e-02,5.54566026e-01,6.81658597e-01,9.63064359e-01,4.51872129e-01,9.64518553e-01,-3.46842954e-01,-5.37426385e-01,-7.32590599e-01,2.83124837e-01,-3.04852331e-02,-1.18651245e+00,-4.36045839e-02,7.30743341e-01,1.20453818e+00,-4.26037497e-01 -contig-0,1.33260466e+01,-1.05779942e+00,-7.28500865e+00,4.67898681e-02,-1.77629747e-01,2.57809591e-02,-6.56324349e-01,9.54519782e-01,-2.87306331e-01,-4.15142338e-01,-8.99509394e-01,4.08285224e-01,3.41603493e-01,-6.27390195e-01,-1.20992172e-01,3.97805050e-02,-2.49813385e-01,1.52442428e-01,5.87662082e-01,1.56574134e-01,3.57146383e-01,8.02518386e-02,1.45037396e-01,1.64831715e-02,3.75618423e-02 -contig-258000000,-2.96869300e-01,5.63544865e+00,-2.30765891e-01,1.31511726e+00,-2.40616899e-01,8.88909354e-01,-1.55958107e-02,1.04044200e-01,2.38483023e-01,2.54565754e-01,3.44633151e-01,-5.95918219e-01,7.45246766e-01,7.70236749e-01,-1.15928504e-01,3.28410472e-01,4.41099142e-02,-5.92078587e-01,-1.59143275e-01,-7.92781733e-01,-1.61620417e-02,-9.74503814e-01,7.22774615e-01,9.04404202e-02,1.19274259e+00 -contig-41000000,-6.54714163e+00,-5.70504735e-01,-4.19411027e+00,-2.44661818e-01,-9.67356525e-01,6.40006749e-01,8.98525663e-01,5.27032868e-01,5.78631039e-01,-3.06393569e-01,2.26866072e-01,-1.90059477e-01,4.15411715e-01,-4.61539439e-01,6.28031975e-02,1.07029333e-01,2.21899603e-02,2.22065673e-01,3.78893691e-01,-2.02943499e-01,8.67802642e-03,3.41258750e-02,-1.41918615e-01,-2.30079525e-01,1.77370222e-01 -contig-254000000,7.04787581e-01,3.10895270e-01,4.62111044e+00,-9.77679810e-01,2.33750098e-01,-6.73076364e-01,-2.24526538e-01,-4.50429153e-01,9.94776388e-01,7.18480765e-01,-5.01740683e-01,7.85871038e-01,-4.38718523e-02,-3.33612613e-01,-7.26332503e-01,-7.76283878e-01,-8.01547065e-01,-1.18508927e-01,-4.33839507e-01,-2.76083477e-01,5.20419108e-01,-8.25302871e-01,-1.60233966e-01,4.86586229e-01,-4.93347571e-01 -contig-252000000,-3.59926145e-01,6.42083845e+00,-7.66981754e-01,9.83297008e-01,-2.43678752e-01,1.10392472e+00,-1.05958356e-01,-1.22790973e-01,-8.11441397e-01,1.05635194e+00,-6.95436661e-02,-7.36942944e-01,-1.91212290e-01,-2.85211715e-01,3.36239941e-01,5.33469903e-02,9.85697844e-02,-1.21928712e+00,-1.79712425e-02,-1.31765204e-01,-1.71088339e-01,-4.78428198e-01,1.07210916e+00,2.98006453e-01,1.86754744e-01 -contig-272000000,-3.23813722e-01,5.01012841e+00,1.72288612e-01,2.65234631e-01,4.12414298e-02,-1.15241291e-01,2.72391108e-01,-4.77299208e-01,5.15866698e-01,-8.47689392e-02,3.55557674e-01,4.35059121e-01,-8.31871060e-01,6.13180302e-01,6.40004008e-01,3.54610138e-02,1.75072035e-01,8.28424012e-01,7.20959549e-01,3.42190876e-01,-7.79103751e-01,-1.61112889e-01,-5.98736609e-01,3.90840757e-01,5.11932413e-01 -contig-387000000,-2.61985540e+00,-1.34345310e+00,6.03455479e-01,8.57371632e-01,5.67249589e-01,-2.78805083e-01,-1.33847107e+00,-1.42392784e+00,3.99948314e-01,-3.59590487e-02,7.26114807e-01,5.02311412e-01,1.51136740e+00,-4.76229218e-01,-3.77570287e-01,-3.40505796e-01,-9.45240231e-01,-7.22281364e-01,-1.03360499e-01,3.76370890e-01,4.40046110e-01,1.30643733e-01,7.21037667e-01,8.76596415e-01,2.72843872e-01 -contig-190000000,-6.59217100e-01,3.97246070e+00,7.12972226e-01,9.95233579e-02,9.67655033e-01,-3.92948831e-02,6.74680421e-01,-9.07020326e-01,-4.39452116e-01,6.16199106e-01,1.03207070e+00,-6.14034586e-01,-1.10680632e+00,1.27673070e-01,-5.37647045e-01,-7.40256189e-01,-9.21853423e-01,1.32209483e+00,2.26866790e-01,-3.24744567e-02,-4.28032877e-01,3.89606590e-02,1.05990840e+00,4.61366645e-01,-8.38611975e-01 -contig-135000000,-3.03541655e+00,-4.48848756e+00,2.47974938e+00,-5.65503820e-01,7.62882958e-01,3.49770251e-02,-1.65039525e+00,1.34649636e-01,-5.86003270e-01,6.98843743e-01,1.30854604e-01,6.63566322e-01,1.50526692e-01,1.73898627e-01,-1.16169513e+00,2.60752726e-01,-4.96969933e-01,3.80011124e-02,2.18751200e-01,3.15528973e-02,-2.53974541e-01,3.30076051e-01,-2.09229436e-01,-5.04101552e-01,-3.40533006e-01 -contig-111000000,-1.36284350e-01,1.51754171e+00,2.70022575e+00,-1.33629708e+00,2.37761204e-01,-1.44965102e-01,5.33688581e-01,-3.44284206e-01,-6.10589299e-01,-2.53231331e-01,-2.70441179e-01,1.96109668e-01,2.16655072e-01,4.57056749e-01,1.01463584e-01,-3.34753057e-02,-3.74042356e-01,-1.67996123e-01,-5.37913801e-01,-1.31034990e-01,-3.47036898e-01,-2.53186837e-01,2.10967995e-01,7.54078705e-01,-2.89691037e-02 -contig-63000000,1.15659501e+01,-2.27251044e+00,-1.93306613e+00,-4.27257431e-01,-6.04660394e-02,6.22438146e-01,1.57299273e-01,-1.19404607e+00,2.14679529e-01,-3.81056050e-01,9.59290494e-01,-1.60361058e-01,-6.87326611e-01,3.42839199e-01,2.24652621e-01,-1.59382739e-01,2.66160438e-01,1.32534924e-01,-1.25045416e-01,2.12638722e-01,-3.42853839e-01,1.06371596e-04,2.66026377e-01,2.04414670e-01,2.54769290e-03 -contig-8000000,-6.94185388e+00,-2.67275427e+00,-3.85770416e+00,-1.97878482e-01,1.31286264e-01,-4.65073440e-01,6.76745574e-01,3.78898554e-01,-4.23840297e-02,1.28302581e-01,2.43567199e-01,2.02110320e-01,-1.05844768e-01,-1.37249188e-01,1.08657622e-01,-1.82947928e-01,3.69222681e-02,3.55222381e-01,-2.07688978e-01,-2.71533761e-01,-2.47811131e-02,-6.45717778e-02,-1.54050929e-02,3.47618400e-02,2.47238492e-02 -contig-259000000,2.31701483e+00,-4.74567273e+00,1.02280238e+01,-5.05547026e-01,-1.16662711e+00,2.01547299e+00,3.91407326e-01,-5.95315058e-02,-1.68307864e+00,-2.67327758e-01,3.62970251e-01,1.03559675e+00,4.37729814e-01,-2.07112500e+00,6.31772195e-01,6.97106961e-01,-2.91450428e-01,-5.58512983e-01,-6.72076256e-01,7.80209511e-01,-3.61701898e-01,9.01108067e-01,7.27933118e-01,-1.51563782e+00,-2.70532095e-01 -contig-4920000000,-7.22364036e+00,-2.65994669e+00,-3.95638854e+00,-2.69735849e-01,-6.58276150e-02,1.08784026e-01,4.95994725e-01,2.20309143e-01,-5.75315566e-01,7.80165329e-03,3.68114040e-01,-1.09301130e-01,-1.84496487e-01,-9.33531452e-02,1.62813097e-02,-1.39956234e-01,3.62602773e-01,2.45016447e-01,-2.95656112e-01,-6.82382972e-02,-2.57137033e-01,-2.94142663e-01,-1.95412394e-01,-7.89913201e-02,-3.32138675e-03 -contig-139000000,-6.70566627e-01,3.71504616e+00,7.56672357e-01,-9.89263860e-02,-2.49437803e-01,2.43780281e-01,-3.43372432e-01,5.62479537e-01,1.86066587e-02,-4.99143670e-01,4.49788265e-01,2.95620972e-01,4.92608906e-01,1.34921116e+00,-1.00896015e+00,-6.64339813e-02,-7.92877129e-02,-2.71818341e-01,2.40614916e-01,-5.16355299e-01,5.91978758e-01,-1.83460330e-01,-1.05832840e-03,-6.38783430e-01,-1.35076892e-01 -contig-179000000,-6.78678682e+00,-1.45929648e+00,-4.49272059e+00,4.02453588e-01,1.67073810e-01,3.20039800e-01,4.76080146e-01,2.45626329e-01,-9.33046396e-01,1.07208311e-01,-8.46999342e-02,-3.99594904e-01,-1.97618439e-01,-3.08827115e-01,-1.32056627e-01,-8.68989689e-02,2.56150629e-01,-3.86420941e-01,-1.78697331e-01,1.33267630e-01,-2.30601831e-01,-4.84956829e-02,2.30257431e-01,-1.21866368e-01,1.34230894e-01 -contig-157000000,-4.11878514e+00,8.62557598e-01,-2.85895849e+00,1.51276592e+00,3.53277316e-01,2.17037258e-01,-3.85528364e-01,-8.62283890e-01,2.63621703e-01,5.22233403e-01,6.28588217e-01,1.09596357e+00,-6.88048518e-01,-5.84651218e-01,-7.53956283e-01,-1.32178428e-01,5.33871401e-01,-2.90166189e-01,5.44700929e-01,8.19715572e-01,4.66264310e-01,2.74295157e-01,-9.26688118e-03,-1.39367612e-02,9.43967452e-03 -contig-402000000,-3.67995886e+00,-2.77344789e+00,1.25817477e-01,-1.98133028e-01,4.69961490e-01,2.16729341e-02,-3.58365933e-01,-5.13063574e-01,4.76711933e-01,-2.80302894e-01,-2.08715564e-01,-2.97058757e-01,5.41550229e-03,1.37219505e-01,-2.92821477e-01,4.11933975e-01,-1.14579323e-01,3.91205067e-01,5.30715785e-01,-6.43806025e-01,7.77759488e-02,1.18917539e-01,-1.01284880e-01,4.39180036e-01,3.20041609e-02 -contig-505000000,4.50812881e-01,2.89244474e+00,1.56909118e+00,-5.51148887e-01,6.76445800e-02,-7.01088217e-01,1.97482028e-01,1.75718256e-01,2.95173939e-01,-2.25517202e-01,-5.09559191e-01,-1.45049689e+00,7.66840514e-01,-4.94048634e-01,4.08707870e-01,-1.14005416e+00,-3.83212582e-01,5.74914395e-01,-1.42945529e-01,-2.59412639e-01,-1.86977054e-01,-1.56355218e-01,-2.20103418e-01,-5.45949531e-01,1.19562459e+00 -contig-300000000,1.51311343e-01,5.49128065e+00,-1.65696168e-01,2.42067307e-01,1.14509548e+00,-2.44729942e-01,-3.58394722e-01,6.91089598e-01,-1.42324559e+00,6.45046611e-01,6.49539143e-02,2.78610812e-01,1.08593440e-01,-8.35635980e-01,-7.00409442e-01,-9.40394732e-01,-3.72843796e-01,-1.04469376e+00,-5.12395617e-02,-1.11621603e-01,-1.82743676e+00,6.98077823e-01,-7.57740017e-02,3.03713182e-01,3.72249153e-01 -contig-33000000,-4.11002409e+00,-5.62466044e+00,1.62169384e+00,-5.24605495e-01,-1.66042683e-01,-1.89916653e-01,-4.73390481e-01,1.75139961e-01,7.04810677e-01,-2.27360407e-01,-3.53965874e-01,-5.22739365e-01,4.67827599e-01,-3.02636530e-01,-8.31133634e-02,3.54620811e-01,-1.96476370e-01,3.93427252e-01,2.21262747e-01,8.60008050e-02,4.87108235e-01,1.68321341e-01,-2.12225136e-01,5.21741668e-02,-2.96922308e-01 -contig-62000000,1.19716640e+01,-4.35902731e+00,-4.71614594e-01,-6.89961015e-01,-1.35569002e-01,1.12717894e+00,-1.16231758e+00,-7.60201159e-01,4.05442208e-01,-2.75782699e-01,2.78894528e-01,-2.45675090e-01,1.91369010e-01,3.86561307e-01,6.44232343e-01,-5.41369055e-01,3.29278274e-01,3.30876308e-01,-1.05050001e+00,-7.16725015e-01,-3.38857154e-01,-3.93241857e-01,-1.88340760e-01,1.28824914e-02,-5.00011292e-02 -contig-27000000,1.22841999e+01,-4.10367480e-01,-6.50324908e+00,-9.39926439e-02,1.11257904e-01,3.42751048e-01,-2.71402382e-01,6.22033248e-01,-1.90368863e-01,-9.91126235e-02,-4.84457869e-01,1.16769764e-01,8.31301799e-02,-5.53826019e-01,-2.66358483e-01,4.76641156e-02,2.13988202e-01,3.19919878e-01,9.93597909e-02,2.98717200e-01,4.36721042e-01,9.35432199e-02,-1.01420801e-01,-3.39013811e-02,1.36979034e-01 -contig-42000000,-4.81984424e+00,-3.39178817e+00,-7.71383068e-01,-1.24464573e-01,1.02718584e+00,-4.29592987e-01,-2.70466628e-01,-2.47061659e-01,-5.07957406e-01,1.27422277e-01,1.70937043e-01,-4.32087928e-01,-3.74678776e-01,2.14109897e-01,-1.96690538e-01,-1.48106991e-02,-3.22563731e-01,-1.07723220e-01,2.12091925e-01,2.85404066e-01,3.08625910e-01,2.61834252e-01,4.68079082e-01,-2.27759293e-01,7.99728143e-02 -contig-134000000,2.82997070e-02,3.46071742e+00,6.41101707e-01,-6.30188085e-01,-6.47204670e-01,2.05279782e-01,7.15789350e-01,3.02061632e-01,5.33657409e-01,-5.01465860e-01,-9.31390986e-01,1.43087106e-01,-6.13547435e-01,-6.66530061e-02,-6.01623547e-01,1.62801929e-01,3.15653169e-01,-3.02524067e-01,-4.71711197e-01,1.19928519e-01,-7.12888230e-01,-1.83262815e-01,1.05380344e-01,-1.02517541e-01,-1.86245504e-01 -contig-107000000,-7.93969750e-01,5.38390861e+00,-7.85668194e-01,5.23582643e-01,-1.22978575e+00,6.71927217e-01,1.39646398e+00,2.27278585e-01,1.37368584e+00,-2.20095617e-01,4.22317134e-01,3.36235862e-01,2.93679137e-01,-2.88827991e-01,-4.32505720e-01,6.29582414e-02,-4.01276663e-01,1.32508458e-01,-3.08790081e-01,-2.72242353e-01,7.51203500e-02,-1.55893239e-01,6.29458670e-01,7.80586370e-02,-3.71799965e-01 -contig-1039000000,-3.04315038e+00,-1.16808644e-01,-1.91958401e-01,6.83249545e-01,6.12003293e-01,9.92820045e-02,-1.29099967e+00,-8.24687460e-01,4.25514224e-01,-3.67238825e-01,5.28833245e-01,-5.80136530e-01,1.04713257e+00,-1.33460639e-02,3.63882323e-01,3.41812831e-01,9.12009695e-02,-7.22763768e-01,1.99765789e-01,1.43303096e-01,-1.71081097e-01,-4.07297051e-01,5.41792661e-01,4.66331618e-01,7.55717595e-01 -contig-116000000,-6.08085942e-01,6.41334106e+00,-1.88585301e+00,7.85480295e-01,3.63321264e-01,2.24243656e-01,8.39440764e-01,7.76774806e-01,-1.21873908e+00,1.46702964e+00,1.35628198e-01,1.78104259e+00,-5.88622402e-01,-4.30760450e-01,-8.58582709e-01,-4.93325179e-01,-1.96756255e-01,4.94182102e-01,-3.60230090e-01,3.76340599e-01,-5.12496949e-01,8.65348057e-02,4.99634202e-01,-9.39294238e-01,-1.70822905e+00 -contig-294000000,1.49406701e+00,1.10923799e+00,3.48474210e+00,2.62910669e-01,1.22065410e+00,-1.05291357e-01,1.61128381e+00,-5.25097356e-01,-4.62876695e-01,-1.16558859e+00,-1.22643704e+00,7.84300334e-01,3.67828424e-01,2.44922898e-01,2.39389857e-01,-8.34123581e-01,-2.99253041e-01,2.27023764e-01,3.63211366e-01,3.85159122e-01,-1.14860898e+00,-9.17201738e-01,1.92787843e-01,-8.40068692e-01,6.97893612e-01 -contig-273000000,-2.16948731e-01,3.64887902e+00,1.39910626e+00,3.95902099e-02,4.20489343e-01,1.80519081e-01,-7.96848362e-03,-6.26170959e-01,5.20507434e-01,2.77849460e-01,-9.56668135e-02,5.52210181e-01,-1.99261968e+00,1.03619382e+00,1.44010984e-01,-9.81346922e-01,-1.14676608e+00,1.06310209e-01,1.90942756e-01,1.63309098e+00,4.13777833e-02,-4.69131487e-01,8.09982541e-01,-4.49820805e-01,-3.57756328e-01 -contig-143000000,-4.46625171e-01,3.65204051e+00,8.69484209e-01,-4.00953191e-01,-2.17594579e-01,2.36195997e-01,7.85702035e-02,2.91591415e-01,-2.02068819e-01,-3.87744998e-01,-8.18645210e-01,-1.32004576e+00,-1.66422589e+00,8.88857935e-01,7.74186890e-01,5.41625618e-01,-1.55358547e-01,-7.25353623e-02,4.52916533e-01,-1.95084844e-01,-7.99599329e-02,-7.62029870e-01,-2.19703327e-01,-2.98470587e-01,8.06394614e-01 -contig-178000000,4.27022719e-01,1.23127009e+00,3.04597061e+00,-9.58669894e-01,2.18749603e-01,-5.98942207e-01,2.84503411e-01,7.00006480e-01,1.18356439e+00,-9.03268074e-01,-8.92434943e-01,-1.69458160e-01,-2.58415084e-01,5.57742122e-01,-4.72585470e-01,4.81408126e-01,2.34888119e+00,7.70843976e-01,2.95845668e-01,3.59897695e-01,-4.46978511e-01,1.87568127e-01,-5.52531467e-02,3.29787448e-01,8.04020364e-01 -contig-4930000000,-7.26724455e+00,-4.06943518e+00,-3.37286687e+00,-3.52438615e-01,-9.18664516e-01,3.51619220e-01,6.11265168e-01,4.64987377e-01,1.93453247e-01,1.10975977e-01,-1.53591099e-01,-1.22802989e-01,1.60249024e-01,1.10515329e-01,-6.40285522e-02,-1.53966916e-01,-3.58130971e-01,2.87023032e-01,-5.59433441e-01,-1.10025458e-01,-1.86055778e-01,-1.20139309e-02,-5.88719523e-02,-8.47329897e-03,1.12921780e-02 -contig-2179000000,-6.84311045e+00,-1.95267826e+00,-4.25957250e+00,8.53718455e-02,-2.13991935e-02,-5.78049613e-02,2.80569661e-01,3.18990327e-01,-1.26678636e-01,2.28895883e-01,4.31895811e-01,2.71527069e-01,2.26642214e-02,-4.58737821e-03,-6.03989405e-02,-4.44305624e-01,1.79948573e-01,1.22369506e-01,-9.46037244e-02,3.02538658e-02,-7.45127984e-02,-4.03657681e-02,9.36165557e-02,-7.48824662e-04,1.10399994e-01 -contig-79000000,-1.13153115e+00,3.67491352e+00,6.56902466e-01,-4.94926260e-01,-1.77973384e+00,8.71005854e-01,7.64677539e-01,3.86403571e-01,1.33444059e+00,-1.07576400e+00,3.10628161e-01,5.77067395e-02,-3.32759106e-01,5.28640094e-01,6.15591513e-01,4.56544387e-01,-2.84914711e-02,5.75418035e-01,-1.42984226e-02,4.19689903e-01,-5.14041654e-01,2.68833552e-03,-3.09020214e-01,-8.82419691e-02,-1.60905749e-01 -contig-2699000000,-2.59653262e+00,2.41865918e+00,-1.27597095e+00,1.32926145e+00,7.44367687e-01,-3.30517623e-01,-1.22445976e+00,-1.28735719e+00,5.34249017e-01,3.83288654e-01,1.15144853e+00,-3.03413352e-01,8.23848078e-02,-1.57057962e+00,-3.54251812e-01,-1.31609403e-02,-2.19236002e-01,6.50579063e-01,1.08042186e+00,-7.53010825e-01,-5.10022877e-01,6.02128676e-01,-3.98537830e-01,-3.41884644e-01,1.37427598e-01 -contig-184000000,-3.40697463e-01,4.73280367e+00,-4.31188022e-02,2.69456358e-01,-5.74848110e-01,6.78447476e-01,-3.13071975e-01,6.56215566e-01,4.11220754e-01,5.21090679e-01,-2.31016850e-01,1.18686420e+00,-4.25173551e-01,-7.63407945e-02,1.04871172e+00,1.06352768e+00,-2.10906833e-01,-1.76986069e-01,-4.62493169e-01,9.91504992e-01,4.13664213e-01,5.53645953e-01,-1.12466261e+00,-1.00413924e-01,-4.87635859e-02 -contig-92000000,-1.09019842e+00,4.81620816e+00,-7.36897069e-02,-3.80379208e-01,-1.52598023e+00,6.47414974e-01,-3.70817334e-02,3.82465603e-01,6.74950561e-01,3.17970908e-01,3.87277249e-01,9.08007215e-01,-9.47263603e-01,8.05670253e-01,5.77381403e-01,1.18164596e+00,-8.33585713e-01,6.19300585e-01,-9.08150203e-01,-1.72206959e-02,7.66631433e-01,-3.44028358e-01,5.97814391e-01,-2.79332301e-01,3.68849064e-01 -contig-156000000,-6.14370816e-01,4.58600323e+00,1.94827950e-01,3.34501155e-01,-2.09867429e+00,2.18856270e+00,3.08286730e-02,-3.42404187e-01,1.19793354e-02,-1.38237075e+00,-4.76183810e-02,-5.42156965e-01,-3.23776125e-01,4.84720184e-02,-1.80102003e-01,-2.28538963e-01,-6.65838471e-01,-7.60489238e-01,1.35104751e-01,5.00429386e-01,-1.93293208e-01,1.65803927e-01,-3.14187684e-01,-8.91541208e-01,4.25182614e-01 -contig-1949000000,-3.26639480e+00,-1.37817138e+00,1.33490999e+00,9.99526006e-01,-5.85175622e-01,-1.74175615e+00,-1.64695649e+00,-4.81363732e-01,8.78077224e-01,4.09172124e-01,-3.29272447e-01,9.07745780e-02,1.15441372e-01,-2.53080203e-01,1.47317222e-02,7.84902302e-01,-5.55770584e-01,5.64627718e-01,7.17467867e-01,-2.24236014e-01,-8.79163683e-01,2.21811807e-01,-4.24044235e-01,3.45851531e-01,1.72956433e-01 -contig-4934000000,-4.57177474e+00,-5.42967029e+00,1.81214613e+00,-1.19403695e+00,3.68434970e-01,9.40037148e-02,1.38188702e-01,3.00644483e-01,6.05962216e-02,5.24498729e-02,2.11285003e-01,-3.84279641e-01,-1.20458214e-01,2.72040538e-01,3.64817954e-01,1.27324993e-01,-5.47383981e-01,-1.46984606e-01,2.31456842e-01,-5.90537412e-02,3.96324268e-01,2.27496726e-01,-1.88485798e-01,2.28959785e-01,-1.04658414e-02 -contig-3463000000,9.65686861e+00,-5.04985924e-01,-2.29298952e+00,3.54164788e-01,6.19601612e-01,6.22242752e-01,1.24897311e+00,-1.86599919e+00,6.27138840e-01,1.04636018e+00,-1.97230114e-01,-3.33193008e-01,7.47609358e-01,6.25798790e-01,-1.81708208e-01,-4.91152367e-02,1.21916458e+00,-2.20744612e-01,-3.73269312e-01,2.19465289e-01,8.83409020e-01,1.85923911e-01,-5.80515571e-01,-4.21457554e-01,5.43103387e-01 -contig-1916000000,1.09023573e+01,-9.48851412e-01,-1.22555218e+00,6.58655687e-01,-2.01990670e-01,4.71714150e-01,1.64748591e+00,-1.48960704e+00,-3.27047056e-01,-4.24176112e-01,-2.23283031e-01,-1.03473437e+00,-3.69151287e-01,-4.49609476e-02,-2.56059552e-01,1.03347227e+00,2.84951804e-01,-8.32795700e-02,5.02099596e-01,6.23055951e-01,5.47959976e-02,-3.02834944e-01,-2.17051641e-01,-4.11588330e-01,1.71241876e-01 -contig-4940000000,-7.82833300e+00,-5.05866119e+00,-3.23991084e+00,-1.00996977e+00,-5.24451898e-01,-3.61388147e-02,4.93532469e-01,1.00462745e+00,-3.40634910e-01,-1.32759450e-01,1.19648004e-01,-1.21410120e-01,1.96383763e-01,4.74902181e-01,1.37479624e-01,-2.02837048e-01,3.69586729e-02,-6.61467743e-02,-3.52103398e-01,-3.80000306e-02,1.63459531e-01,2.87972261e-02,1.38866003e-01,-9.32330611e-03,-1.16647243e-01 -contig-105000000,1.12827118e+01,-3.55387747e+00,2.28022331e+00,1.00786763e-01,-2.67088766e-01,-4.75495160e-01,2.11799495e+00,-9.47702696e-02,1.78029492e+00,1.11178586e+00,5.55147930e-01,-3.04669832e-01,-2.60834104e-02,3.79262869e-01,2.85569974e-01,5.64800548e-01,-3.58315030e-02,-1.06426636e+00,8.91738924e-01,-6.12336057e-01,4.93776865e-01,-1.48964736e-01,2.01284554e-01,4.09024364e-01,2.74350375e-02 -contig-220000000,-2.55121674e-01,5.01305568e+00,7.17704323e-02,9.79852141e-02,-6.33918107e-02,-6.48331950e-02,1.46121442e-01,4.31192791e-01,5.16174981e-01,-9.40729129e-02,9.65230686e-01,8.45133103e-02,-1.70109162e-01,5.74928830e-01,-3.88479408e-01,5.63274793e-01,-2.22130895e-01,-1.10530868e+00,6.69475494e-01,7.98834657e-01,-4.41526059e-01,-2.11901063e-01,-9.06965598e-01,6.71127158e-02,-8.01650360e-01 -contig-327000000,5.34095115e-01,4.34474420e+00,6.22668111e-01,-1.10859685e+00,7.83175232e-01,-1.73802649e+00,-3.83119343e-01,-1.42029086e-02,2.21823671e-01,-6.36681358e-01,2.07700167e-01,-5.89650841e-01,3.41319412e-01,-2.42941753e-01,8.59802342e-01,5.07354543e-01,7.91596624e-01,1.70187863e-01,5.79132042e-02,1.98124831e-01,3.23726136e-01,7.53137742e-01,-5.00437317e-01,-4.18746435e-01,-2.91202694e-01 -contig-4918000000,-7.34807282e+00,-2.79712023e+00,-4.07783993e+00,-2.51553152e-01,-6.31691238e-01,3.93169047e-01,3.77824291e-01,6.27515019e-01,-5.47528643e-02,1.22212284e-01,2.22306820e-02,-1.43585381e-01,-1.29561126e-01,2.34504618e-01,1.25866314e-01,-1.50506444e-01,1.39621023e-01,-1.10343608e-01,-3.54582422e-01,9.75950597e-02,1.56130285e-01,-1.41561848e-01,8.78492130e-02,-1.26548483e-01,7.13258221e-02 -contig-208000000,9.66664191e-02,4.76101953e+00,2.15629866e-01,-7.36352256e-01,1.22116596e+00,-9.05962444e-01,1.42924769e-01,1.23192478e-01,-5.40216243e-01,-1.36878540e+00,2.87578596e-01,6.42984080e-01,-5.51288821e-01,-4.41207675e-01,1.50806512e-01,1.15682752e+00,1.49716861e-01,-6.19752018e-01,-1.39179942e-01,-1.42671480e+00,-6.13417315e-01,-1.92762684e-01,1.50432443e-01,7.22259304e-01,1.06980167e+00 -contig-1207000000,1.09237898e+01,-1.55108906e+00,-4.11600615e-01,6.77010411e-01,2.93723634e-02,1.71548120e-01,6.63934014e-01,-1.90235138e+00,-1.26153693e+00,7.72399155e-01,4.22577292e-02,-1.70923664e+00,3.36093232e-01,7.07711842e-01,2.16253682e-01,3.20107844e-01,6.75095308e-01,7.26036787e-01,-8.39620602e-02,6.90697861e-01,1.69556287e-01,5.78763523e-01,1.32110403e-01,2.01123062e-01,3.32578046e-01 -contig-73000000,-3.52493824e+00,-8.83639138e+00,5.07674106e+00,-1.80134120e-01,-1.13486762e+00,2.21136439e+00,-2.23255991e-01,4.99361535e-01,-9.08901811e-01,1.54328436e+00,5.12512050e-01,-2.78002932e-01,2.73833454e-01,-5.28929556e-01,4.17438683e-01,-3.61604596e-01,5.85480883e-01,3.72184686e-03,4.44361217e-01,-8.46418267e-01,-4.43150883e-01,-5.30374401e-02,-4.54772648e-01,-7.51813237e-01,2.17414725e-01 -contig-4911000000,-6.46623513e+00,-2.99824059e+00,-2.38390103e+00,-8.65066133e-01,-3.53749209e-01,2.68671154e-01,5.71883535e-01,3.31876318e-01,1.20468884e-01,-2.28314779e-01,2.85432984e-01,-2.15440281e-01,1.51691022e-01,3.04135891e-02,-1.93429604e-02,-1.73409443e-01,-1.27879858e-01,4.94950927e-01,-4.79814863e-02,-8.88224738e-02,-3.24535768e-01,-5.59184400e-02,-2.96372204e-01,-7.49818644e-02,2.39920685e-01 -contig-1819000000,-3.19640249e+00,-1.33193574e+00,-1.02247108e-01,1.51153424e+00,-3.66998979e-02,2.88272834e-03,-1.04879814e+00,-1.84814438e+00,1.79369863e+00,-7.28745967e-01,3.17717564e-01,2.33370344e-01,7.85615132e-01,-3.45752826e-01,-4.04379829e-01,-6.24426906e-01,-5.15847701e-01,1.22495387e+00,1.80978254e-01,-7.32273417e-01,1.91048409e-01,-2.39007399e-01,1.28976080e-01,-5.54163337e-01,1.09055393e-01 -contig-4901000000,-3.10346394e+00,-5.54054125e+00,3.38100785e+00,-2.63417185e-01,1.73219062e-01,6.23351342e-01,-5.58499662e-01,2.86014046e-02,-9.90859622e-03,3.97392105e-01,9.32153030e-02,2.88764657e-01,7.60497238e-01,3.25410265e-01,-4.38591323e-01,-2.27574317e-01,-8.94722684e-01,6.08228341e-01,2.28714779e-01,-1.89451870e-01,-3.00095753e-01,3.70737392e-01,-1.81519443e-01,-5.15495782e-01,-9.26569870e-03 -contig-161000000,-5.94409834e-01,3.79933111e+00,1.36485012e+00,-5.51680982e-01,-5.15551485e-01,-3.10665105e-01,-5.50886280e-02,2.54867149e-03,1.46560455e+00,1.40623675e-01,5.68014078e-01,4.38084678e-02,-2.55946378e-01,4.42107611e-01,-4.58883775e-01,-3.18912461e-01,-1.23795842e+00,4.71237176e-01,-1.19386605e+00,6.92135954e-01,2.53301679e-02,1.30325588e+00,-6.76389752e-01,5.19642901e-01,1.12118062e+00 -contig-244000000,2.30720585e+00,-5.03264041e+00,9.94172895e+00,-6.45942585e-01,1.66787710e-01,1.60487487e+00,2.42992662e-01,1.82776813e+00,-1.56747477e+00,1.03117378e+00,-1.97524737e-01,8.62538020e-01,1.26787550e-02,-2.07999736e+00,5.73039377e-01,-1.10579759e+00,-6.91960517e-01,-1.73918445e+00,2.24471056e-02,5.52322686e-01,5.16232465e-02,-8.64542274e-02,7.70278472e-01,-3.04611825e-01,1.71839736e+00 -contig-4927000000,-7.74004245e+00,-2.60573750e+00,-4.74858964e+00,-2.73404592e-01,-6.84028020e-01,3.24592141e-01,7.20637312e-01,6.29674648e-01,-1.77557478e-01,1.38881625e-01,1.12938913e-01,-1.51566774e-01,5.84081873e-03,-2.03020437e-01,1.11021440e-01,-1.06409764e-01,-3.34916854e-02,8.64023166e-02,-4.35656744e-01,-9.47698548e-02,-7.90521720e-02,-9.39057548e-02,-1.09189366e-01,-1.22017601e-01,-4.56844467e-02 -contig-303000000,-5.06731870e-01,3.60793991e+00,1.40899131e+00,3.39991557e-01,1.50979567e+00,-1.55158897e+00,1.53717332e-01,-5.88718406e-01,-8.73806301e-01,-5.87567291e-01,1.93714997e-01,-3.20521640e-02,7.97248848e-01,-1.05291434e+00,6.46343378e-01,-9.80058980e-01,1.22569482e+00,9.47931556e-01,5.83982395e-01,-3.80988088e-01,1.11503461e+00,6.09481264e-02,4.08107839e-01,-5.83115581e-02,8.01999039e-01 -contig-444000000,2.58395905e+00,-2.31194983e+00,8.31523526e+00,2.17944025e-01,-3.11758557e+00,-5.93037163e-01,-3.52694606e-02,-7.65976859e-01,-5.81369143e-01,1.25135717e+00,-5.34178316e-01,-1.29926310e-01,2.12358555e-02,-5.05478245e-01,1.42504886e-01,-2.82738488e-02,2.96399134e-01,-9.48398625e-02,1.06776992e+00,-4.09566489e-01,4.48849941e-02,2.29003602e-01,1.05261112e-01,8.95942252e-01,-2.59759136e-01 -contig-31000000,-3.91172171e+00,-6.04307497e+00,1.89319168e+00,6.10900438e-02,2.97123013e-01,6.73648403e-02,8.33171004e-02,-2.01123929e-01,3.71515573e-01,-1.77802068e-02,-4.94245929e-01,-8.40699795e-02,-3.54162417e-01,5.47544735e-02,1.49204606e-01,4.18638739e-01,-3.33931410e-01,2.16598497e-01,7.20580290e-02,3.15902275e-01,2.01613211e-01,-1.13351100e-01,-1.23995917e-01,1.36311322e-01,7.69641098e-03 -contig-4905000000,-5.93853885e+00,-1.89519931e+00,-2.71425990e+00,-1.51734211e-01,9.70719510e-02,9.57880011e-02,-1.50942118e-01,1.27012035e-01,-2.95570933e-01,2.38160333e-01,1.89061255e-01,-7.37755061e-02,-1.11688397e-01,9.82372428e-02,-1.29843737e-01,4.27913172e-01,-1.02417092e-01,-2.77497904e-01,-2.60944528e-01,1.22946707e-01,3.32405864e-02,-1.38668469e-01,4.00205420e-02,9.78831005e-02,1.57788080e-02 -contig-129000000,-5.64317289e-01,3.98628102e+00,5.53436949e-01,-2.37555352e-01,3.57895098e-01,-1.29778508e-01,9.58787846e-01,2.82703263e-02,5.72226566e-01,-9.28173356e-01,-5.16491153e-02,-7.98147885e-01,-8.53332941e-01,-6.76069946e-01,1.31313527e-01,-5.93552154e-01,-2.95575641e-01,4.81765922e-01,7.26300798e-01,3.11422658e-01,-5.58022360e-01,3.31475093e-01,-2.47692621e-01,-4.05790404e-01,-2.52441192e-01 -contig-4923000000,-7.64668222e+00,-4.62343635e+00,-2.95681489e+00,-1.09495514e+00,-5.59560128e-01,2.68151628e-02,1.97491269e-01,9.07733602e-01,-3.79093797e-01,2.64964256e-01,1.70009184e-01,-4.69764068e-01,3.87838508e-01,2.63978183e-01,1.63826516e-01,3.41215280e-02,8.23724476e-03,2.99807212e-01,-5.87953292e-01,-3.54308325e-01,-3.06010416e-01,-2.26983804e-01,-1.54236816e-01,1.56740352e-01,-1.17939847e-01 -contig-304000000,6.83348463e-01,4.68871315e+00,1.58786607e-01,-7.27909618e-01,4.16729987e-02,-4.17441819e-01,-1.21575086e+00,1.00515990e+00,-1.14255845e-01,3.01949008e-01,8.41257983e-01,3.36894738e-01,3.76407666e-01,5.56290768e-01,7.33648116e-02,7.32232982e-01,-5.99846263e-01,2.30726905e-01,6.49493408e-01,2.45926436e-03,-1.35524233e+00,-2.16974761e-01,-7.59053913e-02,-2.07120974e-01,-1.02587818e+00 -contig-103000000,1.33954393e-01,2.91882883e-02,4.34577965e+00,-1.10944469e+00,3.38486812e-01,-9.14650201e-01,6.70116604e-01,-2.57538867e-01,-2.95350499e-01,-1.74980590e+00,-3.85220158e-02,8.28081337e-01,4.90471611e-03,6.35185453e-01,7.39293702e-01,-5.13952288e-01,2.91160113e-01,1.32835302e-01,-5.07341071e-01,5.34313216e-03,-2.13290298e-01,5.33538839e-01,-7.27614377e-02,-2.43213264e-01,5.76450701e-02 -contig-205000000,1.17076070e+00,-2.53202657e+00,8.33372953e+00,-1.99364646e+00,-3.06652469e-01,8.81429617e-01,2.86097822e-01,2.90159460e-01,1.95707622e-01,-3.31961578e+00,1.67081923e+00,-1.59515405e+00,-1.45985197e+00,-3.10158135e+00,-6.85267530e-01,8.51359211e-01,-5.96268699e-01,-1.06168819e+00,-8.04764290e-01,-9.22057087e-01,1.55944487e+00,1.19758518e+00,-3.43143171e-01,4.60235155e-01,3.58830222e-01 -contig-39000000,-4.90566040e+00,-2.27893882e+00,-1.34207601e+00,1.43034554e-01,1.29762276e-01,2.86498663e-02,-7.04788913e-01,-4.31101609e-01,2.88309533e-01,2.04410328e-01,5.13980076e-03,-2.93817702e-01,-2.34118646e-01,-1.54429731e-01,-1.33537367e-01,2.71413115e-01,1.75996081e-01,3.60286568e-01,-1.01849321e-01,-1.71816503e-01,-1.02532812e-01,-1.15579172e-01,-4.83492880e-01,-2.29836997e-01,-2.80004315e-01 -contig-271000000,7.41520223e-02,4.74115103e+00,5.10176015e-01,-2.32512025e-01,1.12756444e+00,-8.12397826e-01,-4.06655491e-01,4.99398567e-01,-1.76982785e-01,7.33653076e-02,1.04476208e+00,7.85256391e-02,7.91958145e-01,-1.73730185e-01,-6.57191130e-01,-2.85162583e-01,7.86397290e-02,1.26678872e-01,1.03003982e+00,8.33859612e-01,1.49080271e-02,9.05255397e-02,5.09098621e-01,-1.09100879e+00,-7.43666079e-01 -contig-1421000000,-3.28537322e+00,-2.77861873e+00,1.13723620e+00,-1.18530164e+00,1.68595860e+00,-1.05679130e+00,-4.20246865e-01,-3.65208712e-01,-2.01414193e-01,4.70871344e-01,5.47346758e-01,3.10726378e-01,7.43885795e-04,-1.87630315e-02,-2.94185532e-01,4.93754364e-01,8.34289478e-01,-2.34395934e-01,4.43553549e-01,-6.49378385e-02,-2.43304686e-01,-2.15853202e-02,-1.73408746e-01,1.80783497e-01,-2.35794846e-01 -contig-168000000,4.36986099e+00,-3.88733735e+00,3.26834914e+00,4.96775770e+00,3.25395495e+00,-8.56745195e-01,-9.46643081e-01,2.21640411e+00,3.39745042e-01,-2.14215893e-01,1.00380326e+00,-3.81295722e-01,6.90059103e-01,2.15908135e-01,-9.13744001e-01,-3.33140659e-01,-6.21393214e-01,2.02987663e+00,-5.55939253e-01,2.45054532e-01,1.00802228e+00,6.13316920e-02,4.65146940e-01,8.58067856e-01,-1.53919039e-01 -contig-289000000,4.37514033e-01,3.46999375e+00,1.53476720e+00,-5.08032880e-01,1.73078022e+00,-1.61375151e+00,5.97605524e-01,-5.06026966e-01,-7.67680775e-01,-2.80232764e-01,-4.89410967e-01,-3.66951101e-01,3.50489698e-01,-1.18593536e+00,1.20006987e-01,6.39375857e-01,-7.27209556e-02,-2.71936689e-02,-1.07740913e+00,-8.23229966e-01,-6.67478810e-01,-5.99203873e-02,1.78952900e+00,-5.19836507e-02,1.22852995e+00 -contig-154000000,-4.59631508e+00,-1.86719249e+00,-1.36641101e+00,4.89439651e-01,3.43334556e-01,1.27313624e-02,-9.92024326e-01,-4.08288886e-01,9.92495860e-02,2.96553469e-01,-4.45828178e-01,-7.84171040e-01,-2.75517696e-01,3.53781073e-01,1.59524308e-01,5.43279094e-01,2.27761136e-01,-7.50305918e-01,-3.31350597e-01,1.21701154e-01,-3.47537505e-01,-1.15908427e-01,9.22094297e-02,3.08033953e-01,-1.72423570e-02 -contig-298000000,-4.96884994e-01,5.84105269e+00,-2.85220638e-01,4.39226431e-01,-1.21612238e+00,8.42664311e-01,-1.40816893e+00,7.00822967e-01,1.01916642e+00,3.03752655e-03,1.04525208e+00,-8.12731813e-01,5.10770447e-01,4.49366494e-01,4.58546868e-01,-1.82665441e-01,-1.29120066e-02,-4.22081180e-01,6.75927115e-01,-5.54603234e-01,6.67192976e-02,-6.05817053e-01,2.19846474e-01,-7.20857330e-01,1.20798502e+00 -contig-189000000,3.62697048e-01,3.93684221e+00,6.42417689e-01,-9.12222166e-01,9.21475381e-01,-9.35832310e-01,1.07340343e+00,-6.70162907e-01,-1.12868220e+00,2.46865395e-01,-4.32614218e-01,-4.56135641e-01,3.80788775e-01,-7.75432264e-01,3.34532132e-01,-1.52576100e+00,-1.14066738e+00,1.84074449e-02,4.41596816e-01,6.64335608e-01,-7.06858122e-01,1.27004205e-01,-7.58881599e-01,-2.30238140e-01,-4.25668228e-01 -contig-221000000,-3.24639605e+00,-2.39382111e+00,1.16219010e-01,7.86938835e-01,4.75045067e-01,-5.00816566e-01,-1.84682392e+00,-3.78083763e-01,3.57254888e-01,1.02688770e+00,-1.28341623e+00,-2.86164899e-01,1.92962232e-01,1.01972558e-01,3.46467944e-01,-6.37076122e-01,-1.32954243e-01,-6.55986567e-01,-2.08392243e-01,4.00663396e-01,7.17140811e-01,1.59231612e-02,-1.83188485e-02,-3.89836755e-01,5.34230925e-01 -contig-32000000,-3.60061758e+00,-4.40328395e+00,2.43169666e+00,6.59068936e-01,-5.96794186e-01,-9.89366064e-01,2.25102751e-02,-9.97552707e-01,-4.77808597e-01,-1.99657278e-01,-5.61213920e-01,5.74929760e-01,-1.52801767e-01,-2.10126338e-01,-4.18105757e-01,3.27555368e-01,-7.18058051e-01,-7.50097056e-02,1.39496474e+00,1.71737752e-01,-1.68120080e-02,4.49559829e-01,5.45944069e-01,6.84974341e-01,1.77073191e-01 -contig-266000000,5.94698313e-01,2.77237951e+00,2.32441127e+00,-6.37105891e-01,-4.12215882e-01,6.97816844e-01,-2.26070395e-01,3.27013061e-01,3.98485731e-01,-7.68490364e-01,-1.06516228e-01,-5.12118728e-01,3.11881347e-01,-2.45636802e-02,-1.49210454e+00,7.15745611e-01,-5.74592161e-01,-5.41399850e-01,-2.67139994e-01,2.39453506e-01,-2.24050459e-01,2.86474899e-01,2.13776858e-01,3.71233723e-01,-6.03104111e-01 -contig-267000000,2.15452623e+00,-4.34852918e+00,1.02877054e+01,-4.81928700e-01,-1.14289588e+00,1.93389769e+00,-4.57523082e-01,9.73323108e-01,-2.65374964e+00,5.66493345e-01,7.33397694e-01,1.72020115e+00,9.41756487e-01,-1.22045920e+00,1.07267570e+00,7.96255702e-02,-1.21186881e-01,2.10451988e-01,-5.62264304e-01,1.54926198e+00,1.02642907e+00,7.06742266e-01,-9.60390368e-01,-1.77405337e+00,1.55576160e+00 -contig-473000000,-5.52423338e+00,-5.33818677e+00,3.49715479e-01,-8.21902119e-01,-2.86083799e-01,9.93606286e-02,-7.26121016e-01,3.24793628e-01,2.74250077e-01,5.16010989e-01,9.30835949e-02,-1.16650016e-01,4.33486099e-02,2.93854138e-01,5.94521855e-02,-9.21311935e-02,-8.46223623e-02,4.61371978e-01,-5.86613761e-01,6.42157823e-02,-3.89539576e-01,-6.90442937e-02,-4.72257827e-01,-1.76294251e-01,-3.72616401e-02 -contig-94000000,-5.25556765e+00,-9.47329423e-02,-3.01520231e+00,4.43049958e-01,2.36244714e-01,-7.30978600e-02,-6.34244003e-01,7.29153092e-03,4.01353644e-01,7.69449100e-01,3.05022003e-01,4.88418495e-01,-4.34550464e-01,-8.72006952e-02,1.00430991e-01,1.17375508e-01,9.28828057e-02,-3.12072078e-01,-3.17299849e-01,2.41392519e-01,-1.61055644e-01,1.65534281e-01,3.43219408e-02,-1.41526656e-01,7.71204008e-02 -contig-64000000,8.66341163e-01,-3.39008197e+00,7.34442276e+00,-9.21596368e-01,-1.69293141e+00,1.56374165e+00,1.09564997e+00,1.00334557e+00,4.80948153e-01,6.58038024e-01,-5.30739773e-01,-1.10052446e-01,6.71136792e-01,-3.63843776e-01,-7.74305076e-01,-5.87670487e-01,1.81393080e-01,5.16645648e-01,1.89817929e-01,-8.03569293e-01,-5.32759352e-01,-8.31711535e-01,-1.55270492e-01,3.30398125e-01,-3.33342329e-01 -contig-57000000,-3.09980414e+00,-4.90946961e+00,1.99922253e+00,2.35595934e-01,-1.68244026e-01,4.29995220e-01,-3.44776341e-01,-2.33778782e-01,7.90849701e-01,7.00988385e-01,-2.79387114e-01,-3.46684695e-01,1.78144374e-01,-4.29983731e-01,-8.07104327e-01,-2.18107781e-02,1.55805483e-01,-6.55429574e-01,7.16647142e-01,-3.96099759e-01,-1.37095029e-01,4.43185244e-01,4.05086052e-02,4.42463400e-01,-3.70349490e-01 -contig-98000000,-8.05062265e-01,3.39919589e+00,7.42996325e-01,-5.14667271e-01,1.42967464e+00,-1.47242512e+00,1.07021152e+00,4.85494332e-01,-4.75830818e-01,-6.13780795e-01,2.04914586e-01,5.34096072e-01,7.21787681e-01,-6.21098303e-01,-1.80771121e+00,4.07954284e-01,6.04909501e-01,-2.88397774e-01,-8.89399322e-01,2.16758811e-01,3.60464007e-01,-4.43507016e-01,-1.43165764e-02,-4.21710412e-01,3.54015922e-01 -contig-249000000,1.15199799e+01,-5.36798839e+00,2.37479101e+00,-2.37892952e-01,3.26417356e-01,1.14855574e+00,1.17260750e+00,-7.94217309e-01,2.66026373e-01,1.38448582e+00,1.00411817e+00,-5.42238614e-01,4.41001832e-01,-3.08746757e-01,1.81472255e-01,-5.75652254e-03,-2.03311808e-01,-1.04347676e-01,3.22834545e-03,-5.43760683e-01,-2.05305983e-01,-9.54359132e-02,-1.99999721e-03,-2.72341618e-01,-1.34881709e-01 -contig-467000000,-4.78677531e+00,-2.62715520e+00,-5.79758126e-01,-5.01521861e-01,3.21474317e-01,-2.81246183e-01,-9.59314968e-01,-1.23558846e-01,3.54105825e-02,1.01323107e-01,-3.52493932e-03,-2.83301664e-01,2.82104280e-01,6.87237590e-02,-1.59831628e-01,-1.80687834e-01,1.37446512e-01,-2.17735417e-01,-1.95666001e-01,-5.11319770e-01,-9.23422099e-03,-6.62489584e-02,-1.91039982e-02,-3.45916442e-01,1.55060411e-01 -contig-162000000,-4.69913707e-01,3.16115223e+00,2.00842151e+00,1.54910219e-01,-8.31000803e-01,6.80472230e-01,1.26432200e+00,-4.09578897e-01,8.96749683e-01,-1.69236373e+00,1.38665757e+00,-5.86828332e-01,-1.24620795e+00,-4.85671936e-01,4.40686722e-01,-1.11275908e+00,-8.98215713e-01,-9.55436248e-01,7.76822001e-02,-9.80611133e-02,-2.18512044e-01,6.55808158e-01,-1.19172474e+00,1.48598637e-01,-1.93843383e-01 -contig-4902000000,-4.41297269e+00,4.16266184e-01,-2.72496431e+00,7.75250057e-01,8.82636606e-01,-2.57547703e-01,3.56935234e-01,-4.21514806e-01,-1.49503564e-01,-1.96809259e-01,3.00229911e-02,6.97224507e-01,7.49890356e-01,-5.59313507e-01,-5.25420343e-02,1.04887828e+00,7.17984709e-01,-5.20736509e-01,4.66715367e-01,5.03805871e-01,-3.44569536e-01,-5.79766853e-02,-3.57086219e-01,-6.03457117e-02,6.66252634e-02 -contig-76000000,-1.37761983e+00,4.21569412e+00,-1.41783864e-01,-4.54521886e-01,-1.67976120e+00,5.27158552e-01,8.07025745e-01,3.14971244e-01,4.86743383e-01,-1.05334348e+00,5.28677553e-01,1.11402310e+00,9.22932830e-01,3.31336359e-01,-1.16071593e+00,-2.35217076e-01,5.57428976e-01,-9.47466876e-01,-5.29244174e-01,3.52222100e-01,-4.81880765e-01,-2.27642658e-01,-9.84611292e-02,3.19039779e-01,-3.28966981e-02 -contig-95000000,-3.31938976e+00,-4.74339950e+00,2.26767255e+00,1.10884533e-02,8.58959614e-01,2.87369694e-03,-9.53610465e-01,-2.52758934e-01,-1.38676239e-02,-2.33511069e-01,8.90171942e-01,-8.59875371e-03,-1.33827224e-01,2.31021193e-01,6.94888750e-02,-1.57299256e-01,-1.35524410e-01,-1.88161516e-01,3.96243716e-01,-1.75654016e-01,1.69975119e-01,5.51471787e-01,3.26380988e-01,5.39021588e-01,-1.85492926e-01 -contig-125000000,-3.53147427e+00,-5.08820707e+00,2.14624344e+00,-6.25201479e-01,1.02222324e-01,-2.73604943e-01,4.02133652e-01,-5.14816793e-01,5.36450522e-01,-1.21986716e-01,-6.49677990e-01,1.33538722e-02,5.74813116e-01,-6.80175920e-01,-4.27560069e-02,4.32213196e-01,-6.36452889e-01,1.64492473e-01,5.35365674e-01,-7.48558465e-02,2.62994771e-01,8.81748332e-02,2.94650658e-01,3.12387089e-01,-2.26651704e-01 -contig-124000000,-3.91458033e+00,-1.40641661e+00,-3.69125982e-01,-1.15809546e-01,7.14988452e-01,-1.49170000e-01,4.29450621e-02,-3.49702809e-01,5.94436101e-01,-1.50878544e-01,-6.89778699e-01,-2.68015121e-01,-4.81807951e-01,-5.06774276e-03,-1.18168042e-01,-2.34211075e-01,3.96989299e-01,1.21109691e-01,4.16573749e-01,-1.22355344e-01,-1.04915212e-01,3.56402697e-01,-1.04907387e-01,-4.43111039e-01,1.50176922e-01 -contig-980000000,1.00525175e+01,-2.54317310e+00,1.44184042e+00,-3.66648689e-01,2.79601627e-01,1.12118327e+00,5.90248835e-01,-1.46434911e+00,-6.68026187e-01,1.84624127e-01,1.16421183e+00,-5.49587168e-01,-5.12129598e-01,1.39726502e-01,-1.39702886e+00,-2.71108531e-01,5.43641193e-01,1.97395718e-01,-6.18171385e-01,-5.94081586e-01,2.92119807e-01,2.02111117e-01,3.29938588e-01,2.88269743e-01,2.74078485e-01 -contig-148000000,-4.09143235e+00,2.15538916e+00,-3.99695452e+00,1.96692316e+00,7.49896658e-01,7.06356561e-01,6.53422987e-03,-1.06412309e+00,-4.27978785e-01,2.30157349e-01,-6.26893553e-01,8.04964542e-01,-1.26594444e+00,-4.22797709e-01,-1.06364504e-02,1.40735898e-01,6.89221960e-01,-7.32310886e-01,1.62013042e-01,5.47450670e-01,3.17496907e-01,-2.72474740e-01,5.08566965e-01,-3.89855961e-01,1.63359698e-01 -contig-169000000,-8.54200448e-01,4.75721715e+00,3.63683571e-01,7.52717795e-01,-6.27947664e-02,2.37222137e-02,-3.64587942e-01,7.96684465e-02,-5.50851124e-01,1.08076659e-01,2.86905775e-01,3.87107782e-01,8.88573230e-01,1.00439662e+00,-9.46386467e-01,-1.86126827e-01,1.32118520e+00,2.88830101e-02,5.95564399e-02,-7.31309268e-01,-2.89277628e-01,4.28743960e-01,-4.41575363e-02,-9.25585978e-01,-4.95636145e-01 -contig-13000000,1.28920168e+01,-1.74483640e+00,-4.51269535e+00,1.12753499e-01,-3.57941658e-01,1.86300386e-01,1.26746875e-01,-1.28325410e-01,7.17497232e-01,1.45592727e-01,-1.05575213e-01,-4.59753638e-01,-7.68412009e-02,-6.65430908e-01,1.57856861e-01,-2.39990056e-01,3.44018028e-01,7.09577939e-01,-3.31455593e-02,2.00344831e-02,-5.95299354e-02,-2.19864832e-01,-5.11134411e-01,3.23367322e-01,2.41691683e-01 -contig-2461000000,1.13668432e+01,-3.40469531e+00,1.07583866e-01,-7.75978875e-01,4.17243980e-01,-3.55071288e-01,3.17889528e+00,-4.77062642e-01,2.14047419e+00,1.90145437e+00,4.10398117e-01,-1.63150728e-01,3.25067906e-01,-7.85444966e-01,7.51365474e-01,1.15050697e-01,4.06747080e-01,-7.70646308e-01,7.22170328e-01,-1.83443939e-01,4.35332037e-01,4.10865119e-02,2.00945566e-01,1.17517869e-01,-2.78952434e-01 -contig-118000000,1.32231759e+01,-2.28996503e+00,-5.00196661e+00,-5.17993920e-01,-1.31063757e-01,-3.51011011e-02,-1.16162470e+00,2.77035016e-01,-4.01274478e-01,-4.11545673e-01,-4.65734552e-01,1.16623674e-01,-4.08127482e-02,-2.43193479e-01,-8.34079590e-02,-4.52434975e-02,-1.03174265e-01,3.85773139e-02,9.70138068e-02,-5.20937252e-02,-1.48120574e-01,-4.88140945e-02,-9.92492036e-02,9.84310786e-02,-3.45774308e-02 -contig-280000000,1.25303490e-01,2.73123170e+00,2.16349332e+00,-1.08949066e-01,4.37332865e-01,-1.57318404e-01,1.85495228e-01,-9.42646504e-01,3.42976451e-01,-1.60194023e+00,5.85369483e-01,4.08186694e-01,1.10052575e-01,6.65837958e-02,-2.66365814e-01,1.17819864e-01,-1.09642190e+00,-5.57464743e-01,6.27563905e-01,4.42339158e-01,-8.43543599e-01,-3.36730200e-01,-2.93266142e-01,1.96681535e-01,6.17327634e-01 -contig-54000000,-5.61190647e+00,-1.77295398e+00,-3.30747368e+00,8.52099188e-03,2.80783214e-01,2.34264976e-01,-2.68564843e-01,-1.85837480e-01,-3.76634923e-01,4.54322865e-01,-7.90810368e-02,-1.72511017e-02,5.70299696e-01,4.83954947e-02,-1.80377478e-01,9.93089029e-02,1.17968899e-01,-2.81458678e-01,9.51003168e-03,1.58868970e-01,3.28965317e-01,4.67446322e-01,5.24332915e-01,7.19938795e-04,-1.21920532e-01 -contig-16000000,-4.77736648e+00,-6.10736069e+00,1.16593773e+00,-1.70362994e-02,2.75361993e-01,1.00267860e-01,-2.51017328e-02,-1.19186370e-01,-1.88422010e-01,-5.02867903e-01,-1.84659153e-01,3.02537803e-01,3.13327766e-01,2.51273065e-01,-1.01373402e-01,2.87824763e-01,-5.36280005e-01,4.03837527e-01,-4.22999733e-01,2.48571359e-02,-1.18791371e-01,8.00201771e-02,-1.48959165e-01,-2.57461851e-01,5.38920136e-02 -contig-10000000,-5.85346325e+00,-6.50368078e+00,-3.19607910e-01,-8.63548043e-01,-2.62060441e-01,-1.19724215e-01,8.27025162e-01,6.10093378e-01,2.74681438e-01,-3.92538366e-02,-2.31659219e-01,-1.92312389e-01,1.94574613e-01,5.54024588e-02,7.17140735e-02,1.82963638e-01,-7.43688542e-01,1.85443017e-01,-8.32909728e-02,-8.91755444e-02,2.43611745e-01,2.22136211e-01,-1.68807277e-01,3.31280495e-01,-1.04574277e-03 -contig-288000000,5.05490185e+00,-3.87595967e+00,5.48770978e+00,4.61923618e+00,1.46733218e+00,1.65666687e+00,-2.52003982e-01,1.69691112e+00,-4.38568656e-01,-5.57545250e-01,-2.13292491e-01,-3.03980329e-01,7.80735071e-01,-1.41940085e-01,-1.06652581e+00,-1.21258846e+00,6.66417209e-02,5.08221004e-01,3.12012770e-01,-4.60820581e-01,1.13929626e+00,-1.10375537e-02,7.78616757e-02,8.43280682e-01,-1.01835402e+00 -contig-813000000,-3.25536244e+00,2.08794911e-01,-1.54679199e+00,1.84158572e+00,7.51661607e-01,-5.35640275e-01,-1.56606027e+00,-1.03062333e+00,1.13390853e+00,4.54320607e-01,-1.03057374e+00,1.03519013e+00,6.42119427e-02,-5.23195278e-01,-5.30002221e-01,1.43476322e-01,5.45989512e-01,-7.03107643e-02,-4.22957561e-01,-4.88446415e-02,-1.27127843e+00,4.53926904e-02,-2.83258892e-01,-2.68028534e-01,3.87095317e-01 -contig-4511000000,1.09238868e+01,-2.45900676e+00,-2.10059013e+00,-6.02209834e-01,9.51201504e-01,8.81544239e-01,1.68715483e+00,-1.32400312e+00,-1.18239786e-01,6.01743929e-01,3.92959669e-01,-1.01612206e+00,4.53551524e-01,1.98241690e-01,3.38325443e-01,4.02725191e-01,3.05025517e-01,6.55242297e-02,-4.93558267e-01,8.17670881e-01,5.13192369e-01,3.19312075e-01,-3.85305914e-01,1.12337188e-01,5.24383663e-01 -contig-4000000,1.35892599e+01,-1.53198175e+00,-6.83035243e+00,-1.68630559e-01,-9.18608770e-02,-1.13869532e-01,-8.72800840e-01,9.47618661e-01,-2.61166485e-01,-6.18017398e-01,-8.30785184e-01,4.63402409e-01,2.05216841e-01,-4.93209339e-01,-1.10281570e-01,5.29114560e-03,1.33388387e-01,1.99928655e-01,3.35832884e-01,7.85500681e-02,-1.88690265e-02,3.19482590e-02,1.29425480e-01,-1.62967188e-01,6.05444339e-02 -contig-4939000000,-8.09974653e+00,-2.14435587e+00,-5.83982843e+00,-3.73946369e-02,-8.31457152e-01,5.77038323e-01,1.36039228e+00,7.84969910e-01,-2.61630789e-01,8.58659982e-02,2.78259221e-01,2.22612920e-01,-1.94521805e-01,-1.23728001e-01,3.38827530e-02,-1.14214119e-01,-1.45717717e-01,-1.36608263e-01,-6.64818473e-02,6.02828527e-02,3.02568195e-01,2.82619775e-02,1.97175475e-01,3.65582504e-02,-9.52574769e-03 -contig-4936000000,-6.78501844e+00,-1.52540477e+00,-4.54691527e+00,3.42681223e-01,-2.94162112e-01,7.16354875e-01,9.94861603e-01,2.13980201e-01,-6.81597519e-01,-1.73436682e-01,1.80830890e-01,-1.98410312e-02,-3.46602619e-01,-4.29294390e-02,1.45082795e-02,2.22293767e-01,2.32612740e-02,-5.98127196e-01,2.05613887e-01,5.09437791e-01,2.95242339e-01,2.12048635e-01,3.09718084e-01,4.23853188e-02,-5.47329427e-02 -contig-4926000000,1.28455458e+01,-1.82254024e+00,-5.01323157e+00,-4.34203732e-01,-1.11669865e-01,-3.10184111e-01,-4.34194378e-01,7.71867731e-01,-6.68910308e-02,-4.36922376e-01,-3.43266161e-01,-5.80717303e-03,3.08421335e-01,1.43136085e-01,-9.10166416e-02,2.81656573e-01,-4.66704399e-01,-1.61313906e-01,3.13487046e-01,-6.34866688e-02,4.18535219e-01,2.07364418e-01,2.67559121e-01,-1.14666662e-01,1.59224026e-01 -contig-44000000,-5.90769830e+00,-7.97232686e-01,-4.20609096e+00,6.74314494e-01,1.72941753e-01,1.66540687e-01,4.02050334e-01,2.33170301e-02,-1.32572250e-01,2.50950381e-01,1.26265328e-01,1.77074080e-01,-3.30293010e-01,-1.17808343e-01,-1.28797712e-01,1.61995350e-01,2.48008297e-01,2.46928075e-02,3.92068807e-01,-9.33682288e-02,2.37538019e-01,1.81737039e-01,9.12168022e-02,2.47436519e-03,-2.72483850e-02 -contig-211000000,8.68433107e-01,6.54287549e-01,4.01266627e+00,-9.49325845e-01,-9.80605765e-02,-4.97519278e-02,-5.45666421e-02,-6.00843201e-01,-7.54583410e-01,-2.03005176e-01,-1.03157406e+00,6.76311059e-01,-3.84066078e-01,7.57014286e-01,-1.56369452e-04,-3.80587247e-01,1.18248287e+00,1.91706843e-01,-1.59154179e-01,-3.54200033e-01,-4.65267981e-01,9.54085262e-01,1.88649290e-01,7.80644073e-01,-6.08763324e-02 -contig-30000000,-5.66499128e+00,-6.84562144e+00,2.23042560e-01,-9.57129648e-01,-3.15905791e-02,-1.47126715e-01,8.60444262e-01,5.22115948e-01,1.35878765e-01,-2.58953362e-01,-8.18867884e-02,-9.02461027e-02,2.54892634e-01,1.68477716e-01,2.18849031e-01,2.45964914e-01,-6.41263291e-01,2.47830297e-01,1.29845657e-01,9.50584356e-02,2.49879561e-01,-4.19835257e-02,-7.65978858e-03,1.79597962e-01,-4.39541486e-02 -contig-203000000,-2.13029756e-01,5.60763523e+00,-5.17096280e-01,-5.57050690e-01,8.49148708e-01,-8.90071082e-01,-6.32597909e-01,1.06430372e+00,-5.69338362e-01,1.07746818e+00,1.28592833e+00,-5.45036471e-01,1.33297568e-01,-1.82352971e-01,1.00912561e-01,-3.02840526e-01,8.84452199e-02,-6.52779506e-01,-4.60522023e-01,-3.95115017e-02,-2.01031096e+00,1.10564746e+00,7.35745443e-01,-3.05572814e-01,6.81449296e-02 -contig-78000000,3.51776024e-01,-3.46392759e+00,7.52650010e+00,-1.02985623e+00,-4.92464363e-01,1.22125684e+00,1.29230028e-01,7.56891936e-01,-1.46856103e+00,3.20200032e-01,-2.86598687e-01,1.58066773e-01,6.81126078e-01,5.59818748e-01,-8.64667707e-02,-5.80671417e-01,-5.22695921e-01,6.27152845e-01,-7.25469631e-01,2.76588180e-01,-2.12529303e-01,-1.12975292e+00,-2.62893662e-01,4.88245977e-02,5.63546356e-01 -contig-219000000,-2.56804930e-01,3.65532255e+00,1.14062212e+00,1.09650240e-02,6.67396833e-01,-4.32306118e-01,3.43405983e-01,8.54951972e-02,3.62112719e-01,2.07765771e+00,-1.28908044e+00,3.51628926e-01,-1.41588919e+00,-2.70536867e-01,-1.30740378e+00,4.67246637e-01,-7.05430388e-01,2.32380171e-01,-4.74296164e-01,-2.37964781e-01,1.49050198e-01,8.94951064e-02,-1.35169644e+00,-1.45025692e+00,-5.47152815e-01 -contig-209000000,3.37313520e+00,-4.04108724e+00,9.30055958e+00,1.46738747e+00,-3.69652142e+00,5.05939954e-01,5.03791418e-02,9.10851591e-01,-1.21532155e+00,-1.49171719e-01,-8.05430950e-03,-3.02177182e-02,-6.74187063e-01,-8.29240720e-02,-4.75727719e-02,3.90794798e-02,4.16282886e-01,1.89756664e-01,2.39256429e+00,6.12951168e-01,-9.93236900e-01,-6.03351924e-01,7.77765368e-01,-4.49761518e-01,3.65052024e-01 -contig-292000000,1.08874300e+01,-3.24741284e+00,-7.99530383e-02,-4.00316570e-01,-1.74546659e-01,1.05328317e+00,-5.59927814e-02,-4.80350257e-01,1.40476350e-01,2.06538324e-01,5.63346213e-01,-5.40067906e-01,-2.62457292e-01,8.26575780e-01,-1.42507675e-01,6.39966730e-01,1.20535868e+00,-4.85833462e-01,4.19676677e-02,6.90003960e-02,-5.07081637e-01,1.49163942e-01,3.94290184e-01,-6.67254750e-02,-1.29918719e-01 -contig-174000000,-3.62826289e-01,4.38569109e+00,4.96293420e-01,-1.83288681e-01,3.45872885e-01,-2.18479876e-01,5.01799344e-01,1.47270870e-01,4.45987325e-02,-9.33821898e-01,8.10588919e-01,6.71169792e-01,9.39288144e-02,8.30504115e-01,-4.78365243e-01,-3.88791070e-01,9.57721756e-01,-2.08242061e-01,-7.84767849e-02,2.49482850e-01,1.23773374e+00,-5.59621567e-01,1.69367209e-01,9.23681702e-03,-2.39472095e-01 -contig-316000000,8.83627569e-01,7.90661972e-01,4.67427009e+00,-8.24330596e-02,1.14677291e+00,-1.17950487e+00,3.47659942e-01,-3.91163641e-01,-1.26869337e-01,-1.53143836e+00,-3.34755039e-02,-3.64101850e-01,1.67748147e+00,-6.46804591e-01,1.24948667e-01,7.35894844e-01,-7.20256864e-01,-2.90077880e-02,-7.86438995e-01,-7.79377320e-02,5.32986842e-01,4.91463394e-01,-4.57959321e-01,1.23796548e-01,1.24276547e+00 -contig-202000000,-6.28662484e-02,3.14748852e+00,1.39899662e+00,-1.18363865e+00,6.46055741e-01,-4.38362390e-01,-1.01767320e+00,5.54797077e-01,-5.12712867e-01,-1.25276405e+00,-1.56040304e-01,6.83040682e-01,-1.64922932e-01,5.76344056e-01,-5.90262139e-02,3.42503152e-01,9.87305573e-02,5.26998439e-01,-5.70599660e-01,-1.81316087e-01,7.36813319e-01,4.73100162e-01,3.48773634e-01,6.83627438e-01,8.90158425e-02 -contig-293000000,3.19012826e-01,6.06378558e-01,4.95053878e+00,-7.82072884e-01,1.75290644e+00,-6.63089248e-01,1.50736598e-01,-5.67129189e-01,-5.20745446e-01,-1.03808103e+00,5.04628258e-01,-6.14689937e-01,-2.14093639e+00,2.19184440e-01,2.93384879e-01,8.24180382e-01,5.35761767e-01,-5.19180618e-01,3.55305495e-02,1.79338319e-01,1.33186418e-01,-4.67804765e-01,1.24746128e+00,9.13492622e-01,1.78793709e-01 -contig-180000000,-6.77988923e+00,-2.84892521e+00,-3.46199784e+00,-1.08737437e-01,-2.09959362e-01,7.79297060e-02,2.62066564e-01,3.06550512e-01,-7.68764876e-02,6.48468149e-02,2.26749853e-02,3.20606060e-02,-1.75304172e-01,1.00232688e-01,1.56930120e-01,2.51625408e-02,1.21998716e-01,-2.26795284e-01,-4.05973211e-01,1.82005355e-02,1.29290043e-01,-3.10953148e-02,-2.51471609e-02,1.29127370e-01,-1.50715909e-01 -contig-694000000,-2.73040296e+00,-4.33044133e+00,2.63415036e+00,-1.08068145e+00,4.16153235e-01,-1.47078130e-01,-1.24028750e-01,-3.94556774e-01,9.49721935e-01,-1.18485621e-01,-7.92585787e-01,-6.54230174e-01,8.17261445e-01,-1.13183409e+00,3.16501010e-01,1.88465028e-01,-6.72268146e-01,-2.64317790e-02,3.70093938e-01,-1.08787627e-01,4.05065736e-01,2.26357644e-01,1.09046029e-01,1.63298025e-01,-3.88737106e-01 -contig-225000000,-9.12560623e-02,4.99169332e+00,7.42153916e-01,-8.24511923e-01,-3.75275444e-01,-1.16555189e+00,-1.57962888e+00,1.89081920e+00,1.93743609e+00,-1.86976049e-01,6.44119061e-01,-7.93798172e-01,1.07877903e+00,4.04478548e-01,2.08258668e+00,-1.48692498e-01,7.41342868e-01,-2.34227157e-01,-6.15884712e-01,2.66833042e-01,6.05715178e-01,8.29799630e-01,1.55527713e+00,-1.40266635e-01,-1.59807185e-02 -contig-235000000,-1.94643906e-01,2.66403823e+00,2.18619733e+00,3.19366443e-01,1.40685960e+00,-5.72586076e-01,2.32972274e-01,-3.95420885e-01,-1.18079638e+00,-1.67510142e-01,4.89676280e-01,1.26067159e+00,9.83821528e-01,1.08117034e+00,-5.39014098e-01,-1.47165663e+00,4.35520265e-01,6.76494422e-02,1.72088423e-01,6.87213154e-01,2.10705041e-01,-7.23896372e-01,-3.21542507e-02,6.94210586e-01,-3.65295261e-01 -contig-4909000000,1.29675822e+01,-3.03861337e+00,-3.37049293e+00,-5.18967829e-01,-1.75556327e-01,5.26795610e-01,-4.78678206e-01,-1.19789993e-01,2.31042129e-02,-4.29719123e-01,2.36947309e-02,-1.43882018e-01,-1.79018051e-01,2.83568043e-01,2.20647358e-01,-2.08308751e-01,1.27802219e-01,3.23936923e-01,-4.88403976e-01,1.37940410e-01,-2.29698207e-01,-2.56900521e-01,-1.59249147e-01,3.06335833e-02,7.24091616e-02 -contig-307000000,6.62529597e-02,4.39461957e+00,6.23847055e-01,5.44195792e-02,-7.49520685e-01,9.19620430e-01,2.51442452e-01,-8.91385274e-01,-2.78616347e-01,1.08956084e+00,2.65661214e-01,-7.25710480e-01,7.80889283e-02,1.06908895e-01,-3.90176279e-01,-5.51904553e-02,-1.02963117e+00,9.81721358e-01,2.84797464e-01,6.11955838e-01,-6.58345051e-01,8.95055805e-02,2.69970029e-01,1.59250648e-02,-2.81851173e-01 -contig-261000000,7.32029974e-01,4.96219675e+00,-1.54745286e-01,-2.00825339e-01,5.71342182e-02,-2.63442909e-01,1.54854377e-01,2.74798892e-01,-1.00471937e+00,6.82287297e-01,-7.76582633e-01,-4.46280409e-01,-9.14456379e-02,-1.08976947e+00,3.59088583e-01,1.90100408e+00,8.54277934e-01,5.65297625e-01,-1.08637707e+00,2.88918956e-01,-1.33708388e+00,4.59299524e-01,2.32785958e-01,5.71008840e-01,-1.39286005e+00 -contig-145000000,-4.63870874e+00,1.18392961e-01,-3.13232071e+00,1.27669374e+00,2.25253380e-01,1.07548161e+00,-3.76108896e-02,-5.24267170e-01,-5.19627410e-01,8.59194122e-02,-3.23311862e-01,-3.65035264e-02,-6.32707543e-01,7.40961081e-02,1.71922414e-01,4.61544946e-01,1.80375771e-01,-3.01179691e-01,4.15048714e-01,5.52716438e-01,4.02602597e-01,-6.45581285e-02,-1.77762895e-01,3.77799431e-01,1.72961343e-01 -contig-166000000,-4.90609531e-01,4.50323373e+00,5.42050316e-01,-1.06914198e-01,-4.18639514e-01,6.61100327e-02,-4.99218546e-01,1.93452921e-01,-3.90077768e-02,7.64259732e-01,-1.04311481e+00,-9.03831730e-01,-2.31489712e-01,4.33372146e-01,6.49379966e-01,7.71271117e-02,-3.43516521e-01,9.27429815e-02,-4.37893167e-01,-6.62258706e-01,1.16085315e+00,7.57459328e-02,-1.04503599e+00,-3.00822842e-01,-2.17146644e-01 -contig-80000000,-1.16574509e+00,4.55758456e+00,-6.14221134e-01,-3.84608996e-01,1.66107825e-01,4.88382511e-02,8.50779849e-01,4.09868624e-01,-8.86795432e-01,1.59838507e-01,-5.42423553e-01,-2.84424261e-01,-1.94521391e-01,2.92242783e-01,-4.72753902e-01,7.37425430e-01,3.71777311e-01,9.39071812e-01,-4.58561330e-01,-6.27836781e-01,8.05221384e-01,1.05846044e-01,-3.97545777e-01,2.13952450e-01,-4.73652856e-01 -contig-83000000,-1.36660725e+00,4.58918342e+00,-5.30996285e-01,-1.44616422e-02,3.28791143e-01,-1.02229137e-01,1.14103305e+00,8.46587177e-01,-7.66980374e-01,-7.34419177e-03,-4.83324721e-02,-3.82093303e-02,-2.88895320e-01,4.08678894e-01,-4.59644181e-01,-3.73284105e-01,5.39374942e-01,2.09169410e-01,-1.15855021e-01,-3.48600141e-02,-3.82893112e-01,7.02028292e-01,-6.30952872e-01,2.12401123e-01,1.70209835e-01 -contig-72000000,4.95890963e+00,-6.48834795e+00,6.70303824e+00,4.57594371e+00,8.71131411e-01,5.93698814e-01,2.78124259e+00,2.88626014e+00,1.04436527e+00,1.54545600e-01,1.07296128e+00,-5.34174167e-02,2.76651097e-01,2.17479778e-01,1.09341273e+00,4.93728287e-01,8.57714673e-02,1.58154885e-01,-3.36812889e-01,-2.78436354e-01,3.96863517e-01,-1.61790145e-01,-2.43100414e-01,-1.93250033e-01,-2.45345278e-01 -contig-144000000,-6.43570636e-03,3.48924928e+00,8.54451218e-01,-8.81887108e-01,8.66338363e-01,-9.57515167e-01,5.00571184e-01,2.37728980e-01,3.43034154e-02,6.83402838e-01,-9.29917741e-01,-5.14953655e-02,2.84549631e-01,3.89527110e-01,-2.29654259e-01,8.06912088e-01,6.27420317e-02,7.52602925e-02,-5.29946597e-01,2.28953791e-01,-8.39473114e-01,-5.60310418e-01,9.96686416e-02,-2.88699210e-02,4.11455181e-01 -contig-108000000,5.26662235e+00,-4.56896852e+00,6.23568295e+00,6.52849823e+00,2.03788114e+00,-1.43003587e+00,2.74412519e+00,2.10855908e+00,5.60450791e-01,-3.01208093e-01,-9.36348522e-01,8.73524181e-01,-8.06433773e-01,-4.54813187e-01,3.36883151e-01,3.20096589e-01,-1.01081793e-01,-5.85297494e-01,-6.07746483e-01,-8.41900959e-02,-9.05577015e-01,5.65317405e-01,7.40503994e-01,-4.33146640e-01,-8.18308430e-01 -contig-198000000,-4.13455115e-02,3.37888823e+00,1.47073131e+00,-8.29338098e-02,1.16226303e+00,-6.42633749e-01,-8.82848580e-01,9.64026347e-01,-8.03449520e-01,-3.02098312e-01,2.81527821e-01,4.26719100e-02,4.20535126e-01,5.51279855e-01,9.54963322e-01,3.34649705e-01,2.54858000e-02,3.85877540e-01,1.44451078e-01,5.47616959e-01,9.97728122e-01,1.68740209e-01,8.87504400e-01,-4.20846020e-01,-1.10329109e+00 -contig-181000000,3.33999634e-01,5.74272318e+00,-1.22679035e+00,-1.60677309e-01,-3.10970739e-01,4.61806517e-02,-1.67900571e-01,8.78201419e-01,7.04477563e-03,-3.18265692e-01,-1.16538252e+00,-2.11141384e-01,-1.52849770e-01,-4.29975825e-01,6.97115504e-01,-2.57408581e-02,-1.64074344e-01,5.07129076e-01,2.38276263e-01,3.94300923e-01,-4.15801069e-01,-5.16036701e-01,-2.83304590e-01,2.44107214e-01,-3.12282824e-01 -contig-104000000,-6.37429258e+00,-3.13485780e+00,-2.40003209e+00,-7.31779438e-01,-9.36008037e-03,-1.99098362e-01,5.32660730e-01,3.09843676e-01,2.00467649e-01,-2.65793187e-01,-4.44287966e-02,-4.46692618e-02,-1.41423097e-01,1.78343363e-01,1.83076564e-01,8.95363486e-02,2.93862342e-01,1.26913234e-01,-1.05883957e-01,-4.17738190e-01,-2.38458892e-01,-1.43334671e-01,2.09388775e-02,-3.65900309e-02,9.81317289e-03 -contig-250000000,4.67113072e-01,4.98497524e+00,5.07534072e-02,-9.08638617e-01,-9.51390148e-01,-1.51706656e-01,-2.44342232e-01,-4.12069742e-01,-6.32131004e-01,-3.59735672e-03,1.89513156e-01,1.85252659e-01,-1.29419353e+00,-6.78069439e-01,1.90384855e+00,5.58317525e-01,3.99585262e-01,6.49493313e-01,2.33193684e-01,3.32370827e-02,-3.16568258e-01,1.09358404e+00,5.56674408e-01,2.86645447e-01,4.97943741e-01 -contig-102000000,-1.06338905e+00,5.29577715e+00,-6.21272362e-01,1.94331186e-01,-1.31863846e+00,1.23970944e+00,7.53018545e-01,-1.12321874e-01,6.21133897e-02,2.09945646e-02,5.01906689e-01,-5.88970343e-02,-9.99955621e-02,-5.04935566e-01,-8.84040122e-01,5.58154538e-01,-8.97272601e-01,6.52504264e-01,4.87311238e-02,-3.46500774e-01,-2.04993426e-01,1.12050629e-01,-6.39674062e-01,-1.91873576e-01,1.10415520e-02 -contig-122000000,-6.37403986e-01,3.95931274e+00,6.17679875e-01,5.47509075e-02,5.14645222e-02,-5.76008084e-02,1.59391125e-01,2.63680751e-01,2.80325062e-01,-3.04056693e-01,4.98290720e-01,8.54892493e-01,-5.16822391e-01,5.83681818e-02,-5.25835184e-01,-7.43234800e-01,-3.31207459e-01,3.65943852e-01,-1.92818415e-01,4.31996262e-01,-2.56499254e-01,8.72719264e-01,1.25275040e-01,4.40664782e-01,-1.61902342e-01 -contig-268000000,5.31592068e-02,5.68917488e+00,-4.78428210e-01,3.19126934e-01,-3.94901516e-01,2.47768709e-01,-1.89668177e-01,4.69405096e-01,-8.64262068e-01,4.44765665e-01,-5.76688997e-01,8.74969396e-01,1.90336446e-01,-5.87051972e-01,3.37908421e-01,6.72862822e-02,7.12317963e-01,-5.56640404e-01,8.01037637e-01,-9.93689372e-01,4.64143649e-02,4.94443937e-02,-1.18362828e+00,1.12040766e+00,5.75156156e-02 -contig-313000000,9.78773293e-01,-4.91240818e-01,5.34523881e+00,-1.44871379e+00,5.09350380e-01,-2.76861504e-01,-8.38073484e-01,-3.72902103e-01,-1.00540082e-01,-1.31310011e+00,1.08546048e-01,3.94815524e-01,-5.16260250e-01,3.29951750e-01,5.64258788e-01,3.02153022e-01,-5.28368087e-01,1.22934173e-01,-1.14008057e+00,9.69316574e-01,2.62933270e-01,-5.02472109e-01,1.07484770e+00,5.40131975e-01,-1.58402788e+00 -contig-20000000,-5.50689070e+00,-4.21635517e+00,-9.53457745e-01,-2.18084789e-01,-6.95008432e-01,-1.31189896e-01,-2.41919920e-02,1.78274049e-01,-4.59416192e-02,2.71290929e-01,-3.91672216e-01,5.81227446e-02,4.92285738e-02,2.68278648e-01,-5.79155879e-01,1.39632020e-01,-3.24744735e-01,-3.25994313e-01,3.52469812e-01,1.60472509e-01,2.83472952e-02,2.45237710e-01,2.52655148e-01,2.63301941e-01,1.39761198e-01 -contig-12000000,-5.92184271e+00,-1.72954319e+00,-3.11881885e+00,2.35062549e-01,4.09252316e-01,-3.25327237e-01,2.70562482e-01,-4.25898121e-01,-3.75810233e-01,-1.73789304e-01,3.96710393e-01,-1.93700252e-01,1.90364320e-01,-5.62356618e-01,1.40986561e-01,1.32193920e-01,4.04022731e-01,7.84555288e-02,-5.79705363e-02,-7.23599816e-02,-3.06166651e-01,-1.77806663e-01,-6.02378259e-01,-1.08044647e-01,-2.17415886e-01 -contig-50000000,-5.21784841e+00,-4.53171316e+00,2.42961401e-02,-3.08497435e-01,3.16702141e-01,-2.90742395e-01,-6.28126026e-01,-4.56501368e-01,-1.17759012e-01,-1.00047244e-01,4.97800648e-01,-1.50352875e-02,3.55218089e-02,9.09294648e-02,2.25310613e-02,-1.89976320e-01,6.95252312e-02,2.34596417e-01,-5.13219624e-01,-3.26490883e-01,-2.10755849e-01,-1.09896445e-01,-2.66768342e-01,-3.08982634e-02,-2.57763164e-01 -contig-109000000,-1.10958334e+00,4.76884639e+00,-1.08190689e-01,2.60270282e-01,-2.36668951e-01,2.19852046e-01,1.98792773e-02,3.83788177e-01,-7.07944413e-01,7.33449396e-01,-7.32900431e-01,5.81024716e-02,-7.71080537e-02,8.16161558e-02,-1.52056344e-01,-1.03906016e+00,2.81807963e-01,1.95206351e-01,-4.62554649e-01,-7.22914115e-01,1.01559292e+00,1.13483685e+00,-7.44473706e-01,3.87476425e-01,-1.70037683e-01 -contig-4924000000,-7.22113139e+00,-3.32230279e+00,-3.81559551e+00,-4.83167254e-01,-2.60202980e-01,-5.77277848e-02,8.11576674e-01,4.98618806e-01,-9.82909371e-02,-3.05015698e-01,1.79867226e-01,-1.11173486e-01,-7.14894819e-02,-1.96708834e-02,1.35409320e-03,3.90935972e-02,6.40304050e-03,1.40174592e-01,-1.05108161e-01,-1.62732591e-02,7.14600629e-02,6.18043121e-02,2.88567116e-01,5.78518396e-02,-7.11862989e-02 -contig-859000000,1.08611754e+01,-6.80189934e-01,-3.12369937e+00,3.63691646e-01,-7.06929486e-03,4.35815647e-01,-5.86923753e-01,-8.59413161e-01,1.60043758e-01,-3.37153024e-01,2.34757221e-01,-5.34098674e-02,-6.63174667e-02,1.44376464e-01,1.78621787e-01,-1.90650849e-01,1.01859281e-01,-4.33541188e-01,-6.54505662e-01,-2.71040168e-01,-7.22246378e-01,-3.56142946e-01,2.42602316e-01,2.93891043e-01,-4.66444539e-01 -contig-475000000,1.04359304e+01,-2.17087262e+00,1.55450221e-01,3.56386966e-01,4.07293114e-01,2.67320327e-01,8.88123927e-01,-2.30120322e+00,-2.36715013e-01,5.82424844e-01,1.10661095e+00,-3.76454651e-01,-3.29245144e-02,4.87014685e-01,-1.76666488e-01,1.39892654e-01,4.50058022e-01,-3.14055414e-01,7.58230460e-02,-3.13584197e-01,7.23795177e-01,4.61735815e-01,-1.07073611e-01,7.60565195e-01,-2.97006286e-01 -contig-230000000,-4.74752888e-01,5.40679366e+00,-6.05093592e-01,2.38572198e-01,3.01821899e-02,4.09510821e-01,1.27911657e-01,7.45634340e-01,-5.81769766e-01,9.40318065e-01,-6.97985980e-01,-1.53227503e+00,-4.97885424e-03,-1.32744124e-01,-1.75058250e-01,-1.99495462e+00,6.13165647e-01,-8.10506044e-01,1.17618834e-01,5.41070018e-01,-9.56593239e-01,1.12614143e+00,3.17313920e-01,-2.61514420e-01,1.73053625e-01 -contig-2920000000,-2.43507522e+00,-2.56805834e+00,2.21380516e+00,1.14018755e+00,1.45273807e-01,1.96585359e-01,-2.33570812e+00,-1.61119359e+00,2.67469568e-01,2.35802490e-01,-3.26457689e-01,5.21101399e-01,-1.24991395e-02,2.76794435e-01,-1.78606302e-01,4.13399724e-01,7.89941700e-01,-6.97290124e-01,-7.53419809e-01,-4.97152119e-01,1.22305970e-01,3.79476834e-01,-4.02661859e-01,-6.40759999e-01,-1.38171384e+00 -contig-260000000,-2.85826599e-01,3.84213921e+00,1.52164657e+00,4.16278683e-02,-2.62274056e+00,1.08516350e+00,-8.27822462e-01,-1.92982747e-01,2.28644358e+00,-7.51974876e-01,1.86887783e-01,5.34017287e-01,2.57867561e-01,-3.09460957e-01,-6.13962775e-02,-1.99109416e-01,1.65541378e-01,-1.46132914e+00,3.34290643e-01,-3.27859233e-01,-5.03942858e-01,3.50953444e-01,3.19611156e-01,-1.11595431e+00,-3.86482957e-01 -contig-314000000,1.86071990e-01,4.96211359e+00,7.74105893e-01,-1.28817457e-01,-2.30130641e-01,-1.60548875e-01,-1.26613352e-03,-1.17929040e+00,-9.01294531e-01,2.30977779e-01,6.41663084e-01,9.62026615e-01,-1.66102373e-01,3.17504463e-02,1.25681894e+00,-1.30554439e-01,-1.68390703e-01,4.11469520e-01,4.82107581e-01,-2.15596009e-01,1.65097386e+00,-3.69940725e-01,-8.30356294e-01,8.47286097e-01,-3.02388823e-01 -contig-123000000,-2.62790714e-01,3.51837185e+00,9.60612036e-01,-5.80086694e-01,7.54381404e-01,-9.60826113e-01,7.70466531e-01,4.65049423e-01,5.33203489e-01,-5.19158176e-01,-1.40814589e+00,-1.96806601e-01,-1.06402050e+00,-4.09011792e-01,-5.91951991e-04,3.75237210e-01,-4.00274464e-01,-1.05013676e+00,-6.97663961e-01,1.09317421e+00,-2.22553070e-01,4.42157565e-03,-3.72628651e-01,-5.64569216e-01,-3.63288467e-02 -contig-253000000,-2.88962942e-01,4.44505718e+00,5.57694249e-01,-5.99205462e-02,-2.35787628e-01,2.22018071e-01,1.36343478e-01,-5.35982129e-01,6.05882911e-01,7.27496228e-01,2.64317652e-01,1.85908479e-01,-9.08598765e-01,-1.04529445e-01,-1.23999388e+00,-1.44323913e-01,-7.83254870e-01,1.29977850e+00,4.09901356e-01,6.47358489e-01,-2.57931947e-01,-4.48438410e-01,6.57226377e-02,-5.63304728e-01,7.06248043e-01 -contig-4914000000,-6.33937884e+00,-2.34288718e+00,-3.27606766e+00,-2.12492455e-01,2.71230421e-01,-1.44091814e-01,1.16956682e-01,1.34959002e-01,-1.10340013e-01,1.52203545e-01,2.86195847e-01,3.71331064e-02,-4.24971383e-01,1.35101198e-01,7.95651903e-02,2.28267768e-02,1.05938494e-01,8.28640294e-02,-2.38176851e-01,-5.67083673e-02,-1.18873206e-01,-6.51467316e-02,2.06584325e-02,9.80958916e-03,-8.63524863e-02 -contig-1820000000,-2.51499489e+00,4.08229987e-01,4.82800994e-01,4.13719688e-01,1.40590218e+00,-8.80265064e-01,-8.65949665e-01,-1.32615921e+00,9.07963520e-01,-7.00091779e-02,1.86084918e-01,1.86348171e+00,8.00593129e-02,1.35780415e-03,9.16988099e-01,-2.69801621e-01,6.62687699e-02,-1.13023472e+00,-2.15837653e-01,-3.90470815e-01,-5.38070263e-01,7.96945159e-01,-1.70597892e-01,-4.32921225e-01,-1.88620963e-01 -contig-1529000000,-6.05893240e+00,-2.82514626e+00,-2.74721694e+00,-1.88639788e-01,7.85348196e-02,-3.41128547e-02,2.98439074e-01,4.71704730e-01,-4.27944291e-02,-3.02308812e-02,-1.56959840e-01,-5.55670350e-02,6.82385362e-02,4.22300910e-01,-1.80724789e-01,-9.12561463e-02,1.17536366e-01,-8.52817244e-02,3.42197861e-01,7.14825674e-02,2.72507564e-01,2.04951911e-01,2.90176831e-01,8.05488185e-02,-1.14279695e-01 -contig-142000000,-6.88380095e-01,3.88824353e+00,9.36657137e-01,-8.71060799e-01,-1.25830048e+00,2.72949342e-01,-6.95300668e-01,5.20652359e-01,6.19162798e-01,-1.17720045e+00,-1.83448023e-01,-7.98977682e-01,7.34544879e-02,1.61685377e-01,6.08913828e-01,-2.15103464e-01,8.60521697e-01,-2.39234268e-01,9.73859977e-03,6.58031885e-01,-1.38905698e-01,3.41959188e-01,9.25021926e-02,6.09207960e-01,4.49713672e-01 -contig-18000000,1.33487027e+01,-2.64410884e+00,-4.31595405e+00,-5.67111089e-01,-2.70422954e-01,1.81051364e-01,-9.59529019e-01,9.70423887e-02,-1.56079977e-01,-3.60928621e-01,1.83911372e-01,-1.77974591e-02,-2.08339561e-01,-6.07132940e-02,5.55360378e-02,-2.38347911e-01,-2.70825403e-01,3.15787840e-01,-5.22317967e-01,-3.11415688e-02,-1.91403580e-01,-7.84120779e-02,-2.41352655e-01,2.95267110e-01,8.27068315e-02 -contig-19000000,-5.30642047e+00,-5.07834379e+00,-6.79272101e-01,-2.49948727e-01,-6.34956078e-02,9.02279340e-02,6.58469232e-01,-4.33292434e-02,2.18636230e-01,-5.95722354e-01,-5.14945338e-01,-9.01426524e-02,2.81272242e-01,3.75054386e-01,-1.15102850e-01,-1.36495868e-01,-4.60032389e-01,1.15907730e-01,1.49557256e-01,1.35110879e-01,6.55422318e-02,2.71055062e-02,1.01631370e-01,-8.38739344e-03,-1.59283387e-01 -contig-2000000,1.39430686e+01,-2.51056687e+00,-5.84681451e+00,-4.90375084e-01,-1.19390533e-02,-3.66805083e-02,-1.13799816e+00,4.71915316e-01,-6.01502607e-01,-5.47410522e-01,-2.89726631e-01,2.26154455e-01,-7.49589644e-02,-2.44245441e-01,1.90727816e-01,-1.57075191e-01,-3.74046296e-01,1.52452651e-01,-7.02708588e-02,-6.05756186e-02,-1.62427704e-01,-9.37933466e-02,-4.72082396e-02,1.10917831e-01,-1.72407926e-01 -contig-2983000000,1.10389691e+01,-1.81897285e+00,-1.34793575e+00,-9.49728298e-02,3.55716696e-01,5.84545440e-01,-2.55451762e-01,-6.44245915e-01,4.45054799e-02,7.22069921e-01,1.44485030e-01,8.98706447e-02,-7.52808926e-01,1.06691917e+00,1.27831755e-01,-1.40519953e-01,7.71214211e-01,3.18928705e-01,-3.88721266e-01,3.75435135e-01,-7.24921103e-01,1.44293764e-01,-1.40468422e-01,-1.59029443e-01,6.82238179e-02 -contig-217000000,3.42919523e-02,6.00455914e+00,-5.69877381e-01,8.99922159e-01,-5.52272377e-01,8.85335672e-01,1.02836871e+00,-2.76026053e-01,-1.15853524e+00,-2.97509471e-01,-1.24092697e-01,-2.02068679e+00,4.33467906e-01,-4.12545233e-01,9.74515512e-01,-2.86769169e-01,2.27606551e-01,-4.70807028e-01,-6.31662570e-03,6.36659665e-01,2.63874619e-01,-2.82524579e-01,2.45936421e-02,-1.38356054e-01,-1.02289610e+00 -contig-158000000,4.83949666e+00,-4.62819816e+00,4.97724466e+00,4.37861529e+00,2.15232014e+00,6.32797793e-01,6.69636410e-01,2.51863135e+00,4.34810045e-01,-1.73542458e+00,-5.21577344e-02,1.68015056e-01,-1.44615000e-01,1.02555622e-01,1.21193906e-01,7.46613198e-01,6.20275725e-01,8.75585847e-01,-6.29149616e-01,2.66490100e-01,-4.60280384e-01,2.18338964e-01,6.87743835e-02,-4.13216576e-01,9.59258090e-02 -contig-552000000,1.13632298e+01,-2.69285616e+00,3.99652745e-01,-7.09198164e-01,2.03722053e-02,-5.21087840e-01,1.82213385e+00,8.47858762e-02,1.22246188e+00,1.77710917e+00,-8.00987838e-02,3.98782901e-01,2.83780902e-01,9.05982895e-01,3.23678780e-01,8.24720225e-01,-6.67144882e-01,-6.66523543e-01,1.00668931e+00,-1.22778224e-01,7.43305974e-01,4.46925218e-01,-2.68808025e-01,-2.81370385e-01,1.50169631e-02 -contig-241000000,-4.05226090e+00,-4.67185027e-01,-1.77055084e+00,1.10154374e+00,3.18163583e-01,8.03481306e-01,-1.00641610e+00,-9.10574423e-01,-1.06652729e+00,-3.01949557e-01,3.22698326e-01,-3.02482466e-01,1.08560977e+00,-2.00937600e-01,2.54751552e-01,2.78796184e-01,5.59939560e-02,-1.03762169e+00,3.77350152e-01,9.60861454e-02,3.10240694e-01,-3.27944980e-01,2.18579039e-01,1.44063440e-01,-3.55923441e-01 -contig-257000000,1.94995119e-01,1.87727342e+00,2.72355990e+00,-2.03240624e-01,6.92485205e-01,-1.02957156e+00,6.50419701e-01,2.93214244e-01,4.53723114e-01,-8.61374491e-01,-1.33176464e+00,9.66602175e-01,6.80264283e-01,-4.80081734e-01,8.50657939e-01,-6.66847575e-01,6.56583597e-01,-9.95406481e-01,3.71166108e-01,5.16839522e-01,3.21394113e-01,-6.80434839e-01,-1.00607604e+00,8.36222136e-01,-7.40423423e-01 -contig-172000000,1.46945232e+00,6.99325259e-01,3.88943467e+00,1.22076613e+00,-2.38553588e+00,-3.13476412e+00,8.99047636e-01,2.09395147e-01,3.75322287e-02,-9.45775573e-01,-1.85727803e+00,-8.51540500e-02,4.65075138e-01,-7.35140151e-01,-8.48586053e-01,-5.02547481e-02,-9.63208429e-01,6.54738584e-01,5.00726323e-01,-7.75752689e-01,4.05874642e-01,-4.77223472e-01,8.04306449e-01,7.30401005e-01,-2.14544457e-01 -contig-196000000,-9.03920235e-01,3.67154154e+00,1.19927765e+00,-3.24758774e-01,5.42581839e-01,-2.96325612e-01,-5.45202581e-01,-3.29802428e-01,-6.26743621e-01,6.02929562e-01,-2.40528936e-01,-5.10798668e-01,-4.93281111e-01,2.19904758e-01,-1.33475737e+00,1.49813463e-01,-1.76061933e-01,4.97942046e-01,-3.65401745e-01,-1.19365743e-02,4.05166162e-01,3.46324501e-01,1.20167762e-02,-8.09878772e-01,-8.00552122e-01 -contig-52000000,-5.51235798e+00,-1.54918781e+00,-2.66650803e+00,4.13472914e-01,2.20096836e-01,3.73904913e-01,3.35136596e-02,-3.11448262e-01,-2.82478938e-01,-2.49395279e-01,1.35812820e-01,3.69284708e-02,-3.82749181e-01,3.77068166e-01,1.95914367e-01,5.01820621e-02,3.20632107e-01,-5.11069725e-01,1.99289868e-01,9.89230377e-02,-1.75628791e-01,9.88216458e-02,2.65450674e-01,-2.36703224e-01,-2.76776078e-01 -contig-22000000,1.28547547e+01,-4.97483557e-01,-6.36767382e+00,-8.76677113e-02,1.29661751e-01,-4.48862093e-01,-5.00433909e-01,7.09782360e-01,-4.48801145e-01,3.23311286e-01,-5.34028140e-01,4.38961438e-01,4.04005641e-05,-5.38439930e-01,-5.09063357e-01,4.12504625e-02,1.52295917e-01,-5.64402336e-02,2.06978409e-01,7.00828110e-02,1.38820614e-01,5.25343257e-02,1.99988626e-01,-6.97833148e-02,7.97432253e-02 -contig-284000000,4.73650755e+00,-6.20350985e+00,8.45721904e+00,3.03051463e+00,1.79915866e+00,2.04610416e+00,-1.62454928e+00,2.23126846e+00,-1.31561267e+00,-1.53487611e-01,1.11775225e+00,5.64451966e-01,-6.62090400e-01,-1.61838028e+00,5.25620103e-01,1.17703757e-01,-4.53496554e-01,1.20930323e-01,-8.38675127e-01,-1.29049154e-01,5.02576015e-02,-7.07495434e-01,3.11384664e-01,6.91985336e-01,8.69103588e-01 -contig-295000000,-6.64833843e+00,-3.54041548e+00,-2.20972225e+00,-1.34085845e+00,3.13217973e-01,-5.34291068e-01,1.81191500e+00,1.22015296e-01,1.28831237e-01,-9.78587293e-01,3.49167510e-01,-1.10383317e-01,1.06045525e-01,-2.40730269e-01,1.74266545e-01,-3.06373020e-01,-1.84583176e-01,1.94085526e-01,2.64301813e-01,-3.12640434e-01,-4.75176546e-01,1.73295519e-01,-1.11104347e-01,-2.44321457e-01,2.47113619e-01 -contig-270000000,4.47199755e+00,-3.50056625e+00,5.94826447e+00,-1.08004458e+00,-1.73874273e+00,5.44951841e-01,9.96170936e-01,-2.19815675e+00,-1.90189797e-01,1.60286530e+00,-5.49115906e-01,5.15613696e-01,8.58655648e-01,-7.67248532e-01,8.62568615e-01,3.26843624e-01,1.22617406e+00,1.56725968e+00,-7.07721833e-01,-4.68768467e-01,8.89781214e-01,2.03897471e-01,1.56875777e+00,8.45801023e-01,-9.36054639e-01 -contig-1058000000,6.67568754e+00,-4.64914576e+00,9.77359224e-01,4.54810450e+00,-8.11997009e+00,-7.48980139e+00,-1.33742696e+00,-4.72779468e-01,-1.15212107e+00,8.20741403e-01,1.52165885e+00,-9.36634391e-01,-5.97958267e-01,1.06745103e+00,4.58720812e-01,-3.17808539e-01,-7.24270433e-01,-1.21732914e-01,-1.58576645e+00,-4.64122277e-01,-2.59066349e-01,-9.76118051e-01,-1.11969040e+00,-8.16811150e-01,2.37484832e-01 -contig-262000000,-3.61311258e-01,3.88548945e+00,1.39267904e+00,4.51182424e-01,5.52809742e-01,8.52125968e-02,-9.76322815e-01,3.53335877e-01,2.40184647e-01,9.27162707e-01,-9.39169111e-02,5.98192962e-01,-1.24111341e+00,6.31465410e-01,1.51896136e-02,2.48454111e-01,2.90910375e-01,5.78328092e-01,-7.90076255e-01,-9.49734247e-01,4.50602646e-01,1.66731923e-01,-6.65442605e-01,6.27178118e-01,-5.08648015e-02 -contig-233000000,3.23584613e-01,-9.95971291e-01,5.56203572e+00,-6.80886279e-01,1.11498605e+00,2.48102945e-01,6.99196825e-01,-8.65657915e-01,-6.54151241e-01,-1.11585374e+00,-1.18677043e-01,-1.06717027e-01,-1.40838220e+00,9.13794860e-01,-4.52172459e-01,1.93331074e-01,-5.30943074e-01,2.02130006e-01,2.63280779e-01,-2.87207814e-01,5.68558632e-02,-5.04973666e-01,6.34289323e-02,-8.32262841e-02,-2.60074206e-01 -contig-4925000000,1.34807499e+01,-2.26995168e+00,-5.71158125e+00,-4.76361463e-01,3.09096116e-01,-6.82500102e-02,-9.41658373e-01,4.87624068e-01,-4.27595318e-01,-3.67412181e-01,-4.66758992e-01,4.77114131e-01,-1.83289507e-01,-3.63867147e-01,-2.14942104e-01,-2.63444556e-01,-2.61080892e-01,2.44137697e-01,6.09074377e-02,-3.08676257e-02,-3.00022336e-01,-4.30397984e-02,4.10984514e-02,-4.71886461e-02,1.20541604e-01 -contig-4907000000,-6.06351651e+00,-2.08464665e+00,-2.88666548e+00,1.65841693e-01,-5.09435311e-01,5.10288420e-01,-2.00590501e-03,5.44535829e-02,4.54740958e-02,-1.16439698e-01,-8.25172650e-01,-3.34884914e-01,-2.08994515e-01,2.82671678e-01,1.39483989e-01,-4.67724958e-01,9.32474560e-02,-6.47500430e-01,-4.07454159e-01,4.17784080e-01,2.00957482e-01,1.21115727e-01,1.80280906e-01,-2.66226451e-01,1.40455373e-01 -contig-4917000000,-7.09724158e+00,-3.58094482e+00,-3.26131511e+00,-4.61490186e-01,-7.43486231e-02,2.53846498e-02,4.00408612e-01,2.06796609e-01,-5.86557946e-01,-4.40877936e-03,5.24560165e-01,2.26556775e-01,6.75820490e-02,1.87521035e-01,-1.16073140e-01,-3.23347539e-02,1.68053594e-01,2.83525221e-01,-3.82368306e-01,1.35466171e-01,-1.02636645e-01,-4.24363255e-01,-2.00997849e-01,5.80769475e-02,-1.30846683e-01 -contig-234000000,-5.12359356e-01,4.55617383e+00,6.86102866e-01,-4.45973061e-01,7.07608954e-01,-9.86908018e-02,-3.01439005e-01,-1.92596564e-01,-9.57119784e-01,6.69371864e-01,5.32002490e-01,-8.05934718e-01,-1.12725037e+00,5.81478137e-03,-2.67984611e-01,8.38803900e-01,-1.13272895e-01,-9.63458082e-02,1.09770647e-01,2.18838282e-01,-7.96409081e-01,-8.95326355e-01,-4.47068063e-01,-5.54856610e-02,-6.98278411e-02 -contig-115000000,-5.43188002e+00,-2.35018903e+00,-2.41340062e+00,2.31612207e-02,1.56948521e-01,2.05150869e-01,2.50682385e-02,3.78886623e-03,-2.96476425e-01,3.97409555e-03,-3.64640731e-02,1.12308426e-01,-2.64614978e-01,-2.93943077e-02,-3.95315549e-01,2.17262157e-01,-3.24393874e-01,-4.07323247e-01,9.93070644e-03,1.02914923e-01,4.45455703e-01,2.40710580e-01,3.29897794e-01,1.46739745e-02,-8.77254607e-02 -contig-155000000,-5.33520967e-01,4.40483099e+00,5.28361693e-01,-8.33907993e-02,-5.83487369e-01,6.98299173e-01,-5.38561634e-02,6.24146272e-02,-1.90445298e-01,-1.77887384e-01,-1.72827829e-01,-2.29029203e-01,2.05561320e-01,4.53278845e-01,-8.01079606e-01,3.42320263e-01,9.25653998e-02,-4.78756656e-02,1.68167354e-02,-5.69627889e-02,9.49206489e-01,-2.52787874e-01,-2.21488959e-01,-5.94149915e-01,-3.03639222e-01 -contig-1117000000,9.70817102e+00,-6.07761881e-01,-4.01374835e-01,-1.87708020e-01,1.84306198e-01,3.84504144e-01,5.25469740e-01,-1.00303108e+00,-1.03440774e-01,-2.67710768e-01,1.53931749e-01,-3.83529269e-01,1.15784320e+00,3.76802470e-01,-9.78079775e-01,-4.32094105e-01,7.25219592e-01,5.59004814e-01,-1.81265697e+00,8.92242771e-02,-2.97152177e-01,-1.06278168e+00,-4.20387955e-02,8.79271494e-02,-3.79574136e-01 -contig-121000000,-5.88309400e-02,3.09592670e+00,7.89618342e-01,-4.17149145e-01,1.50300496e-01,-9.86328228e-02,8.85483971e-01,6.34544024e-01,-1.33276836e-02,-5.06945527e-01,-3.29304357e-01,5.62851561e-01,1.00314939e+00,-5.33368436e-01,-6.33999114e-01,-1.04289510e+00,-5.92779687e-01,-4.58845122e-01,3.44654133e-01,-2.16819320e+00,-2.13587769e-01,-4.40153347e-01,2.24663991e-01,7.72608354e-01,-1.78548921e-02 -contig-287000000,-4.38006597e+00,-7.30411445e-01,-2.48949248e+00,9.83451954e-01,-9.66225190e-03,6.69195442e-01,-8.66473318e-02,-8.30794266e-01,2.46056339e-01,-3.90128950e-01,8.44448844e-02,4.78560878e-01,-4.98267955e-01,1.97870840e-01,-1.23696774e+00,-3.29421798e-01,1.20127897e-01,3.38101661e-01,4.61844094e-01,2.30838438e-01,-8.57583481e-02,2.55514173e-01,3.75140243e-01,1.30264781e-01,5.74776269e-01 -contig-214000000,3.56834572e-01,5.19586953e+00,-4.71669488e-01,-2.29073371e-01,1.06215581e-01,-2.69991013e-02,8.21739162e-01,7.67255003e-02,-5.33048885e-01,4.35645862e-01,-1.22417929e-02,2.53609491e-01,8.91493710e-01,-7.36238772e-01,7.00183164e-01,1.31983902e+00,8.15391210e-01,-2.68451389e-01,-2.49229589e-02,1.93258354e-01,-2.95887675e-01,5.28653440e-02,-3.26380239e-01,-4.28903147e-01,-1.81751148e+00 -contig-21000000,1.12744718e+01,-3.49748277e+00,8.09518943e-01,-3.84124641e-01,8.47313272e-01,-3.24252625e-01,1.31072068e+00,1.20085284e-01,-3.09669800e-01,6.77268916e-01,3.91957152e-01,1.32528350e-01,4.12434200e-01,1.33132107e+00,3.22507395e-01,9.14814044e-01,-7.19946729e-01,-4.35413423e-01,2.96645180e-01,-2.90599989e-01,3.91424511e-01,6.04510821e-01,-1.22652666e-03,-3.91296545e-01,1.57223951e-01 -contig-237000000,-8.15762799e-01,4.00714915e+00,9.51105958e-01,2.13630243e-01,1.27613173e+00,-1.03938384e+00,-7.48871212e-01,1.15124730e-01,-1.09221565e+00,-1.37832902e-02,-3.81703021e-01,1.16763736e-01,-4.01547678e-01,5.85789869e-02,-1.10379162e-01,-1.05788573e-01,1.64227785e-01,2.12318709e-01,-1.08365861e-01,-5.10425121e-01,3.29694668e-01,-8.98061092e-01,2.97679714e-02,-4.79737408e-02,-1.34475867e-01 -contig-2451000000,-3.54102136e+00,-6.02660698e+00,3.03361877e+00,-1.33343687e+00,3.68624957e-01,-2.66593661e-01,-2.18303957e-01,1.95980071e-01,3.11158891e-01,-3.07484215e-02,4.52757563e-01,-5.98184988e-01,7.01544249e-01,-9.76427936e-01,2.02317039e-01,7.37991874e-01,-9.07360304e-02,1.24368403e-01,4.45769862e-01,-2.49817502e-02,1.04883546e-01,-3.94552862e-02,-5.27403586e-02,-2.38885315e-01,-1.20382403e-01 -contig-74000000,-2.20664666e+00,-5.68879322e+00,4.07008092e+00,1.12011841e-01,1.37976614e-01,3.77889641e-01,-1.28658107e+00,-1.03571117e+00,2.64059692e-01,-9.12138309e-02,3.36472779e-01,1.93533740e-02,3.86808719e-02,-9.40293204e-02,2.42681881e-01,4.72761135e-01,-2.70398267e-01,3.01085141e-01,4.29645327e-01,-1.81376327e-01,2.84046369e-01,1.57831306e-01,-1.59902856e-01,1.23533713e-01,-3.53883326e-01 -contig-59000000,-3.27726725e+00,-4.99753463e+00,1.69859697e+00,1.45962454e-01,2.61406211e-01,2.08158568e-01,-1.01076251e+00,-3.79455422e-01,5.67829493e-01,-5.04251629e-01,-3.26139590e-01,-7.77276154e-02,3.15650892e-01,1.00750016e-01,-1.54240408e-01,2.81252071e-01,-1.86664654e-01,3.96505066e-01,1.17686616e-01,4.44963090e-01,7.07906510e-02,-3.24555607e-02,-3.46943415e-02,9.11526287e-02,-8.23899122e-02 -contig-81000000,1.04692888e+01,-1.51779454e+00,-1.76880525e+00,-3.53383563e-01,9.38570133e-01,7.92913751e-01,1.12929436e+00,-1.48877368e+00,8.06779754e-01,1.47679811e-01,9.39600107e-01,5.80446522e-01,-3.05806217e-01,4.58152927e-01,-4.28035461e-01,-1.20768422e+00,1.06939745e+00,5.32927300e-02,-1.12565841e+00,8.27540869e-02,-2.67962814e-01,-7.35395386e-01,-2.99196613e-01,6.14447664e-02,-1.93391441e-01 -contig-40000000,1.05839084e+01,-1.79726166e+00,-1.25242243e+00,-5.40517960e-01,8.01783877e-01,-7.73210718e-01,1.34896585e+00,5.25626170e-01,8.52595158e-01,9.57999103e-01,-2.92719704e-02,4.76431924e-02,4.23677505e-01,1.07238704e+00,-3.04229376e-01,9.32300725e-01,-4.26678770e-01,-5.93814103e-01,6.47391671e-01,-9.85711611e-02,7.69916611e-01,5.71276324e-01,1.83809985e-01,-4.62076691e-01,4.69379058e-01 -contig-199000000,7.78493322e-01,1.03796263e+00,3.33380089e+00,-1.61544617e+00,4.64064597e-02,-4.03325698e-01,5.90659555e-01,-1.16384185e+00,-6.73001380e-01,-7.70112438e-01,-4.11847377e-01,6.62812323e-01,-1.17202634e+00,3.57228270e-01,9.81122027e-01,-4.05262202e-01,-2.73238934e-01,2.33190927e-01,3.03500831e-01,9.12883439e-01,-5.00241886e-01,-5.72805384e-01,-6.49731018e-02,-5.16618916e-01,-1.00565740e+00 -contig-87000000,-2.15148950e-01,5.46800948e-01,3.33205140e+00,-8.36794681e-01,-2.73186107e-02,-4.60103490e-01,1.17991817e+00,-3.52253745e-01,8.14765248e-03,-1.25049163e+00,-6.26030934e-01,6.11624328e-01,6.71154047e-01,2.57839278e-01,-9.02956443e-01,-1.21588512e-01,-6.64752353e-01,-2.31354999e-01,-3.73601855e-01,1.33753083e-01,3.49851175e-01,-4.17730968e-01,1.64930213e-01,-9.09994496e-01,2.32380883e-01 -contig-1486000000,9.32895819e+00,9.09258816e-01,-3.44932134e+00,8.86257962e-01,3.19470565e-01,-2.55410183e-02,-7.69160602e-01,-5.27192365e-01,1.25599059e+00,8.96514578e-01,-7.21089310e-01,1.02388573e-01,1.74666522e+00,-3.78968438e-01,-3.36761412e-01,6.18871187e-01,5.48101508e-01,-2.28962452e-01,-2.55219495e-01,3.57025129e-01,-4.16932579e-01,-4.21219732e-01,1.44825609e+00,-5.25279224e-02,1.89073143e-01 -contig-412000000,-3.55875460e+00,-1.13242719e+00,-2.14087168e-01,1.49428539e+00,-6.72831551e-01,6.99790261e-01,-1.92557863e+00,-7.90764748e-01,5.90669568e-01,5.12034880e-01,-1.31621956e+00,5.60841260e-02,6.12442403e-01,5.59882311e-01,7.08777910e-01,-2.53089396e-01,9.85825884e-01,-2.61850594e-01,-1.75045482e-01,5.69053447e-01,-1.86194673e-01,-6.09337204e-01,-6.20387351e-01,-8.59061971e-01,3.12335488e-01 -contig-171000000,2.86186266e-01,5.47902288e-01,4.29505932e+00,-6.01917534e-01,5.92400233e-01,-2.44421539e-01,7.50664326e-01,-3.01433236e-01,-2.76999262e-02,-4.04228840e-01,-6.38458236e-01,-8.66293449e-01,3.40580170e-01,5.53577849e-01,-2.10402486e-01,3.10220859e-01,4.01602096e-02,6.38703594e-01,-2.40835945e-01,4.54458715e-02,-5.37567491e-02,2.98382121e-01,-3.30090675e-01,-3.80140545e-01,-3.00538929e-01 -contig-4937000000,-7.44894906e+00,-2.60605850e+00,-4.35285388e+00,1.11711598e-02,-7.37468448e-01,5.13656039e-01,3.90222270e-01,3.59028388e-01,-6.77004894e-02,8.40333131e-03,-1.70921858e-01,-1.08836697e-01,-1.46738596e-01,3.99483096e-02,3.16949798e-01,-1.62244234e-01,3.19062638e-01,4.77350182e-02,-5.20595646e-01,-7.57111389e-02,-1.67206804e-01,-4.45340435e-01,-8.43983275e-02,-1.44210472e-01,2.29582047e-02 -contig-65000000,-5.16748836e+00,-1.14045383e+00,-3.09939093e+00,8.11674240e-01,7.26127367e-01,-2.86007186e-01,3.51404595e-01,-5.97853078e-01,5.33585474e-02,-1.82469383e-01,-6.48660512e-01,6.10883669e-01,1.33014090e-01,8.67655351e-02,3.62366567e-01,-3.58474743e-01,7.20498000e-01,2.66837301e-01,3.74415760e-01,-4.90779633e-01,1.32222736e-01,-5.64119853e-01,2.47911917e-01,9.07612208e-02,3.08874417e-01 -contig-136000000,-4.58607548e-01,3.95491904e+00,9.01064087e-01,1.81515087e-01,-2.36840726e-01,6.49782655e-01,6.00843778e-01,-2.83011601e-01,-6.55504341e-01,-3.45436300e-01,-1.40939327e-01,-1.38631628e-01,6.33903288e-01,8.79194198e-01,-6.16523567e-01,4.98696665e-03,1.33863354e-01,-2.47189368e-01,2.46594350e-01,-4.91764479e-02,5.00438203e-01,6.83321102e-01,-1.79647943e-01,2.05757497e-01,2.46417255e-01 -contig-137000000,3.48341468e-01,-1.88481170e+00,6.74783313e+00,-3.23850661e-01,-1.96649542e-01,-4.56112227e-01,7.47976599e-01,-6.40857048e-01,6.18564385e-01,-1.22889284e+00,-2.64104015e-01,-4.34251063e-01,-2.70258541e-01,-8.38994180e-01,1.63492425e-01,-5.06156350e-01,-1.69172182e-01,-1.12780197e+00,-1.00050618e+00,7.98515722e-01,6.31813532e-01,-4.25501626e-02,-4.72968496e-01,-2.03620536e-01,-1.86708589e-01 -contig-1042000000,1.03482391e+01,-4.71368943e-01,-2.21834739e+00,-2.13535791e-02,1.82247798e-01,3.24085135e-01,5.98045288e-01,-1.13102892e+00,9.25737880e-01,-8.54554380e-01,7.13350681e-01,-8.91860451e-01,-9.11815992e-02,-3.77784708e-01,-5.90612442e-02,-1.73947010e-01,9.20361333e-01,-6.03614048e-02,-9.54696977e-02,4.00836530e-01,-9.44678280e-01,-1.47861544e-01,7.18512448e-02,-3.10626187e-01,1.34543464e-01 -contig-119000000,-5.75253181e-01,3.38243847e+00,7.47281721e-01,2.75229427e-01,1.00891985e+00,-4.00091545e-01,7.45510561e-01,1.18431436e-01,-2.27123102e-01,-3.85956905e-01,-7.35673403e-01,1.21545141e+00,8.07732013e-01,1.00095792e+00,-1.37464275e-01,2.10887820e-01,4.94206375e-01,8.58014003e-02,-2.54843704e-01,-1.33590055e-01,4.94515791e-01,-9.65382942e-01,4.59202031e-01,4.21014096e-01,-2.98114003e-02 -contig-527000000,-2.71094074e+00,-3.72786816e+00,2.35716740e+00,1.31835617e-01,4.20029817e-01,-4.88630508e-01,-2.74879371e-01,-1.24410797e+00,1.61744659e+00,6.59159427e-02,-4.10981741e-01,7.25101327e-01,1.78436909e-01,-2.78182521e-01,5.33651378e-01,-2.33846107e-01,-2.90928056e-02,1.22436133e-01,3.07722419e-01,-3.80292861e-01,-1.47918632e-02,-9.68406278e-01,-4.40858465e-01,4.41719397e-02,-1.87997270e-02 -contig-310000000,-8.04961028e-02,4.35654103e+00,7.62551511e-01,-5.99544066e-01,4.72011568e-01,-9.65635826e-01,-1.19913334e+00,3.56140901e-01,-4.66582407e-01,3.46336851e-01,-1.50765148e+00,2.53692335e-01,-3.68090145e-01,2.60632379e-03,6.00335988e-01,-9.36307258e-01,4.56456381e-01,-9.16389541e-02,9.96541059e-03,-4.03845991e-01,1.86719466e-01,3.24430248e-01,-7.61267239e-01,-1.70316621e-01,-4.29144513e-01 -contig-6000000,-7.66815022e+00,-2.20356531e+00,-5.02258366e+00,7.24341799e-02,-5.95038060e-01,2.84821211e-01,7.14807484e-01,3.97714571e-01,-2.03799846e-01,-2.77738248e-03,3.36438669e-01,2.44039966e-01,-5.28280222e-02,-1.54676217e-01,1.71219726e-01,-9.65812713e-02,3.33613739e-01,1.73170494e-01,-3.89209062e-01,-8.95083268e-02,-2.59764003e-01,-1.87859959e-01,-5.21336239e-02,-1.84657876e-01,4.22149710e-02 -contig-4941000000,-6.73240516e+00,-4.10844390e+00,-9.71594781e-01,7.64764774e-01,-2.10609912e+00,-2.08644437e+00,4.66714719e-01,7.92078051e-01,-1.10756460e+00,-1.84243534e-01,-6.92089155e-01,4.57707448e-02,-3.76682250e-01,3.16840479e-01,-8.08555863e-01,5.16505161e-01,-8.79828162e-01,-2.39956270e-01,1.90524459e+00,9.04055760e-02,-2.30846172e-01,2.70931438e-01,6.55670512e-01,7.90924713e-01,4.83614111e-02 -contig-43000000,-7.33603074e+00,-3.12649766e+00,-3.86882790e+00,-3.47637500e-01,-3.02151903e-01,-7.12224455e-02,5.25414292e-01,4.89995677e-01,-2.45232052e-01,-1.19329899e-01,1.63463353e-01,-1.69726545e-01,-7.33701304e-02,-1.06169952e-01,1.32184458e-01,-5.31858468e-02,3.10506530e-01,-8.26086537e-02,-3.18356615e-01,-7.58027525e-03,2.70859436e-01,4.73681391e-02,1.03559980e-01,-5.20991161e-02,-8.67306035e-02 -contig-384000000,-4.53014356e+00,-3.93537999e-01,-2.28087429e+00,7.77232767e-01,2.54381261e-01,4.51590212e-01,-2.98422600e-01,-3.84294667e-01,-4.86941031e-02,3.98685112e-01,-2.43414003e-01,-3.66683931e-01,2.11569793e-01,-1.51401559e-01,1.10730649e-02,-1.81676209e-01,6.21295121e-02,-4.97476342e-01,2.71605814e-01,3.50599866e-01,8.20550618e-01,-3.67250845e-02,-6.55168543e-01,3.38255590e-01,3.39687243e-01 -contig-483000000,-2.74369167e+00,-1.43137009e+00,3.88538895e-01,1.39626016e+00,2.79442162e-01,2.49443221e-02,-1.57175726e+00,-1.55248123e+00,7.03810131e-01,-8.62515833e-01,-4.21853462e-01,1.19422288e+00,5.08635204e-02,5.27987430e-01,-2.01473135e-01,1.09503639e-01,7.38893225e-01,-3.86480082e-01,5.36505107e-01,1.20590674e-01,2.71820934e-01,3.70184998e-01,-3.57144545e-01,-2.19571039e-01,-3.82138202e-01 -contig-4932000000,1.54769852e+01,-5.21432962e+00,-3.99828962e+00,-9.40418927e-01,-7.50220123e-01,2.93524940e-01,-2.12017765e+00,2.69893764e-01,-7.84961114e-01,-1.13398085e+00,-1.99940783e-01,-2.69825273e-02,-6.58233323e-01,-3.43755998e-01,5.96425951e-01,-5.91515404e-01,-5.25099802e-01,-2.62738505e-01,-3.08192295e-01,-5.69564942e-01,-7.17519397e-01,-3.62664713e-01,-3.03658798e-01,9.20774089e-02,-3.38381697e-01 -contig-75000000,-8.19973429e+00,-3.49885764e+00,-4.84835982e+00,-4.81648409e-01,-8.89493601e-01,5.50440832e-01,9.24188884e-01,8.17247833e-01,-4.18621791e-01,-3.04356363e-02,4.21143455e-02,-1.48935514e-01,-6.21687790e-02,1.73824540e-01,1.15490066e-01,-1.16806003e-01,1.11952124e-01,5.46174990e-02,-3.55889821e-01,5.28111598e-02,4.37384412e-03,-1.51061799e-01,9.84187159e-02,-2.68708755e-02,-1.62863390e-01 -contig-666000000,-3.70940385e+00,-4.77564320e+00,1.50903116e+00,1.44592041e-01,6.51449278e-01,1.63578425e-01,-9.20086027e-02,-1.28403487e+00,1.62266788e-01,3.06383758e-01,-2.63620614e-01,4.34849265e-03,-1.18555511e-01,4.37021111e-01,5.58303413e-01,2.28783473e-01,-4.74616862e-01,7.89337892e-01,3.76678912e-01,6.15533719e-02,-3.78304573e-01,-4.52819403e-01,-8.20969389e-02,-2.23018914e-01,-4.41324174e-03 -contig-106000000,1.97958015e-01,1.62869528e+00,2.66965099e+00,-1.07396637e+00,-5.27466797e-01,1.53701886e-02,8.41417659e-02,4.75735272e-01,-2.05680080e-01,5.18184498e-01,-4.05741997e-01,-9.57880717e-01,1.56553196e+00,1.06583384e+00,9.32340257e-02,9.32191971e-01,-1.31965795e-01,-2.70022751e-02,-4.69342989e-01,4.22976959e-01,2.51290738e-01,-2.14106014e-01,-4.36596892e-01,7.80115698e-01,1.03804400e+00 -contig-4105000000,1.40516143e+01,-2.37451412e+00,-6.23312047e+00,-4.82836996e-01,-3.52596635e-02,-1.39988485e-01,-1.03246760e+00,7.23880157e-01,-3.17781965e-01,-4.23067271e-01,-2.96628387e-01,4.35749158e-01,-3.79217016e-02,-4.02676112e-01,8.13646100e-03,-1.82655253e-01,-9.29418893e-02,3.01401600e-01,1.29901780e-01,-1.73155800e-01,5.17043396e-02,-9.86231298e-02,-1.53844332e-02,-7.31619539e-02,-2.20396195e-01 -contig-359000000,-3.84839722e-01,4.45187834e+00,8.43155348e-01,8.72583105e-01,-9.07224093e-01,3.37206149e-01,6.48477696e-02,3.24566510e-01,8.06988770e-01,-1.04708185e+00,4.00725762e-01,1.75016562e-01,2.47053991e-03,2.27176591e-01,-2.43157177e-01,2.21723690e-01,1.00163217e+00,-1.17006884e+00,-5.39913788e-01,-2.89229449e-01,-5.48509980e-01,5.93233689e-01,-1.24484846e+00,4.51432649e-01,-9.75306198e-01 -contig-185000000,-6.43948051e-01,3.64484762e+00,1.35835266e+00,-9.06517902e-01,3.62956772e-01,-1.49373931e+00,-1.68741656e-01,3.38284697e-01,7.32691445e-01,-9.21426405e-01,1.61076492e+00,7.25864351e-02,1.75684216e+00,2.45384201e-01,-2.92689023e-01,-1.73650227e+00,1.97385138e-01,-1.04614950e-01,2.36464860e-01,-4.33946265e-01,-5.75320419e-02,-2.97188540e-01,4.74614000e-01,-1.03173596e-01,-7.29669719e-01 -contig-319000000,-3.27908337e-01,4.35885394e+00,1.00468099e+00,5.94486952e-01,-2.47204708e+00,1.14553558e+00,-7.36155105e-01,-6.22106532e-02,1.67759725e+00,-2.58782430e-01,-5.76538392e-01,5.87175516e-01,1.64056160e-02,-5.19176545e-01,-2.16480380e-01,5.60190984e-01,-8.19195182e-02,-2.51687774e-01,-1.65869624e-01,3.65062827e-01,7.13091376e-01,3.77321052e-01,8.75991187e-02,-9.86582671e-01,-5.30923390e-01 -contig-356000000,-2.54432004e+00,-3.94262642e+00,2.55450713e+00,6.93876798e-01,7.58228445e-01,-1.26532359e-01,-1.30739817e+00,-4.78796773e-01,-6.09738728e-02,9.92840064e-01,-3.42192432e-01,-4.24693734e-01,-1.84161719e-01,-5.49624977e-01,-3.44209402e-01,-8.98060622e-01,-3.35134919e-01,-1.30290823e-01,2.68802312e-01,3.55574082e-01,2.57534649e-01,1.13082608e+00,-1.35040396e+00,4.02657826e-01,1.70619789e-01 -contig-460000000,-2.05741985e-01,3.33657236e+00,1.45496415e+00,-8.77567087e-01,-2.72970633e-02,-8.26430645e-01,-8.60854214e-01,2.38728835e-01,5.20109545e-01,-2.05886390e+00,5.43767806e-01,3.68549776e-01,4.90394699e-02,-4.38353543e-01,2.88600923e-02,3.42596228e-01,1.35460398e+00,7.95533163e-01,3.54337622e-01,1.94894850e+00,4.34758802e-01,-4.08241101e-01,-3.89677145e-01,-1.43475814e+00,5.70952674e-01 -contig-276000000,-1.41236877e-01,6.40609212e+00,-1.23107699e+00,-8.80949005e-02,-8.00906200e-01,2.99276032e-01,-1.14330028e+00,1.33457171e+00,7.04961841e-01,1.98020188e-01,1.16330155e+00,3.01242902e-01,-8.21018937e-02,-9.54200274e-01,5.69455970e-01,1.93968227e-01,-1.77233062e-01,1.19915454e+00,5.24131548e-01,-1.24269847e+00,-4.96371640e-02,-2.86772306e-01,5.61670907e-01,7.39818991e-01,-1.62277331e-01 -contig-4040000000,-4.46906109e+00,-3.80516178e+00,-1.06826296e-01,4.46108871e-01,-4.40900331e-01,4.72419509e-01,-2.96343522e-01,-7.40451045e-01,1.25086891e+00,-6.72273403e-01,-2.53413206e-01,-3.86711505e-01,-9.43570280e-02,-1.38232917e-01,1.06867122e-01,-2.21409430e-01,-3.04551368e-01,5.04011825e-01,9.52692926e-02,-1.40288682e-01,-2.78497057e-01,2.17617030e-01,-2.31551716e-01,3.78379141e-01,7.62325198e-02 -contig-680000000,-2.83063321e+00,-1.68675419e+00,4.54566891e-01,7.61661196e-01,2.03127347e+00,-1.05520754e+00,-2.15731642e+00,-9.77341461e-01,-1.06735831e+00,1.30014495e+00,-2.15322812e-02,3.19320246e-01,2.96837462e-01,-3.07611553e-01,-5.00675024e-01,2.54702385e-01,-1.02115461e+00,1.99455245e-01,-5.97964965e-02,4.82609131e-01,2.64819715e-02,4.52711514e-01,-5.78235298e-01,3.24069554e-01,7.71468460e-01 -contig-584000000,-7.54514984e+00,-2.13234266e+00,-5.17923359e+00,1.02727469e-01,-6.39045458e-01,6.12111812e-01,1.10496870e+00,5.26564202e-01,-3.27043365e-01,-6.20656066e-02,2.92816146e-01,1.60291770e-01,-1.10585634e-01,-9.00902573e-02,5.65747682e-02,-3.71280217e-03,-1.11480158e-02,1.71716639e-01,-2.91327751e-03,3.54643315e-02,9.74446350e-02,-3.45355128e-03,-3.65738433e-02,-6.93625701e-03,-4.34299171e-02 -contig-5000000,1.33348063e+01,-1.52162556e+00,-5.75451540e+00,-4.03688801e-01,-9.80488770e-02,-4.02093182e-01,-3.95233538e-01,1.03697919e+00,-6.84946754e-02,-3.22522702e-01,-5.26753155e-01,2.48738673e-01,1.53992428e-01,-2.15842308e-01,-1.16189175e-01,5.82381795e-02,-2.70014362e-01,-2.10141499e-02,5.24662239e-01,8.85743754e-02,4.90046268e-02,9.13216845e-02,3.64950712e-02,-1.51405367e-01,5.18760195e-02 -contig-141000000,-9.80530326e-02,2.76800066e+00,1.75964767e+00,-5.10353229e-01,8.57044084e-01,1.28791309e-01,2.76641282e-01,-1.25374396e-01,-1.03878886e+00,-9.37606282e-02,5.45586967e-01,-6.29744449e-01,3.00867913e-01,8.33048173e-01,-6.03070497e-01,-8.13936100e-01,-1.12346408e+00,5.34647144e-01,-3.18405110e-01,3.67122512e-01,-3.99851741e-02,-3.49180060e-01,-2.09341103e-01,7.31809328e-01,-6.54526879e-01 -contig-153000000,-1.89315166e-02,5.40874849e+00,-5.47983497e-01,-7.49434803e-02,-1.61432643e+00,1.00653321e+00,9.10103414e-01,2.96193824e-01,1.37271582e+00,1.33134796e+00,4.49193966e-02,8.84121813e-01,-1.06892430e+00,-8.05125271e-01,-6.63653752e-01,2.16261816e-01,1.15948433e-01,4.47390960e-01,-1.36577805e-02,-4.57037006e-01,-9.19782003e-01,-5.18055519e-01,7.63185114e-01,3.98514794e-01,2.46767918e-01 -contig-318000000,4.76731160e-01,4.55975366e+00,1.00195371e+00,-4.19083300e-01,5.02885732e-03,-2.33351932e-01,-1.45567804e+00,3.07888252e-01,4.66608976e-02,3.81178772e-01,2.81025517e-02,7.99961469e-01,2.54441310e-01,5.39990589e-01,8.66396956e-01,7.14201557e-01,-4.42074697e-01,-1.81027271e+00,-1.93022776e-01,-4.37446767e-01,3.32022503e-02,-5.87230272e-01,6.35308052e-02,1.06829471e+00,-5.44920683e-01 -contig-277000000,-7.93670307e+00,-2.94457395e+00,-4.96309611e+00,-3.78303403e-01,-8.01184329e-01,4.41964737e-01,8.29940152e-01,8.85976269e-01,-3.33479810e-01,-6.51963093e-02,3.01347959e-01,-1.05125329e-01,1.98984134e-01,3.50106369e-02,1.16823415e-01,-5.53452174e-02,-2.19558310e-03,2.57402090e-03,-9.41106411e-02,2.12968999e-02,2.84063651e-01,-6.66804201e-02,1.50182025e-01,3.53427224e-02,-1.09983864e-01 -contig-117000000,1.23168752e+00,-1.22193759e-02,3.90141095e+00,-2.16384876e+00,-5.23750014e-01,-4.28506122e-01,-2.86076337e-01,1.00081669e+00,-1.12200720e+00,-1.22103745e+00,-1.21060680e+00,-3.86984673e-01,1.28989545e-01,3.16393802e-01,5.86651128e-01,7.41586670e-01,3.23578121e-01,3.03402604e-01,-1.07851936e-01,-2.90691186e-01,1.24536928e-01,5.55288313e-01,1.38655438e-01,-4.17818564e-01,-9.00716889e-01 -contig-317000000,9.63688376e-02,4.12363073e+00,9.92992807e-01,6.23216961e-01,-3.07617218e-01,1.10087635e+00,-1.10621807e+00,4.31724487e-02,8.23337116e-03,6.51012778e-01,-1.06793727e+00,-1.33860609e+00,2.57109423e-01,-1.81895291e-01,3.79472923e-01,-4.97516932e-01,-1.56340697e+00,-6.15044123e-01,1.17731936e-01,1.28254685e+00,-2.68784871e-01,3.84156612e-01,-3.02040046e-01,8.50767818e-01,-4.95946513e-01 -contig-149000000,-2.25486380e-01,4.55996871e+00,-2.51615775e-02,-1.51205361e-01,1.07175177e-02,2.93019463e-01,9.70922926e-01,2.46379655e-01,-1.00364703e-01,6.09076093e-01,-3.28250450e-01,1.05441806e+00,-4.31474225e-01,7.59884685e-01,-7.75473891e-03,1.14708104e+00,1.32200349e-01,9.52139352e-03,-2.33110972e-01,-5.25706814e-01,-5.98495838e-01,2.81901439e-01,-9.77963934e-02,7.16432250e-01,6.01830025e-01 -contig-197000000,-3.31775519e-01,5.39929234e+00,-1.90903454e-01,6.11445888e-01,-1.09128698e+00,1.21843576e+00,8.01264846e-01,-5.78095394e-01,1.03629322e+00,6.25838011e-02,1.60115157e-01,3.62820842e-01,-3.28342112e-01,-2.50014169e-01,-1.03068113e+00,-1.05263952e+00,-6.97013845e-01,2.97898259e-01,2.51667624e-01,-1.01449379e+00,1.47938660e-01,7.38765591e-02,5.51422393e-01,-5.08035081e-01,5.47299067e-02 -contig-159000000,4.81015398e-01,1.71073168e+00,3.00900380e+00,-1.12068248e+00,1.23807674e+00,-1.92034691e+00,8.33761033e-01,-2.87179321e-02,-1.09228239e-01,-1.51081265e-01,9.40602266e-01,-3.94118857e-01,1.25678973e+00,6.34731571e-01,-1.25652720e+00,-2.68717924e-01,8.18120999e-01,-7.97675685e-01,-1.70685364e-01,7.51481252e-01,-3.64615033e-01,-9.77380673e-01,1.56379813e-02,-1.11678749e-01,-4.19407609e-01 -contig-114000000,-6.31956058e+00,-2.03090856e+00,-3.96871440e+00,3.76281894e-01,-2.33381354e-01,5.04904672e-01,4.60487431e-01,3.12558525e-01,-3.52272249e-01,-8.30814534e-03,1.25841981e-02,1.53113398e-01,8.59371009e-02,2.72066074e-01,-3.09175481e-01,1.06748678e-01,1.54866482e-01,-2.05453128e-01,4.31078579e-01,1.37806014e-01,4.29964744e-01,2.43075426e-02,2.12436380e-01,1.20837249e-01,-2.01031083e-01 -contig-283000000,-1.44434109e-01,5.91616415e+00,-6.25675493e-01,1.38287839e+00,-3.56510203e-01,1.00598091e+00,7.51824733e-01,-9.85949451e-02,-1.41313638e+00,-7.86793328e-02,6.03866234e-01,-5.65402230e-01,2.71516026e+00,-4.75559292e-01,4.73295722e-02,1.28944184e+00,2.89519047e-01,8.34291902e-01,1.85702440e-01,1.69163591e-01,-1.32716915e+00,-9.93548550e-02,-5.33128470e-01,1.06647140e+00,4.56419819e-01 -contig-210000000,1.17418905e+00,-6.70245161e-01,5.56546932e+00,-1.21055367e+00,1.56827459e+00,-1.46601658e-01,1.63190765e+00,-7.18437150e-01,-1.24805262e+00,-2.96226447e-03,2.48825493e-01,-5.45151326e-02,-8.16691426e-01,-4.49719015e-02,1.48117136e-01,-8.75141291e-02,-5.08671388e-01,-4.53835007e-01,1.51926611e-01,-1.26056883e-01,2.43857996e-01,-5.84778161e-01,-3.17400411e-01,-1.38823420e-01,-4.17261942e-01 -contig-251000000,5.16209875e-01,2.52305885e+00,2.48342400e+00,9.21395772e-02,-1.03833720e+00,1.51697959e+00,-2.87928495e-01,-4.91768978e-01,-2.09654713e-01,-4.66512313e-01,-3.53784382e-01,-7.54921698e-02,4.46358141e-01,1.27458192e+00,-8.91819291e-01,-2.65087118e-01,-9.56297436e-01,5.99186900e-01,9.86226242e-02,4.98348441e-01,4.88394781e-01,-4.43874615e-01,-2.04998736e-01,-7.74643032e-01,-1.18861604e-01 -contig-226000000,2.83403165e-01,3.63051086e+00,1.74778298e+00,-1.37429291e+00,-7.80871979e-02,-9.98169455e-01,-8.84544125e-01,-3.10449698e-02,2.00846770e-01,-1.09167945e+00,1.83367396e-02,7.37804465e-01,-5.07974217e-01,-1.05649517e+00,7.41413129e-01,1.27051646e+00,-2.34989442e-01,7.12382074e-02,-6.20343226e-01,7.59888000e-01,-3.51211874e-02,2.81980791e-01,-2.19841555e-02,-4.22984909e-02,-6.61940190e-01 -contig-68000000,-5.77461487e+00,-7.30015021e-01,-3.96035932e+00,7.48421382e-01,-2.38357410e-01,5.67822399e-01,1.75623213e-01,-1.62981083e-01,-3.25215083e-02,-2.65314239e-02,1.43785721e-01,4.09486631e-01,-2.47421674e-01,2.09416501e-01,-1.82075876e-01,1.14847684e-01,3.58876399e-01,-5.34070322e-01,2.95676951e-01,3.20608253e-01,7.71820531e-02,1.72009104e-01,1.02206898e-01,1.16866977e-01,1.51105157e-01 -contig-152000000,-3.21655247e-01,3.74751547e+00,6.84809074e-01,-8.24633304e-01,6.87794326e-02,2.15553815e-01,-1.34399155e-01,8.46162196e-01,4.92956921e-01,-8.89706425e-01,5.27785981e-01,2.71476829e-01,-1.02321846e+00,9.70995178e-02,-1.10090772e+00,6.50227248e-01,-2.97492918e-01,2.11288582e-01,-7.20375576e-01,-1.10600714e+00,-1.33450986e-01,7.83572005e-01,4.67489263e-01,9.58205607e-02,-1.45144397e-01 -contig-85000000,-5.69139415e+00,-2.01579794e+00,-2.68931029e+00,-4.94828186e-02,-5.01473915e-02,1.20105015e-01,-5.90443770e-01,2.73608356e-01,-1.76711659e-01,3.03751832e-01,6.88547148e-02,-4.17066440e-01,1.55799937e-01,1.93008538e-02,7.58629183e-03,3.19560324e-01,1.59741475e-01,2.16412908e-01,7.48914130e-02,3.46857947e-02,2.15224970e-01,-1.61822497e-01,-3.43108110e-01,6.85981733e-02,1.74769002e-01 -contig-24000000,1.54186605e+01,-2.91226821e+00,-7.31212401e+00,-4.87814841e-01,-3.18604892e-01,-3.86075025e-01,-1.66525155e+00,1.02158817e+00,-8.61879343e-01,-9.40694343e-01,-7.54029828e-01,6.44344651e-01,-3.52260569e-01,-7.67750776e-01,8.50329140e-02,-3.63992775e-01,-5.35716913e-01,2.17116804e-02,4.73555601e-01,-2.79321773e-01,-4.19582437e-01,-2.73413281e-01,-4.46919665e-02,-6.00560039e-02,-2.55976921e-01 -contig-1000000,1.48393385e+01,-2.65310634e+00,-7.13914012e+00,-7.01830300e-01,-3.56607594e-01,-1.59994717e-02,-1.20735531e+00,5.92846299e-01,-5.70124138e-01,-9.93324830e-01,-3.65959383e-01,4.70890232e-01,-5.32450936e-01,-9.06616945e-01,1.34163742e-01,-4.29236258e-01,-3.05251163e-01,-1.81732716e-02,3.72824298e-01,-1.33235429e-01,-3.13397601e-01,-2.38223176e-01,-2.45275342e-01,1.36037082e-01,-1.03456678e-01 -contig-175000000,-6.32443787e-01,4.94955951e+00,5.16975348e-03,-6.42908116e-01,9.00686636e-01,-1.41057990e+00,5.59552197e-01,6.97257313e-02,3.85015808e-01,1.15360902e+00,-3.30554718e-01,-1.15763321e+00,-6.63814993e-01,-7.18469708e-01,5.56135289e-01,-1.32878404e+00,4.15737539e-01,-2.54380892e-02,6.77343278e-02,-3.69945271e-01,-2.63835315e-01,-5.94436769e-03,3.93539202e-01,-4.58551392e-01,-4.66996220e-02 -contig-717000000,-3.73050314e+00,-5.12444963e+00,1.68486635e+00,1.74109545e-01,6.59533680e-01,-5.29050375e-01,-3.54421554e-01,-1.76143192e+00,2.80388922e-01,-3.04385064e-01,-4.63792410e-01,5.31398652e-01,1.85616384e-01,-5.11778657e-01,7.88674293e-01,-1.48337967e-01,2.13254033e-01,3.60129772e-01,-3.03391167e-01,-7.60647224e-02,-5.38165663e-01,-6.80733447e-01,-5.74305532e-01,-6.73033871e-01,-2.15245752e-01 -contig-61000000,-5.40321309e+00,-2.02992869e+00,-2.42896746e+00,1.86010754e-02,-9.59047214e-02,4.29703697e-01,-1.24867821e-01,-1.73024356e-01,2.63164557e-02,1.67694302e-01,-1.10751977e-01,-4.18713677e-01,-2.96432142e-01,5.27322012e-02,-1.87836726e-01,5.11709097e-02,-1.57855035e-01,-1.09223589e-01,-1.03469118e-01,2.94703250e-01,-1.09364899e-01,3.62030321e-02,2.80187367e-01,1.63189067e-01,4.02286850e-02 -contig-165000000,-1.10299885e+00,7.22786471e+00,-2.15538594e+00,9.91061032e-01,8.76511399e-01,-4.98633185e-01,1.62611411e+00,1.14845397e-01,-3.52798841e-01,1.25520457e+00,3.92277715e-01,-6.60847935e-01,-4.34440797e-02,-1.88013965e+00,1.58790612e-01,-2.86280648e-02,7.80426790e-02,4.49048055e-01,4.37704859e-01,-6.08539797e-01,1.77298201e-01,-1.08046801e+00,-2.23646385e-01,-1.11528967e+00,-4.42658877e-01 -contig-49000000,-4.92637080e+00,-2.30230216e-01,-2.93880377e+00,5.07145650e-01,3.00166712e-03,-1.94348631e-01,-8.18014307e-01,-2.23210364e-01,4.59136908e-01,3.58316220e-01,2.40364238e-01,1.30040625e-01,8.21849968e-02,-3.59495563e-01,1.79428029e-01,4.31085749e-01,-2.57750512e-01,-3.75556257e-01,-1.42538951e-01,4.12956871e-01,3.83491589e-02,3.60430351e-01,2.89413074e-01,2.44786009e-02,-1.66088789e-01 -contig-223000000,-1.62183427e-01,3.39315381e+00,1.56530985e+00,6.31226060e-01,1.14430853e+00,-8.48118230e-01,4.56065308e-01,-3.61756703e-02,-8.51500166e-02,1.76310978e+00,-1.58793538e+00,6.18563085e-01,-6.96740869e-03,5.21194588e-01,7.11699585e-01,-4.55848921e-01,-3.10332442e-01,-5.55428221e-01,-8.54898670e-01,-1.42832332e+00,6.91524031e-01,4.10836247e-01,-8.72567492e-01,8.22302280e-01,-2.36025280e-02 -contig-113000000,-6.74601141e+00,-2.21899432e+00,-4.06504045e+00,-6.78227351e-02,1.12792075e-01,1.32755734e-01,4.82022672e-01,3.10166429e-01,-3.95926878e-01,-7.80870789e-02,6.84755298e-02,5.08705314e-03,-3.33111248e-01,1.62095904e-01,-1.51362145e-01,4.14700861e-02,9.96321714e-02,-2.81896861e-01,-1.16240161e-01,3.32100003e-02,6.77533102e-02,-4.40168747e-02,3.03691555e-01,9.23854991e-02,-8.09088673e-02 -contig-131000000,4.99024712e+00,-3.62832647e+00,5.47059611e+00,5.73962447e+00,1.39614690e+00,-1.21077992e+00,2.76873254e+00,1.94233028e+00,9.10058245e-01,-4.42613219e-01,-5.30070293e-01,-6.45124983e-01,-8.39038958e-01,-2.59789276e-01,-4.70359732e-02,1.71147412e-01,1.49391940e-02,1.13723207e-02,-5.34790256e-01,3.03281498e-02,-2.52236078e-01,1.06841622e+00,3.73229494e-01,-1.51488631e-01,1.98647043e-01 -contig-255000000,-3.87311932e-02,3.31437623e+00,1.75815925e+00,-3.77071533e-01,-1.32446575e+00,6.62531845e-01,-9.91330781e-01,-4.44388878e-01,4.91560549e-01,4.41908064e-01,-3.23722132e-01,1.18496712e-01,2.93778696e-01,6.44481452e-01,2.42184867e-01,-2.56270844e-02,-8.47515497e-01,-5.97889235e-01,-4.71192468e-01,-1.90940549e-02,2.37511990e-01,9.18994172e-01,-2.61927102e-01,6.50690918e-01,6.87230810e-01 -contig-15000000,-5.15039995e+00,-4.27039399e+00,-4.26153312e-01,-3.49908920e-01,5.42870158e-01,-4.21542990e-01,-8.19523131e-02,-6.62823628e-01,3.62226486e-02,-9.65928857e-01,4.94914325e-01,-6.02531547e-01,1.51747863e-01,-1.18961846e-01,2.27423003e-01,-1.09432547e-01,5.05177366e-01,5.34912719e-01,-2.05635784e-01,-2.33500131e-01,-5.30985365e-01,-1.79005860e-01,-4.92196497e-01,-3.59756303e-01,7.82164049e-02 -contig-48000000,-5.21672781e+00,-3.82972333e+00,-1.01562950e+00,-4.59635414e-01,3.35539147e-01,-1.39968651e-01,-7.76776467e-01,2.83837126e-01,-2.49041190e-02,2.75508753e-01,1.68875609e-01,-1.51398863e-01,-6.91719622e-02,4.56000372e-01,-1.87436366e-01,1.06190119e-02,-1.67595749e-01,1.30273686e-01,-4.81838047e-02,3.04677056e-01,-7.22677240e-03,4.62568151e-02,1.75113852e-02,2.49055608e-01,-2.56620981e-02 -contig-47000000,-5.09091595e+00,-1.16441417e+00,-2.66977881e+00,5.05590897e-01,2.79349374e-01,-6.84491631e-02,-3.10458665e-01,-5.46720191e-01,1.95579749e-01,4.13806509e-01,1.40067133e-02,2.62675795e-01,-5.73780363e-01,1.51594525e-01,2.47295026e-01,2.60260671e-01,-9.40720986e-02,-2.75607806e-01,-9.41912271e-02,-1.64564505e-01,-1.90837568e-02,2.87918254e-02,-2.36927972e-02,1.16104777e-01,4.68177366e-02 -contig-4912000000,1.20924313e+01,-3.05440101e+00,-2.78429410e+00,-4.91209536e-01,2.53564195e-01,5.20226578e-01,-5.45946009e-01,1.31026594e-01,-2.29274061e-01,-3.48575597e-01,2.55709565e-01,-1.79619308e-01,2.76787971e-01,8.69642117e-01,9.27945031e-02,-8.34100273e-03,-5.22818364e-01,-1.86387007e-01,-4.41908873e-01,-6.60604228e-02,1.79166478e-01,1.62804728e-01,2.46916247e-01,-4.74020782e-02,7.27312385e-02 -contig-1194000000,-5.09538574e+00,-2.40061726e+00,-1.33963720e+00,2.00450543e-01,-6.71123309e-01,3.04147162e-01,-1.04598615e+00,-4.73345407e-01,8.89370516e-01,5.18757979e-01,-5.73935732e-01,-3.59151915e-01,6.42332139e-01,-2.55898663e-02,1.49668770e-01,-4.35252738e-01,4.68762014e-02,1.40530686e-01,-7.40682435e-01,-3.51906650e-01,-3.24498217e-01,-3.16502007e-01,-3.94226498e-01,-2.14281479e-01,-1.91025256e-01 -contig-138000000,-5.41935918e-01,3.79701373e+00,9.92683975e-01,-2.92326265e-01,-5.98832895e-01,-4.17111332e-01,-4.97705403e-02,1.09832903e-01,9.85655334e-01,-7.62412190e-01,-1.54025202e-01,-8.60245245e-01,9.44816711e-01,-1.37163630e-01,-1.03204916e+00,-2.99764404e-01,1.11179616e+00,1.53923083e-01,4.30387762e-01,-5.34317025e-01,1.09711226e-01,-5.88119749e-01,-2.82065916e-01,9.68529444e-02,9.77759031e-02 -contig-4910000000,-6.47406330e+00,-4.35175277e+00,-1.64999273e+00,-6.69612896e-01,1.51853915e-01,-1.61974628e-01,-2.49842023e-01,1.81167086e-01,-5.92666332e-01,-2.65247187e-02,4.60551836e-01,-3.96251241e-02,2.60596478e-01,2.10686061e-01,-1.10284280e-01,-5.06585725e-02,-9.97773565e-02,1.75212235e-01,-7.35569510e-01,-2.65165942e-01,-1.35841028e-01,-9.65446092e-02,-2.80719110e-01,4.88022470e-02,-1.36137109e-01 -contig-301000000,2.52420654e-02,5.39712809e+00,3.45258520e-01,-4.00948410e-01,3.67222525e-01,-5.42039991e-01,-6.69472366e-01,1.56792389e-01,-1.51195637e-01,2.15376999e+00,3.90084087e-01,-2.23944116e+00,-1.17333184e+00,-5.50839723e-01,4.54374280e-02,7.36860149e-01,1.39110299e-01,2.65740122e-02,-6.30977796e-01,-3.77091610e-01,2.09849625e-01,-8.58167236e-01,1.17423143e+00,-3.00640835e-01,4.46604973e-02 -contig-28000000,-4.95763650e+00,-2.64412701e+00,-1.40150490e+00,-3.02710755e-02,7.49559520e-01,-5.18929461e-01,-1.95686516e-01,-9.61657389e-02,2.20626072e-01,1.96019535e-01,-2.42920159e-01,-7.18046488e-02,-5.01833354e-01,4.41845069e-01,1.40403362e-01,6.37343235e-02,1.61090778e-01,-2.44651369e-01,2.42570352e-01,-4.85721409e-01,-2.48148931e-01,2.07787588e-01,5.10697253e-01,1.33625283e-01,-1.99163221e-02 -contig-1412000000,-4.53818946e+00,1.63480565e+00,-2.96885010e+00,2.05848579e-01,6.86701383e-01,-6.00466331e-01,-5.00662549e-01,-1.45063200e-01,5.79197662e-01,-4.71162485e-01,6.90942432e-01,-1.84510240e-01,-1.73999372e-01,-1.11279342e+00,1.42315069e+00,5.00509407e-01,9.88202338e-01,2.60206788e-01,9.65261213e-01,1.73941631e-01,-8.93989641e-02,-1.55352091e-01,-2.14745997e-01,-6.16809957e-02,3.95024182e-01 -contig-96000000,-1.25060212e+00,4.44726950e+00,3.14511660e-01,-1.65152972e-01,-1.23160168e+00,7.61886355e-01,7.81121506e-01,-1.75057482e-01,2.37437450e-01,-1.32265490e+00,1.51189884e+00,1.00516490e+00,9.10741332e-01,1.57949776e-01,-2.14411922e-01,-1.24718437e+00,-1.66638066e-01,-6.55262413e-01,-1.49104037e-02,6.55506279e-01,2.41897400e-01,9.73957522e-02,5.60447502e-01,1.11655022e+00,2.13996379e-01 -contig-97000000,6.82080191e-02,4.36556956e+00,-1.20332811e-01,-2.28653539e-02,-2.36338793e+00,1.61946835e+00,-9.31540272e-02,1.66669863e+00,1.85896980e+00,-3.82324499e-01,4.96247938e-01,2.77264657e-02,1.31375086e-01,4.22211598e-01,1.65875036e-01,-3.97814356e-01,-3.50562361e-01,9.27456533e-01,9.59380227e-02,-8.38719940e-02,-2.15786315e-01,5.22533291e-01,1.36440479e+00,6.85021469e-01,-8.38752599e-03 -contig-160000000,-4.22401058e-02,3.77341356e+00,4.87032759e-01,-1.09784954e+00,5.46415712e-01,-4.42309132e-01,2.43313592e-01,3.88706334e-01,-3.10686266e-01,7.39259518e-01,-1.30217279e-01,-2.00123294e-01,-2.14822264e-01,1.46965896e-01,8.10664585e-02,1.79170921e-02,-6.11680885e-01,6.03789423e-01,2.78514051e-01,7.15090524e-01,-1.24994212e-01,2.89019587e-01,-7.10098630e-01,3.37304388e-01,-1.45890902e-01 -contig-1296000000,3.67681924e+00,-2.97976728e+00,3.76512473e+00,-1.18514662e+00,-3.81019293e+00,-8.62321277e-01,1.45621482e+00,-2.78850637e+00,-1.13450714e+00,1.25779684e+00,-1.49207241e+00,2.93940585e+00,9.00543927e-01,-1.05226023e+00,1.21829104e+00,-3.20609765e-01,3.83287738e-01,2.47986287e+00,-7.98856217e-01,5.02257742e-01,3.04667917e-01,1.55714611e+00,1.77378322e+00,1.79419768e-02,-2.22445917e-01 -contig-609000000,-4.24360813e+00,-3.61221564e+00,1.42750394e-01,-7.32336962e-02,4.75774973e-01,-3.54891183e-01,-1.20250641e+00,-2.80241984e-01,5.43059780e-01,2.93003681e-01,-1.63465982e-01,-3.77880768e-01,2.42585022e-01,3.09390039e-01,6.04863338e-01,-1.47208730e-01,-6.92537469e-01,2.30728644e-01,2.78761496e-02,3.01481283e-01,2.93304136e-01,-2.21325876e-02,-4.10129488e-01,1.48404617e-01,1.63296769e-01 -contig-130000000,-1.34223366e-01,4.15464165e+00,5.24549272e-02,-1.16345713e+00,3.06188305e-02,-8.58673799e-01,-3.46247617e-01,1.61460220e+00,4.66457066e-01,4.59017647e-01,-3.70265663e-01,-4.69465311e-01,2.93957681e-01,2.64990735e-01,1.58626423e-01,-6.36167650e-01,1.27082219e-01,3.57888516e-01,5.73516365e-01,1.13559527e+00,-3.37539562e-01,3.36329424e-01,-1.68354899e-01,8.52694424e-02,-4.82619359e-01 -contig-110000000,-6.89660429e+00,-5.07007977e+00,-2.31373295e+00,-9.22752216e-01,-2.18832436e-01,-2.02095808e-01,5.48218939e-01,8.47491931e-01,-9.01713849e-02,-1.65724786e-01,-2.34468134e-01,-4.19042686e-01,9.50205752e-02,2.24848356e-01,-2.39404908e-01,1.49582240e-01,-1.78916520e-01,1.77235808e-01,-1.00565418e-01,9.20036652e-02,5.32238351e-02,2.16111385e-01,1.44293848e-01,7.71653727e-02,-3.97657162e-02 -contig-278000000,3.95765845e-01,5.16391146e+00,-1.82721376e-01,-1.08573492e-01,2.03699295e+00,-2.13372104e+00,-5.69184557e-01,1.03892525e+00,1.31540066e-02,4.51730024e-01,3.83510524e-01,1.45293428e-01,5.32316011e-01,3.18885276e-01,1.09856928e+00,-4.11061701e-01,-1.75658216e+00,-6.38593324e-01,4.72548635e-03,-1.52350990e+00,-2.27254304e-01,-6.68049873e-01,8.72149122e-01,-1.72212543e+00,3.62974371e-01 -contig-281000000,9.98184290e-01,-7.02673014e-01,5.70932830e+00,-1.89748684e+00,-6.71786062e-01,4.51554209e-01,-1.24182919e+00,-1.25356340e-01,-5.01575051e-01,2.76580150e-01,5.01985019e-01,3.95156436e-01,-2.42860165e-01,6.56707712e-01,-2.13173220e+00,5.81418982e-01,4.70178065e-01,-3.10548527e-01,2.44426686e-01,-2.41924976e-01,3.54982084e-01,-1.35001562e-01,-5.39278977e-01,-4.77519441e-01,7.14976325e-01 -contig-193000000,1.18478471e+00,6.62664700e-02,4.36720054e+00,-2.91392153e-01,-2.94223104e-01,5.44934989e-01,-1.99372269e-01,2.71881267e-01,-4.22541580e-01,-2.78624102e-01,-1.19559126e+00,7.49408806e-01,7.36243334e-01,1.30250221e+00,-1.23089119e+00,-8.57554133e-01,-1.06231366e-01,7.44649644e-01,-6.36740332e-04,-7.00930803e-01,-9.42578984e-02,4.54012222e-01,-3.99164054e-01,3.22222587e-01,8.85537010e-01 -contig-224000000,1.12630648e+00,-1.03991172e+00,6.39428439e+00,-1.43192465e+00,5.88711776e-01,-6.74490685e-02,-3.80971622e-01,4.46770902e-01,-1.84245259e-01,5.82002102e-01,2.40784240e-01,-6.78898868e-01,1.01262937e-02,-1.02163094e-01,2.94655775e-01,-8.06571900e-01,-9.63735374e-01,-1.18820283e-02,1.13539243e-01,-8.55821004e-01,-9.37353488e-01,4.57036417e-01,-3.26435168e-01,3.72086666e-02,4.65301405e-01 -contig-302000000,8.51027501e-02,3.61391688e+00,1.32601808e+00,6.86545090e-01,-4.30019715e-01,1.36002088e+00,-5.61151230e-01,-1.29022545e-01,3.94843238e-01,1.62367105e-01,-8.48702807e-01,2.10751067e-02,-2.82766739e-02,6.28526968e-01,-1.26302396e+00,2.82930342e-01,-2.97480885e-01,1.08250176e-01,-4.44937123e-01,1.14810614e+00,-4.40405268e-01,6.51926978e-02,1.20982719e+00,-6.36183449e-01,-2.85763203e-01 -contig-182000000,7.69182206e-02,4.15935728e+00,5.61102829e-01,4.32340861e-01,2.14279101e-01,5.98556399e-02,3.26184579e-01,4.58790733e-01,-5.89466625e-01,-2.63720349e-02,-1.14415860e+00,-1.00671769e+00,1.12117651e+00,-8.91090240e-01,-1.16762548e+00,-5.21318063e-01,-5.13062456e-01,-4.10292634e-01,-7.13107951e-01,3.94874953e-01,-4.93691092e-01,3.90987725e-01,-4.75497804e-01,2.98674996e-01,-1.50974120e-01 -contig-112000000,-3.26472161e+00,-2.18800523e+00,8.90113596e-01,5.17854986e-01,6.21641327e-01,-4.11179858e-01,-1.08817278e+00,-7.29040138e-01,5.90970667e-01,-4.47124849e-01,2.58974925e-01,1.70595258e-01,3.03885734e-01,-8.18172843e-03,1.78378232e-01,-3.47968402e-01,-6.21824873e-01,6.66799793e-01,5.61038392e-01,-2.67063627e-01,5.67728274e-01,7.85548161e-01,-3.50561030e-01,-1.52685654e-01,-1.11965238e-01 -contig-536000000,-4.47488207e+00,-1.40402079e+00,-1.33016416e+00,8.66397692e-01,8.16971049e-01,-2.59667705e-01,-1.30466262e-01,-8.28234108e-01,7.85073321e-01,2.94061582e-01,-5.03979985e-01,1.17771428e+00,-3.36741258e-01,6.15814673e-01,5.94940215e-01,-2.40732131e-01,7.32199687e-02,-1.46150544e-01,-4.31932119e-01,-1.17418516e+00,-2.35220977e-02,-8.90862271e-02,4.53943455e-01,-1.03641422e-01,2.57295149e-01 -contig-4935000000,-5.99435384e+00,-1.85567754e+00,-2.76125354e+00,-4.51372971e-01,-2.22105962e-01,1.40400190e-01,1.01665891e+00,-5.72534845e-02,5.30446370e-01,-8.33379148e-01,3.39678003e-01,2.28245391e-01,7.72063834e-02,4.49025051e-02,2.25978701e-01,-4.52618334e-01,-3.34799780e-01,-3.54597998e-01,3.71990006e-01,5.27578875e-02,2.99334484e-01,2.62689845e-01,3.26762417e-01,-2.55425779e-02,7.52524237e-02 -contig-147000000,-3.23354481e-01,2.97261866e+00,1.64661853e+00,-9.16687882e-01,-4.91263714e-01,-3.24410902e-01,1.80634421e-01,-6.64425983e-01,7.73033199e-01,-1.05386944e+00,1.12068483e-01,1.10945189e+00,-7.06407122e-01,-1.20708570e-01,-1.72582609e-01,5.66110241e-02,-1.55084590e-01,5.70224530e-01,1.62475141e-01,8.09854491e-01,1.81612755e-01,-4.02528302e-01,-3.54339344e-01,7.24426324e-01,7.12043263e-01 -contig-45000000,1.24723061e+01,-2.77432737e+00,-1.61527844e+00,-8.87312078e-01,-3.68908958e-02,-1.65584386e-01,1.37979982e-01,2.22544051e-01,-1.78318592e-02,1.34970791e-01,1.97046564e-01,-1.85740259e-01,9.13311388e-02,5.47503818e-01,2.92540523e-01,1.03277996e-01,-6.73551625e-01,-1.92974432e-01,1.09143462e-01,-2.04674807e-01,-1.55336963e-01,6.66642945e-02,-3.97480343e-01,-2.39827210e-01,1.64393937e-02 -contig-378000000,1.14152207e+01,-2.06012329e+00,-2.20072165e+00,-1.06788774e-01,4.43146103e-02,8.98444539e-01,1.91028584e-01,-3.57107873e-01,4.51721176e-02,-2.68456004e-01,-2.84654259e-01,-1.02037585e-01,-4.46389692e-01,5.52536732e-01,-1.60849044e-01,-2.44584408e-01,2.10432488e-01,-1.19095634e-01,-3.77134908e-01,2.07150703e-01,-3.36927122e-01,-7.12538944e-02,-1.13640759e-01,7.13684288e-02,-2.33413988e-02 -contig-200000000,1.19443253e+01,-3.58083779e+00,-5.93776453e-01,-6.88923234e-01,-2.61246973e-02,4.12380634e-01,7.33769818e-02,-8.35098264e-01,-1.96639358e-02,1.97436295e-01,6.17357593e-01,-4.62300884e-01,-1.40758712e-02,9.30908480e-02,2.58973266e-02,-5.90477444e-01,2.90458856e-01,-8.43219110e-03,-2.98687275e-01,1.51070382e-01,4.84060913e-01,8.34458133e-02,-6.38321696e-02,2.74947142e-01,2.20346911e-01 -contig-201000000,-7.03664658e-01,3.44141112e+00,1.86966090e+00,6.37730216e-01,-5.72331208e-01,-3.88473484e-01,-9.38940910e-01,-4.30352373e-02,5.46559840e-01,-1.15475824e+00,9.88933771e-01,4.74005116e-01,9.87533572e-01,9.62711772e-01,3.97630045e-01,-2.94161537e-01,2.30291132e-01,-3.64172765e-01,-3.51400822e-01,-1.59302526e-01,1.12694908e-01,7.27313612e-01,-3.60222978e-01,-6.46015375e-01,-1.24004138e+00 -contig-60000000,-6.73800335e+00,-3.20901141e+00,-3.21828835e+00,-4.38482694e-01,1.77486264e-01,-1.84519774e-01,4.09954133e-02,6.10939855e-01,-3.66248693e-01,1.88996635e-01,-4.08661446e-02,-1.68268400e-01,-2.27866725e-01,2.17068589e-01,-1.85005063e-01,1.46010034e-01,-1.60927811e-02,1.41795216e-01,-2.52186563e-01,-1.34618477e-01,-9.39868419e-02,8.39076411e-02,2.23802192e-02,4.90234926e-02,9.72903610e-02 -contig-263000000,3.87556447e-04,2.37866798e+00,2.88121714e+00,-5.80786175e-01,9.51268802e-01,-9.96754464e-01,-2.32217255e-01,2.16144143e-01,1.65923202e-01,-3.06730878e-01,6.29504174e-01,8.93799703e-01,5.98712014e-01,9.71656153e-01,-3.49748672e-01,5.49321762e-01,-7.83530180e-01,-1.79103603e-01,-4.01192738e-01,-3.75044804e-01,-3.67709242e-02,6.67874491e-02,-2.83300255e-01,-3.42009422e-01,-3.50642483e-01 -contig-592000000,-4.06753647e+00,-2.79609851e+00,2.29953234e-01,2.90873997e-01,-2.34066163e-01,3.01900082e-01,-1.03845076e+00,-3.26363839e-01,7.80389191e-01,2.35556650e-02,-1.03069955e+00,-4.48384261e-01,2.22660036e-01,2.07718749e-01,-2.80588850e-01,-1.98445640e-02,1.72040653e-01,-9.37851529e-01,-4.27009075e-01,-7.81514628e-02,1.55827514e-01,-4.63251636e-01,6.14673028e-01,1.20387302e-01,3.00887160e-01 -contig-188000000,1.83388796e-01,3.52592633e+00,1.35079409e+00,-8.29979108e-01,1.24537506e+00,-1.12147600e+00,3.44856720e-01,1.79047603e-01,5.16158329e-02,-5.35485929e-02,-2.95316119e-02,1.47167483e+00,-9.96752010e-01,2.16201306e-01,-3.87399410e-01,-3.20620507e-01,-1.80360689e-01,-5.11715601e-01,6.56471451e-02,-5.58827651e-01,-7.78217271e-01,7.75118746e-01,-3.31497104e-01,9.59867694e-01,1.17776923e-01 -contig-349000000,-9.66670077e-02,5.34559714e+00,1.60742972e-02,3.82463328e-01,-1.75248100e-01,1.07391278e+00,3.85801171e-02,-6.65594332e-01,-2.58754800e+00,1.37485685e+00,-7.13491016e-01,-1.56639545e+00,1.88295337e-01,3.10578705e-01,8.63540038e-02,-9.35374024e-01,-3.17089215e-01,-1.54735136e-03,-8.49834742e-01,9.03253665e-01,1.19079081e-01,1.48472271e+00,4.82507410e-01,1.89001692e-01,5.16374888e-01 -contig-227000000,-9.04371787e-03,4.70037797e+00,4.89005362e-01,-4.26052478e-01,1.22363283e+00,-6.21624723e-01,-6.97346520e-01,-2.02262145e-01,-1.30089815e+00,1.29936160e-01,8.75505657e-01,-1.45652256e+00,1.18584937e+00,7.11035497e-01,1.40818661e+00,-7.75581927e-01,-5.15959596e-01,2.83973573e-01,1.24444070e+00,-1.42678199e-01,7.37088306e-01,-1.31180620e-01,3.97263723e-01,-2.42906115e-01,2.87877002e-01 -contig-120000000,-4.52450246e-01,2.33075878e+00,1.84282708e+00,-4.00890220e-01,-2.10365743e-01,-1.81150761e-01,-2.67545620e-01,2.74588677e-01,1.80058993e-01,-1.59552829e+00,6.42912993e-02,4.29351779e-01,7.50826280e-01,1.20341936e+00,3.30271363e-01,7.16118886e-01,-2.28882850e-01,3.13239346e-02,5.14833492e-01,-6.34906007e-02,-7.29205607e-01,4.81502798e-02,-8.31290883e-01,-2.27464444e-01,2.07502517e-01 -contig-183000000,-8.99048948e-01,5.95429182e+00,-8.21289983e-01,1.31615078e+00,-6.33559495e-01,1.37947463e+00,5.14907680e-01,-2.38138284e-01,-1.28615310e+00,-3.13115360e-01,6.38712193e-01,-2.69331742e-01,1.34983676e+00,-3.05584255e-01,1.42437969e-01,1.05774502e-01,-6.40313130e-01,8.73573939e-02,1.96978135e-01,2.45317546e-01,5.04873183e-01,-8.71665165e-01,-2.95164944e-01,-2.08487907e-01,-8.44006703e-01 -contig-35000000,1.22651344e+01,-4.22397724e+00,-4.36513290e-01,-6.19617794e-01,3.07397793e-02,4.22245730e-01,-4.97681967e-01,-3.72212055e-01,-2.81193940e-01,-6.05788082e-02,6.77491379e-01,2.10466077e-01,-6.05579235e-01,8.79379418e-01,2.16308876e-01,-3.59980326e-01,9.68219604e-01,1.81120165e-01,3.02235706e-01,-2.25362049e-01,2.09641998e-02,2.80480014e-01,9.72769112e-02,-6.22698321e-02,1.23652013e-01 -contig-132000000,1.26905766e+00,-3.24926971e+00,8.15547973e+00,-1.67169139e+00,-3.20189670e-01,6.24357867e-01,2.85971395e-01,2.70943544e-01,-5.49501423e-01,2.60962070e-02,6.99460722e-01,6.34433493e-01,4.83255414e-02,-2.40275055e-01,8.24520814e-01,-1.41725414e-01,-1.98340323e-01,-4.21295307e-01,-3.70702301e-01,3.14802717e-01,8.66074126e-02,-1.34067000e+00,7.18634659e-02,8.00523059e-01,-5.81284991e-01 -contig-163000000,-5.80947569e-01,3.19816498e+00,1.60170188e+00,-5.55313060e-01,6.67838416e-01,-4.19006676e-01,-7.56347632e-01,9.97924515e-01,-2.39305719e-01,8.50755607e-01,1.22649426e-01,-9.53292720e-01,6.79582507e-02,6.61096031e-01,2.96433808e-01,-4.89734449e-01,-5.58625327e-01,-3.20988458e-02,-8.88019851e-02,6.85885348e-01,-2.59815919e-02,-3.30021704e-03,-5.42090754e-01,5.02894908e-01,-1.05082222e-01 -contig-14000000,-5.80233668e+00,-3.17824188e+00,-1.81391471e+00,-3.10954232e-01,2.06200413e-01,-2.88769338e-01,2.23585030e-01,-5.48723132e-01,1.14318283e-02,-9.03105235e-01,5.85043756e-01,-1.52564226e-01,1.51557514e-01,-1.20983255e-01,2.13922872e-01,-3.04238697e-01,3.24782035e-01,3.12124625e-01,-4.55972777e-02,1.23876353e-01,-2.96404890e-01,-1.37069960e-01,-2.59356126e-01,-1.46513714e-01,2.40194669e-01 -contig-67000000,-5.75936062e+00,1.96891505e-02,-4.05944796e+00,8.54894728e-01,-1.96698462e-01,6.85660350e-01,-1.23952044e-01,-1.61650391e-01,-3.56227087e-01,3.57287563e-01,4.39445473e-01,2.92135868e-01,-3.30734907e-01,-1.51090010e-01,-2.20330558e-01,-2.40787432e-02,-1.95815657e-01,-4.59643298e-01,9.62334201e-02,6.58562227e-01,5.56666097e-01,8.24466297e-02,4.52119262e-01,3.38052437e-01,-2.96907404e-02 -contig-559000000,-3.84654823e+00,-2.46916282e+00,1.17240314e+00,7.24337211e-01,-1.71726439e+00,-2.46780960e+00,-1.83493264e-01,-7.64731155e-01,-2.66690138e-01,-2.23765260e-01,-1.12870235e+00,2.52900519e-01,1.44031386e-01,-3.07767122e-01,-7.24071428e-01,9.25793911e-01,-8.80000384e-01,-3.96320575e-01,2.34131642e+00,3.02834109e-01,3.20887202e-01,6.76725818e-01,1.30716415e+00,1.24403480e+00,-3.50684172e-02 -contig-36000000,-4.57879993e+00,-5.37737662e+00,1.28782507e+00,-5.98288530e-01,6.02864408e-01,3.93222913e-02,5.76835714e-02,-3.20414177e-01,-4.72253010e-01,-4.12671700e-01,3.24632740e-01,8.06091857e-02,7.96186326e-02,1.90461687e-01,-5.91373776e-02,-5.12132313e-02,-5.51739107e-01,2.08561870e-01,-3.17651149e-03,8.63500854e-02,-2.20711262e-01,-1.02639479e-01,8.02586881e-02,1.57736666e-01,9.96305122e-02 -contig-164000000,5.70586832e-01,1.26656522e-01,4.97939313e+00,-2.52054237e+00,3.61820007e-01,-1.75458575e+00,-4.90119749e-01,8.76149657e-01,8.61212045e-01,-9.21917790e-02,-2.31767914e-01,-1.38778500e+00,-8.62643633e-02,-9.10596080e-01,-1.20510413e+00,-1.09534952e-01,3.43172042e-01,3.40755774e-01,-9.00363226e-01,-5.39218331e-01,4.21144366e-01,1.19658729e+00,7.72349862e-01,-5.31897732e-01,2.16418340e-01 -contig-815000000,-3.23901521e+00,-8.94251289e-01,4.75186749e-05,9.58069128e-01,5.26496718e-01,1.12725788e-01,-2.07376446e+00,2.02205855e-01,4.21960045e-01,5.95241820e-01,-1.11372045e+00,-6.24419743e-01,9.87962469e-02,3.90757992e-01,-3.95816281e-02,-7.47021998e-01,3.05292882e-01,-5.32413408e-01,2.57030951e-01,8.66143196e-01,8.63660957e-01,2.11556887e-02,4.45604465e-01,-5.50451737e-01,-6.38740575e-01 -contig-4894000000,1.01223556e+01,-9.03460970e-01,6.35386882e-01,-4.68129668e-01,2.45533844e-01,-8.37881244e-01,2.07008564e+00,-8.43479453e-01,1.04563151e+00,8.11890979e-01,6.85600116e-01,1.54476436e-01,-5.65682661e-02,-9.50340789e-01,-1.31166051e+00,-5.55391448e-01,2.03812002e-01,-1.80613467e-01,-6.82614841e-01,1.38495233e-01,1.96087330e-01,-1.12132416e-01,-4.66588470e-01,1.89950388e-01,-3.56184934e-01 -contig-90000000,-1.39019287e+00,4.28949473e+00,1.37070792e-01,-4.03272213e-02,-1.79871331e+00,7.03684437e-01,2.70206677e-01,2.35370553e-01,1.16748138e+00,-5.18658633e-01,-3.95216132e-01,1.74445889e-01,-2.13837918e-01,2.79246232e-01,-1.22247380e-01,-7.18704092e-01,-4.06994015e-02,-3.11038848e-01,-8.18543292e-01,-1.09438182e-02,3.93179637e-01,2.84947471e-01,-3.66910389e-01,4.07359868e-03,1.01437079e+00 -contig-51000000,-4.98439662e+00,-4.93873653e+00,7.60167333e-02,-1.45649627e-01,-6.30033676e-01,4.10012946e-01,-5.41587238e-02,1.47886781e-01,9.90078717e-01,6.86604508e-01,-8.85538031e-01,-1.56427852e-01,2.00421975e-01,3.81890247e-01,1.51908937e-01,-2.58839174e-01,-2.78173794e-01,-1.12527147e-02,1.76643991e-02,-4.44084337e-01,-4.55626805e-01,-5.97588243e-02,-2.42960406e-02,2.90377582e-01,-1.66860417e-01 -contig-58000000,-4.69866602e+00,1.85323450e-01,-3.17607043e+00,5.98239607e-01,1.50734287e+00,-8.79371280e-01,-1.32226378e-01,-2.49039122e-01,-1.08736503e-01,8.17131004e-01,5.88561906e-01,1.02629573e-01,-6.98192011e-01,-4.90397608e-01,-8.13745742e-02,-3.44273188e-02,3.48286296e-01,3.04482614e-01,5.18197882e-01,7.22653149e-02,-3.64308244e-01,1.19925323e-01,-1.22179959e-01,3.14008268e-01,6.94117104e-01 -contig-186000000,-5.64082091e-01,4.41953824e+00,3.47731767e-01,3.44222229e-01,3.70173102e-02,-8.50690021e-03,1.43771574e-02,-2.91632222e-01,-5.57503110e-01,5.73552162e-01,-2.48971645e-01,-1.07168480e-01,3.26847065e-01,6.44217268e-01,1.58550050e-01,-9.70461387e-01,-3.75584779e-01,-8.24350310e-01,-6.34797456e-01,-7.88504120e-01,8.32462940e-01,1.60858027e-01,2.42371669e-01,-5.55594736e-01,2.04198461e-01 -contig-99000000,-5.42973211e+00,-5.11992801e+00,3.40818474e-01,-1.87191349e+00,2.44659880e-01,-3.44446859e-01,4.47898694e-01,1.02397771e+00,1.06231627e-01,5.66797498e-01,2.03085964e-01,-4.50863115e-01,3.20522824e-02,1.20064192e-01,-1.21209022e-01,3.85192851e-01,-4.68235500e-02,1.58377729e-01,4.25274323e-01,-1.99069220e-02,1.84371315e-01,1.21151981e-01,-1.49014585e-01,-9.92649785e-02,-1.50514387e-01 -contig-4933000000,1.46759135e+01,-2.21358037e+00,-7.28779828e+00,-4.09807043e-01,-1.63771660e-01,-2.13031966e-01,-1.16563370e+00,9.85313495e-01,-6.86337359e-01,-5.58279005e-01,-5.49442627e-01,5.19473876e-01,-3.03607449e-01,-7.67579364e-01,1.31260986e-03,-2.14627124e-01,-5.71824950e-01,3.96104879e-02,3.88819910e-01,1.31146794e-01,-4.36597765e-02,-1.41174565e-01,-2.13002661e-02,-5.36871652e-02,-1.89600232e-01 -contig-589000000,1.04568540e+01,-4.29802711e-01,-2.84481215e-01,1.37815556e-01,5.92815136e-01,-8.86004821e-01,1.87242082e+00,3.67254854e-01,5.38002288e-01,4.39174816e-01,-2.66563208e-01,1.06781444e+00,5.08720940e-01,1.58324927e+00,5.61021767e-01,1.58923669e+00,-9.52802996e-01,-1.29036672e-01,9.67010723e-01,2.41433275e-01,2.47317143e-01,5.56076134e-01,-5.34594118e-01,-3.26759553e-01,2.20628869e-01 -contig-91000000,-3.02754399e+00,-2.65813499e+00,7.87046659e-01,3.53277909e-01,1.95024534e+00,-6.92541283e-01,-4.60221142e-01,-1.11883118e+00,-1.17052083e-01,1.34595403e-01,1.93763462e-01,2.42679426e-01,-3.17806762e-01,-8.77012052e-02,2.49574304e-01,6.24391250e-01,-2.58538720e-01,-1.36600953e-01,-1.60997503e-02,9.60287132e-02,-1.60571739e-01,2.78939553e-01,2.39413122e-01,6.05971327e-01,-1.58518974e-01 -contig-66000000,-5.50309642e+00,-2.63546170e+00,-2.40030076e+00,2.26627810e-02,3.11198300e-01,9.73215774e-02,2.84800518e-01,3.09953652e-02,-1.37885866e-01,8.14542287e-02,-5.58729855e-02,-1.84971678e-01,-2.66467603e-01,1.90309713e-01,6.49375320e-02,5.32050124e-01,-2.80761519e-01,-8.50507455e-02,-1.00942150e-02,-1.31987880e-01,2.25301992e-02,7.07004499e-02,3.25195990e-02,2.70379296e-01,-2.36878749e-01 -contig-146000000,-6.73923278e-01,6.47727987e+00,-1.66815537e+00,-6.44599056e-01,-2.72169317e-02,-1.62438768e+00,-8.18341578e-01,8.19565175e-01,-3.61718486e-01,7.27472230e-01,-3.81283327e-01,5.88627779e-01,2.70891393e-01,-7.12474697e-01,1.30282337e+00,-6.10852570e-01,7.10658407e-01,-2.28501655e-01,-1.88347171e-01,-1.16654908e+00,3.95440123e-01,9.66984014e-02,-1.06488891e-01,-4.57080734e-01,4.36127723e-01 -contig-306000000,-3.57980996e-01,5.98090905e+00,-2.39404192e-01,1.65124185e-01,-6.95466588e-01,1.56543554e+00,-1.05829477e+00,3.72465628e-01,-7.25903329e-01,1.24842815e+00,1.38730650e+00,-1.50969386e-01,-8.09313137e-01,-1.13150289e-01,-7.06442472e-01,4.14493583e-01,-1.06397070e+00,-4.94709255e-01,1.07079468e-01,-4.49543510e-01,-3.97457771e-01,6.34742594e-01,9.74977509e-02,-3.73649494e-01,6.14626287e-02 -contig-2866000000,-5.07111129e+00,-2.09076589e+00,-1.62642190e+00,-3.43976821e-02,3.28308815e-01,-7.30871938e-01,-3.96054965e-01,-4.98338486e-01,2.16297319e-01,-8.59026936e-01,2.51254814e-01,-9.54242584e-02,5.65040380e-01,-2.62036980e-01,3.17924183e-01,-3.89194520e-01,6.64575991e-01,-4.22626266e-01,1.05389299e-01,6.12144182e-01,-1.68958830e-01,5.58503527e-01,5.77024578e-02,-5.59812716e-01,4.09770111e-01 -contig-364000000,-4.05438936e+00,-2.99942488e+00,5.49366331e-01,-2.82372072e-01,5.95927767e-01,9.82337889e-04,5.15946766e-02,-5.97833950e-01,6.46242278e-01,-1.20076690e-01,-2.83045148e-01,-3.63062706e-01,-9.86631501e-02,2.41216174e-01,4.82416456e-01,1.23496629e-01,-4.81761565e-02,4.14926656e-02,3.31667943e-03,-1.41486485e-01,-5.59573816e-01,-5.25845487e-01,-5.27242173e-02,-2.35703332e-01,-1.28271440e-01 -contig-192000000,-1.67305401e-01,5.13147915e+00,-6.44124454e-01,7.73586991e-01,-5.15584646e-02,-2.60500341e-02,6.73431418e-01,-3.76296956e-01,-1.83873285e-02,6.37471977e-02,-1.80008961e+00,-5.27886173e-02,1.26798335e+00,-6.61392101e-01,2.24496822e-01,7.80427915e-01,8.00958950e-01,5.15366087e-01,-1.02468150e-02,-1.42211003e+00,-3.39497165e-01,-3.72915935e-01,-7.73089935e-01,3.44162786e-01,1.00335700e-01 -contig-299000000,-3.54686083e-01,4.97642509e+00,3.66684652e-01,2.15019020e+00,-1.00804012e+00,2.10254930e+00,-6.34106606e-01,-1.11175101e+00,-6.64030714e-01,-5.22396940e-01,-1.02050143e+00,-1.12103818e-02,-4.07841673e-01,-6.59630909e-01,1.00404732e+00,1.07783830e+00,-1.39205462e-01,3.11762333e-02,-2.02083246e-01,-1.81258093e-01,1.42376940e+00,-6.29742437e-01,-6.11730577e-01,4.28925088e-01,-2.40052171e-01 -contig-308000000,-1.38221255e-01,5.56599499e+00,-1.80503491e-01,8.38809519e-01,-6.61342508e-01,7.25102969e-02,9.02761176e-01,-1.19866665e+00,9.82446945e-01,4.86321856e-01,-7.06487387e-01,3.97545138e-01,-6.98057089e-01,-1.16738209e+00,1.16233130e+00,-7.77649305e-01,-1.45245536e-01,-4.34205596e-01,-5.56182040e-01,-2.63142964e-01,3.02086115e-01,-4.54210496e-01,1.60936851e-01,4.55268549e-01,5.43689279e-01 -contig-265000000,1.26471681e+00,-2.06751484e+00,7.52957472e+00,-2.62495010e+00,1.07464026e+00,-2.01144250e+00,-1.70111986e+00,2.91834922e+00,1.74265414e+00,1.92295332e+00,1.55922720e+00,9.37462386e-01,-8.83718133e-02,-1.66032471e+00,-4.73062021e-01,-7.15381179e-01,1.09718991e+00,-2.38924316e-01,4.37598295e-01,2.38789689e+00,2.55800247e-01,-1.15460694e+00,5.51109853e-02,1.31248643e+00,3.54276306e-01 -contig-56000000,1.20509748e+01,-2.97215999e+00,-1.55222372e+00,-2.63090459e-01,-2.69621907e-01,4.33932575e-01,-1.90893056e-01,-8.14012756e-01,4.91140967e-01,-1.13868483e-01,6.63830914e-01,-7.14625026e-01,-8.12315285e-01,1.01024649e-01,9.11364490e-02,-2.59541494e-01,2.57797388e-01,-2.45031518e-01,1.29262449e-01,-8.38000228e-02,-3.29918089e-01,2.34662955e-01,1.01334681e-01,4.96589834e-01,7.10100533e-02 -contig-290000000,2.10058849e-01,3.78682800e+00,1.17566351e+00,-2.92506476e-01,-8.89792727e-01,1.49430444e-01,-7.03263613e-02,-1.89008114e-01,4.84480423e-01,3.57074863e-01,-1.70445692e+00,-1.52857845e+00,3.73841250e-01,-9.64433910e-01,2.59597487e-01,-1.35778087e-01,4.40501484e-01,4.68203075e-01,1.74241410e-01,4.15896706e-01,3.18042729e-01,-3.99375438e-02,-4.44737847e-01,2.88714470e-01,-3.11592171e-01 -contig-269000000,5.27806575e-01,2.20640818e+00,2.66271606e+00,4.04730443e-01,6.75806997e-01,-1.07148599e+00,1.20069315e+00,-1.02568428e+00,-1.40767818e-01,-9.62290643e-01,-1.24409869e+00,4.08069746e-01,-8.54184475e-01,-2.74114253e-01,-6.74551442e-01,-7.68064665e-01,1.54601793e+00,9.61243878e-01,1.33808321e-02,9.52196346e-02,-1.60944452e-01,8.98976847e-01,2.86788816e-01,-2.78444358e-01,1.19474052e+00 -contig-229000000,-4.27193536e-01,4.95991253e+00,4.80802819e-01,-1.39582100e-01,-1.75657206e+00,9.98612739e-01,-9.71308746e-01,4.21233924e-01,1.69121117e+00,-7.87045770e-01,3.35339280e-01,-6.31000827e-01,-4.70839817e-02,2.15254129e-01,1.31136053e+00,-7.07869149e-01,3.25875142e-02,-4.35133347e-01,5.98021783e-01,3.30085384e-01,3.56250682e-01,6.27742501e-01,4.26801501e-01,-3.88537609e-01,-2.12173288e-01 -contig-207000000,-6.92292692e-01,4.61720375e+00,3.48648592e-01,9.91237770e-01,1.23996552e+00,-3.82523556e-01,8.71665825e-01,-1.51806931e-01,-1.43138451e-01,3.17122386e-01,2.50816458e-01,9.79225825e-01,-5.58184825e-01,3.12991232e-01,4.04145110e-01,-9.66176818e-01,-5.61151037e-01,4.12167772e-01,4.42142319e-01,7.95460464e-02,-2.94412721e-01,-2.46844118e-01,5.30077160e-02,-2.46051287e-01,-1.58112390e-01 -contig-37000000,-5.21520652e+00,-7.45803204e-01,-3.17768097e+00,7.81790307e-01,8.47122073e-01,1.45533883e-01,-1.19621512e-01,-6.03659934e-01,-6.51249112e-01,3.95695901e-01,-7.70827087e-02,2.13948571e-01,-5.57127563e-01,5.49779215e-02,-8.41129740e-02,8.39850062e-02,2.04615287e-01,-1.41956939e-01,-2.18863372e-01,-2.47989320e-01,4.95764897e-02,-3.60866699e-01,-2.64701686e-02,-2.06724166e-01,1.59829625e-01 -contig-4915000000,-6.13175447e+00,-2.78147405e+00,-2.61810068e+00,-2.14390167e-02,-5.12253284e-01,4.12705790e-01,-1.70622807e-01,3.07835017e-01,7.40415220e-02,3.24336329e-01,-6.25857357e-01,-3.64233166e-01,-4.37047517e-02,2.33115461e-01,-5.85003911e-03,3.05386495e-02,-3.92051683e-02,9.49758470e-03,-4.08418848e-01,1.89164852e-01,1.35570382e-02,-7.50303087e-02,-1.53359463e-01,1.39618220e-01,2.21235645e-01 -contig-4942000000,-8.35284775e+00,-3.33700021e+00,-4.98073784e+00,-4.09444041e-01,-8.07370921e-01,3.50702520e-01,9.24392124e-01,8.04926398e-01,-3.21062585e-01,-1.48671398e-02,2.60174595e-01,6.68467229e-03,-4.30708792e-02,9.71877444e-02,1.73672441e-01,-2.33501624e-01,2.27210495e-01,5.17640137e-02,-3.52586484e-01,3.58305875e-02,-1.00701283e-01,-1.64973469e-01,4.82820218e-02,-2.37665664e-02,-4.48809338e-02 -contig-243000000,4.91277559e+00,-4.56677137e+00,5.34507874e+00,5.52372327e+00,5.43931459e-01,2.65462407e+00,-9.90208607e-01,1.89463256e+00,4.19654343e-01,-1.63152571e+00,-1.10177697e+00,-3.60646680e-01,-1.46039233e+00,7.44469994e-01,3.55932097e-02,-1.04087573e+00,7.12327140e-01,1.01974492e+00,-2.96431129e-01,-4.89709321e-01,6.00700910e-01,-9.15615756e-01,2.12555397e-01,4.91467788e-01,-6.15247461e-01 -contig-187000000,-9.07403771e-01,5.29302675e+00,-1.18303807e-01,2.01231931e+00,5.82540017e-01,-2.71733798e-01,1.09765504e+00,-8.50797102e-01,-9.72347242e-01,-2.99232938e-01,2.26891974e-01,5.62945642e-01,1.55881639e+00,2.80537369e-02,8.21274683e-01,-3.90232464e-01,3.64518268e-02,4.66981613e-02,-1.77357375e-01,9.31805453e-01,-6.22403231e-01,3.12992702e-01,-5.55768914e-01,2.54016767e-02,3.24956099e-01 -contig-126000000,1.15067444e-01,6.85913586e-01,3.72172793e+00,-1.03859277e+00,3.25371991e-01,-8.79921373e-01,1.14065930e+00,3.99339611e-02,2.76745450e-01,-2.38800673e+00,-2.32921323e-01,-4.00686824e-01,5.78165770e-01,-5.04733969e-01,6.35145118e-01,-2.39512801e-01,-1.37665819e-01,3.47982600e-01,1.31525241e-01,7.76228613e-02,-2.88581992e-01,1.01101913e-01,-2.74364457e-01,-9.87342653e-02,1.76671259e-02 -contig-70000000,-1.37007182e+00,4.85066652e+00,-1.01483008e+00,-2.27350179e-01,-5.14580297e-01,-9.63640113e-02,1.64060590e+00,-2.95637446e-01,-1.04923499e+00,2.37455803e-03,-4.29188679e-01,1.86188531e-01,-3.68876552e-01,3.43113726e-01,-4.54793618e-01,-5.56269915e-01,1.14675416e+00,-1.93932418e-01,-4.25944185e-01,6.05240338e-02,7.15395677e-01,6.49152437e-01,2.44058411e-01,5.97481718e-01,1.30958344e+00 -contig-264000000,-7.88692698e+00,-5.36674035e+00,-3.10112854e+00,-1.18165592e+00,-6.81141850e-01,-1.22563327e-01,3.66667517e-01,1.16071669e+00,-1.79882080e-01,6.32108576e-02,1.48626630e-01,-2.79867841e-01,4.07607103e-01,2.85513057e-01,1.04007012e-01,-1.56177254e-01,-5.68927179e-02,4.02036579e-01,-3.86017126e-01,-1.27617189e-01,5.02316928e-02,-1.20975533e-01,-1.99489593e-01,-1.10177795e-02,-8.48723179e-02 -contig-222000000,1.14158274e+00,-1.84174670e+00,6.96882479e+00,-1.44748658e+00,-1.53608741e+00,1.25444274e+00,-1.65708696e-01,5.97652411e-01,2.71118956e-01,7.73078564e-01,6.45497436e-02,-9.86099347e-01,-3.00923008e-01,2.13067098e-01,-5.49335114e-01,-1.35335901e-01,9.80417970e-01,5.80572115e-01,1.87428936e+00,-7.47581256e-01,8.49935287e-02,-3.09873131e-01,-9.46562849e-01,-2.23503199e-01,-5.15114647e-01 -contig-245000000,1.54981177e+00,9.42530448e-02,5.13815049e+00,-1.10972721e+00,-9.79979846e-01,3.54663087e-01,1.81169230e-01,-2.71101717e-01,6.77842813e-01,-3.26483739e-01,-9.41302263e-01,-3.01864334e-01,-8.35620169e-01,1.04984975e+00,7.36063895e-01,-8.56639970e-01,9.96097931e-01,-8.94671749e-01,1.32537802e+00,-5.34370628e-02,1.22070328e-01,-9.00397323e-01,-1.45151197e-01,8.24231500e-01,-5.62311292e-01 -contig-4916000000,-7.69977525e+00,-3.15247538e+00,-4.52938169e+00,-3.32102364e-01,-7.48260872e-01,2.90340318e-01,9.63789798e-01,6.08950541e-01,-4.38542856e-02,-1.86302147e-01,1.77656816e-01,-2.38666283e-01,-1.15038023e-01,-4.39936231e-02,-9.69506661e-02,-1.92581951e-01,2.20139536e-01,2.41011968e-01,-7.60176999e-02,1.20469500e-02,7.56870575e-02,7.26177956e-02,6.78983741e-02,-4.98282519e-02,-6.11741782e-02 -contig-23000000,1.23324948e+01,-2.64132294e+00,-2.89453733e+00,-4.22885253e-01,3.75484183e-01,-1.67935947e-01,2.36478579e+00,1.61912567e-01,2.28651320e-01,-7.65828019e-02,-6.84091128e-01,9.83250920e-01,6.96464827e-01,7.61697132e-01,3.42197933e-01,7.81437099e-01,-1.02422841e+00,-4.56480878e-01,3.84016981e-01,1.48752238e-01,3.95550249e-01,4.92664549e-01,-1.63671661e-01,-4.80256605e-01,2.88519910e-01 -contig-71000000,-1.63500279e+00,4.09188474e+00,-9.00903759e-02,-7.00812820e-01,4.08255068e-01,-5.41564261e-01,7.91392981e-01,8.44382893e-01,-3.62075376e-01,7.10656505e-01,7.14305843e-01,-7.42958580e-02,-3.36031015e-01,4.66045546e-01,8.98785662e-03,2.49079694e-02,-7.67718818e-02,5.70021586e-01,3.29937519e-01,-1.09131553e-01,1.33704497e-01,-9.85031322e-01,-5.28238465e-01,6.68194367e-01,-6.03385377e-01 -contig-1023000000,1.10638415e+01,-3.51119078e+00,6.73072820e-01,-1.85209852e-01,1.07529456e+00,-1.31873806e-01,3.90448025e+00,-4.42704498e-01,2.34590234e+00,1.88229428e+00,6.08188702e-01,-5.57192614e-01,3.28235184e-01,-2.48120847e-01,6.32693078e-01,3.75693763e-01,-9.10665106e-02,-8.84071396e-01,1.08367887e-01,3.06476078e-02,4.08846458e-01,5.61984198e-02,-2.11221780e-01,-2.05840556e-01,-5.89217388e-02 -contig-213000000,-9.19837509e-01,5.76311857e+00,-6.47476659e-01,4.52261243e-01,5.34817909e-02,1.15801344e-01,-6.84143715e-01,3.16211302e-01,1.42590220e-01,2.83604799e-01,-3.76637177e-01,3.61682007e-02,-8.82159339e-01,5.10833118e-01,2.23957091e-01,2.83128441e-02,3.63806266e-01,-2.52826636e-01,4.68965491e-02,-7.74592606e-01,4.95754168e-01,4.87144836e-01,1.14137409e-01,-1.22898815e+00,1.00907877e+00 -contig-228000000,-3.24660916e+00,-5.59121114e-01,-6.19073217e-01,1.26722000e+00,7.44045073e-01,8.09689756e-01,-1.61184617e+00,-1.18246584e+00,-3.19705819e-01,-1.12128638e-01,1.60643808e-01,-3.59787758e-01,-6.42736254e-01,2.85419958e-02,-2.39957944e-01,-5.07924901e-03,4.34957807e-01,5.01865790e-01,6.95970522e-01,-4.95047416e-01,-6.08390013e-01,2.41719659e-01,4.36582945e-03,-6.96666305e-02,1.36052621e-01 -contig-34000000,-2.93459131e+00,-8.47699762e+00,5.87702760e+00,2.86340408e-01,-9.09997988e-01,1.83952741e+00,-8.88231626e-01,-1.86541590e-01,-4.92343592e-01,5.60492648e-01,4.56484099e-01,3.80488776e-01,4.22200977e-01,-1.01395049e+00,4.98350823e-01,-2.68245995e-01,5.84698942e-01,-1.58641640e-01,-3.45711801e-01,-3.05214444e-01,-2.94125576e-01,-5.36145888e-01,-5.28903569e-01,-5.27134913e-01,-1.16563362e-01 -contig-55000000,-7.54144056e+00,-2.58747742e+00,-4.67922920e+00,-1.88276207e-01,-4.67574891e-01,7.65817587e-02,8.19548977e-01,6.28137431e-01,-1.86350375e-01,3.63522311e-02,2.62637223e-01,2.63958926e-01,4.64166437e-02,6.30306335e-02,3.43050335e-02,-9.90181229e-03,4.13067193e-02,-9.72213938e-02,-1.33909793e-01,-6.89002798e-02,2.40621600e-01,-3.98945862e-03,2.09307427e-01,-6.85006148e-02,-9.24530940e-02 -contig-127000000,2.39659624e-01,-1.57184838e+00,6.35707111e+00,-2.61056292e+00,-1.49759427e-01,-1.28925204e+00,-1.88559590e+00,3.50063731e+00,2.77495201e+00,2.66456282e+00,2.13045147e-01,4.26706826e-01,-7.99687698e-01,-6.94951278e-01,-7.12156525e-01,-6.94624679e-01,1.44655953e+00,-6.54676894e-01,-7.42481812e-01,1.16912806e+00,5.32431049e-01,-9.21677005e-01,-1.97115416e-01,9.95907952e-01,-3.32047831e-01 -contig-832000000,-1.69982752e+00,-2.58169134e+00,2.17429509e+00,6.34290759e-01,-6.35123954e-02,3.21140841e-01,-1.28633931e+00,-1.78929985e+00,2.10101567e+00,-4.31528445e-01,1.59469882e-01,-7.92286679e-01,-9.03944507e-01,-9.63106340e-01,-1.83803802e-01,6.70212969e-01,-7.00873134e-01,9.68409154e-01,3.86223095e-02,3.82320683e-02,-1.57793655e-01,-1.42716400e-01,-1.49783961e-01,2.21799476e-01,1.84464881e-01 -contig-11000000,-5.97311305e+00,-2.17193340e+00,-3.37343189e+00,1.40380200e-01,-1.39122603e-01,5.15713851e-02,1.54662221e-01,3.20120776e-01,1.89602067e-01,-2.55588550e-01,-1.86168803e-01,-1.33377810e-01,-1.60166406e-01,6.99035663e-02,-6.75596859e-03,3.39213580e-01,2.90179915e-01,-5.22885025e-02,2.14153605e-01,2.22292112e-01,1.78191351e-01,1.97545040e-01,2.77949824e-01,6.01331070e-02,1.33571127e-01 -contig-4931000000,1.31459803e+01,-2.04494587e+00,-5.15147160e+00,-3.39013162e-01,2.08308478e-01,-6.08963387e-02,-4.71643704e-01,5.13645006e-01,-8.15531584e-02,-3.91567867e-01,-1.26269153e-01,4.79685956e-02,7.67321571e-02,-1.20954366e-01,-7.83076060e-02,-1.11595451e-01,-3.73641699e-01,2.83328040e-02,-9.53356511e-03,-1.77608055e-01,-1.08778637e-02,-1.87768666e-01,-2.05777734e-01,-1.93238620e-01,2.48291686e-01 -contig-84000000,-9.17482081e-01,3.73258399e+00,1.88765690e-01,-5.91134634e-01,4.68209840e-01,-1.32709581e+00,1.28774323e+00,3.17543009e-01,5.74863223e-01,2.43118019e-01,-6.12634041e-01,9.27056080e-02,-4.02947336e-01,-3.43291633e-01,-3.02064342e-01,4.91132470e-01,-3.20243403e-01,1.17261905e-01,-4.87605749e-01,2.55656026e-01,-5.74521655e-01,-2.48260492e-01,3.36686797e-01,-6.84555465e-01,-1.59085631e-01 -contig-297000000,-1.93365547e-01,4.16214277e+00,1.04024239e+00,5.79414473e-01,1.77836918e+00,-7.75942748e-01,-1.04089881e-01,-1.09628987e+00,-9.20827864e-01,2.26285463e-01,-1.02947540e+00,-8.00179318e-01,-1.16159510e+00,6.80366157e-01,5.25876024e-01,1.05275956e-02,-2.52965394e-01,-1.04001744e+00,-3.96950884e-01,-2.17988019e-02,-3.71391675e-01,-1.99432393e+00,7.73100743e-01,-5.82273786e-01,1.88454266e-01 -contig-140000000,-5.12105905e-01,4.94665402e+00,-6.65365060e-02,2.76695075e-02,-1.27959733e-01,1.03553498e-01,4.24804105e-01,3.38931689e-01,-2.44761930e-01,6.91016522e-02,3.77321796e-01,-8.53926133e-01,-9.59607293e-02,3.39150248e-01,8.46172032e-01,8.80437448e-01,-9.81624215e-01,1.07486054e+00,-3.36961117e-01,4.92746598e-01,-1.64187431e-01,-8.00215040e-01,7.16072937e-02,4.51339715e-01,-7.04981472e-02 -contig-101000000,-9.13793526e-01,3.53989340e+00,7.66643113e-01,-6.87574538e-01,-2.13177857e-01,-7.66300058e-02,-7.14209741e-02,6.29491425e-01,2.53013048e-01,2.27506309e-01,-5.09831295e-01,-1.05917997e+00,-7.30612770e-01,2.00541138e-01,3.46081434e-01,-4.82198640e-01,-4.01596290e-01,6.87468562e-01,-1.97700381e-01,7.20299038e-01,4.78426554e-01,6.07917858e-01,-1.62819373e-01,-9.11122909e-02,-5.39879948e-01 -contig-206000000,-7.71638527e-01,5.90185805e+00,-7.55635126e-01,6.32591099e-01,2.03121746e-01,-4.28338253e-01,-1.08748788e-01,1.00797973e+00,7.48654609e-01,4.05430604e-01,6.58853723e-01,5.28697223e-01,-4.35303536e-01,-3.47047324e-01,1.34042252e+00,-1.16701490e+00,5.21440416e-01,9.35227247e-01,7.66660171e-01,-9.58312401e-01,5.47713679e-01,-2.78131816e-01,7.32804716e-02,-5.32068982e-01,2.65968909e-01 -contig-176000000,-6.96616011e-01,4.66891574e+00,3.54178544e-01,7.77545991e-02,-6.00382888e-01,4.33574233e-02,-5.49804318e-01,1.82635727e-01,5.18421427e-01,1.76888223e-01,-1.06733988e-01,-6.68342293e-01,-1.48786649e-01,1.85400696e-01,3.59948448e-01,2.02400493e-01,-3.07672224e-01,-4.53927746e-01,-6.73622582e-01,-7.19849148e-01,2.96694655e-01,-2.98405025e-01,2.74995034e-01,2.10056356e-01,3.80807461e-01 -contig-246000000,-3.17913433e-01,5.37591677e+00,1.20290946e-02,9.37792131e-01,-7.37247071e-01,1.19400699e+00,4.44569518e-02,5.73875472e-01,1.04015853e-01,5.77512198e-02,8.93637573e-01,3.76464706e-02,5.89558281e-01,1.62357405e-01,-4.83289555e-01,4.37574054e-01,-8.01804097e-02,1.66031222e-01,4.90741593e-01,-3.78994167e-01,-1.20175468e+00,2.17199913e-01,-5.54794999e-01,5.11826811e-01,1.88083511e-01 -contig-476000000,-3.58499387e+00,-5.50341543e+00,3.26543094e+00,-6.76434762e-01,4.86184343e-01,7.48457398e-01,-8.14003381e-01,2.30377447e-01,-7.31346217e-01,2.48262454e-01,2.49135259e-01,-5.90490707e-01,4.21610931e-02,8.28069495e-01,1.41345843e-01,-3.48133341e-01,-1.86593069e-01,2.66284927e-01,6.26030802e-01,1.33591177e-01,1.27727373e-01,-6.33153051e-03,2.37234207e-01,-1.83743194e-01,3.62865932e-01 -contig-291000000,-3.11100428e-02,3.22513767e+00,1.64732284e+00,-7.50085448e-01,-1.08710651e-01,-2.26529108e-01,-1.44252176e+00,-1.66592087e-01,-1.98205904e-01,-6.74050081e-01,-7.93329386e-01,-1.18659114e-01,-1.13153509e+00,-4.95863788e-01,-6.59227373e-01,-2.82314495e-01,-4.45207958e-01,4.07405670e-01,2.60615063e-01,-1.30001038e-01,1.61032199e+00,3.12535341e-01,-4.36320954e-01,-7.75545348e-01,-4.13508499e-01 -contig-4913000000,-6.81650409e+00,-9.47895308e-01,-4.96075022e+00,3.49612889e-01,-3.58592230e-01,4.59282910e-01,5.80763669e-01,4.93656413e-01,-1.77394384e-01,3.30559159e-01,1.85533917e-01,1.04795296e-01,-4.64657524e-01,-7.65429461e-02,3.94069034e-02,-3.96665179e-02,2.35144637e-01,-4.29357053e-01,2.20433054e-01,1.26883385e-01,4.76781609e-01,2.17753720e-01,3.74451918e-01,-7.37394109e-02,4.15642956e-02 -contig-3000000,1.26112375e+01,-7.41313187e-01,-6.68774354e+00,4.39414850e-02,6.72258555e-02,2.75115401e-01,-2.58212323e-01,5.99610155e-01,-1.94346137e-01,-4.38022145e-01,-8.79433273e-01,1.56754465e-01,7.04578785e-02,-6.78184315e-01,-4.81770183e-01,5.95794030e-02,5.45085742e-02,4.89763717e-02,1.71054888e-01,3.71919597e-01,1.88325285e-01,-1.03893081e-01,1.70463782e-01,7.31339801e-02,-2.62645609e-02 -contig-38000000,-5.48262446e+00,-8.81832331e-01,-3.18204308e+00,6.92800961e-01,2.51604649e-01,-1.74424972e-01,-2.31024966e-01,-1.81057626e-01,8.98064805e-02,-3.93954740e-01,1.91638147e-01,1.39627359e-01,-8.24155266e-02,-3.68881433e-01,2.43241922e-02,-1.68727388e-03,4.59614436e-01,-1.44171975e-01,1.84985877e-01,-2.00986515e-01,-6.11171566e-02,3.68623661e-01,-1.42026428e-01,-2.87583812e-02,1.06911220e-01 -contig-93000000,-7.48503030e+00,-4.66284039e+00,-2.90978832e+00,-5.50509901e-01,-7.94494196e-01,4.52776244e-01,1.24424876e-01,6.27465517e-01,-2.64395826e-01,4.97683970e-02,7.82952145e-02,-2.20436793e-01,2.99374557e-01,3.83178866e-01,6.12769386e-02,-1.70107271e-01,5.25069742e-02,3.83905403e-01,-6.63503569e-01,-2.21458485e-01,-1.79658222e-01,-3.39018739e-01,-1.11941784e-01,-4.81216879e-02,-4.61069771e-02 -contig-4523000000,8.99225013e+00,-1.39213239e-02,2.21584969e-01,9.56376604e-01,2.87293212e-01,-2.36256072e-01,-4.95059650e-01,-1.03610472e+00,7.75920658e-01,-6.80722881e-02,7.32640131e-01,-1.49350862e+00,4.80146827e-01,8.48917472e-01,2.76242914e-01,1.49373921e-01,8.23878154e-01,4.09874568e-01,3.76799485e-01,1.06137521e+00,-5.50194122e-01,1.13509418e+00,8.32333929e-01,-5.78267356e-01,-7.43950177e-01 -contig-338000000,1.16663060e+01,-1.88467042e+00,-3.02673146e+00,-3.26080387e-01,3.41456540e-01,1.25963195e-01,9.79952178e-01,-1.03879794e+00,5.05585041e-01,2.86617221e-01,4.44999281e-01,-4.09593855e-01,-7.18020872e-01,-2.07916820e-01,2.49717054e-01,-3.54172966e-01,1.16342314e-01,-1.62402686e-01,3.71828079e-01,5.54103863e-02,-1.24799997e-01,8.41312688e-02,-1.65802914e-01,1.89234692e-01,1.71254276e-01 -contig-216000000,-5.21875851e-01,6.62845986e+00,-9.69313112e-01,1.29262278e+00,-9.02334582e-02,8.05121469e-01,2.87700117e-02,1.08492854e-01,-1.29037456e+00,1.99028344e-01,-1.84481715e-01,-1.94132612e-01,-9.05452859e-01,-6.28418768e-01,7.63158242e-01,-5.05499257e-02,2.88850365e-01,9.07936242e-02,-9.52637242e-02,4.94898351e-01,1.55428200e+00,-1.20504207e-01,-7.88765135e-01,7.31799067e-01,-4.41597473e-01 -contig-4922000000,1.30575632e+01,-1.09717099e+00,-6.42130799e+00,-1.02126723e-01,-1.29848636e-01,2.90941525e-02,-7.46632821e-01,4.86128171e-01,-4.13514217e-01,-2.73875722e-01,-8.44224120e-01,2.82925212e-01,-8.73697311e-02,-7.22447154e-01,-3.99386023e-01,5.95105220e-02,-3.48543404e-01,-1.62968870e-01,2.92349087e-01,8.03012143e-02,2.58795903e-01,-1.22891501e-02,1.39331318e-01,1.80774312e-01,-4.49641520e-02 -contig-4906000000,-6.34347362e+00,-6.02138472e-01,-4.56680866e+00,6.44438203e-01,9.63552032e-02,2.64407565e-01,5.19451803e-01,3.07820974e-02,-4.49487373e-01,-1.02552512e-01,4.14706272e-02,4.98993885e-01,-4.61804976e-01,-6.04498152e-02,-5.02234591e-02,-3.52677229e-01,3.66515401e-01,-5.35210098e-01,3.61068716e-01,2.38497650e-01,3.69949569e-01,1.20948921e-01,2.51921477e-01,-1.27263146e-01,2.47008646e-01 -contig-312000000,8.24576898e-02,2.36435020e+00,2.79502455e+00,2.13440478e-01,5.87303382e-01,1.88417171e-01,-5.54314567e-01,-8.68318746e-01,-4.30796966e-01,7.93621540e-02,-1.76556257e-01,-6.87923130e-01,-5.28957570e-01,9.75800998e-01,2.52109762e-01,-3.61192633e-01,-1.05965514e+00,2.59327907e-01,-3.81422955e-02,-5.74842572e-02,-4.30496065e-01,1.52483518e-01,2.01110940e-01,-1.95038130e-01,-1.25970148e-01 -contig-256000000,-2.18213870e-01,4.59607890e+00,6.77968686e-01,3.91844356e-01,5.12361825e-01,2.09835428e-02,-3.53699733e-01,-1.11145592e-01,-1.43595035e+00,1.37850098e-01,-1.49698290e-01,-1.45447290e+00,1.99823566e+00,-4.88329695e-01,6.28662786e-01,1.15942337e-01,-2.13379961e-01,-1.19992088e-01,-1.30188685e-01,1.19341051e-01,1.12530455e-01,-6.32630462e-01,8.90538996e-01,1.60268193e-01,-5.06961568e-01 -contig-89000000,-7.34496348e-01,3.00142483e+00,9.16644065e-01,-1.37209443e+00,5.36437718e-01,-7.70849818e-01,9.57733154e-01,5.45486205e-01,-1.50280529e-01,-7.62397342e-01,3.99501779e-01,-1.69628335e-01,-2.83360950e-01,4.95741128e-01,4.38463601e-02,-6.21873013e-01,3.11879493e-01,6.72111117e-01,7.50672906e-01,3.77888105e-01,1.11576001e+00,-2.10807774e-01,-3.06248032e-01,-5.29692599e-01,6.21067934e-01 -contig-4919000000,-7.52161141e+00,-2.55898693e+00,-4.68127038e+00,-1.01904743e-01,-4.27162826e-01,3.18626333e-01,7.75730572e-01,4.73523118e-01,-2.83087617e-01,-2.48204591e-02,3.80571493e-02,1.22903947e-01,-1.99708215e-01,7.86055891e-02,2.43574294e-01,-1.47800209e-01,2.92100372e-01,-2.32783689e-01,-4.46431514e-01,1.12218332e-01,9.28574588e-03,-1.08738112e-01,1.04423796e-01,-6.43114521e-02,2.76277163e-02 -contig-88000000,-3.82130375e+00,-9.68522757e-01,-1.05866098e+00,6.06805151e-01,2.89277749e-01,8.13853046e-01,-6.25202777e-01,-4.63798105e-01,-5.62952844e-01,5.86331220e-01,7.27468406e-01,-1.71273843e-01,5.72993286e-01,1.49311211e-02,-2.88440096e-01,1.31662481e+00,1.90260498e-01,-2.04364814e-01,5.96688747e-01,1.33715260e-01,-3.76697513e-01,3.79331775e-01,-4.00451444e-01,6.20921938e-01,-6.43913362e-01 -contig-173000000,-8.66455395e-01,6.46014181e+00,-1.22420771e+00,7.11465512e-01,2.23426233e-01,1.48102777e+00,5.69919613e-01,-7.06201262e-01,-1.74021687e+00,1.37927190e-02,1.23773250e+00,3.79598909e-01,-5.13274036e-01,2.96033740e-02,1.90211245e-01,6.56975352e-01,-3.47642557e-01,2.09330273e-01,5.71131296e-01,-1.87453857e-01,7.14570817e-01,-6.53412522e-01,6.51918680e-02,2.58996744e-01,3.81141724e-01 -contig-4928000000,-7.18358248e+00,-2.80153487e+00,-4.17830878e+00,-2.05252742e-01,-5.52944604e-01,2.73121866e-01,7.76788829e-01,5.65195767e-01,-1.83940533e-01,-3.84304884e-01,8.44951435e-02,1.32430711e-01,4.02279257e-01,1.55057147e-01,1.05891015e-01,-5.08843321e-02,2.22023676e-01,-1.98254356e-01,2.77626251e-02,8.54632194e-02,2.66327421e-01,-4.23878930e-02,2.42880949e-01,6.95531728e-02,4.59085309e-02 -contig-231000000,-3.20664580e+00,-2.80305584e+00,1.57368944e+00,4.14207759e-01,6.60074882e-01,-4.20945264e-01,-2.21760422e+00,-8.87831850e-01,1.87118472e-01,1.04451093e-01,8.15430799e-01,8.89797313e-01,5.20987670e-01,-4.35673586e-01,-3.77122318e-01,7.26112123e-02,-1.02248806e-01,-1.91102773e-01,-8.41328927e-01,-7.03605924e-01,-4.27669042e-02,1.47682555e-01,-1.43553473e-01,-1.00698116e-01,-1.95111986e-01 -contig-377000000,2.05819447e+00,-2.26190052e+00,7.56143109e+00,-8.97191171e-01,-7.76918787e-02,8.88949817e-01,-4.20697228e-01,9.64118922e-01,-3.32430220e-01,3.09968256e-01,3.87940767e-02,1.10468428e+00,4.98851176e-01,7.32756419e-01,6.89020086e-01,1.11872034e+00,4.72079326e-01,1.00830448e+00,6.36162086e-01,2.30266820e-01,-1.07129032e+00,-3.08919875e-01,-1.05985120e-01,-4.40799816e-01,-1.91923817e-01 -contig-1887000000,1.16583743e+01,-8.70661442e-01,-3.84183640e+00,1.72832532e-01,7.89290732e-01,-3.03528118e-01,1.72507076e-01,9.35429498e-01,1.15046776e-02,3.43527595e-01,-1.06906319e-01,-2.00210227e-01,4.94961490e-01,8.16844100e-01,-4.07700207e-01,3.79641857e-01,-3.97599176e-01,-3.27843387e-01,1.76270542e-01,-1.76330415e-01,2.21237179e-01,-9.54264480e-03,6.09774494e-02,-5.58710566e-01,5.87972093e-01 -contig-4904000000,-5.96818698e+00,-2.39920286e+00,-2.81002801e+00,2.03058846e-01,-5.81248122e-02,3.10068113e-01,2.59651732e-01,6.31048932e-02,-1.11609205e-01,-3.05292668e-01,-4.93624488e-02,2.29197385e-02,-2.73817495e-01,5.48526592e-02,-2.07231691e-01,-6.09027602e-02,-7.07318167e-03,-5.91185585e-01,-3.85132114e-03,2.38622923e-01,5.31508940e-01,1.91443326e-01,4.13148536e-01,2.03983475e-01,-2.08286668e-01 -contig-1345000000,-4.15100263e+00,-2.54023770e+00,-6.25441888e-01,5.46254407e-01,1.63881564e-01,2.80340142e-02,-1.48313904e-01,-7.83585591e-01,7.08256749e-01,6.40768441e-02,-8.06370894e-01,-2.74810532e-02,2.93102886e-02,-9.43680224e-02,8.65751838e-02,-2.28852436e-01,-1.38361627e-01,-6.19512936e-02,-4.71308549e-02,1.66064036e-01,-2.46849409e-01,2.17553158e-01,-5.69623817e-02,-1.86987132e-01,-4.97192783e-01 -contig-279000000,2.39433264e-01,1.16630992e+00,3.55532803e+00,-4.87544866e-01,9.16473153e-01,-1.57813899e-02,-1.31016932e-01,-4.40442373e-01,-1.16340023e+00,-7.79194781e-01,-7.67814854e-01,-2.30996553e-01,-1.14763230e+00,3.20765826e-01,-1.02374298e+00,2.37195236e+00,9.21510041e-01,-2.95461146e-01,-2.08002058e-01,7.52347833e-01,4.03466935e-01,-1.82923174e+00,-9.45037659e-02,3.11033527e-03,8.37955853e-01 -contig-2648000000,-3.24057964e+00,4.70295614e-01,-1.33593494e+00,3.38830551e-01,1.26014594e+00,-2.70817260e-01,-4.90704270e-01,-6.04605307e-01,-3.55467616e-01,1.64439830e-01,4.33324667e-01,5.86462572e-01,1.05421013e+00,-1.01478498e-02,-6.98816369e-01,3.25955965e-01,7.96882253e-01,-2.99371954e-01,4.68581664e-01,2.71418603e-01,-1.98507146e-01,2.91787438e-01,2.93013824e-01,1.40728933e-01,5.61728476e-01 -contig-4908000000,-6.53012365e+00,-1.60105959e+00,-4.13977778e+00,4.82892860e-01,-2.28001043e-01,4.92834541e-01,3.57677066e-01,9.34335199e-02,-2.22369471e-01,2.02749115e-01,-2.22727788e-01,2.87761400e-01,-4.18162726e-01,2.65540738e-02,-6.37067017e-02,8.74203277e-02,3.16871115e-01,-1.37375576e-01,-2.86216370e-01,2.02342957e-01,-7.57083286e-02,-1.19814021e-01,1.24329217e-01,-9.32903379e-02,2.44703734e-02 -contig-247000000,5.47899280e-01,1.17737563e+00,3.65521470e+00,9.90830243e-01,-6.04116613e-01,1.14419882e+00,1.38102656e+00,-1.74852190e+00,2.90995380e-01,-3.33554870e-01,-1.27554763e+00,5.70777609e-01,3.33223490e-01,-4.15288227e-01,-3.44329303e-01,-4.16571889e-01,-1.70478363e+00,-4.43225828e-01,-9.12504351e-01,5.26298038e-01,-6.13413078e-01,-6.88157407e-01,4.31474721e-01,4.77610275e-01,4.57820824e-01 -contig-128000000,2.16832216e+00,-3.11887691e+00,8.05615535e+00,1.07789834e+00,-3.41219794e+00,-1.30401322e+00,-2.59010764e-01,1.92889520e-01,-8.25385749e-01,8.32423881e-01,-7.68533511e-01,-5.49769624e-01,-6.40124657e-01,8.85540655e-01,-1.08810517e+00,-2.59799081e-01,1.54579247e+00,2.82038683e-01,1.39901326e+00,8.46488660e-02,-6.39953020e-01,3.60662571e-01,3.39448540e-01,2.19406790e-01,1.40845579e+00 -contig-238000000,-3.78276915e+00,1.99471768e-01,-1.45733685e+00,8.76609327e-01,1.59965917e+00,-5.72611985e-01,2.93288298e-03,-1.36568120e+00,-4.85631073e-01,-7.06848122e-01,6.94701164e-01,-6.55421596e-01,1.89704902e-02,-8.01563508e-01,1.13867783e+00,-7.11722697e-01,3.36789161e-01,-5.65969811e-01,4.88058976e-01,-4.61295365e-01,-2.94112113e-01,6.75631265e-01,4.50499576e-03,-2.11078898e-01,3.92774642e-01 -contig-532000000,-2.15102538e+00,-3.95618278e-01,3.53495081e-01,1.34630961e+00,6.88439095e-01,5.90934585e-01,-1.58671588e+00,-1.04364090e+00,8.97145004e-02,-2.83281503e-01,-2.69163722e-01,-1.38357156e-01,7.32296536e-01,3.40924375e-01,-4.88905701e-01,-1.05026722e-01,1.21608295e-02,-7.43910589e-01,4.93908633e-01,1.11502322e-01,5.55586231e-02,-7.63759019e-01,3.42831450e-01,2.09253557e-01,3.71143897e-01 -contig-53000000,-5.77533127e+00,-1.52844452e+00,-3.10476691e+00,-6.60730886e-02,5.53410356e-01,-2.96332539e-01,4.65805385e-01,-2.54589012e-01,-2.39092369e-01,4.51237685e-01,1.94992872e-01,-2.74906325e-01,-4.80236847e-01,-3.10937272e-01,-3.49548691e-02,1.77021434e-01,-9.41079277e-02,1.89084593e-01,3.17832059e-02,1.04263821e-01,-2.15488772e-02,-1.14429379e-01,-1.98456753e-01,2.07495070e-01,8.15913286e-02 -contig-551000000,-6.41776747e+00,-2.62240221e+00,-3.39521037e+00,-3.64262111e-01,3.28137935e-01,-3.01560482e-01,6.13553881e-01,4.09489725e-01,-2.74459992e-01,8.96092248e-02,1.05003421e-01,1.58073690e-01,-3.76477197e-01,2.06590777e-01,-5.36819917e-02,5.97377558e-02,2.32138543e-01,-5.20141763e-02,3.22982513e-01,-1.51296322e-01,3.04629970e-01,1.81953272e-01,8.79043216e-02,8.96827606e-02,-5.47630126e-02 -contig-204000000,-3.56611507e-01,6.03778089e+00,-7.58624653e-01,3.03617656e-01,-1.12176497e+00,1.26833007e+00,-6.14854416e-01,4.41380228e-01,-2.52798597e-01,5.61717036e-01,2.12127509e-01,-5.63083509e-01,5.05657240e-01,-1.41645448e-01,-4.54509172e-01,-9.94853940e-02,8.72869675e-02,-2.99680448e-01,7.64056680e-02,1.08385699e-01,-6.46817659e-01,3.00342568e-01,-6.04270488e-01,-2.48488107e-01,-2.11701885e-03 -contig-311000000,9.36755133e-01,3.11892272e+00,2.05602094e+00,-5.18881600e-01,6.26749457e-02,5.44419388e-01,-9.21870336e-01,1.24383496e-01,-8.61555569e-02,5.36974562e-01,2.47478354e-01,1.00795802e+00,-8.02005767e-01,1.37787159e+00,-1.89888530e-01,-5.14571678e-01,4.07411108e-05,2.10056298e-01,4.85889752e-01,1.64586477e-01,1.26048828e+00,2.90502291e-01,9.06536070e-01,-4.56170112e-01,-4.11582206e-01 -contig-195000000,2.22127402e+00,-1.88111941e+00,6.16424215e+00,-1.38805187e+00,-5.77560487e-01,6.52794203e-01,1.08829339e+00,2.68452562e-01,-1.68854607e+00,7.46670769e-01,-1.82424267e+00,-3.21800889e-01,1.08121521e-03,-2.72410448e-01,-3.68739400e-01,2.91617080e-01,5.38300910e-01,-6.40624463e-01,9.83081767e-01,-4.05710303e-01,-3.89541137e-01,2.97854086e-01,-4.07824287e-01,-4.62653308e-01,-7.26488467e-01 -contig-1693000000,-2.21022549e+00,-2.71816484e+00,3.26378768e+00,5.31097423e-01,8.16865587e-01,1.63908966e-01,-7.77965971e-01,-1.09355841e+00,4.79533701e-01,2.47891462e-01,1.94382687e-02,-3.89851760e-02,2.64212828e-02,8.08176399e-01,6.32184638e-01,-8.32585387e-01,-2.70129436e-01,-3.87563643e-01,6.66573201e-01,4.92480247e-01,-6.49224047e-02,1.03128684e-01,6.50882326e-01,-4.79456000e-01,-1.38596526e-01 -contig-296000000,-4.61405417e-02,4.48776116e+00,1.03759620e+00,-1.77230375e-01,1.49899174e+00,-8.50198734e-01,1.35744184e-01,-1.24893592e-01,-1.10314421e+00,-1.22357201e-01,9.40740517e-01,6.67874518e-01,-4.63535863e-02,-2.30337208e-01,-4.08998191e-01,1.36746148e-01,1.88699479e-01,-8.40737033e-01,-5.34306078e-01,-3.54753770e-01,4.10215155e-01,5.16724860e-01,-9.29588224e-01,2.23110822e-02,1.20758345e-02 -contig-1111000000,1.31777723e+01,-5.43149655e+00,2.08072881e-01,-8.83713644e-01,-2.81162692e-01,6.29133106e-01,-1.02665459e+00,-3.41004349e-01,-6.68300223e-01,-5.66211194e-01,8.29315200e-01,-1.03811869e-01,-5.01657674e-01,2.60303625e-02,3.29433669e-01,-1.55882037e-01,7.60305677e-02,2.44762574e-01,-1.40868048e-01,-4.13320240e-01,-2.14111084e-01,-9.09483081e-02,5.31403233e-02,1.42787279e-01,1.82087199e-01 -contig-232000000,-4.18103099e+00,-5.06322462e+00,1.59045442e+00,-9.16136464e-01,4.89449999e-01,2.43385973e-02,-8.53888484e-02,1.04796937e-01,-3.71036030e-02,-1.68783095e-01,1.59635499e-01,-3.99533121e-01,-3.79598742e-01,3.69548885e-01,8.41423282e-02,1.91124840e-01,1.94901894e-01,-3.34974888e-01,6.63613293e-01,-4.22861400e-01,2.04113036e-01,1.69736362e-01,-2.76653630e-02,-2.93470220e-01,-1.79084826e-02 -contig-2089000000,-2.74764259e+00,-1.95426029e+00,4.54421784e-01,9.40156124e-01,1.11954979e+00,-4.21168196e-01,-1.02531979e+00,-1.20704094e+00,6.83297403e-01,-4.39810064e-01,-3.90578325e-01,-3.85495727e-01,-1.07271357e-01,3.73768823e-02,1.58955536e-03,-1.10246200e-01,2.86439320e-01,-1.55968260e-01,1.51054519e-01,-7.58940987e-01,2.45751232e-01,3.36064574e-01,3.74764255e-02,-4.29165659e-01,-7.07498608e-01 -contig-4938000000,-7.77079450e+00,-3.06931198e+00,-4.69040141e+00,-3.98891596e-01,-3.96824162e-01,1.84051673e-01,1.02231354e+00,8.02317105e-01,-4.28509468e-01,-1.48478535e-01,1.90995736e-01,3.10619062e-02,7.83152259e-02,1.89161001e-01,-1.67753573e-02,2.15650712e-02,1.44469888e-01,-1.89891345e-01,-8.53944552e-02,1.65642801e-01,2.60452995e-01,-2.70401613e-02,3.59469593e-01,1.21884261e-01,-4.87360921e-02 -contig-282000000,2.84539456e-01,2.94655773e+00,2.51802728e+00,-4.59136140e-01,-2.15852367e-01,1.58983798e-01,-1.35432101e+00,2.46660827e-01,5.13854851e-01,-9.15594084e-01,-8.87100973e-01,-1.54956440e+00,1.73246120e-01,5.76039371e-01,1.25134848e-01,9.38771488e-01,1.57540638e-01,-7.18103264e-01,-5.57706450e-01,-7.36916349e-01,7.22302002e-01,1.67002011e-01,9.49909411e-01,6.94973715e-01,6.33228310e-01 -contig-275000000,-3.13794137e-01,4.71068603e+00,8.11896691e-01,-2.00299404e-01,-1.89075956e-01,-3.14522542e-01,-8.44370986e-01,1.42220228e-01,2.07852052e-01,-3.34249776e-01,8.34023189e-01,1.31823645e-01,2.87340979e-01,3.06036574e-01,4.73402703e-01,6.02866851e-01,5.81902002e-01,6.30532440e-01,2.01585094e-01,8.41124344e-01,-6.79615578e-01,5.75117446e-01,3.65646142e-01,1.81302700e-01,-2.81383902e-01 -contig-274000000,-8.57406146e-01,5.21660301e+00,3.47783162e-01,2.20248766e-01,-2.65581220e-01,-1.57128571e-01,-2.16965485e-01,-6.80764821e-01,1.52464223e-02,-4.96922607e-01,1.12305660e+00,-1.06784350e+00,6.36518282e-01,-1.92490432e+00,-1.49028438e+00,1.28340373e+00,1.07710019e+00,5.33062922e-01,9.38258261e-03,-3.64998012e-01,3.72317431e-01,5.72697805e-01,-7.07831631e-01,9.14044530e-02,-7.04023371e-01 -contig-77000000,6.61137777e+00,-5.52205012e+00,7.56456378e-01,3.98186142e+00,-6.18070467e+00,-7.86329796e+00,5.74307458e-01,-9.78356351e-01,-2.57590633e+00,-2.63324613e-01,2.15384590e+00,-3.76488435e-01,-5.84855329e-01,1.76644894e-01,-5.51871074e-01,-1.24217514e-02,3.73095705e-01,-1.01038251e+00,-7.34353353e-01,5.38510399e-01,4.79651436e-01,-4.19049361e-01,-2.55075202e-01,2.26061123e-01,-4.53844757e-01 -contig-7000000,-6.23550015e+00,-3.65519477e+00,-2.14643854e+00,-2.41025631e-01,-8.86233721e-02,-4.76294989e-02,5.87502878e-01,-5.46594612e-01,2.07415262e-01,-4.97944670e-01,3.73119989e-01,-1.52459259e-02,-2.29391046e-01,-1.90879306e-01,3.52828089e-01,-4.13351166e-01,-3.09006629e-01,4.10245387e-01,-4.41452610e-01,-1.13332841e-01,-4.62318450e-01,-1.64649419e-01,-3.39675536e-01,6.02466764e-04,4.43450311e-01 -contig-218000000,4.63790689e+00,-4.44987789e+00,6.66472776e+00,4.42080486e+00,1.07809202e+00,4.08418377e-01,-3.01011023e-01,2.35902101e+00,1.82091218e-01,-2.57671527e-01,4.77073428e-01,-8.14200491e-01,-5.82665004e-01,9.72920587e-01,4.40936143e-01,6.96475982e-01,2.02308096e-01,-3.10385336e-01,4.11660307e-01,3.53448041e-01,-5.69660309e-01,7.31926589e-01,-9.23536596e-01,-3.50382501e-01,4.11489758e-01 -contig-239000000,2.88323224e-01,4.93361842e+00,1.89853545e-01,7.94818678e-01,5.73327284e-01,-3.47196053e-01,4.19161549e-01,5.64898353e-01,3.14743625e-01,7.40049502e-02,-1.14501008e-01,3.08975107e-01,9.05667163e-01,8.50401383e-02,1.12138096e+00,-4.53012831e-01,3.04732712e-01,5.10081239e-01,5.08449741e-01,-2.07699773e-01,6.79810545e-02,1.61459991e-01,-2.97201490e-01,2.50093291e-01,3.20256643e-01 -contig-4929000000,-8.30249445e+00,-2.47190993e+00,-5.63204517e+00,-2.65894235e-01,-7.72824777e-01,2.32963631e-01,1.24901335e+00,8.18094118e-01,-1.53869091e-01,6.46252760e-02,3.67553769e-01,4.42427865e-01,-2.61638864e-01,-9.07593227e-02,-1.47535547e-02,-2.26740456e-01,2.02387476e-01,-9.79532986e-03,-1.73018857e-01,-5.90894964e-02,2.16171518e-01,-6.56014459e-02,1.15358419e-01,-1.16359002e-01,1.33020601e-01 -contig-248000000,-1.97132108e-01,6.31638579e+00,-1.03265541e+00,8.19234864e-01,-1.55226503e+00,6.80826328e-01,7.63003555e-02,1.93258468e-02,1.31011621e+00,4.87286635e-01,7.26664912e-01,6.47906513e-01,9.12433311e-01,-4.69879635e-01,-6.80957023e-01,8.64187558e-01,-5.87565556e-01,2.22702917e-01,1.48115500e-01,-8.34460345e-01,8.87923995e-02,-6.85467610e-01,3.41992226e-01,-1.22555957e+00,7.25199570e-01 -contig-215000000,4.29221476e-01,1.68268860e+00,3.25032812e+00,-1.43809466e+00,1.90000335e+00,-1.27070982e+00,-2.34118699e-01,6.43876234e-01,-3.13842380e-01,5.13391210e-01,6.99234296e-02,-1.41688681e+00,-5.82448866e-01,-4.50000627e-01,-9.78081369e-01,1.23019336e-01,1.90373326e-02,1.02209456e+00,-7.72939434e-02,-7.34675293e-01,1.34476486e-03,8.74100220e-01,5.93859352e-01,-1.92702613e-01,-7.22693739e-01 -contig-3909000000,1.12845554e+01,-3.30955771e+00,-5.51057094e-01,-5.99046514e-01,1.02314259e+00,-3.60551506e-01,2.32870961e+00,-6.09211913e-01,1.27649592e+00,1.02217390e+00,4.88888772e-01,-3.62666157e-01,4.14683971e-01,-2.56972377e-01,2.15739284e-01,4.53850215e-01,-9.93744062e-01,-3.96101091e-01,5.25611067e-01,2.47421857e-01,6.22470328e-01,1.18726040e-01,-1.12550163e-01,-3.00350252e-01,-4.68403568e-02 -contig-150000000,1.23900621e-02,-1.35093110e-02,4.62547577e+00,-1.64593372e+00,-1.84336757e-01,-2.84733997e-02,2.59504570e-01,7.79701387e-01,8.53499997e-02,-1.37606592e-01,-1.32904955e-01,-1.18455687e-01,-4.43890538e-01,8.17598680e-01,8.54423253e-02,1.13380171e-01,6.87821050e-01,-1.32647542e+00,2.87106349e-01,-1.03416922e+00,-2.69655444e-01,-1.03564936e-01,-1.11785557e-01,-3.68361352e-01,-1.12302665e-01 -contig-151000000,-9.14592765e-01,5.37335378e+00,-3.27785186e-01,7.90024933e-01,-1.70818718e+00,1.01534263e+00,4.97922228e-01,-8.43714197e-01,1.63610182e+00,4.99760124e-02,2.45380873e-01,4.26386198e-01,-8.17460241e-01,-7.99044819e-01,-4.87089822e-01,-5.57348906e-01,-4.13202522e-01,3.16798669e-01,-3.80610808e-01,8.07466038e-01,2.51040385e-01,1.27354134e-01,-3.68096234e-01,2.27902785e-02,5.00789494e-03 -contig-212000000,-4.29796189e-01,5.03987213e+00,-2.67132436e-01,5.67133756e-01,7.71369938e-02,4.76388566e-01,1.37236764e-01,6.22119021e-01,3.23824547e-01,5.29209726e-01,5.61446119e-01,3.78426360e-01,4.05806483e-01,6.70507970e-01,1.11442437e+00,1.34617825e-01,2.82367163e-01,1.07491450e+00,8.93354118e-01,-4.95613600e-01,-3.80029996e-01,-8.67372740e-01,-3.50390878e-01,2.77525804e-01,-2.63545809e-01 -contig-133000000,-7.30816069e-01,5.16423002e+00,-4.04556542e-01,2.41151555e-01,3.41138411e-01,1.82071295e-01,6.92488251e-01,3.58842147e-03,-1.03895853e+00,9.32766214e-02,-6.13776529e-02,3.04099123e-01,4.04142109e-01,-9.95399692e-02,-8.44162169e-01,-8.53346436e-01,1.93458424e-01,6.40914566e-01,7.58008910e-01,2.34490726e-01,6.96073902e-01,-7.22572533e-01,-1.00314731e+00,6.32699875e-01,6.77656865e-01 -contig-194000000,-2.98606751e-01,5.62270465e+00,-5.33670978e-01,1.74962986e-02,-3.20576482e-01,1.49016715e-01,-3.33067846e-01,-1.18674563e-01,-1.82330202e-01,6.23904608e-01,4.23852791e-01,-1.23603947e-01,2.94029488e-01,-5.75790799e-01,-1.48742137e-01,4.70927666e-01,-6.69865200e-01,9.98040937e-01,8.12788659e-02,-2.19024375e-01,3.28788830e-01,-2.78543006e-01,5.58186688e-01,-1.03351088e+00,3.13628860e-01 -contig-26000000,-5.60322723e+00,-2.69146566e+00,-2.24698994e+00,3.67857691e-02,-3.34706091e-01,-1.97678314e-01,2.80637068e-02,-1.05434846e-01,9.31968717e-01,8.59578752e-02,-4.39746506e-01,-4.72859581e-01,-1.60857186e-01,-3.87913497e-01,1.50449351e-02,-3.66529802e-01,1.09237149e-01,1.70653021e-01,-7.07753307e-02,-2.09353831e-01,-4.65078671e-01,-1.73638349e-01,7.01661536e-03,-2.30190606e-01,-2.08299983e-01 -contig-170000000,1.74668928e+00,-3.25165921e+00,7.85320733e+00,-5.64991756e-01,-8.10671399e-01,1.44337786e+00,1.74569570e+00,-5.10636003e-01,-3.26782173e-01,1.86776204e-01,-7.82448030e-01,1.05076362e-02,-3.89227411e-01,-1.07784713e+00,-5.55826776e-01,-3.17334514e-01,-3.37316640e-01,-8.21777517e-01,4.28984174e-01,-5.71544521e-01,-8.80541086e-01,-1.21587342e+00,-3.61815658e-01,-6.26056471e-02,-4.16019970e-01 -contig-82000000,-1.06957525e+00,3.21933536e+00,5.66053820e-01,-1.03117693e+00,7.76688705e-01,-1.35084292e+00,1.36216501e+00,6.76014254e-01,1.38543299e-01,-1.10667615e+00,-7.36845059e-01,-9.97774921e-02,-4.65007014e-01,-1.01039968e-01,3.76374389e-01,-8.10447496e-01,7.58877637e-01,5.78287645e-01,1.51092040e-01,4.82114806e-01,-8.29659596e-01,-2.75461666e-02,-2.24772393e-01,1.35591390e-01,7.09613636e-01 -contig-29000000,-4.21254399e+00,-6.50943409e+00,1.92216113e+00,-1.98766941e-02,2.32780730e-01,1.14928932e-01,3.19090061e-01,-5.28665314e-01,9.33049883e-02,-3.43878188e-01,-2.18073291e-01,9.89505039e-02,4.72678729e-01,-2.04235254e-01,-2.99887741e-01,4.66364558e-02,-4.85154913e-01,6.80950789e-02,-2.94409130e-01,6.84038892e-02,-1.51084906e-01,-1.59860940e-01,-4.85509997e-02,-1.27178467e-01,-9.18551610e-03 -contig-69000000,1.35401059e+01,-1.08866484e+00,-6.96161189e+00,-2.36837303e-01,-7.73774453e-02,-3.59467212e-01,-9.57147214e-01,1.01605032e+00,-1.34427083e-01,7.60142706e-02,-6.95373323e-01,3.16296942e-01,-1.58280950e-01,-9.78139744e-01,-3.03444062e-01,1.17562900e-01,-4.91302602e-02,1.14459448e-01,2.96076199e-01,9.58739971e-02,2.79550763e-02,-6.57995782e-02,8.42088769e-02,-5.92304938e-02,-9.38758787e-02 -contig-25000000,1.28359081e+01,-1.20581490e+00,-6.68346887e+00,-4.15448798e-01,8.79819252e-02,8.41120547e-02,-8.78083048e-02,1.03924772e+00,5.39313911e-02,-7.36698658e-02,-4.81067026e-01,5.34062730e-01,2.32112124e-01,-3.51878111e-01,-4.14858806e-01,2.41686539e-01,1.43772182e-02,-2.67616107e-03,1.46635810e-01,2.15558487e-01,1.94903591e-01,1.30059912e-01,2.54369930e-01,3.65337229e-02,-2.50587108e-03 -contig-4903000000,-4.59262559e+00,-2.80139699e+00,-3.79699005e-01,-3.86011678e-01,4.03205209e-01,-2.44390915e-01,2.04499186e-01,-4.70786662e-01,6.12884702e-01,-3.88596218e-01,-2.14586082e-02,7.13077196e-02,-1.91976088e-01,-1.10469043e-02,3.75383047e-01,2.04848359e-01,-1.79863077e-01,1.13459056e-02,1.75808379e-01,1.38910970e-01,1.31630144e-01,-5.67471011e-02,-1.64318547e-01,1.77667218e-02,-8.58418630e-02 -contig-177000000,-3.83335050e+00,1.01237896e+00,-2.93297366e+00,1.20663596e+00,6.19481962e-01,3.87028094e-01,-3.56853504e-01,-6.03756940e-01,-4.38419294e-01,3.34589578e-01,5.82340213e-01,1.11815609e+00,4.29093060e-01,-6.26200139e-01,-1.17343665e+00,3.61604511e-01,4.73252640e-02,-1.12019148e-01,4.98866590e-01,7.48777944e-02,2.98941183e-01,7.80303326e-01,-1.15357541e-01,-1.53327127e-01,-4.19375030e-01 -contig-339000000,-3.52361231e-01,4.57487557e+00,2.75780377e-01,-3.89500237e-01,-7.42672344e-01,-5.57832173e-02,-1.54817802e-01,-9.18579774e-01,9.46959143e-01,-9.67166487e-01,1.03768702e+00,4.82025757e-01,-4.13965350e-01,-1.33370286e+00,-2.77340369e-01,2.70803227e-01,-1.25158538e-01,3.10008081e-01,6.84794865e-01,-6.43853869e-01,9.46748141e-01,-1.95757401e+00,1.12226318e+00,-9.41318857e-01,-2.44052222e-01 -contig-46000000,1.16901809e+01,-1.01134296e+00,-4.36723218e+00,-3.88697772e-01,1.29644259e-01,5.27082278e-01,-5.67831385e-01,2.89623159e-01,-1.51273673e-01,-2.01222766e-01,-1.20149831e-01,6.11620590e-01,6.79087134e-01,5.09827076e-01,-5.18939875e-01,-1.10402310e-01,1.36743922e-01,3.16311124e-01,8.22277006e-02,-1.27164315e-01,-3.96858137e-02,1.70284844e-02,3.23524052e-02,-1.21431971e-01,3.76576407e-02 -contig-240000000,3.78309519e-01,2.60779736e+00,2.07797227e+00,-1.79979259e+00,3.23219523e-01,-5.88802244e-01,-1.07825796e+00,-2.46459343e-01,-1.38415200e+00,-9.55653447e-01,-8.37964646e-02,-7.83205674e-01,-8.03167632e-01,6.54628113e-01,-7.32722124e-01,1.13093068e+00,6.96574542e-02,-8.00729242e-02,-2.61757658e-01,-5.93503342e-01,4.57979362e-01,-3.89340246e-01,6.74431873e-01,-5.14159213e-01,4.74143032e-01 -contig-684000000,-2.69811247e+00,-3.51294780e+00,1.83867983e+00,-5.88643388e-01,1.48638175e+00,-1.57567576e+00,-2.06876565e+00,-2.98667906e-01,1.16145729e+00,2.12302288e+00,3.03422331e-01,1.29901896e+00,5.68845270e-02,-4.54351959e-01,-5.13267997e-01,1.74340676e-01,-1.19053544e-01,4.06055688e-02,-3.06399919e-01,1.13170133e+00,1.89657787e-01,-1.24188280e+00,-3.60066758e-01,-2.73325023e-01,1.16738313e+00 -contig-191000000,-3.04041452e+00,-2.98949200e+00,1.20787473e+00,-2.95001995e-02,1.01364125e+00,-3.13789740e-01,-2.70576589e-01,-6.80057532e-01,7.04032688e-01,9.18358034e-02,-6.83959973e-01,-2.71251469e-01,-1.15337554e-01,2.88224025e-01,2.28344424e-01,1.40077596e-01,-3.35229735e-01,1.32174661e-01,3.07576176e-01,-2.74316986e-01,-1.94333201e-01,-7.24473665e-03,-1.49513187e-01,1.00658810e-01,-2.74765665e-01 -contig-3908000000,-4.32684449e+00,-3.51145603e+00,3.45174059e-01,-4.70111094e-01,1.24012810e+00,-7.07662150e-01,3.98154331e-01,-4.49208204e-01,3.12858736e-01,-2.62892208e-01,-4.32817749e-02,1.58229340e-01,-1.29680345e-01,3.17907584e-01,-3.49416320e-02,-1.02699860e-02,-2.91187618e-01,-1.81729095e-01,2.09629577e-01,-5.85758869e-01,7.97871787e-02,-1.80771987e-01,1.51760185e-01,-2.29505036e-01,-4.17332195e-01 -contig-3964000000,-4.16051813e+00,-1.14562237e+00,-1.63654387e+00,9.16905907e-01,3.10440789e-01,-3.92384445e-01,-1.69858473e+00,-5.41015601e-01,1.17288484e+00,5.12218709e-01,-9.09933181e-01,-6.62540340e-01,-9.00058322e-02,-6.16873803e-01,3.34230105e-01,1.12438776e+00,7.35288856e-02,4.29057856e-01,-5.96575056e-01,5.46791781e-01,-8.11818283e-01,-1.09524109e-01,1.85363462e-02,5.60155899e-01,3.64906095e-01 -contig-100000000,4.64947805e-01,7.21420443e-01,3.58246161e+00,-9.36468793e-01,-1.12337689e+00,-2.60602246e-01,-3.02181378e-01,6.24309990e-01,1.32430967e+00,-4.68271083e-01,-1.72221856e+00,2.52146010e-01,1.76644767e+00,1.11467449e+00,4.89502598e-03,5.81975798e-01,4.29559284e-02,-3.91973524e-01,-1.05314972e+00,-3.46260365e-01,-3.15839172e-01,5.00265643e-01,4.26424600e-01,-1.16716348e-01,-3.31705248e-01 -contig-4921000000,-7.78661997e+00,-3.23275949e+00,-4.30816783e+00,-5.26324449e-01,-4.43818150e-01,9.88229667e-02,4.09506613e-01,6.67595221e-01,-4.33282569e-01,3.20029453e-01,2.36228224e-01,-1.66329962e-02,1.23532234e-01,2.17715768e-01,1.46169420e-01,-1.67017569e-01,5.94430931e-03,1.82577560e-01,-5.77042911e-01,-1.31596008e-01,-2.88236770e-01,-2.48835676e-01,-2.39600518e-02,-1.53240084e-01,-9.82618721e-02 -contig-86000000,1.03566650e+01,4.01312835e-01,-2.74222729e+00,-9.03737046e-02,-2.37623888e-01,-8.02002565e-02,-6.51307972e-01,-1.43398922e-01,7.67986506e-01,7.90366700e-01,5.92234590e-01,-1.44095200e-01,5.65828660e-01,-1.79038279e-01,-9.35440381e-01,-1.61448401e-01,5.07358241e-01,1.47423042e-01,6.94153189e-02,-1.14927818e-01,5.67207940e-01,-1.12216266e-01,-3.59632292e-01,-4.40270681e-02,6.13528677e-02 -contig-285000000,3.91701575e-01,4.97036916e+00,3.08290660e-01,-5.94350100e-01,3.15493242e-01,-2.89327694e-01,2.34839333e-01,-5.57113218e-01,-2.60894859e-01,5.67178241e-03,7.49267752e-01,1.65516194e+00,-1.30500943e+00,4.68433099e-01,1.13202284e+00,6.96413876e-01,-3.10682820e-01,7.14776916e-01,-1.45078954e-01,-1.04031140e+00,-1.57418286e-01,1.06066184e+00,-7.79885427e-01,4.33364015e-01,-1.00072129e-01 diff --git a/c-concoct/test_vbgmm_fit.c b/c-concoct/test_vbgmm_fit.c new file mode 100644 index 0000000..3cc3769 --- /dev/null +++ b/c-concoct/test_vbgmm_fit.c @@ -0,0 +1,243 @@ +/*System includes*/ +#include +#include +#include +#include +#include +#include + +/*GSL includes*/ +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +/*User includes*/ +#include "c_vbgmm_fit.h" + +void readInputData(const char *szFile, t_Data *ptData); + +void c_vbgmm_fit (double* adX, int nN, int nD, int nK, int* anAssign, int debug, int bAssign); + +void readAssigns(const char *szFile, int *anAssign, int nN); + +int main() +{ + t_Data tData; + int *anAssign = NULL; + int i = 0, j = 0, nN = -1, nD = -1, nK = 0; + double* adX = NULL; + const gsl_rng_type * T; + gsl_rng * r; + + gsl_rng_env_setup(); + + T = gsl_rng_default; + r = gsl_rng_alloc (T); + + + readInputData("PCA_transformed_data_gt2000.csv", &tData); + + nN = tData.nN; + nD = tData.nD; + + adX = (double *) malloc(nN*nD*sizeof(double)); + anAssign = (int *) malloc(nN*sizeof(int)); + + readAssigns("clustering_gt2000.csv", anAssign, nN); + + for(i = 0; i < nN; i++){ + if(anAssign[i] > nK){ + nK = anAssign[i]; + } + for(j = 0; j < nD; j++){ + adX[i*nD + j] = tData.aadX[i][j]; + } + } + + nK = nK + 1; + fprintf(stderr,"Run c_vbgmm_fit with %d clusters\n",nK); + fflush(stderr); + + c_vbgmm_fit (adX, nN, nD, nK, anAssign, FALSE, TRUE); + for(i = 0; i < nN; i++){ + printf("%d,%d\n",i,anAssign[i]); + } + free(adX); + free(anAssign); + return 0; +} + +void readInputData(const char *szFile, t_Data *ptData) +{ + double **aadX = NULL; + int i = 0, j = 0, nD = 0, nN = 0; + char *szLine = (char *) malloc(sizeof(char)*MAX_LINE_LENGTH); + FILE* ifp = NULL; + + if(!szLine) + goto memoryError; + + ifp = fopen(szFile, "r"); + + if(ifp){ + char* szTok = NULL; + char* pcError = NULL; + + if(fgets(szLine, MAX_LINE_LENGTH, ifp) == NULL) + goto formatError; + + szTok = strtok(szLine, DELIM); + /*count dimensions*/ + while(strtok(NULL, DELIM) != NULL){ + + nD++; + } + /*count data points*/ + while(fgets(szLine, MAX_LINE_LENGTH, ifp) != NULL){ + nN++; + } + fclose(ifp); + + /*reopen input file*/ + ifp = fopen(szFile, "r"); + + if(fgets(szLine, MAX_LINE_LENGTH, ifp) == NULL) + goto formatError; + + + /*allocate memory for dimension names*/ + //ptData->aszDimNames = (char **) malloc(nD*sizeof(char*)); + //if(!ptData->aszDimNames) + //goto memoryError; + + szTok = strtok(szLine, DELIM); + /*read in dim names*/ + for(i = 0; i < nD; i++){ + szTok = strtok(NULL, DELIM); + // ptData->aszDimNames[i] = strdup(szTok); + } + + /*allocate memory for data matrix*/ + aadX = (double **) malloc(nN*sizeof(double*)); + if(!aadX) + goto memoryError; + for(i = 0; i < nN; i++){ + aadX[i] = (double *) malloc(nD*sizeof(double)); + if(!aadX[i]) + goto memoryError; + } + + /*read in input data*/ + //ptData->aszSampleNames = (char **) malloc(nN*sizeof(char*)); + //if(!ptData->aszSampleNames) + //goto memoryError; + + for(i = 0; i < nN; i++){ + + if(fgets(szLine, MAX_LINE_LENGTH, ifp) == NULL) + goto formatError; + + szTok = strtok(szLine, DELIM); + // ptData->aszSampleNames[i] = strdup(szTok); + for(j = 0; j < nD; j++){ + szTok = strtok(NULL, DELIM); + + aadX[i][j] = strtod(szTok,&pcError); + + if(*pcError != '\0'){ + goto formatError; + } + } + } + } + else{ + fprintf(stderr, "Failed to open abundance data file %s aborting\n", szFile); + fflush(stderr); + exit(EXIT_FAILURE); + } + + free(szLine); + ptData->nD = nD; + ptData->nN = nN; + ptData->aadX = aadX; + return; + + memoryError: + fprintf(stderr, "Failed allocating memory in readInputData\n"); + fflush(stderr); + exit(EXIT_FAILURE); + + formatError: + fprintf(stderr, "Incorrectly formatted abundance data file\n"); + fflush(stderr); + exit(EXIT_FAILURE); +} + +void readAssigns(const char *szFile, int *anAssign, int nN) +{ + int i = 0; + char *szLine = (char *) malloc(sizeof(char)*MAX_LINE_LENGTH); + FILE* ifp = NULL; + + if(!szLine) + goto memoryError; + + ifp = fopen(szFile, "r"); + + if(ifp){ + char* szTok = NULL; + char* pcError = NULL; + + if(fgets(szLine, MAX_LINE_LENGTH, ifp) == NULL) + goto formatError; + + for(i = 0; i < nN; i++){ + if(fgets(szLine, MAX_LINE_LENGTH, ifp) == NULL) + goto formatError; + + szTok = strtok(szLine, DELIM); + szTok = strtok(NULL, DELIM); + anAssign[i] = strtod(szTok,&pcError); + + if(*pcError != '\0'){ + goto formatError; + } + } + } + else{ + fprintf(stderr, "Failed to open abundance data file %s aborting\n", szFile); + fflush(stderr); + exit(EXIT_FAILURE); + } + + free(szLine); + + return; + + memoryError: + fprintf(stderr, "Failed allocating memory in readInputData\n"); + fflush(stderr); + exit(EXIT_FAILURE); + + formatError: + fprintf(stderr, "Incorrectly formatted abundance data file\n"); + fflush(stderr); + exit(EXIT_FAILURE); +} diff --git a/c-concoct/vbgmm.pyx b/c-concoct/vbgmm.pyx new file mode 100644 index 0000000..8043334 --- /dev/null +++ b/c-concoct/vbgmm.pyx @@ -0,0 +1,43 @@ +""" +vbgmm.pyx + +simple cython wrapper for variational Gaussian mixture model in C + +""" + +import cython + +# import both numpy and the Cython declarations for numpy +import numpy as np +cimport numpy as np + +# declare the interface to the C code +cdef extern void c_vbgmm_fit (double* adX, int nN, int nD, int nK, int seed, int* anAssign, int nThreads) +@cython.boundscheck(False) +@cython.wraparound(False) + +def fit(np.ndarray[double, ndim=2, mode="c"] xarray not None, nClusters, seed, threads): + """ + fit (xarray, nClusters, seed, threads) + + Takes a numpy array xarray as input, fits the vbgmm using nClsuters initial clusters + + param: xarray -- a 2-d numpy array of np.float64 + param: nClusters -- an int, number of start clusters + param: seed -- an int, the random seed + param: threads -- int, the number of threads to use + + """ + cdef int nN, nD, nK, nThreads + + nN, nD = xarray.shape[0], xarray.shape[1] + + nK = nClusters + + nThreads = threads + + cdef np.ndarray[int, ndim=1,mode="c"] assign = np.zeros((nN), dtype=np.intc) + + c_vbgmm_fit (&xarray[0,0], nN, nD, nK, seed, &assign[0], nThreads) + + return assign diff --git a/c-concoct/vbgmmmodule.c b/c-concoct/vbgmmmodule.c deleted file mode 100644 index 1b1c4b0..0000000 --- a/c-concoct/vbgmmmodule.c +++ /dev/null @@ -1,1845 +0,0 @@ -/*System includes*/ -#include -#include -#include -#include -#include -#include - -/*GSL includes*/ -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include - -/*User includes*/ -#include "vbgmmmodule.h" - - -static PyObject *vbgmm_fit(PyObject *self, PyObject *args) -{ - const char *szFileStub = NULL; - int nKStart = 0, nLMin = 0, nMaxIter; - unsigned long lSeed; - double dEpsilon; - int bCout = 0; - int sts; - - if (!PyArg_ParseTuple(args, "siikidi", &szFileStub,&nKStart,&nLMin,&lSeed,&nMaxIter,&dEpsilon,&bCout)) - return NULL; - sts = driver(szFileStub,nKStart,nLMin,lSeed,nMaxIter,dEpsilon,bCout); - return Py_BuildValue("i", sts); -} - -static PyMethodDef VbgmmMethods[] = { - {"fit", vbgmm_fit, METH_VARARGS, - "Fit a variational Bayesian Gaussian mixture."}, - {NULL, NULL, 0, NULL} /* Sentinel */ -}; - - -/* Python 2.x code */ - -PyMODINIT_FUNC -initvbgmm(void) -{ - (void) Py_InitModule("vbgmm", VbgmmMethods); -} - - -int driver(const char* szFileStub, int nKStart, int nLMin, unsigned long lSeed, int nMaxIter, double dEpsilon, int bCOut) -{ - t_Params tParams; - t_Data tData; - gsl_rng *ptGSLRNG = NULL; - const gsl_rng_type *ptGSLRNGType = NULL; - int i = 0, k = 0, nD = 0, nN = 0; - char szOFile[MAX_FILE_NAME_LENGTH]; - FILE *ofp = NULL; - t_VBParams tVBParams; - t_Cluster *ptBestCluster = NULL; - gsl_matrix *ptTemp = NULL; - gsl_matrix *ptTVar = NULL; - /*initialise GSL RNG*/ - gsl_rng_env_setup(); - - gsl_set_error_handler_off(); - - ptGSLRNGType = gsl_rng_default; - ptGSLRNG = gsl_rng_alloc(ptGSLRNGType); - - /*get command line params*/ - tParams.nKStart = nKStart; - tParams.nLMin = nLMin; - tParams.nMaxIter = nMaxIter; - tParams.dEpsilon = dEpsilon; - tParams.lSeed = lSeed; - - setParams(&tParams,szFileStub); - - /*read in input data*/ - readInputData(tParams.szInputFile, &tData); - - readPInputData(tParams.szPInputFile, &tData); - - nD = tData.nD; - nN = tData.nN; - - ptTemp = gsl_matrix_alloc(tData.nT,nD); - ptTVar = gsl_matrix_alloc(tData.nT,tData.nT); - - setVBParams(&tVBParams, &tData); - - ptBestCluster = (t_Cluster *) malloc(sizeof(t_Cluster)); - - ptBestCluster->nN = nN; - ptBestCluster->nK = tParams.nKStart; - ptBestCluster->nD = nD; - ptBestCluster->ptData = &tData; - ptBestCluster->ptVBParams = &tVBParams; - ptBestCluster->lSeed = tParams.lSeed; - ptBestCluster->nMaxIter = tParams.nMaxIter; - ptBestCluster->dEpsilon = tParams.dEpsilon; - - if(bCOut > 0){ - ptBestCluster->szCOutFile = szFileStub; - } - else{ - ptBestCluster->szCOutFile = NULL; - } - runRThreads((void *) &ptBestCluster); - - compressCluster(ptBestCluster); - - calcCovarMatrices(ptBestCluster,&tData); - - sprintf(szOFile,"%sclustering_gt%d.csv",tParams.szOutFileStub,tParams.nLMin); - writeClusters(szOFile,ptBestCluster,&tData); - - sprintf(szOFile,"%spca_means_gt%d.csv",tParams.szOutFileStub,tParams.nLMin); - writeMeans(szOFile,ptBestCluster); - - sprintf(szOFile,"%smeans_gt%d.csv",tParams.szOutFileStub,tParams.nLMin); - writeTMeans(szOFile,ptBestCluster,&tData); - - for(k = 0; k < ptBestCluster->nK; k++){ - sprintf(szOFile,"%spca_variances_gt%d_dim%d.csv",tParams.szOutFileStub,tParams.nLMin,k); - - writeSquareMatrix(szOFile, ptBestCluster->aptSigma[k], nD); - - /*not entirely sure this is correct?*/ - gsl_blas_dgemm (CblasNoTrans,CblasNoTrans,1.0,tData.ptTMatrix,ptBestCluster->aptSigma[k],0.0,ptTemp); - - gsl_blas_dgemm (CblasNoTrans,CblasTrans,1.0,ptTemp,tData.ptTMatrix,0.0,ptTVar); - - sprintf(szOFile,"%svariances_gt%d_dim%d.csv",tParams.szOutFileStub,tParams.nLMin,k); - - writeSquareMatrix(szOFile, ptTVar, nD); - } - - sprintf(szOFile,"%sresponsibilities.csv",tParams.szOutFileStub); - - ofp = fopen(szOFile,"w"); - if(ofp){ - - for(i = 0; i < nN; i++){ - for(k = 0; k < ptBestCluster->nK - 1; k++){ - fprintf(ofp,"%f,",ptBestCluster->aadZ[i][k]); - } - fprintf(ofp,"%f\n",ptBestCluster->aadZ[i][ptBestCluster->nK - 1]); - } - - fclose(ofp); - } - else{ - fprintf(stderr,"Failed openining %s in main\n", szOFile); - fflush(stderr); - } - - sprintf(szOFile,"%svbl.csv",tParams.szOutFileStub); - - ofp = fopen(szOFile,"w"); - if(ofp){ - fprintf(ofp,"%d,%f,%d\n",ptBestCluster->nK,ptBestCluster->dVBL,ptBestCluster->nThread); - - fclose(ofp); - } - else{ - fprintf(stderr,"Failed openining %s in main\n", szOFile); - fflush(stderr); - } - - /*free up memory in data object*/ - destroyData(&tData); - - /*free up best BIC clusters*/ - - destroyCluster(ptBestCluster); - free(ptBestCluster); - - destroyParams(&tParams); - gsl_rng_free(ptGSLRNG); - gsl_matrix_free(tVBParams.ptInvW0); - gsl_matrix_free(ptTemp); - gsl_matrix_free(ptTVar); - - return EXIT_SUCCESS; -} - -void setParams(t_Params *ptParams, const char *szFileStub) -{ - - ptParams->szInputFile = (char *) malloc(MAX_FILE_NAME_LENGTH*sizeof(char)); - if(!ptParams->szInputFile) - goto memoryError; - - ptParams->szPInputFile = (char *) malloc(MAX_FILE_NAME_LENGTH*sizeof(char)); - if(!ptParams->szInputFile) - goto memoryError; - - sprintf(ptParams->szInputFile,"%s%s%d.csv",szFileStub,INPUT_FILE,ptParams->nLMin); - - sprintf(ptParams->szPInputFile,"%s%s%d.csv",szFileStub,PINPUT_FILE,ptParams->nLMin); - - ptParams->szOutFileStub = szFileStub; - - return; - - memoryError: - fprintf(stderr, "Failed allocating memory in setParams\n"); - fflush(stderr); - exit(EXIT_FAILURE); -} - -void destroyParams(t_Params *ptParams) -{ - - free(ptParams->szInputFile); - - free(ptParams->szPInputFile); -} - -void setVBParams(t_VBParams *ptVBParams, t_Data *ptData) -{ - int i = 0, nD = ptData->nD; - double adVar[nD], adMu[nD]; - - ptVBParams->dBeta0 = DEF_BETA0; - ptVBParams->dNu0 = (double) nD; - ptVBParams->ptInvW0 = gsl_matrix_alloc(nD,nD); - - calcSampleVar(ptData,adVar, adMu); - gsl_matrix_set_zero (ptVBParams->ptInvW0); - - for(i = 0; i < nD; i++){ - double dRD = adVar[i]*((double) nD); - - gsl_matrix_set(ptVBParams->ptInvW0,i,i,dRD); - } - - ptVBParams->dLogWishartB = dLogWishartB(ptVBParams->ptInvW0, nD, ptVBParams->dNu0, TRUE); -} - - -void readInputData(const char *szFile, t_Data *ptData) -{ - double **aadX = NULL; - int i = 0, j = 0, nD = 0, nN = 0; - char *szLine = (char *) malloc(sizeof(char)*MAX_LINE_LENGTH); - FILE* ifp = NULL; - - if(!szLine) - goto memoryError; - - ifp = fopen(szFile, "r"); - - if(ifp){ - char* szTok = NULL; - char* pcError = NULL; - - if(fgets(szLine, MAX_LINE_LENGTH, ifp) == NULL) - goto formatError; - - szTok = strtok(szLine, DELIM); - /*count dimensions*/ - while(strtok(NULL, DELIM) != NULL){ - - nD++; - } - /*count data points*/ - while(fgets(szLine, MAX_LINE_LENGTH, ifp) != NULL){ - nN++; - } - fclose(ifp); - - /*reopen input file*/ - ifp = fopen(szFile, "r"); - - if(fgets(szLine, MAX_LINE_LENGTH, ifp) == NULL) - goto formatError; - - - /*allocate memory for dimension names*/ - ptData->aszDimNames = (char **) malloc(nD*sizeof(char*)); - if(!ptData->aszDimNames) - goto memoryError; - - szTok = strtok(szLine, DELIM); - /*read in dim names*/ - for(i = 0; i < nD; i++){ - szTok = strtok(NULL, DELIM); - ptData->aszDimNames[i] = strdup(szTok); - } - - /*allocate memory for data matrix*/ - aadX = (double **) malloc(nN*sizeof(double*)); - if(!aadX) - goto memoryError; - for(i = 0; i < nN; i++){ - aadX[i] = (double *) malloc(nD*sizeof(double)); - if(!aadX[i]) - goto memoryError; - } - - /*read in input data*/ - ptData->aszSampleNames = (char **) malloc(nN*sizeof(char*)); - if(!ptData->aszSampleNames) - goto memoryError; - - for(i = 0; i < nN; i++){ - - if(fgets(szLine, MAX_LINE_LENGTH, ifp) == NULL) - goto formatError; - - szTok = strtok(szLine, DELIM); - ptData->aszSampleNames[i] = strdup(szTok); - for(j = 0; j < nD; j++){ - szTok = strtok(NULL, DELIM); - - aadX[i][j] = strtod(szTok,&pcError); - - if(*pcError != '\0'){ - goto formatError; - } - } - } - } - else{ - fprintf(stderr, "Failed to open abundance data file %s aborting\n", szFile); - fflush(stderr); - exit(EXIT_FAILURE); - } - - free(szLine); - ptData->nD = nD; - ptData->nN = nN; - ptData->aadX = aadX; - return; - - memoryError: - fprintf(stderr, "Failed allocating memory in readInputData\n"); - fflush(stderr); - exit(EXIT_FAILURE); - - formatError: - fprintf(stderr, "Incorrectly formatted abundance data file\n"); - fflush(stderr); - exit(EXIT_FAILURE); -} - -void readPInputData(const char *szFile, t_Data *ptData) -{ - int i = 0, j = 0, nD = ptData->nD, nT = 0; - char* szLine = (char *) malloc(sizeof(char)*MAX_LINE_LENGTH); - FILE* ifp = NULL; - - if(!szLine) - goto memoryError; - - ifp = fopen(szFile, "r"); - - if(ifp){ - char* szTok = NULL; - char* pcError = NULL; - nT = 1; - - if(fgets(szLine, MAX_LINE_LENGTH, ifp) == NULL) - goto memoryError; - - szTok = strtok(szLine, DELIM); - /*count dimensions*/ - while(strtok(NULL, DELIM) != NULL){ - nT++; - } - - ptData->ptTMatrix = gsl_matrix_alloc(nT,nD); - - fclose(ifp); - - /*reopen input file*/ - ifp = fopen(szFile, "r"); - - for(i = 0; i < nD; i++){ - double dTemp = 0.0; - - if(fgets(szLine, MAX_LINE_LENGTH, ifp) == NULL) - goto formatError; - - szTok = strtok(szLine, DELIM); - - dTemp = strtod(szTok,&pcError); - if(*pcError != '\0'){ - goto formatError; - } - - gsl_matrix_set(ptData->ptTMatrix,0,i,dTemp); - - for(j = 1; j < nT; j++){ - szTok = strtok(NULL, DELIM); - - dTemp = strtod(szTok,&pcError); - if(*pcError != '\0'){ - goto formatError; - } - - gsl_matrix_set(ptData->ptTMatrix,j,i,dTemp); - } - } - } - else{ - fprintf(stderr, "Failed to open abundance data file %s aborting\n", szFile); - fflush(stderr); - exit(EXIT_FAILURE); - } - - free(szLine); - ptData->nT = nT; - return; - - formatError: - fprintf(stderr, "Incorrectly formatted abundance data file\n"); - fflush(stderr); - exit(EXIT_FAILURE); - - memoryError: - fprintf(stderr, "Failed allocating memory in readPInputFile\n"); - fflush(stderr); - exit(EXIT_FAILURE); -} - -void destroyData(t_Data *ptData) -{ - int nN = ptData->nN, nD = ptData->nD; - int i = 0; - - gsl_matrix_free(ptData->ptTMatrix); - - for(i = 0; i < nD; i++){ - free(ptData->aszDimNames[i]); - } - free(ptData->aszDimNames); - - for(i = 0; i < nN; i++){ - free(ptData->aadX[i]); - } - free(ptData->aadX); - - for(i = 0; i < nN; i++){ - free(ptData->aszSampleNames[i]); - } - free(ptData->aszSampleNames); - - return; - -} - -void destroyCluster(t_Cluster* ptCluster) -{ - int i = 0, nN = ptCluster->nN, nKSize = ptCluster->nKSize; - - if(ptCluster->szCOutFile != NULL){ - free(ptCluster->szCOutFile); - } - - free(ptCluster->anMaxZ); - - free(ptCluster->anW); - - for(i = 0; i < nN; i++){ - free(ptCluster->aadZ[i]); - } - free(ptCluster->aadZ); - - free(ptCluster->adLDet); - free(ptCluster->adPi); - free(ptCluster->adBeta); - free(ptCluster->adNu); - - for(i = 0; i < nKSize; i++){ - free(ptCluster->aadMu[i]); - free(ptCluster->aadM[i]); - } - - free(ptCluster->aadMu); - free(ptCluster->aadM); - - for(i = 0; i < nKSize ; i++){ - gsl_matrix_free(ptCluster->aptSigma[i]); - gsl_matrix_free(ptCluster->aptCovar[i]); - } - free(ptCluster->aptSigma); - free(ptCluster->aptCovar); - return; -} - -void allocateCluster(t_Cluster *ptCluster, int nN, int nK, int nD, t_Data *ptData, long lSeed, int nMaxIter, double dEpsilon, char *szCOutFile) -{ - int i = 0, j = 0, k = 0; - - ptCluster->szCOutFile = szCOutFile; - ptCluster->ptVBParams = NULL; - ptCluster->lSeed = lSeed; - ptCluster->nMaxIter = nMaxIter; - ptCluster->dEpsilon = dEpsilon; - ptCluster->ptData = ptData; - - ptCluster->nN = nN; - ptCluster->nK = nK; - ptCluster->nKSize = nK; - ptCluster->nD = nD; - - ptCluster->dVBL = 0.0; - - ptCluster->anMaxZ = (int *) malloc(nN*sizeof(int)); /*destroyed*/ - if(!ptCluster->anMaxZ) - goto memoryError; - - ptCluster->anW = (int *) malloc(nK*sizeof(int)); /*destroyed*/ - if(!ptCluster->anW) - goto memoryError; - - for(i = 0; i < nN; i++){ - ptCluster->anMaxZ[i] = NOT_SET; - } - - for(i = 0; i < nK; i++){ - ptCluster->anW[i] = 0; - } - - ptCluster->aadZ = (double **) malloc(nN*sizeof(double *)); /*destroyed*/ - if(!ptCluster->aadZ) - goto memoryError; - - for(i = 0; i < nN; i++){ - ptCluster->aadZ[i] = (double *) malloc(nK*sizeof(double)); /*destroyed*/ - if(!ptCluster->aadZ[i]) - goto memoryError; - - for(j = 0; j < nK; j++){ - ptCluster->aadZ[i][j] = 0.0; - } - } - - ptCluster->adLDet = (double *) malloc(nK*sizeof(double)); /*all*/ - ptCluster->adPi = (double *) malloc(nK*sizeof(double)); - ptCluster->adBeta = (double *) malloc(nK*sizeof(double)); - ptCluster->adNu = (double *) malloc(nK*sizeof(double)); /*destroyed*/ - - if(!ptCluster->adLDet || !ptCluster->adPi) - goto memoryError; - - if(!ptCluster->adBeta || !ptCluster->adNu) - goto memoryError; - - for(k = 0; k < nK; k++){ - ptCluster->adLDet[k] = 0.0; - ptCluster->adPi[k] = 0.0; - ptCluster->adBeta[k] = 0.0; - ptCluster->adNu[k] = 0.0; - } - - ptCluster->aadMu = (double **) malloc(nK*sizeof(double *)); - if(!ptCluster->aadMu) - goto memoryError; - - ptCluster->aadM = (double **) malloc(nK*sizeof(double *)); - if(!ptCluster->aadM) - goto memoryError; - - for(i = 0; i < nK; i++){ - ptCluster->aadM[i] = (double*) malloc (nD*sizeof(double)); - if(!ptCluster->aadM[i]) - goto memoryError; - - ptCluster->aadMu[i] = (double*) malloc (nD*sizeof(double)); - if(!ptCluster->aadMu[i]) - goto memoryError; - } - - ptCluster->aptSigma = (gsl_matrix **) malloc(nK*sizeof(gsl_matrix *)); - if(!ptCluster->aptSigma) - goto memoryError; - - for(i = 0; i < nK ; i++){ - ptCluster->aptSigma[i] = (gsl_matrix*) gsl_matrix_alloc (nD, nD); - } - - ptCluster->aptCovar = (gsl_matrix **) malloc(nK*sizeof(gsl_matrix *)); - if(!ptCluster->aptCovar) - goto memoryError; - - for(i = 0; i < nK ; i++){ - ptCluster->aptCovar[i] = (gsl_matrix*) gsl_matrix_alloc (nD, nD); - } - - return; - - memoryError: - fprintf(stderr, "Failed allocating memory in allocateCluster\n"); - fflush(stderr); - exit(EXIT_FAILURE); -} - -void writeSquareMatrix(char*szFile, gsl_matrix *ptMatrix, int nD) -{ - int i = 0, j = 0; - FILE* ofp = fopen(szFile,"w"); - - if(ofp){ - for(i = 0; i < nD; i++){ - for(j = 0; j < nD - 1; j++){ - fprintf(ofp,"%f,",gsl_matrix_get(ptMatrix,i,j)); - } - fprintf(ofp,"%f\n",gsl_matrix_get(ptMatrix,i,j)); - } - } - else{ - fprintf(stderr,"Failed to open %s for writing in writeSquareMatrix\n", szFile); - fflush(stderr); - } -} - -double decomposeMatrix(gsl_matrix *ptSigmaMatrix, int nD) -{ - double dDet = 0.0; - int status; - int l = 0; - - status = gsl_linalg_cholesky_decomp(ptSigmaMatrix); - - if(status == GSL_EDOM){ - fprintf(stderr,"Failed Cholesky decomposition in decomposeMatrix\n"); - fflush(stderr); - exit(EXIT_FAILURE); - } - else{ - for(l = 0; l < nD; l++){ - double dT = gsl_matrix_get(ptSigmaMatrix,l,l); - dDet += 2.0*log(dT); - } - gsl_linalg_cholesky_invert(ptSigmaMatrix); - return dDet; - } -} - -void performMStep(t_Cluster *ptCluster, t_Data *ptData){ - int i = 0, j = 0, k = 0, l = 0, m = 0; - int nN = ptData->nN, nK = ptCluster->nK, nD = ptData->nD; - double **aadZ = ptCluster->aadZ,**aadX = ptData->aadX; - double *adLDet = ptCluster->adLDet, *adPi = ptCluster->adPi; - double **aadCovar = NULL, **aadInvWK = NULL; - t_VBParams *ptVBParams = ptCluster->ptVBParams; - - gsl_matrix* ptSigmaMatrix = gsl_matrix_alloc(nD,nD); - - aadCovar = (double **) malloc(nD*sizeof(double*)); - if(!aadCovar) - goto memoryError; - - for(i = 0; i < nD; i++){ - aadCovar[i] = (double *) malloc(nD*sizeof(double)); - if(!aadCovar[i]) - goto memoryError; - } - - aadInvWK = (double **) malloc(nD*sizeof(double*)); - if(!aadInvWK) - goto memoryError; - - for(i = 0; i < nD; i++){ - aadInvWK[i] = (double *) malloc(nD*sizeof(double)); - if(!aadInvWK[i]) - goto memoryError; - } - - /*perform M step*/ - for(k = 0; k < nK; k++){ /*loop components*/ - double* adMu = ptCluster->aadMu[k]; - gsl_matrix *ptSigmaMatrix = ptCluster->aptSigma[k]; - double dF = 0.0; - /*recompute mixture weights and means*/ - for(j = 0; j < nD; j++){ - adMu[j] = 0.0; - for(l = 0; l < nD; l++){ - aadCovar[j][l] = 0.0; - } - } - - /* compute weight associated with component k*/ - adPi[k] = 0.0; - for(i = 0; i < nN; i++){ - if(aadZ[i][k] > MIN_Z){ - adPi[k] += aadZ[i][k]; - for(j = 0; j < nD; j++){ - adMu[j] += aadZ[i][k]*aadX[i][j]; - } - } - } - - /*normalise means*/ - if(adPi[k] > MIN_PI){ - /*Equation 10.60*/ - ptCluster->adBeta[k] = ptVBParams->dBeta0 + adPi[k]; - - for(j = 0; j < nD; j++){ - /*Equation 10.61*/ - ptCluster->aadM[k][j] = adMu[j]/ptCluster->adBeta[k]; - adMu[j] /= adPi[k]; - } - - ptCluster->adNu[k] = ptVBParams->dNu0 + adPi[k]; - - - /*calculate covariance matrices*/ - for(i = 0; i < nN; i++){ - if(aadZ[i][k] > MIN_Z){ - double adDiff[nD]; - - for(j = 0; j < nD; j++){ - adDiff[j] = aadX[i][j] - adMu[j]; - } - - for(l = 0; l < nD; l++){ - for(m = 0; m <=l ; m++){ - aadCovar[l][m] += aadZ[i][k]*adDiff[l]*adDiff[m]; - } - } - } - } - - for(l = 0; l < nD; l++){ - for(m = l + 1; m < nD; m++){ - aadCovar[l][m] = aadCovar[m][l]; - } - } - - /*save sample covariances for later use*/ - for(l = 0; l < nD; l++){ - for(m = 0; m < nD; m++){ - double dC = aadCovar[l][m] / adPi[k]; - gsl_matrix_set(ptCluster->aptCovar[k],l,m,dC); - } - } - - /*Now perform equation 10.62*/ - dF = (ptVBParams->dBeta0*adPi[k])/ptCluster->adBeta[k]; - for(l = 0; l < nD; l++){ - for(m = 0; m <= l; m++){ - aadInvWK[l][m] = gsl_matrix_get(ptVBParams->ptInvW0, l,m) + aadCovar[l][m] + dF*adMu[l]*adMu[m]; - } - } - - for(l = 0; l < nD; l++){ - for(m = 0; m <= l ; m++){ - aadCovar[l][m] /= adPi[k]; - gsl_matrix_set(ptSigmaMatrix, l, m, aadInvWK[l][m]); - gsl_matrix_set(ptSigmaMatrix, m, l, aadInvWK[l][m]); - } - } - - - /*Implement Equation 10.65*/ - adLDet[k] = ((double) nD)*log(2.0); - - for(l = 0; l < nD; l++){ - double dX = 0.5*(ptCluster->adNu[k] - (double) l); - adLDet[k] += gsl_sf_psi (dX); - } - - adLDet[k] -= decomposeMatrix(ptSigmaMatrix,nD); - } - else{ - /*Equation 10.60*/ - adPi[k] = 0.0; - - ptCluster->adBeta[k] = ptVBParams->dBeta0; - - for(j = 0; j < nD; j++){ - /*Equation 10.61*/ - ptCluster->aadM[k][j] = 0.0; - adMu[j] = 0.0; - } - - ptCluster->adNu[k] = ptVBParams->dNu0; - - - for(l = 0; l < nD; l++){ - for(m = 0; m <= l; m++){ - aadInvWK[l][m] = gsl_matrix_get(ptVBParams->ptInvW0, l,m); - } - } - - for(l = 0; l < nD; l++){ - for(m = 0; m <= l ; m++){ -aadInvWK[l][m] = gsl_matrix_get(ptVBParams->ptInvW0, l,m); - } - } - - for(l = 0; l < nD; l++){ - for(m = 0; m <= l ; m++){ -gsl_matrix_set(ptSigmaMatrix, l, m, aadInvWK[l][m]); - gsl_matrix_set(ptSigmaMatrix, m, l, aadInvWK[l][m]); - } - } - - /*Implement Equation 10.65*/ - adLDet[k] = ((double) nD)*log(2.0); - - for(l = 0; l < nD; l++){ - double dX = 0.5*(ptCluster->adNu[k] - (double) l); - adLDet[k] += gsl_sf_psi (dX); - } - - adLDet[k] -= decomposeMatrix(ptSigmaMatrix,nD); - } - } - -/*Normalise pi*/ - - if(1){ - double dNP = 0.0; - - for(k = 0; k < nK; k++){ - dNP += adPi[k]; - } - - for(k = 0; k < nK; k++){ - adPi[k] /= dNP; - } - } - - /*free up memory*/ - for(i = 0; i < nD; i++){ - free(aadCovar[i]); - free(aadInvWK[i]); - } - - free(aadCovar); - free(aadInvWK); - - return; - - memoryError: - fprintf(stderr, "Failed allocating memory in performMStep\n"); - fflush(stderr); - exit(EXIT_FAILURE); -} - -void calcCovarMatrices(t_Cluster *ptCluster, t_Data *ptData) -{ - int i = 0, j = 0, k = 0, l = 0, m = 0; - int nN = ptData->nN, nK = ptCluster->nK, nD = ptData->nD; - double **aadZ = ptCluster->aadZ,**aadX = ptData->aadX; - double *adPi = ptCluster->adPi, **aadCovar = NULL; - double dN = (double) nN; - - - aadCovar = (double **) malloc(nD*sizeof(double*)); - if(!aadCovar) - goto memoryError; - - for(i = 0; i < nD; i++){ - aadCovar[i] = (double *) malloc(nD*sizeof(double)); - if(!aadCovar[i]) - goto memoryError; - } - - - for(k = 0; k < nK; k++){ /*loop components*/ - double* adMu = ptCluster->aadMu[k]; - gsl_matrix *ptSigmaMatrix = ptCluster->aptSigma[k]; - /*recompute mixture weights and means*/ - for(j = 0; j < nD; j++){ - adMu[j] = 0.0; - for(l = 0; l < nD; l++){ - aadCovar[j][l] = 0.0; - } - /*prevents singularities*/ - aadCovar[j][j] = MIN_COVAR; - } - - /* compute weight associated with component k*/ - adPi[k] = 0.0; - for(i = 0; i < nN; i++){ - adPi[k] += aadZ[i][k]; - for(j = 0; j < nD; j++){ - adMu[j] += aadZ[i][k]*aadX[i][j]; - } - } - /*normalise means*/ - for(j = 0; j < nD; j++){ - adMu[j] /= adPi[k]; - } - - /*calculate covariance matrices*/ - for(i = 0; i < nN; i++){ - double adDiff[nD]; - - for(j = 0; j < nD; j++){ - adDiff[j] = aadX[i][j] - adMu[j]; - } - - for(l = 0; l < nD; l++){ - for(m = 0; m <=l ; m++){ - aadCovar[l][m] += aadZ[i][k]*adDiff[l]*adDiff[m]; - } - } - } - - for(l = 0; l < nD; l++){ - for(m = l + 1; m < nD; m++){ - aadCovar[l][m] = aadCovar[m][l]; - } - } - - for(l = 0; l < nD; l++){ - for(m = 0; m < nD; m++){ - aadCovar[l][m] /= adPi[k]; - gsl_matrix_set(ptSigmaMatrix, l, m, aadCovar[l][m]); - } - } - - adPi[k] /= dN; /*normalise weights*/ - } - /*free up memory*/ - for(i = 0; i < nD; i++){ - free(aadCovar[i]); - } - - //gsl_matrix_free(ptSigmaMatrix); - free(aadCovar); - - return; - memoryError: - fprintf(stderr, "Failed allocating memory in performMStep\n"); - fflush(stderr); - exit(EXIT_FAILURE); -} - -void calcCovarMatricesVB(t_Cluster *ptCluster, t_Data *ptData){ - int i = 0, j = 0, k = 0, l = 0, m = 0; - int nN = ptData->nN, nK = ptCluster->nK, nD = ptData->nD; - double **aadZ = ptCluster->aadZ,**aadX = ptData->aadX; - double *adLDet = ptCluster->adLDet, *adPi = ptCluster->adPi; - double **aadCovar = NULL, **aadInvWK = NULL; - t_VBParams *ptVBParams = ptCluster->ptVBParams; - - aadCovar = (double **) malloc(nD*sizeof(double*)); - if(!aadCovar) - goto memoryError; - - for(i = 0; i < nD; i++){ - aadCovar[i] = (double *) malloc(nD*sizeof(double)); - if(!aadCovar[i]) - goto memoryError; - } - - aadInvWK = (double **) malloc(nD*sizeof(double*)); - if(!aadInvWK) - goto memoryError; - - for(i = 0; i < nD; i++){ - aadInvWK[i] = (double *) malloc(nD*sizeof(double)); - if(!aadInvWK[i]) - goto memoryError; - } - - - /*perform M step*/ - for(k = 0; k < nK; k++){ /*loop components*/ - double* adMu = ptCluster->aadMu[k]; - gsl_matrix *ptSigmaMatrix = ptCluster->aptSigma[k]; - double dF = 0.0; - - /*recompute mixture weights and means*/ - for(j = 0; j < nD; j++){ - adMu[j] = 0.0; - for(l = 0; l < nD; l++){ - aadCovar[j][l] = 0.0; - } - } - - /* compute weight associated with component k*/ - adPi[k] = 0.0; - for(i = 0; i < nN; i++){ - adPi[k] += aadZ[i][k]; - for(j = 0; j < nD; j++){ - adMu[j] += aadZ[i][k]*aadX[i][j]; - } - } - /*normalise means*/ - if(adPi[k] > MIN_PI){ - - /*Equation 10.60*/ - ptCluster->adBeta[k] = ptVBParams->dBeta0 + adPi[k]; - - for(j = 0; j < nD; j++){ - /*Equation 10.61*/ - ptCluster->aadM[k][j] = adMu[j]/ptCluster->adBeta[k]; - adMu[j] /= adPi[k]; - } - - ptCluster->adNu[k] = ptVBParams->dNu0 + adPi[k]; - - - /*calculate covariance matrices*/ - for(i = 0; i < nN; i++){ - double adDiff[nD]; - - for(j = 0; j < nD; j++){ - adDiff[j] = aadX[i][j] - adMu[j]; - } - - for(l = 0; l < nD; l++){ - for(m = 0; m <=l ; m++){ - aadCovar[l][m] += aadZ[i][k]*adDiff[l]*adDiff[m]; - } - } - } - - for(l = 0; l < nD; l++){ - for(m = l + 1; m < nD; m++){ - aadCovar[l][m] = aadCovar[m][l]; - } - } - - /*save sample covariances for later use*/ - for(l = 0; l < nD; l++){ - for(m = 0; m < nD; m++){ - double dC = aadCovar[l][m] / adPi[k]; - gsl_matrix_set(ptCluster->aptCovar[k],l,m,dC); - } - } - - /*Now perform equation 10.62*/ - dF = (ptVBParams->dBeta0*adPi[k])/ptCluster->adBeta[k]; - for(l = 0; l < nD; l++){ - for(m = 0; m <= l; m++){ - aadInvWK[l][m] = gsl_matrix_get(ptVBParams->ptInvW0, l,m) + aadCovar[l][m] + dF*adMu[l]*adMu[m]; - } - } - - for(l = 0; l < nD; l++){ - for(m = 0; m <= l ; m++){ - //aadCovar[l][m] /= adPi[k]; - gsl_matrix_set(ptSigmaMatrix, l, m, aadInvWK[l][m]); - gsl_matrix_set(ptSigmaMatrix, m, l, aadInvWK[l][m]); - } - } - - } - else{ - /*Equation 10.60*/ - adPi[k] = 0.0; - - ptCluster->adBeta[k] = ptVBParams->dBeta0; - - for(j = 0; j < nD; j++){ - /*Equation 10.61*/ - ptCluster->aadM[k][j] = 0.0; - adMu[j] = 0.0; - } - - ptCluster->adNu[k] = ptVBParams->dNu0; - - for(l = 0; l < nD; l++){ - for(m = 0; m <= l; m++){ - aadInvWK[l][m] = gsl_matrix_get(ptVBParams->ptInvW0, l,m); - } - } - - for(l = 0; l < nD; l++){ - for(m = 0; m <= l ; m++){ - //aadCovar[l][m] /= adPi[k]; - gsl_matrix_set(ptSigmaMatrix, l, m, aadInvWK[l][m]); - gsl_matrix_set(ptSigmaMatrix, m, l, aadInvWK[l][m]); - } - } - - /*Implement Equation 10.65*/ - adLDet[k] = ((double) nD)*log(2.0); - - for(l = 0; l < nD; l++){ - double dX = 0.5*(ptCluster->adNu[k] - (double) l); - adLDet[k] += gsl_sf_psi (dX); - } - - adLDet[k] -= decomposeMatrix(ptSigmaMatrix,nD); - } - } - - /*Normalise pi*/ - - if(1){ - double dNP = 0.0; - - for(k = 0; k < nK; k++){ - dNP += adPi[k]; - } - - for(k = 0; k < nK; k++){ - adPi[k] /= dNP; - } - } - - /*free up memory*/ - for(i = 0; i < nD; i++){ - free(aadCovar[i]); - free(aadInvWK[i]); - } - - //gsl_matrix_free(ptSigmaMatrix); - free(aadCovar); - free(aadInvWK); - return; - memoryError: - fprintf(stderr, "Failed allocating memory in performMStep\n"); - fflush(stderr); - exit(EXIT_FAILURE); -} - -void updateMeans(t_Cluster *ptCluster, t_Data *ptData){ - int i = 0, j = 0, k = 0; - int nN = ptData->nN, nK = ptCluster->nK, nD = ptData->nD; - int *anMaxZ = ptCluster->anMaxZ; - int *anW = ptCluster->anW; - double **aadX = ptData->aadX, **aadMu = ptCluster->aadMu; - - for(k = 0; k < nK; k++){ - - for(j = 0; j < nD; j++){ - aadMu[k][j] = 0.0; - } - } - - for(i = 0; i < nN; i++){ - int nZ = anMaxZ[i]; - - for(j = 0; j < nD; j++){ - aadMu[nZ][j] += aadX[i][j]; - } - } - - for(k = 0; k < nK; k++){ /*loop components*/ - - /*normalise means*/ - if(anW[k] > 0){ - for(j = 0; j < nD; j++){ - aadMu[k][j] /= (double) anW[k]; - } - } - else{ - for(j = 0; j < nD; j++){ - aadMu[k][j] = 0.0; - } - } - } - - return; -} - -void initRandom(gsl_rng *ptGSLRNG, t_Cluster *ptCluster, t_Data *ptData) -{ - /*very simple initialisation assign each data point to random cluster*/ - int i = 0, k = 0; - - for(i = 0; i < ptData->nN; i++){ - int nIK = -1; - - for(k = 0; k < ptCluster->nK; k++){ - ptCluster->aadZ[i][k] = 0.0; - } - - nIK = gsl_rng_uniform_int (ptGSLRNG, ptCluster->nK); - - ptCluster->aadZ[i][nIK] = 1.0; - } - - performMStep(ptCluster, ptData); - - return; -} - -double calcDist(double* adX, double *adMu, int nD) -{ - double dDist = 0.0; - int i = 0; - - for(i = 0; i < nD; i++){ - double dV = adX[i] - adMu[i]; - dDist += dV*dV; - } - - return sqrt(dDist); -} - -void initKMeans(gsl_rng *ptGSLRNG, t_Cluster *ptCluster, t_Data *ptData) -{ - /*very simple initialisation assign each data point to random cluster*/ - int i = 0, k = 0, nN = ptData->nN, nK = ptCluster->nK, nD = ptData->nD; - double **aadMu = ptCluster->aadMu, **aadX = ptData->aadX; - int *anMaxZ = ptCluster->anMaxZ, *anW = ptCluster->anW, nChange = nN; - int nIter = 0, nMaxIter = ptCluster->nMaxIter; - for(i = 0; i < nN; i++){ - int nIK = gsl_rng_uniform_int (ptGSLRNG, nK); - - ptCluster->anMaxZ[i] = nIK; - anW[nIK]++; - } - - updateMeans(ptCluster, ptData); - - while(nChange > 0 && nIter < nMaxIter){ - nChange = 0; - /*reassign vectors*/ - for(i = 0; i < nN; i++){ - double dMinDist = DBL_MAX; - int nMinK = NOT_SET; - - for(k = 0; k < nK; k++){ - double dDist = calcDist(aadX[i],aadMu[k],nD); - - if(dDist < dMinDist){ - nMinK = k; - dMinDist = dDist; - } - } - - if(nMinK != anMaxZ[i]){ - int nCurr = anMaxZ[i]; - nChange++; - anW[nCurr]--; - anW[nMinK]++; - anMaxZ[i] = nMinK; - - /*check for empty clusters*/ - if(anW[nCurr] == 0){ - int nRandI = gsl_rng_uniform_int (ptGSLRNG, nN); - int nKI = 0; - /*select at random from non empty clusters*/ - - while(anW[anMaxZ[nRandI]] == 1){ - nRandI = gsl_rng_uniform_int (ptGSLRNG, nN); - } - - nKI = anMaxZ[nRandI]; - anW[nKI]--; - anW[nCurr] = 1; - anMaxZ[nRandI] = nCurr; - } - } - } - //printf("%d %d\n",nIter,nChange); - nIter++; - updateMeans(ptCluster, ptData); - } - - for(i = 0; i < nN; i++){ - for(k = 0; k < nK; k++){ - ptCluster->aadZ[i][k] = 0.0; - } - ptCluster->aadZ[i][anMaxZ[i]] = 1.0; - } - - performMStep(ptCluster, ptData); - return; -} - -/*note assuming you are using inverse W matrix*/ -double dLogWishartB(gsl_matrix *ptInvW, int nD, double dNu, int bInv) -{ - int i = 0; - double dRet = 0.0, dT = 0.0; - double dLogDet = 0.0, dD = (double) nD; - gsl_matrix* ptTemp = gsl_matrix_alloc(nD,nD); - - gsl_matrix_memcpy(ptTemp, ptInvW); - - dLogDet = decomposeMatrix(ptTemp, nD); - - if(bInv == TRUE){ - dRet = 0.5*dNu*dLogDet; - } - else{ - dRet = -0.5*dNu*dLogDet; - } - - dT = 0.5*dNu*dD*log(2.0); - - dT += 0.25*dD*(dD - 1.0)*log(M_PI); - - for(i = 0; i < nD; i++){ - dT += gsl_sf_lngamma(0.5*(dNu - (double) i)); - } - - gsl_matrix_free(ptTemp); - - return dRet - dT; -} - -double dWishartExpectLogDet(gsl_matrix *ptW, double dNu, int nD) -{ - int i = 0; - double dRet = 0.0, dLogDet = 0.0, dD = (double) nD; - gsl_matrix* ptTemp = gsl_matrix_alloc(nD,nD); - - gsl_matrix_memcpy(ptTemp, ptW); - - dLogDet = decomposeMatrix(ptW, nD); - - dRet = dD*log(2.0) + dLogDet; - - for(i = 0; i < nD; i++){ - dRet += gsl_sf_psi(0.5*(dNu - (double) i)); - } - - gsl_matrix_free(ptTemp); - - return dRet; -} - - -double dWishartEntropy(gsl_matrix *ptW, double dNu, int nD) -{ - double dRet = -dLogWishartB(ptW, nD, dNu, FALSE); - double dExpLogDet = dWishartExpectLogDet(ptW, dNu, nD); - double dD = (double) nD; - - dRet -= 0.5 * (dNu - dD - 1.0)*dExpLogDet; - - dRet += 0.5*dNu*dD; - - return dRet; -} - -double calcVBL(t_Cluster* ptCluster) -{ - int i = 0, k = 0, l = 0, nN = ptCluster->nN; - int nK = ptCluster->nK, nD = ptCluster->nD; - double dBishop1 = 0.0, dBishop2 = 0.0, dBishop3 = 0.0, dBishop4 = 0.0, dBishop5 = 0.0; /*Bishop equations 10.71...*/ - gsl_matrix *ptRes = gsl_matrix_alloc(nD,nD); - gsl_vector *ptDiff = gsl_vector_alloc(nD); - gsl_vector *ptR = gsl_vector_alloc(nD); - double dD = (double) nD; - double** aadMu = ptCluster->aadMu, **aadM = ptCluster->aadM, **aadZ = ptCluster->aadZ; - double* adBeta = ptCluster->adBeta, *adNu = ptCluster->adNu, *adLDet = ptCluster->adLDet, *adPi = ptCluster->adPi; - double adNK[nK]; - double d2Pi = 2.0*M_PI, dBeta0 = ptCluster->ptVBParams->dBeta0, dNu0 = ptCluster->ptVBParams->dNu0, dRet = 0.0; - double dK = 0.0; - - for(k = 0; k < nK; k++){ - adNK[k] = 0.0; - } - - /*Equation 10.72*/ - for(i = 0; i < nN; i++){ - for(k = 0; k < nK; k++){ - adNK[k] += aadZ[i][k]; - if(adPi[k] > 0.0){ - dBishop2 += aadZ[i][k]*log(adPi[k]); - } - } - } - - for(k = 0; k < nK; k++){ - if(adNK[k] > 0.0){ - dK++; - } - } - - /*Equation 10.71*/ - for(k = 0; k < nK; k++){ - if(adNK[k] > 0.0){ - double dT1 = 0.0, dT2 = 0.0, dF = 0.0; - - gsl_blas_dgemm (CblasNoTrans, CblasNoTrans, 1.0,ptCluster->aptCovar[k],ptCluster->aptSigma[k],0.0,ptRes); - - for(l = 0; l < nD; l++){ - dT1 += gsl_matrix_get(ptRes,l,l); - } - - for(l = 0; l < nD; l++){ - gsl_vector_set(ptDiff,l,aadMu[k][l] - aadM[k][l]); - } - - gsl_blas_dsymv (CblasLower, 1.0, ptCluster->aptSigma[k], ptDiff, 0.0, ptR); - - gsl_blas_ddot (ptDiff, ptR, &dT2); - - dF = adLDet[k] - adNu[k]*(dT1 + dT2) - dD*(log(d2Pi) + (1.0/adBeta[k])); - - dBishop1 += 0.5*adNK[k]*dF; - } - } - - /*Equation 10.74*/ - for(k = 0; k < nK; k++){ - if(adNK[k] > 0.0){ - double dT1 = 0.0, dT2 = 0.0, dF = 0.0; - - gsl_blas_dgemm (CblasNoTrans, CblasNoTrans, 1.0,ptCluster->ptVBParams->ptInvW0,ptCluster->aptSigma[k],0.0,ptRes); - - for(l = 0; l < nD; l++){ - dT1 += gsl_matrix_get(ptRes,l,l); - } - - for(l = 0; l < nD; l++){ - gsl_vector_set(ptDiff,l,aadM[k][l]); - } - - gsl_blas_dsymv (CblasLower, 1.0, ptCluster->aptSigma[k], ptDiff, 0.0, ptR); - - gsl_blas_ddot (ptDiff, ptR, &dT2); - - dF = dD*log(dBeta0/d2Pi) + adLDet[k] - ((dD*dBeta0)/adBeta[k]) - dBeta0*adNu[k]*dT2 - adNu[k]*dT1; - - dBishop3 += 0.5*(dF + (dNu0 - dD - 1.0)*adLDet[k]); - } - } - - dBishop3 += dK*ptCluster->ptVBParams->dLogWishartB; - - /*Equation 10.75*/ - for(i = 0; i < nN; i++){ - for(k = 0; k < nK; k++){ - if(aadZ[i][k] > 0.0){ - dBishop4 += aadZ[i][k]*log(aadZ[i][k]); - } - } - } - - /*Equation 10.77*/ - for(k = 0; k < nK; k++){ - if(adNK[k] > 0.0){ - dBishop5 += 0.5*adLDet[k] + 0.5*dD*log(adBeta[k]/d2Pi) - 0.5*dD - dWishartExpectLogDet(ptCluster->aptSigma[k], adNu[k], nD); - } - } - - gsl_matrix_free(ptRes); - gsl_vector_free(ptDiff); - gsl_vector_free(ptR); - - dRet = dBishop1 + dBishop2 + dBishop3 - dBishop4 - dBishop5; - - return dRet; -} - -void calcZ(t_Cluster* ptCluster, t_Data *ptData){ - double **aadX = ptData->aadX, **aadZ = ptCluster->aadZ; - int i = 0, k = 0, l = 0; - int nK = ptCluster->nK, nD = ptCluster->nD, nN = ptData->nN; - gsl_vector *ptDiff = gsl_vector_alloc(nD); - gsl_vector *ptRes = gsl_vector_alloc(nD); - double adDist[nK], dD = (double) nD; - double** aadM = ptCluster->aadM, *adPi = ptCluster->adPi; - - for(i = 0; i < nN; i++){ - double dMinDist = DBL_MAX; - double dTotalZ = 0.0; - double dNTotalZ = 0.0; - - for(k = 0; k < nK; k++){ - if(adPi[k] > 0.){ - /*set vector to data point*/ - for(l = 0; l < nD; l++){ - gsl_vector_set(ptDiff,l,aadX[i][l] - aadM[k][l]); - } - - gsl_blas_dsymv (CblasLower, 1.0, ptCluster->aptSigma[k], ptDiff, 0.0, ptRes); - - gsl_blas_ddot (ptDiff, ptRes, &adDist[k]); - - adDist[k] *= ptCluster->adNu[k]; - - adDist[k] -= ptCluster->adLDet[k]; - - adDist[k] += dD/ptCluster->adBeta[k]; - - if(adDist[k] < dMinDist){ - dMinDist = adDist[k]; - } - } - } - - for(k = 0; k < nK; k++){ - if(adPi[k] > 0.){ - aadZ[i][k] = adPi[k]*exp(-0.5*(adDist[k]-dMinDist)); - dTotalZ += aadZ[i][k]; - } - else{ - aadZ[i][k] = 0.0; - } - } - - for(k = 0; k < nK; k++){ - double dF = aadZ[i][k] / dTotalZ; - if(dF < MIN_Z){ - aadZ[i][k] = 0.0; - } - dNTotalZ += aadZ[i][k]; - } - if(dNTotalZ > 0.){ - for(k = 0; k < nK; k++){ - aadZ[i][k] /= dNTotalZ; - } - } - } - - gsl_vector_free(ptRes); - gsl_vector_free(ptDiff); - return; -} - - -void gmmTrainVB(t_Cluster *ptCluster, t_Data *ptData) -{ - int i = 0, k = 0,nIter = 0; - int nN = ptData->nN, nK = ptCluster->nK; - /*change in log-likelihood*/ - double dLastVBL = 0.0, dDelta = DBL_MAX; - double **aadZ = ptCluster->aadZ; - int nMaxIter = ptCluster->nMaxIter; - double dEpsilon = ptCluster->dEpsilon; - FILE *ofp = NULL; - - if(ptCluster->szCOutFile){ - ofp = fopen(ptCluster->szCOutFile,"w"); - if(!ofp){ - fprintf(stderr, "Failed to open file %s in gmmTrainVB\n",ptCluster->szCOutFile); - fflush(stderr); - } - } - - /*calculate data likelihood*/ - calcZ(ptCluster,ptData); - ptCluster->dVBL = calcVBL(ptCluster); - - while(nIter < nMaxIter && dDelta > dEpsilon){ - - /*update parameter estimates*/ - performMStep(ptCluster, ptData); - - /*calculate responsibilities*/ - calcZ(ptCluster,ptData); - - dLastVBL = ptCluster->dVBL; - ptCluster->dVBL = calcVBL(ptCluster); - dDelta = fabs(ptCluster->dVBL - dLastVBL); - - if(ofp){ - fprintf(ofp,"%d,%f,%f,",nIter, ptCluster->dVBL, dDelta); - for(k = 0; k < nK-1; k++){ - fprintf(ofp,"%f,",ptCluster->adPi[k]); - } - fprintf(ofp,"%f\n",ptCluster->adPi[nK - 1]); - fflush(ofp); - } - nIter++; - } - - if(ofp){ - fclose(ofp); - } - - /*assign to best clusters*/ - for(i = 0; i < nN; i++){ - double dMaxZ = aadZ[i][0]; - int nMaxK = 0; - for(k = 1; k < nK; k++){ - if(aadZ[i][k] > dMaxZ){ - nMaxK = k; - dMaxZ = aadZ[i][k]; - } - } - ptCluster->anMaxZ[i] = nMaxK; - } - - return; -} - -void writeClusters(char *szOutFile, t_Cluster *ptCluster, t_Data *ptData) -{ - int nN = ptCluster->nN, i = 0; - FILE* ofp = fopen(szOutFile,"w"); - - if(ofp){ - for(i = 0; i < nN; i++){ - fprintf(ofp,"%s,%d\n",ptData->aszSampleNames[i],ptCluster->anMaxZ[i]); - } - } - else{ - fprintf(stderr,"Failed to open %s for writing in writeClusters\n", szOutFile); - fflush(stderr); - } -} - -void writeMeans(char *szOutFile, t_Cluster *ptCluster) -{ - int nK = ptCluster->nK, nD = ptCluster->nD,i = 0, j = 0; - FILE* ofp = fopen(szOutFile,"w"); - - if(ofp){ - for(i = 0; i < nK; i++){ - for(j = 0; j < nD - 1; j++){ - fprintf(ofp,"%f,",ptCluster->aadMu[i][j]); - } - fprintf(ofp,"%f\n",ptCluster->aadMu[i][nD - 1]); - } - } - else{ - fprintf(stderr,"Failed to open %s for writing in writeMeanss\n", szOutFile); - fflush(stderr); - } -} - -void writeTMeans(char *szOutFile, t_Cluster *ptCluster, t_Data *ptData) -{ - int nK = ptCluster->nK, nD = ptCluster->nD, nT = ptData->nT, i = 0, j = 0; - FILE* ofp = fopen(szOutFile,"w"); - gsl_vector* ptVector = gsl_vector_alloc(nD); - gsl_vector* ptTVector = gsl_vector_alloc(nT); - - if(ofp){ - for(i = 0; i < nK; i++){ - for(j = 0; j < nD; j++){ - gsl_vector_set(ptVector,j,ptCluster->aadMu[i][j]); - } - - gsl_blas_dgemv (CblasNoTrans, 1.0,ptData->ptTMatrix,ptVector,0.0, ptTVector); - - for(j = 0; j < nT - 1; j++){ - fprintf(ofp,"%f,",gsl_vector_get(ptTVector,j)); - } - fprintf(ofp,"%f\n",gsl_vector_get(ptTVector,nD - 1)); - } - } - else{ - fprintf(stderr,"Failed to open %s for writing in writeMeanss\n", szOutFile); - fflush(stderr); - } - - gsl_vector_free(ptVector); - gsl_vector_free(ptTVector); -} - - - -void* fitEM(void *pvCluster) -{ - t_Cluster *ptCluster = (t_Cluster *) pvCluster; - gsl_rng *ptGSLRNG = NULL; - const gsl_rng_type *ptGSLRNGType = NULL; - - /*initialise GSL RNG*/ - ptGSLRNGType = gsl_rng_default; - ptGSLRNG = gsl_rng_alloc(ptGSLRNGType); - - gsl_rng_set (ptGSLRNG, ptCluster->lSeed); - - initKMeans(ptGSLRNG, ptCluster, ptCluster->ptData); - - gmmTrainVB(ptCluster, ptCluster->ptData); - - gsl_rng_free(ptGSLRNG); - - return NULL; -} - -void* runRThreads(void *pvpDCluster) -{ - t_Cluster **pptDCluster = (t_Cluster **) pvpDCluster; - t_Cluster *ptDCluster = (t_Cluster *) *pptDCluster; - double dBestVBL = -DBL_MAX; - t_Cluster** aptCluster = NULL; - pthread_t atRestarts[N_RTHREADS]; /*run each restart on a separate thread*/ - int iret[N_RTHREADS]; - int r = 0, nBestR = -1; - char *szCOutFile = NULL; - aptCluster = (t_Cluster **) malloc(N_RTHREADS*sizeof(t_Cluster*)); - if(!aptCluster) - goto memoryError; - - for(r = 0; r < N_RTHREADS; r++){ - if(ptDCluster->szCOutFile != NULL){ - szCOutFile = (char *) malloc(sizeof(char)*MAX_FILE_NAME_LENGTH); - sprintf(szCOutFile,"%sr%d.csv",ptDCluster->szCOutFile,r); - } - - aptCluster[r] = (t_Cluster *) malloc(sizeof(t_Cluster)); - - allocateCluster(aptCluster[r],ptDCluster->nN,ptDCluster->nK,ptDCluster->nD,ptDCluster->ptData,ptDCluster->lSeed + r*R_PRIME,ptDCluster->nMaxIter,ptDCluster->dEpsilon,szCOutFile); - aptCluster[r]->ptVBParams = ptDCluster->ptVBParams; - aptCluster[r]->nThread = r; - iret[r] = pthread_create(&atRestarts[r], NULL, fitEM, (void*) aptCluster[r]); - } - - for(r = 0; r < N_RTHREADS; r++){ - pthread_join(atRestarts[r], NULL); - } - - /*free up memory associated with input cluster*/ - free(ptDCluster); - - for(r = 0; r < N_RTHREADS; r++){ - if(aptCluster[r]->dVBL > dBestVBL){ - nBestR = r; - dBestVBL = aptCluster[r]->dVBL; - } - } - - *pptDCluster = aptCluster[nBestR]; - for(r = 0; r < N_RTHREADS; r++){ - if(r != nBestR){ - destroyCluster(aptCluster[r]); - free(aptCluster[r]); - } - } - free(aptCluster); - - return NULL; - memoryError: - fprintf(stderr, "Failed allocating memory in runRThreads\n"); - fflush(stderr); - exit(EXIT_FAILURE); -} - -void calcSampleVar(t_Data *ptData,double *adVar, double *adMu) -{ - double **aadX = ptData->aadX; - int i = 0, n = 0; - int nD = ptData->nD, nN = ptData->nN; - /*sample means*/ - double dN = (double) nN; - - for(i = 0; i < nD; i++){ - adMu[i] = 0.0; - adVar[i] = 0.0; - } - - for(i = 0; i < nD; i++){ - for(n = 0; n < nN; n++){ - adMu[i] += aadX[n][i]; - adVar[i] += aadX[n][i]*aadX[n][i]; - } - - adMu[i] /= dN; - - adVar[i] = (adVar[i] - dN*adMu[i]*adMu[i])/(dN - 1.0); - } - - return; -} - -void compressCluster(t_Cluster *ptCluster) -{ - int i = 0, k = 0, nNewK = 0, nN = ptCluster->nN; - double **aadNewZ = NULL, dN = (double) nN; - - for(i = 0; i < ptCluster->nK; i++){ - if(ptCluster->adPi[i] > 0.0){ - nNewK++; - } - } - - aadNewZ = (double **) malloc(nN*sizeof(double *)); - if(!aadNewZ) - goto memoryError; - - for(i = 0; i < nN; i++){ - aadNewZ[i] = (double *) malloc(nNewK*sizeof(double)); - if(!aadNewZ[i]) - goto memoryError; - } - - for(i = 0; i < nN; i++){ - int nC = 0; - for(k = 0; k < ptCluster->nK; k++){ - if(ptCluster->adPi[k] > 0.0){ - aadNewZ[i][nC] = ptCluster->aadZ[i][k]; - nC++; - } - } - } - - for(i = 0; i < nN; i++){ - free(ptCluster->aadZ[i]); - } - free(ptCluster->aadZ); - - /*reset Z and K*/ - ptCluster->aadZ = aadNewZ; - ptCluster->nK = nNewK; - - /*recalculate Pi*/ - for(k = 0; k < ptCluster->nK; k++){ - ptCluster->adPi[k] = 0.0; - for(i = 0; i < nN; i++){ - ptCluster->adPi[k] += ptCluster->aadZ[i][k]; - } - ptCluster->adPi[k] /= dN; - } - - /*assign to best clusters*/ - for(i = 0; i < nN; i++){ - double dMaxZ = ptCluster->aadZ[i][0]; - int nMaxK = 0; - for(k = 1; k < ptCluster->nK; k++){ - if(ptCluster->aadZ[i][k] > dMaxZ){ - nMaxK = k; - dMaxZ = ptCluster->aadZ[i][k]; - } - } - ptCluster->anMaxZ[i] = nMaxK; - } - - for(k = 0; k < ptCluster->nK; k++){ - ptCluster->anW[k] = 0; - } - - for(i = 0; i < nN; i++){ - ptCluster->anW[ptCluster->anMaxZ[i]]++; - } - - return; - - memoryError: - fprintf(stderr, "Failed allocating memory in main\n"); - fflush(stderr); - exit(EXIT_FAILURE); -} diff --git a/c-concoct/vbgmmmodule.h b/c-concoct/vbgmmmodule.h deleted file mode 100644 index 3a5144f..0000000 --- a/c-concoct/vbgmmmodule.h +++ /dev/null @@ -1,189 +0,0 @@ -#ifndef NMGS_H -#define NMGS_H - -typedef struct s_Params -{ - /*seed*/ - unsigned long int lSeed; - /*min change VBL*/ - double dEpsilon; - /*maximum no. iterations*/ - int nMaxIter; - /*csv input file*/ - char *szInputFile; - /*pca transformation*/ - char *szPInputFile; - /*output file stub*/ - const char *szOutFileStub; - /*initial cluster size*/ - int nKStart; - /*min contig length*/ - int nLMin; - /*output convergence*/ - int bConvergeOut; -} t_Params; - - -typedef struct s_Data -{ - int nN; - - int nT; - - int nD; - - gsl_matrix *ptTMatrix; - - double **aadX; - - char **aszDimNames; - - char **aszSampleNames; -} t_Data; - -typedef struct s_VBParams -{ - /*scale for mean prior*/ - double dBeta0; - - /*Wishart degrees of freedom*/ - double dNu0; - - /*Inverse! of the Wishart scale precision-matrix*/ - gsl_matrix *ptInvW0; - - /*Log Wishart normalisation*/ - double dLogWishartB; - -} t_VBParams; - - -typedef struct s_Cluster -{ - /*output file for convergence if not null*/ - char *szCOutFile; - /*parameters for variational Bayes*/ - t_VBParams *ptVBParams; - /*start seed*/ - unsigned long lSeed; - /* maximum no. iterations*/ - int nMaxIter; - /* min. change in VBL bound*/ - double dEpsilon; - /*thread index*/ - int nThread; - /*pointer to data*/ - t_Data *ptData; - /*number of data points*/ - int nN; - /*size no. of clusters allocated*/ - int nKSize; - /*number of clusters*/ - int nK; - /*number of dimensions*/ - int nD; - /*variational lower bound*/ - double dVBL; - /*Means*/ - double **aadMu; - /*Scaled weight Bishop 10.60*/ - double *adBeta; - /*Scaled means Bishop 10.61*/ - double **aadM; - /*sample covariance matrix for each cluster storing this helps with lower bound calcn*/ - gsl_matrix **aptCovar; - /*Inverse regularised variances Bishop 10.62*/ - gsl_matrix **aptSigma; - /*Bishop 10.63*/ - double *adNu; - /*Responsibilities*/ - double **aadZ; - /*log-Matrix determinants*/ - double *adLDet; - /*mixture weights*/ - double *adPi; - /*assigned cluster for each data point*/ - int *anMaxZ; - /*frequencies for each cluster*/ - int *anW; -} t_Cluster; - - -#define DELIM ",\n" -#define MAX_LINE_LENGTH 1048576 -#define MAX_FILE_NAME_LENGTH 1024 -#define MAX_WORD_LENGTH 128 - -#define TRUE 1 -#define FALSE 0 - -#define NOT_SET -1 - -/*Default parameters*/ -#define DEF_BETA0 1.0e-3 - -#define MIN_Z 1.0e-6 -#define MIN_PI 0.1 /*Unormalised*/ -#define MIN_COVAR 0.001 - -#define N_RTHREADS 10 -#define R_PRIME 1009 - -#define INPUT_FILE "PCA_transformed_data_gt" -#define PINPUT_FILE "PCA_components_data_gt" - -int driver(const char* szFileStub, int nKStart, int nLMin, unsigned long lSeed, int nMaxIter, double dEpsilon, int bCOut); - -void setParams(t_Params *ptParams,const char *szFileStub); - -void destroyParams(t_Params *ptParams); - -void setVBParams(t_VBParams *ptVBParams, t_Data *ptData); - -void readInputData(const char *szFile, t_Data *ptData); - -void readPInputData(const char *szFile, t_Data *ptData); - -void destroyData(t_Data *ptData); - -void allocateCluster(t_Cluster *ptCluster, int nN, int nK, int nD, t_Data *ptData, long lSeed, int nMaxIter, double dEpsilon, char *szCOutFile); - -void performMStep(t_Cluster *ptCluster, t_Data *ptData); - -void updateMeans(t_Cluster *ptCluster, t_Data *ptData); - -void gmmTrainVB(t_Cluster *ptCluster, t_Data *ptData); - -void initRandom(gsl_rng *ptGSLRNG, t_Cluster *ptCluster, t_Data *ptData); - -void initKMeans(gsl_rng *ptGSLRNG, t_Cluster *ptCluster, t_Data *ptData); - -double calcDist(double* adX, double *adMu, int nD); - -void calcZ(t_Cluster* ptCluster, t_Data* ptData); - -void writeClusters(char *szOutFile, t_Cluster *ptCluster, t_Data *ptData); - -void destroyCluster(t_Cluster* ptCluster); - -void* fitEM(void *pvCluster); - -void* runRThreads(void *pvpDCluster); - -void writeMeans(char *szOutFile, t_Cluster *ptCluster); - -void writeTMeans(char *szOutFile, t_Cluster *ptCluster,t_Data *ptData); - -void writeSquareMatrix(char*szFile, gsl_matrix *ptMatrix, int nD); - -void calcSampleVar(t_Data *ptData,double *adVar, double *adMu); - -double dLogWishartB(gsl_matrix *ptInvW, int nD, double dNu, int bInv); - -double calcVBL(t_Cluster* ptCluster); - -void compressCluster(t_Cluster* ptCluster); - -void calcCovarMatrices(t_Cluster *ptCluster, t_Data *ptData); - -#endif diff --git a/c-concoct/vbgmmmodule.o b/c-concoct/vbgmmmodule.o deleted file mode 100644 index d5b5132..0000000 Binary files a/c-concoct/vbgmmmodule.o and /dev/null differ diff --git a/concoct/cluster.py b/concoct/cluster.py deleted file mode 100644 index 816bc02..0000000 --- a/concoct/cluster.py +++ /dev/null @@ -1,21 +0,0 @@ -import sys -import logging - -from sklearn.mixture import GMM - -def cluster(args): - c, cv_type,inits,iters,transform_filter,random_seed= args - #Run GMM on the pca transform of contigs with kmer count greater - #than threshold - gmm = GMM(n_components=c, covariance_type=cv_type, n_init=inits, - n_iter=iters, random_state=random_seed).fit(transform_filter) - bic = gmm.bic(transform_filter) - if gmm.converged_: - logging.info("Clustering into {0} clusters converged.".format(c)) - else: - logging.warning(("Clustering into {0} clusters did not " - "converge, consider increasing the number " - "of iterations.").format(c)) - print >> sys.stderr, "Cluster {0} did not converge".format(c) - return bic, c, gmm.converged_, gmm - diff --git a/concoct/input.py b/concoct/input.py index 2823e6b..2e0c392 100644 --- a/concoct/input.py +++ b/concoct/input.py @@ -4,7 +4,7 @@ import numpy as np import pandas as p -from itertools import product, tee, izip +from itertools import product, tee from collections import Counter, OrderedDict from Bio import SeqIO @@ -141,6 +141,6 @@ def generate_feature_mapping(kmer_len): def window(seq,n): els = tee(seq,n) for i,el in enumerate(els): - for _ in xrange(i): + for _ in range(i): next(el, None) - return izip(*els) + return zip(*els) diff --git a/concoct/output.py b/concoct/output.py index 2132a08..5799d77 100644 --- a/concoct/output.py +++ b/concoct/output.py @@ -4,6 +4,7 @@ @author: Johannes Alneberg """ +from __future__ import print_function import os import sys import logging @@ -21,6 +22,7 @@ class Output(object): PCA_FILE_BASE = None PCA_COMPONENTS_FILE_BASE = None FLOAT_FORMAT = '%1.8e' + INT_FORMAT = '%d' @classmethod def __init__(self,basename,args): @@ -44,6 +46,8 @@ def __init__(self,basename,args): self.ORIGINAL_FILE_BASE = self.CONCOCT_PATH + "original_data_gt{0}.csv" self.PCA_FILE_BASE = self.CONCOCT_PATH + \ "PCA_transformed_data_gt{0}.csv" + self.ASSIGN_FILE_BASE = self.CONCOCT_PATH + \ + "clustering_gt{0}.csv" self.PCA_COMPONENTS_FILE_BASE = self.CONCOCT_PATH + \ "PCA_components_data_gt{0}.csv" self.LOG_FILE_BASE = self.CONCOCT_PATH + 'log.txt' @@ -58,12 +62,15 @@ def __init__(self,basename,args): logging.info("Results created at {0}".format( os.path.abspath(self.CONCOCT_PATH))) - print >> sys.stderr, "Up and running. Check {0} for progress".format( - os.path.abspath(self.LOG_FILE_BASE)) + + print("Up and running. Check {0} for progress".format( + os.path.abspath(self.LOG_FILE_BASE) + ), file=sys.stderr) + #Write header to bic.csv with open(self.ARGS_FILE,"w+") as fh: - print >> fh, args - + print(args, file=fh) + @classmethod def write_pca(self, transform, threshold, index): transform_df = p.DataFrame(transform, index=index) @@ -74,7 +81,17 @@ def write_pca(self, transform, threshold, index): ) logging.info('Wrote PCA transformed file.') - + @classmethod + def write_assign(self, assign, threshold, index): + transform_df = p.DataFrame(assign, index=index) + transform_df.columns=['cluster_id'] + transform_df.to_csv( + self.ASSIGN_FILE_BASE.format(threshold), + index_label="contig_id" + ) + logging.info('Wrote assign file.') + + @classmethod def write_pca_components(self, components, threshold): np.savetxt( diff --git a/concoct/parser.py b/concoct/parser.py index 1ab78d8..50ab55d 100644 --- a/concoct/parser.py +++ b/concoct/parser.py @@ -1,3 +1,4 @@ +from __future__ import print_function import os import sys from random import randint @@ -39,6 +40,10 @@ def arguments(): #Kmer length, kmer count threshold and read length parser.add_argument('-k','--kmer_length', type=int, default=4, help='specify kmer length, default 4.') + + parser.add_argument('-t','--threads', type=int, default=1, + help='Number of threads to use') + parser.add_argument('-l','--length_threshold', type=int, default=1000, help=("specify the sequence length threshold, contigs shorter than this " "value will not be included. Defaults to 1000.")) @@ -90,10 +95,10 @@ def arguments(): args = parser.parse_args() if args.debug: - print >> sys.stderr, args + print(args, file=sys.stderr) sys.exit(0) # This can be changed to an or case when input of either case is supported individually - if not (args.coverage_file or args.composition_file): + if not (args.coverage_file or args.composition_file): parser.error("No input data supplied, add file(s) using --coverage_file and/or " "--composition_file ") diff --git a/concoct/transform.py b/concoct/transform.py index 40c30d8..20e90d3 100644 --- a/concoct/transform.py +++ b/concoct/transform.py @@ -1,8 +1,8 @@ from sklearn.decomposition import PCA import pandas as p -def perform_pca(d,nc): - pca_object = PCA(n_components=nc).fit(d) +def perform_pca(d, nc, seed): + pca_object = PCA(n_components=nc, random_state=seed).fit(d) return pca_object.transform(d), pca_object def perform_split_pca(cov_d, composition, pca_components, use_pcas = None): diff --git a/doc/Dockerfile b/doc/Dockerfile deleted file mode 100644 index 5c2e0fa..0000000 --- a/doc/Dockerfile +++ /dev/null @@ -1,98 +0,0 @@ -# Docker for CONCOCT (http://github.com/BinPro/CONCOCT) v0.4.2 -# VERSION 0.4.2 -# -# This docker creates and sets up an Ubuntu environment with all -# dependencies for CONCOCT v0.4.2 installed. -# -# To login to the docker with a shared directory from the host do: -# -# sudo docker run -v /my/host/shared/directory:/my/docker/location -i -t binnisb/concoct_0.4.2 /bin/bash -# - -FROM ubuntu:13.10 -MAINTAINER CONCOCT developer group, concoct-support@lists.sourceforge.net - -ENV PATH /opt/miniconda/bin:$PATH -ENV PATH /opt/velvet_1.2.10:$PATH - -# Get basic ubuntu packages needed -RUN apt-get update -qq -RUN apt-get install -qq wget build-essential libgsl0-dev git zip unzip - -# Set up Miniconda environment for python2 -RUN cd /opt;\ - wget http://repo.continuum.io/miniconda/Miniconda-3.3.0-Linux-x86_64.sh -O miniconda.sh;\ - chmod +x miniconda.sh;\ - ./miniconda.sh -p /opt/miniconda -b;\ - conda update --yes conda;\ - conda install --yes python=2.7 - -# Velvet for assembly -RUN apt-get install -qq zlib1g-dev -RUN cd /opt;\ - wget www.ebi.ac.uk/~zerbino/velvet/velvet_1.2.10.tgz -O velvet.tgz;\ - tar xf velvet.tgz;\ - cd velvet_1.2.10;\ - sed -i "s/MAXKMERLENGTH=31/MAXKMERLENGTH=128/" Makefile ;\ - make - -# Bedtools2.17 -RUN apt-get install -qq bedtools - -# Picard tools 1.118 -# To get fuse to work, I need the following (Issue here: https://github.com/dotcloud/docker/issues/514, -# solution here: https://gist.github.com/henrik-muehe/6155333). -ENV MRKDUP /opt/picard-tools-1.118/MarkDuplicates.jar -RUN apt-get install -qq libfuse2 openjdk-7-jre-headless -RUN cd /tmp ; apt-get download fuse -RUN cd /tmp ; dpkg-deb -x fuse_* . -RUN cd /tmp ; dpkg-deb -e fuse_* -RUN cd /tmp ; rm fuse_*.deb -RUN cd /tmp ; echo -en '#!/bin/bash\nexit 0\n' > DEBIAN/postinst -RUN cd /tmp ; dpkg-deb -b . /fuse.deb -RUN cd /tmp ; dpkg -i /fuse.deb -RUN cd /opt;\ - wget "http://downloads.sourceforge.net/project/picard/picard-tools/1.118/picard-tools-1.118.zip?r=http%3A%2F%2Fsourceforge.net%2Fprojects%2Fpicard%2Ffiles%2Fpicard-tools%2F1.118%2F&ts=1396879817&use_mirror=freefr" -O picard-tools-1.118.zip;\ - unzip picard-tools-1.118.zip - -# Samtools 0.1.19 -RUN apt-get install -qq samtools - -# Bowtie2.1.0 -RUN apt-get install -qq bowtie2 - -# Parallel 20130622-1 -RUN apt-get install -qq parallel - - - -# Install prodigal 2.60 -RUN cd /opt;\ - wget --no-check-certificate https://prodigal.googlecode.com/files/Prodigal-2.60.tar.gz;\ - tar xf Prodigal-2.60.tar.gz;\ - cd Prodigal-2.60;\ - make;\ - ln -s /opt/Prodigal-2.60/prodigal /bin/prodigal - -# Install R -RUN apt-get install -qq r-base - -# Install R packages -RUN cd /opt;\ - RREPO='"http://cran.rstudio.com/"';\ - printf "install.packages(\"ggplot2\", repo=$RREPO)\ninstall.packages(\"reshape\",repo=$RREPO)\ninstall.packages(\"gplots\",repo=$RREPO)\ninstall.packages(\"ellipse\",repo=$RREPO)\ninstall.packages(\"grid\",repo=$RREPO)\ninstall.packages(\"getopt\",repo=$RREPO)" > dep.R;\ - Rscript dep.R - -# Install python dependencies and fetch and install CONCOCT 0.4.2 -RUN cd /opt;\ - conda update --yes conda;\ - conda install --yes python=2.7 atlas cython numpy scipy biopython pandas pip scikit-learn pysam;\ - pip install bcbio-gff;\ - wget --no-check-certificate https://github.com/BinPro/CONCOCT/archive/0.4.2.tar.gz;\ - tar xf 0.4.2.tar.gz;\ - cd CONCOCT-0.4.2;\ - python setup.py install - -ENV CONCOCT /opt/CONCOCT-0.4.2 -ENV CONCOCT_TEST /opt/Data/CONCOCT-test-data -ENV CONCOCT_EXAMPLE /opt/Data/CONCOCT-complete-example diff --git a/doc/source/complete_example.rst b/doc/source/complete_example.rst index a580bba..747f27a 100644 --- a/doc/source/complete_example.rst +++ b/doc/source/complete_example.rst @@ -1,4 +1,4 @@ -Complete Example V0.4 +Complete Example V1.0 ===================== We'd like to here give you a complete example walk through. However, the diff --git a/doc/source/conf.py b/doc/source/conf.py index 13a5d26..c65ba27 100644 --- a/doc/source/conf.py +++ b/doc/source/conf.py @@ -58,17 +58,17 @@ master_doc = 'index' # General information about the project. -project = u'CONCOCT' -copyright = u'2014, Johannes Alneberg, Brynjar Smari Bjarnason, Ino de Bruijn, Melanie Schirmer, Joshua Quick, Umer Z. Ijaz, Nicholas J. Loman, Anders F. Andersson, Christopher Quince' +project = 'CONCOCT' +copyright = '2014, Johannes Alneberg, Brynjar Smari Bjarnason, Ino de Bruijn, Melanie Schirmer, Joshua Quick, Umer Z. Ijaz, Nicholas J. Loman, Anders F. Andersson, Christopher Quince' # The version info for the project you're documenting, acts as replacement for # |version| and |release|, also used in various other places throughout the # built documents. # # The short X.Y version. -version = '0.4' +version = '1.0' # The full version, including alpha/beta/rc tags. -release = '0.4.2' +release = '1.0.0' # The language for content autogenerated by Sphinx. Refer to documentation # for a list of supported languages. @@ -211,8 +211,8 @@ # (source start file, target name, title, # author, documentclass [howto, manual, or own class]). latex_documents = [ - ('index', 'CONCOCT.tex', u'CONCOCT Documentation', - u'Johannes Alneberg, Brynjar Smari Bjarnason, Ino de Bruijn, Melanie Schirmer, Joshua Quick, Umer Z. Ijaz, Nicholas J. Loman, Anders F. Andersson, Christopher Quince', 'manual'), + ('index', 'CONCOCT.tex', 'CONCOCT Documentation', + 'Johannes Alneberg, Brynjar Smari Bjarnason, Ino de Bruijn, Melanie Schirmer, Joshua Quick, Umer Z. Ijaz, Nicholas J. Loman, Anders F. Andersson, Christopher Quince', 'manual'), ] # The name of an image file (relative to this directory) to place at the top of @@ -241,8 +241,8 @@ # One entry per manual page. List of tuples # (source start file, name, description, authors, manual section). man_pages = [ - ('index', 'concoct', u'CONCOCT Documentation', - [u'Johannes Alneberg, Brynjar Smari Bjarnason, Ino de Bruijn, Melanie Schirmer, Joshua Quick, Umer Z. Ijaz, Nicholas J. Loman, Anders F. Andersson, Christopher Quince'], 1) + ('index', 'concoct', 'CONCOCT Documentation', + ['Johannes Alneberg, Brynjar Smari Bjarnason, Ino de Bruijn, Melanie Schirmer, Joshua Quick, Umer Z. Ijaz, Nicholas J. Loman, Anders F. Andersson, Christopher Quince'], 1) ] # If true, show URL addresses after external links. @@ -255,8 +255,8 @@ # (source start file, target name, title, author, # dir menu entry, description, category) texinfo_documents = [ - ('index', 'CONCOCT', u'CONCOCT Documentation', - u'Johannes Alneberg, Brynjar Smari Bjarnason, Ino de Bruijn, Melanie Schirmer, Joshua Quick, Umer Z. Ijaz, Nicholas J. Loman, Anders F. Andersson, Christopher Quince', 'CONCOCT', 'One line description of project.', + ('index', 'CONCOCT', 'CONCOCT Documentation', + 'Johannes Alneberg, Brynjar Smari Bjarnason, Ino de Bruijn, Melanie Schirmer, Joshua Quick, Umer Z. Ijaz, Nicholas J. Loman, Anders F. Andersson, Christopher Quince', 'CONCOCT', 'One line description of project.', 'Miscellaneous'), ] diff --git a/doc/source/installation.rst b/doc/source/installation.rst index 0f0674a..039d5ee 100644 --- a/doc/source/installation.rst +++ b/doc/source/installation.rst @@ -9,23 +9,42 @@ Fundamental dependencies :: - python v2.7.* - gcc - gsl + python version 2.7 or version 3 + gcc - C compiler + gsl - GNU Scientific Library + gslcblas - GNU Scientific Library BLAS library + gomp - GNU OpenMP implementation + These items are prerequisities for the installation of concoct as described below. The installation procedure varies on different systems, and described in this README is only how to proceed with a linux (ubuntu) distribution. -The first item, ``python v2.7.*``, should be installed on a modern -Ubuntu distribution. A c-compiler, e.g. ``gcc``, is needed to compile +We recommend using miniconda to install python. +A c-compiler, e.g. ``gcc``, is needed to compile the c parts of concoct that uses the GNU Scientific Library ``gsl``. For linux (ubuntu) this is installed through: :: - apt-get install build-essential libgsl0-dev + apt-get install build-essential libgsl0-dev libgomp1 + +Making it work on Mac OSX +~~~~~~~~~~~~~~~~~~~~~~~~~ +A bit of a hack. You have been warned: + +:: + + conda install llvm gcc libgcc pip + export CC=/Users/johannes.alneberg/miniconda3/envs/concoct_py3/bin/gcc + export CXX=/Users/johannes.alneberg/miniconda3/envs/concoct_py3/bin/g++ + conda install gsl + pip install -r requirements.txt + unset CC + unset CXX + pip install pysam + Python packages ~~~~~~~~~~~~~~~ diff --git a/doc/source/scripts/dnadiff_dist_matrix.rst b/doc/source/scripts/dnadiff_dist_matrix.rst index eecf468..23fafe2 100644 --- a/doc/source/scripts/dnadiff_dist_matrix.rst +++ b/doc/source/scripts/dnadiff_dist_matrix.rst @@ -21,6 +21,7 @@ This results in the following output files in the folder ``test_dnadiff_out/``: - ``dist_matrix.stv`` The distance matrix - ``fasta_names.tsv`` The names given to each bin (or fasta file) + - ``clustering.tsv`` This file will give a cluster assignment for each bin (or fasta file) - :download:`hcust_dendrogram.pdf <../_static/scripts/dna_diff_dist_matrix/hclust_dendrogram.pdf>` Dendrogram of the clustering (click for example) - :download:`hcust_heatmap.pdf <../_static/scripts/dna_diff_dist_matrix/hclust_heatmap.pdf>` diff --git a/requirements.txt b/requirements.txt index d5f1e1c..90b6bbe 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,12 +1,11 @@ argparse>=1.2.1 bcbio-gff>=0.4 biopython>=1.63 -distribute>=0.6.49 nose>=1.3.0 numpy>=1.8.0 pandas>=0.13.0 -pysam>=0.7.7 python-dateutil>=2.2 pytz>=2013.9 scikit-learn>=0.14.1 scipy>=0.13.3 +cython>=0.28.5 diff --git a/scripts/COG_table.py b/scripts/COG_table.py index fe6a108..0d950ad 100755 --- a/scripts/COG_table.py +++ b/scripts/COG_table.py @@ -161,7 +161,10 @@ def main(args): seq_cov_above_threshold = percent_seq_covered >= RPSBLAST_SCOVS_THRESHOLD if pident_above_threshold and seq_cov_above_threshold: - cog_accession = cogrecords[record_d['sseqid'].split('|')[2]]['Accession'] + thisacc = record_d['sseqid'].split('|')[2] + cog_accession = 'unknown' + if thisacc in cogrecords: + cog_accession = cogrecords[thisacc]['Accession'] if args.gfffile: contig = featureid_locations[record_d['qseqid']] else: @@ -177,7 +180,7 @@ def main(args): markers.sort() # print header - print "\t".join(["Cluster", "Contigs", "Num_contigs"] + markers) + print("\t".join(["Cluster", "Contigs", "Num_contigs"] + markers)) # Per cluster, count the number of features for cluster in clusters: @@ -192,7 +195,7 @@ def main(args): if feature == marker: count += 1 counts.append(str(count)) - print "\t".join(counts) + print("\t".join(counts)) if __name__ == "__main__": parser = argparse.ArgumentParser(usage=usage()) diff --git a/scripts/Sort.pl b/scripts/Sort.pl new file mode 100755 index 0000000..0e628e9 --- /dev/null +++ b/scripts/Sort.pl @@ -0,0 +1,18 @@ +#!/usr/bin/perl + +my $line = ; + +print "$line"; + +my %hashLines = (); +while($line = ){ + chomp($line); + + my @tokens = split(/,/,$line); + + $hashLines{$tokens[0]} = $line; +} + +foreach $key (sort {$a <=> $b} keys %hashLines){ + print "$hashLines{$key}\n"; +} diff --git a/scripts/bam_to_linkage.py b/scripts/bam_to_linkage.py index b2847d5..969b787 100755 --- a/scripts/bam_to_linkage.py +++ b/scripts/bam_to_linkage.py @@ -173,7 +173,7 @@ def parse_linkage_info_bam(bamfile, readlength, min_contig_length, regionlength, # Remove default generators linkdict.default_factory = None - for v in linkdict.itervalues(): + for v in linkdict.values(): v.default_factory = None read_count_dict.default_factory = None @@ -221,15 +221,15 @@ def print_linkage_info(linkdict, read_count_dict, samplenames): where n represents sample name. Number of columns is thus 2 + 6 * n. """ # Header - print ("%s\t%s" + "\t%s" * len(samplenames)) % (("contig1", "contig2") + + print(("%s\t%s" + "\t%s" * len(samplenames)) % (("contig1", "contig2") + tuple(["nr_links_inward_%s\tnr_links_outward_%s\tnr_links_inline_%s\tnr_links_inward_or_outward_%s\t" - "read_count_contig1_%s\tread_count_contig2_%s" % ((s,) * 6) for s in samplenames])) + "read_count_contig1_%s\tread_count_contig2_%s" % ((s,) * 6) for s in samplenames]))) # Content - allcontigs = tuple(set([k for k in linkdict[s].keys() for s in samplenames])) + allcontigs = tuple(set([k for k in list(linkdict[s].keys()) for s in samplenames])) for c in allcontigs: - for c2 in set([k for k in linkdict[s][c].keys() for s in samplenames]): - print get_string_link_row(linkdict, read_count_dict, samplenames, c, c2) + for c2 in set([k for k in list(linkdict[s][c].keys()) for s in samplenames]): + print(get_string_link_row(linkdict, read_count_dict, samplenames, c, c2)) def parallel_get_linkage(bamfiles, readlength, min_contig_length, regionlength, max_n_cores, fullsearch): @@ -308,14 +308,12 @@ def main(fastafile, bamfiles, samplenames, readlength, min_contig_length, region if args.samplenames is not None: samplenames = [s[:-1] for s in open(args.samplenames).readlines()] if len(samplenames) != len(args.bamfiles): - raise(Exception("Nr of names in samplenames should be equal to nr " - "of given bamfiles")) + raise Exception else: samplenames = [str(i) for i in range(len(args.bamfiles))] for bf in args.bamfiles: if not os.path.isfile(bf + ".bai"): - raise(Exception("No index for %s file found, run samtools index " - "first on bam file." % bf)) + raise Exception main(args.fastafile, args.bamfiles, samplenames, args.readlength, args.mincontiglength, args.regionlength, args.max_n_cores, args.fullsearch) diff --git a/scripts/concoct_coverage_table.py b/scripts/concoct_coverage_table.py new file mode 100755 index 0000000..3c49b35 --- /dev/null +++ b/scripts/concoct_coverage_table.py @@ -0,0 +1,77 @@ +#!/usr/bin/env python +""" +A script to generate the input coverage table for CONCOCT using a BEDFile. + +Output is written to stdout. The BEDFile defines the regions used as +subcontigs for concoct. This makes it possible to get the coverage for +subcontigs without specifically mapping reads against the subcontigs. + +@author: inodb, alneberg +""" +from __future__ import print_function +import sys +import os +import argparse +import subprocess +import glob +from signal import signal, SIGPIPE, SIG_DFL +import pandas as pd + +def generate_input_table(bedfile, bamfiles, samplenames=None): + """Reads input files into dictionaries then prints everything in the table + format required for running CONCOCT.""" + + p = subprocess.Popen(["samtools", "bedcov", bedfile] + bamfiles, stdout=subprocess.PIPE) + + out, err = p.communicate() + if p.returncode != 0: + sys.stderr.write(out) + sys.stderr.write(err) + raise Exception('Error with running samtools bedcov') + else: + # Header + if samplenames == None: + # Use index if no sample names given in header + col_names = [os.path.splitext(os.path.basename(bamfile))[0] for bamfile in bamfiles] + else: + # Use given sample names in header + col_names = samplenames + header=["cov_mean_sample_{}".format(n) for n in col_names] + + # Content + if sys.version_info[0] < 3: + from StringIO import StringIO + else: + from io import StringIO + + fh = StringIO(out.decode('utf-8')) + df = pd.read_table(fh, header=None) + avg_coverage_depth = df[df.columns[4:]].divide((df[2]-df[1]), axis=0) + avg_coverage_depth.index = df[3] + avg_coverage_depth.columns = header + avg_coverage_depth.to_csv(sys.stdout, index_label='contig', sep='\t', float_format='%.3f') + +if __name__ == "__main__": + parser = argparse.ArgumentParser(description=__doc__) + parser.add_argument("bedfile", help="Contigs BEDFile with four columns representing: 'Contig ID, Start Position, " + "End Position and SubContig ID' respectively. The Subcontig ID is usually the same as the Contig ID for contigs " + "which are not cutup. This file can be generated by the cut_up_fasta.py script.") + parser.add_argument("bamfiles", nargs='+', help="BAM files with mappings to the original contigs.") + parser.add_argument("--samplenames", default=None, help="File with sample names, one line each. Should be same nr " + "of bamfiles. Default sample names used are the file names of the bamfiles, excluding the file extension.") + args = parser.parse_args() + + # Get sample names + if args.samplenames != None: + samplenames = [ s[:-1] for s in open(args.samplenames).readlines() ] + if len(samplenames) != len(args.bamfiles): + raise Exception("Nr of names ({0}) in samplenames should be equal to nr of given " + "bamfiles ({1})".format(len(samplenames), len(args.bamfiles))) + else: + samplenames=None + + # ignore broken pipe error when piping output + # http://newbebweb.blogspot.pt/2012/02/python-head-ioerror-errno-32-broken.html + signal(SIGPIPE,SIG_DFL) + + generate_input_table(args.bedfile, args.bamfiles, samplenames=samplenames) diff --git a/scripts/contig_read_count_per_genome.py b/scripts/contig_read_count_per_genome.py index 0c6af08..f2924fe 100755 --- a/scripts/contig_read_count_per_genome.py +++ b/scripts/contig_read_count_per_genome.py @@ -80,11 +80,11 @@ def count_contigs_per_genome(bamfile, count_dict, multi_align_tag='XS'): def print_count_dict(count_dict, column_header): - print ("contig" + "\t%s" * len(column_header)) % tuple(column_header) + print(("contig" + "\t%s" * len(column_header)) % tuple(column_header)) for contig in count_dict: - print ("%s" + "\t%i" * len(column_header)) % tuple([contig] + \ - [count_dict[contig][ch] for ch in column_header]) + print(("%s" + "\t%i" * len(column_header)) % tuple([contig] + \ + [count_dict[contig][ch] for ch in column_header])) def parallel_count_contigs_per_genome(args): @@ -131,7 +131,6 @@ def main(contigfa, reffa, bamfiles, max_n_processors): for bf in args.bamfiles: if not os.path.isfile(bf + ".bai"): - raise(Exception("No index for %s file found, run samtools index " - "first on bam file." % bf)) + raise Exception main(args.contigfa, args.reffa, args.bamfiles, args.max_n_processors) diff --git a/scripts/cut_up_fasta.py b/scripts/cut_up_fasta.py index 90f7b39..0b48f3c 100755 --- a/scripts/cut_up_fasta.py +++ b/scripts/cut_up_fasta.py @@ -1,21 +1,35 @@ #!/usr/bin/env python """Cut up fasta file in non-overlapping or overlapping parts of equal length. + +Optionally creates a BED-file where the cutup contigs are specified in terms +of the original contigs. This can be used as input to concoct_coverage_table.py. """ +from __future__ import print_function import argparse from Bio import SeqIO -def cut_up_fasta(fastfiles, chunk_size, overlap, merge_last): +def cut_up_fasta(fastfiles, chunk_size, overlap, merge_last, bedoutfile): + if bedoutfile: + bedoutfile_fh = open(bedoutfile, 'w') for ff in fastfiles: for record in SeqIO.parse(ff, "fasta"): if (not merge_last and len(record.seq) > chunk_size) or (merge_last and len(record.seq) >= 2 * chunk_size): i = 0 for split_seq in chunks(record.seq, chunk_size, overlap, merge_last): - print ">%s.%i\n%s" % (record.id, i, split_seq) + print(">%s.%i\n%s" % (record.id, i, split_seq)) + if bedoutfile: + print("{0}\t{2}\t{3}\t{0}.{1}".format(record.id, i, chunk_size*i, chunk_size*i+len(split_seq)), + file=bedoutfile_fh) i = i + 1 else: - print ">%s\n%s" % (record.id, record.seq) + print(">%s\n%s" % (record.id, record.seq)) + if bedoutfile: + print("{0}\t0\t{1}\t{0}".format(record.id, len(record.seq)), + file=bedoutfile_fh) + if bedoutfile: + bedoutfile_fh.close() def chunks(l, n, o, merge_last): """ Yield successive n-sized chunks from l with given overlap o between the @@ -24,10 +38,10 @@ def chunks(l, n, o, merge_last): assert n > o if not merge_last: - for i in xrange(0, len(l), n - o): + for i in range(0, len(l), n - o): yield l[i:i + n] else: - for i in xrange(0, len(l) - n + 1, n - o): + for i in range(0, len(l) - n + 1, n - o): yield l[i:i + n] if i + n + n - o <= len(l) else l[i:] @@ -39,5 +53,7 @@ def chunks(l, n, o, merge_last): parser.add_argument("-c", "--chunk_size", default=1999, type=int, help="Chunk size\n") parser.add_argument("-o", "--overlap_size", default=1900, type=int, help="Overlap size\n") parser.add_argument("-m", "--merge_last", default=False, action="store_true", help="Concatenate final part to last contig\n") + parser.add_argument("-b", "--bedfile", default=None, help="BEDfile to be created with exact regions of the original" + " contigs corresponding to the newly created contigs") args = parser.parse_args() - cut_up_fasta(args.contigs, args.chunk_size, args.overlap_size, args.merge_last) + cut_up_fasta(args.contigs, args.chunk_size, args.overlap_size, args.merge_last, args.bedfile) diff --git a/scripts/dnadiff_dist_matrix.py b/scripts/dnadiff_dist_matrix.py index 41e0ec2..7079a22 100755 --- a/scripts/dnadiff_dist_matrix.py +++ b/scripts/dnadiff_dist_matrix.py @@ -25,7 +25,8 @@ A hierarchical clustering of the distance using euclidean average linkage clustering is plotted. This can be deactivated by using --skip_plot. The resulting heatmap is in output_folder/hclust_heatmap.pdf or -output_folder/hclust_dendrogram.pdf. The image extension can be changed. +output_folder/hclust_dendrogram.pdf and the resulting clustering is presented +in output_folder/clustering.tsv. The image extension can be changed. """ import argparse import subprocess @@ -101,7 +102,7 @@ def run_dnadiff_star(args): except CmdException as e: # Custom CmdException doesn't work well with multiprocessing so change # to regular Exception http://bugs.python.org/issue16558 - raise(Exception(str(e))) + raise Exception def run_dnadiff_pairwise(fasta_files, fasta_names, output_folder): @@ -155,7 +156,7 @@ def get_dist_matrix(pairwise_folder, fasta_names, min_coverage): return matrix -def plot_dist_matrix(matrix, fasta_names, heatmap_out, dendrogram_out): +def plot_dist_matrix(matrix, fasta_names, heatmap_out, dendrogram_out, cluster_threshold, clustering_out): """Cluster the distance matrix hierarchically and plot using seaborn. Average linkage method is used.""" # Load required modules for plotting @@ -164,14 +165,21 @@ def plot_dist_matrix(matrix, fasta_names, heatmap_out, dendrogram_out): import matplotlib.pyplot as plt import seaborn as sns import pandas as pd - from scipy.cluster.hierarchy import dendrogram, linkage + from scipy.cluster.hierarchy import dendrogram, linkage, fcluster # Create pdm = pd.DataFrame(matrix, index=fasta_names, columns=fasta_names) + # Create linkage clustering + link = linkage(pdm, metric='euclidean', method='average') + flat_clusters = fcluster(link, cluster_threshold, criterion='distance') + + clustering = pd.Series(dict(list(zip(fasta_names, flat_clusters)))) + clustering.to_csv(clustering_out, sep='\t') + # Plot heatmap figsizex = max(10, len(fasta_names) / 4) - clustergrid = sns.clustermap(pdm, metric='euclidean', method='average', + clustergrid = sns.clustermap(pdm, col_linkage=link, row_linkage=link, figsize=(figsizex, figsizex)) clustergrid.savefig(heatmap_out) @@ -179,7 +187,6 @@ def plot_dist_matrix(matrix, fasta_names, heatmap_out, dendrogram_out): sns.set_style('white') figsizey = max(10, len(fasta_names) / 8) f, ax = plt.subplots(figsize=(figsizex, figsizey)) - link = linkage(pdm, metric='euclidean', method='average') dendrogram(link, labels=pdm.index, ax=ax) no_spine = {'left': True, 'bottom': True, 'right': True, 'top': True} sns.despine(**no_spine) @@ -221,6 +228,8 @@ def parse_input(): "plotting the distance matrix. By default the distance matrix is " "clustered hierarchically using euclidean average linkage clustering. " "This step requires seaborn and scipy.") + parser.add_argument("--cluster-threshold", type=float, default=0.05, + help=("The maximum within cluster distance allowed.")) args = parser.parse_args() # Get fasta names if args.fasta_names is not None: @@ -242,7 +251,7 @@ def parse_input(): return args.output_folder, args.fasta_files, fasta_names, \ args.min_coverage, args.skip_dnadiff, args.skip_matrix, \ - args.skip_plot, args.plot_image_extension + args.skip_plot, args.plot_image_extension, args.cluster_threshold def verbose_check_dependencies(progs): @@ -251,12 +260,12 @@ def verbose_check_dependencies(progs): if path: logging.info("Using {}".format(path)) else: - raise(Exception("{} not installed".format(p))) + raise Exception def main(output_folder, fasta_files, fasta_names, min_coverage, skip_dnadiff=False, skip_matrix=False, skip_plot=False, - plot_image_extension="pdf"): + plot_image_extension="pdf", cluster_threshold=0.05): """Output distance matrix between fasta files using MUMmer's dnadiff""" # create logger logging.basicConfig( @@ -291,7 +300,10 @@ def main(output_folder, fasta_files, fasta_names, min_coverage, ospj(output_folder, "hclust_heatmap.{}".format(plot_image_extension)), ospj(output_folder, - "hclust_dendrogram.{}".format(plot_image_extension))) + "hclust_dendrogram.{}".format(plot_image_extension)), + cluster_threshold, + ospj(output_folder, + "clustering.tsv")) else: logging.info("Skipping plotting") logging.info("Writing fasta names of fasta files to " diff --git a/scripts/evaluation/gen_input_table_taxonomy.py b/scripts/evaluation/gen_input_table_taxonomy.py index 4a308fd..dfd8c73 100755 --- a/scripts/evaluation/gen_input_table_taxonomy.py +++ b/scripts/evaluation/gen_input_table_taxonomy.py @@ -179,7 +179,7 @@ def get_taxonomy_dict(taxonomyfile): # Genus, Species. assert(len(cols) == len(TAXONOMY) + 1) - outdict[cols[0]] = dict(zip(TAXONOMY, cols[1:-1] + [cols[-1].rstrip('\n')])) + outdict[cols[0]] = dict(list(zip(TAXONOMY, cols[1:-1] + [cols[-1].rstrip('\n')]))) return outdict diff --git a/scripts/extract_fasta_bins.py b/scripts/extract_fasta_bins.py index 58a5c18..0b1de09 100755 --- a/scripts/extract_fasta_bins.py +++ b/scripts/extract_fasta_bins.py @@ -15,13 +15,14 @@ def main(args): all_seqs = {} for i, seq in enumerate(SeqIO.parse(args.fasta_file, "fasta")): all_seqs[seq.id] = seq - df = pd.read_csv(args.cluster_file, header=None, names=["contig_id", "cluster_id"]) - + df = pd.read_csv(args.cluster_file) + df.columns = ['contig_id', 'cluster_id'] + cluster_to_contigs = defaultdict(list) for i, row in df.iterrows(): cluster_to_contigs[row['cluster_id']].append(row['contig_id']) - for cluster_id, contig_ids in cluster_to_contigs.iteritems(): + for cluster_id, contig_ids in cluster_to_contigs.items(): output_file = os.path.join(args.output_path, "{0}.fa".format(cluster_id)) seqs = [all_seqs[contig_id] for contig_id in contig_ids] with open(output_file, 'w') as ofh: diff --git a/scripts/extract_scg_bins.py b/scripts/extract_scg_bins.py index 29013aa..db5bea5 100755 --- a/scripts/extract_scg_bins.py +++ b/scripts/extract_scg_bins.py @@ -27,10 +27,10 @@ def get_approved_bins(scg_tsv, max_missing_scg, max_multicopy_scg): with COG_table.py""" scgdf = pd.read_csv(scg_tsv, sep="\t") # number of multicopy genes - multi_scgs = scgdf.iloc[:, range(3, len(scgdf.columns))] \ + multi_scgs = scgdf.iloc[:, list(range(3, len(scgdf.columns)))] \ .apply(lambda x: x > 1).sum(axis=1) # number of missing scgs - miss_scgs = scgdf.iloc[:, range(3, len(scgdf.columns))] \ + miss_scgs = scgdf.iloc[:, list(range(3, len(scgdf.columns)))] \ .apply(lambda x: x == 0).sum(axis=1) app_bins = scgdf[(miss_scgs <= max_missing_scg) & (multi_scgs <= max_multicopy_scg)].loc[:, ["Cluster", "Contigs"]] @@ -114,13 +114,11 @@ def parse_input(): args = parser.parse_args() if not (len(args.names) == len(args.scg_tsvs) and len(args.scg_tsvs) == len(args.fasta_files)): - raise(Exception("Should have equal number of scg_tsvs, fasta_files " - "and names")) + raise Exception if args.groups and len(args.groups) != len(args.names): - raise(Exception("Should have equal number of --groups as scg_tsvs, " - "fasta_files and names")) + raise Exception if len(args.names) != len(set(args.names)): - raise(Exception("--names should be unique names")) + raise Exception return args @@ -162,7 +160,7 @@ def main(args): ) if args.groups: group_indices = {g:[i for i, j in enumerate(args.groups) if j == g] for g in args.groups} - for g, indices in group_indices.iteritems(): + for g, indices in group_indices.items(): logging.info("Selecting best SCG clustering for group " "{}".format(g)) select_and_write_approved_bins(args.output_folder, [args.scg_tsvs[i] for i in indices], diff --git a/scripts/fasta_to_features.py b/scripts/fasta_to_features.py index 7997647..259f2a0 100755 --- a/scripts/fasta_to_features.py +++ b/scripts/fasta_to_features.py @@ -6,14 +6,14 @@ # optimized sliding window function from # http://stackoverflow.com/a/7636587 -from itertools import tee, izip +from itertools import tee def window(seq,n): els = tee(seq,n) for i,el in enumerate(els): - for _ in xrange(i): + for _ in range(i): next(el, None) - return izip(*els) + return zip(*els) def generate_feature_mapping(kmer_len): BASE_COMPLEMENT = {"A":"T","T":"A","G":"C","C":"G"} @@ -36,7 +36,7 @@ def generate_features_from_fasta(fasta_file,nr_datapoints,kmer_len,outfile): contigs_id = [] for i,seq in enumerate(seqs): contigs_id.append(seq.id) - for kmer_tuple in window(seq.seq.tostring().upper(),kmer_len): + for kmer_tuple in window(str(seq.seq).upper(),kmer_len): contigs[i,kmer_dict["".join(kmer_tuple)]] += 1 df = pd.DataFrame(contigs,index=contigs_id) df.to_csv(outfile) diff --git a/scripts/features_to_pca.py b/scripts/features_to_pca.py index 6d0c168..ab1ddfd 100755 --- a/scripts/features_to_pca.py +++ b/scripts/features_to_pca.py @@ -1,5 +1,5 @@ #!/usr/bin/env python -from __future__ import division + import cv2 import pandas as pd import numpy as np @@ -11,7 +11,7 @@ def pca_signatures(signature_file): contigs = contigs.as_matrix() contigs += 1 log_contigs = np.log(contigs / contigs.sum(axis=1,keepdims=True)) - print (log_contigs > 0).any() + print((log_contigs > 0).any()) df_log_contigs = pd.DataFrame(log_contigs,index=contigs_idx) df_log_contigs.to_csv(signature_file+".log") pca = cv2.PCACompute(log_contigs,np.mean(log_contigs,axis=0).reshape((-1,1))) @@ -21,4 +21,4 @@ def pca_signatures(signature_file): import sys signature_file = sys.argv[1] pca_results = pca_signatures(signature_file) - print pca_results + print(pca_results) diff --git a/scripts/gen_input_table.py b/scripts/gen_input_table.py index 0462d7b..88173ba 100755 --- a/scripts/gen_input_table.py +++ b/scripts/gen_input_table.py @@ -8,7 +8,7 @@ import subprocess import errno from signal import signal, SIGPIPE, SIG_DFL - +import gzip from Bio import SeqIO def get_gc_and_len_dict(fastafile): @@ -16,17 +16,23 @@ def get_gc_and_len_dict(fastafile): for the inner dictionary.""" out_dict = {} - for rec in SeqIO.parse(fastafile, "fasta"): - out_dict[rec.id] = {} - out_dict[rec.id]["length"] = len(rec.seq) - + if fastafile.endswith('.gz'): + with gzip.open(fastafile) as fhandle: + for rec in SeqIO.parse(fhandle, "fasta"): + out_dict[rec.id] = {} + out_dict[rec.id]["length"] = len(rec.seq) + else: + with open(fastafile) as fhandle: + for rec in SeqIO.parse(fhandle, "fasta"): + out_dict[rec.id] = {} + out_dict[rec.id]["length"] = len(rec.seq) return out_dict def get_bedcov_dict(bedcoverage): """Uses the BEDTools genomeCoverageBed histogram output to determine mean coverage and percentage covered for each contig. - + Returns dict with fasta id as key and percentage covered and cov_mean as keys for the inner dictionary.""" out_dict = {} @@ -36,10 +42,11 @@ def get_bedcov_dict(bedcoverage): if os.path.isfile(bedcoverage): fh = open(bedcoverage) else: + bedcoverage = bedcoverage.decode('utf-8') fh = bedcoverage.split('\n')[:-1] for line in fh: - cols = line.split() + cols = line.split('\t') try: d = out_dict[cols[0]] @@ -99,7 +106,7 @@ def generate_input_table(fastafile, bamfiles, samplenames=None, isbedfiles=False """Reads input files into dictionaries then prints everything in the table format required for running ProBin.""" bedcovdicts = [] - + # Determine coverage information from bam file using BEDTools for i, bf in enumerate(bamfiles): if isbedfiles == False: @@ -112,7 +119,7 @@ def generate_input_table(fastafile, bamfiles, samplenames=None, isbedfiles=False bedcovdicts.append(get_bedcov_dict(out)) else: bedcovdicts.append(get_bedcov_dict(bf)) - + print_input_table(get_gc_and_len_dict(fastafile), bedcovdicts, samplenames=samplenames) @@ -132,7 +139,7 @@ def generate_input_table(fastafile, bamfiles, samplenames=None, isbedfiles=False raise Exception("Nr of names in samplenames should be equal to nr of given bamfiles") else: samplenames=None - + # ignore broken pipe error when piping output # http://newbebweb.blogspot.pt/2012/02/python-head-ioerror-errno-32-broken.html signal(SIGPIPE,SIG_DFL) diff --git a/scripts/merge_cutup_clustering.py b/scripts/merge_cutup_clustering.py new file mode 100755 index 0000000..cda9199 --- /dev/null +++ b/scripts/merge_cutup_clustering.py @@ -0,0 +1,69 @@ +#!/usr/bin/env python +""" +With contigs cutup with cut_up_fasta.py as input, sees to that the consequtive +parts of the original contigs are merged. + +prints result to stdout. + +@author: alneberg +""" +from __future__ import print_function +import sys +import os +import argparse +from collections import defaultdict, Counter + +def original_contig_name_special(s): + n = s.split(".")[-1] + try: + int(n) + except: + return s, 0 + # Only small integers are likely to be + # indicating a cutup part. + if int(n) < 1000: + + return ".".join(s.split(".")[:-1]), int(n) + else: + # A large n indicates that the integer + # was part of the original contig + return s, 0 + +def main(args): + all_seqs = {} + all_originals = defaultdict(dict) + first = True + with open(args.cutup_clustering_result, 'r') as ifh: + for line in ifh: + if first: + first=False + continue + line = line.strip() + contig_id, cluster_id = line.split(',') + original_contig_name, part_id = original_contig_name_special(contig_id) + + all_originals[original_contig_name][part_id] = cluster_id + + merged_contigs_stack = [] + + sys.stdout.write("contig_id,cluster_id\n") + for original_contig_id, part_ids_d in all_originals.items(): + if len(part_ids_d) > 1: + c = Counter(part_ids_d.values()) + cluster_id = c.most_common(1)[0][0] + c_string = [(a,b) for a, b in c.items()] + if len(c.values()) > 1: + sys.stderr.write("{}\t{}, chosen: {}\n".format(original_contig_id, c_string, cluster_id)) + else: + sys.stderr.write("{}\t{}\n".format(original_contig_id, c_string)) + else: + cluster_id = list(part_ids_d.values())[0] + + sys.stdout.write("{},{}\n".format(original_contig_id, cluster_id)) + +if __name__ == "__main__": + parser = argparse.ArgumentParser(description=__doc__) + parser.add_argument("cutup_clustering_result", help=("Input cutup clustering result.")) + args = parser.parse_args() + + main(args) diff --git a/scripts/mummer_clusters.py b/scripts/mummer_clusters.py index 3d0504c..eb4c447 100755 --- a/scripts/mummer_clusters.py +++ b/scripts/mummer_clusters.py @@ -26,7 +26,7 @@ with open(coveragefn, 'r') as csvfile: reader = csv.reader(csvfile, dialect='excel-tab') - reader.next() + next(reader) for row in reader: vals = [row[0], row[1], row[2], str(sum([float(x) for x in row[col1:col2+1]]))] covmap[row[0]] = vals @@ -38,7 +38,7 @@ contig_set = defaultdict(dict) -for chrom, label in refs.iteritems(): +for chrom, label in refs.items(): if not os.path.exists("%s_%s.delta" % (tag, chrom)): os.system("nucmer --prefix=%s_%s %s.fna %s" % (tag, chrom, chrom, tag)) #os.system("show-tiling %s_%s.delta > %s_%s.tiling" % (tag, chrom, tag, chrom)) @@ -56,16 +56,16 @@ start = cols[0] contig_set[label][contig] = start -print "Contig", +print("Contig", end=' ') for label in sorted(contig_set.keys()): - print "\t" + label, -print + print("\t" + label, end=' ') +print() for rec in SeqIO.parse(tag, "fasta"): - print "%s\t%s\t%s" % (rec.id, contigmap[rec.id], "\t".join(covmap[rec.id])), + print("%s\t%s\t%s" % (rec.id, contigmap[rec.id], "\t".join(covmap[rec.id])), end=' ') for label in sorted(contig_set.keys()): - if rec.id in contig_set[label].keys(): - print "\tY\t%s" % (contig_set[label][rec.id]), + if rec.id in list(contig_set[label].keys()): + print("\tY\t%s" % (contig_set[label][rec.id]), end=' ') else: - print "\tN\tNA", - print + print("\tN\tNA", end=' ') + print() diff --git a/scripts/tests/test_data/bins/sample1_gt1000_bin98.fa b/scripts/tests/test_data/bins/sample1_gt1000_bin98.fa new file mode 100644 index 0000000..5a24cc0 --- /dev/null +++ b/scripts/tests/test_data/bins/sample1_gt1000_bin98.fa @@ -0,0 +1,156 @@ +>contig12595 +GgCAACGGCAAAGCATTAGAGCCATTAGAGTCATTAGAGCCATTGTAGGTCATTTGAAGT +CATAAATAAACCTACAATGGCTCATACTTTTTTGTATATACTTTTTGTACATACTTTTTT +CTTATTTCTGATAATTTTCGCTCATTTAATATAATTCTGGTGGAGGATATATTTTATGAG +CATAGATCCCTTTGAGCTATTTGAACCATTTGCTGAAAACAACAGTGCTAAAGAGACAGA +AGAACTAGgAAATATTGAAGCTGGTGtcGCACCTCTACCAcaTGTAGTATCACTTTCAAC +TTCTCCACCGCAACCTATACAACCTGTAGTATCTATAGCACCTACAGAGCCTACAGAAGC +TACTGTAACTACTTCTACTACAACACCTTATAAAGAATTAAAAGAAATTTATACATCAGT +AGCAGAAGAGCTTTTTAGTGAAACACAGAATACATCAACAGAGCCATTAGAGCCATATAA +AGAATTAAAAGAAATTTATACACAAGAAAGTTCTGTTGATGTACAAAAAATGTCTACTAC +TGTAACTACTAAACAACAGTGTCAAGATGCTCAAGATGCTCAAGTTCCAACAGTTCCACA +AAAGAAGCAAGAAGGCCTGTTAAACGAGTTAAGTGAAAGTAATAGTACACCAGAGCCTAT +AGAGCCTAAAGATGAGCCACAGAGCCAACAGAAGCCTCTTAAACGACCACCTGTAGTACC +TTCAGAGTTAATTACAGGTCGTCCTAAAGGTGCAAAGAACAGAACCTGCATGATGTCTTT +AGATGAGCGGTTAAAAGTACTAACAGGAATTATAAAGAACAAAAATACAAAAACATCAGA +TAAAATTGCAGCTATTAAGTGTATAACCGACTTGCTGAATGATAAAGTAGAACGTGAAGG +TACTAACGGACATACTACAATACTGAAATTTGAGAAGATGAATATGCCTAAACAACGTAA +AAAGAATAAAGATAGATATAGTAAAATATTTAGAGTTCGTTCAAATACTATGGAAAACTT +GAATAATTTTTTGGAGAACTTAACTACAGAAGCTACTGAGGCTACTGAAGAAACAGAAGC +TACcGAAGAaGATAGCACTGTTGAAGAcGATAGCACTGTTGAATAAtTGTATAGTGGTAA +CAAAAGAGGAGTGTTAAGGTGCCACATAACATATTAGCCAACGACAAAAGATATAATAAC +TACACAATAGGCAGATATACATATGGTTCTCCTAAAGTACATGGATATAGAAATACCTTA +GAAATAGGCCACTTTTGTAGTATTGCAGAAGGTGTAGAGATATTTTTAGATGGCCAACAT +AGAACTAAATGGATAACTACTTCGCCTTTATATCACTTGTTAATATCTAAAAGAGTATAT +GGTAAACCTAAATACGGAGTTTCTTCTAAAGGGCCTGTAGTTATTGGCTCaGATGTATGG +ATAGGTTATAAGGCTTTAATACTATCTGGAGTaACTATAGGCGATGGTGCAGTTATAGGA +GCAAAGAGTGTAGTAAGTAAAGATATTCCTCCTTATGCTATTGCTGTTGGTTCGCCTATA +GTTGTAAAGAAGTATAGGTTTACAGAAGAACAGATAACAGAGCTACTTAGAATACAGTGG +TGGAATTGGCCTGAAGAGAAGATAAAACAGAATATTAAGTTGCTTTTAAGTGAAAATATA +GAAGAATTTATAAGAACTTTTAAAGTGTAAATGTATAATAATACTGTGAAGCCTAAGAAG +TTAGTGATGGTGGTGAATGACAAGTGCGGAGCCGTAGTAGTAATTTACAAAGATGATATT +A +>contig18313 +AAAATGCCGGTCACAGTAATATTCTACTTGAGATTGGACAACAGGCAGAAGTGATGTTAT +GTAGGCGTCGAAACCATCAGCCGCAGTTGTGTTTGTCAGCGTTCTAAAATGTGCTAACGT +TAAAATACTCATTCCGATACTCCTTTTACATCATCGGTATCGGAATTTAGTCTAACGATG +ATGTAGAACTCTTAGAACTTTCCGAGCTTTCCGATTGTGAAGAATAACTTTCCGGAGTTG +ACGAAGAACTACTTTCACTTACAGAACTTTCCGATTGCGAACTGTTTGTTGATCTACTTG +ATGCCGCTTCATGCGACTCTTCTTCTGAGCTTGTAGATGAAGCAGAACTTTCAGAAGTTT +CAGTTTCAGAGCTTGAACTTTCACTTACAGTACTTTCGCTTACAGAGCTTTCACTTGTCG +AACTATGAGTGCTTTCGCTTACAGTGCTTTCGCTTACAGAACTTTCCGATTGCGAACTTC +CAGTACTAGCAGAACTCTGACTTACCGTACTTGCAGAACTCTGGCTTACAGTACTAGCAG +AACTCTGGCTCTTAGACGAAGAACTACTTGAACTTACAGAACTTGCACTCGATGTTGAAC +TGTCATATATTTCAGTACTCAAGCTTTCCGAACTATCAGAACTCAAGCTTACAACACTCT +GAGAACTCAACGAAGACGAACTATTAGAACTATGCGTAATTTCAGAGCTTGCCGAAGATG +TGCTTGCCGAAGATGTAGAACTTGAAGAAACATTACCGGCACTTTCAGAACTTGAAGAAG +AACTGACAGTAGGACCAGTACCTTCAGCTATTACGAAAGGCGCAACTTGCTCACCATCAT +CCATTGTATATACATTACCATAAGAGCATCCGCCGAAACGAACTTCTAATATTAACTCTT +CTTCATTATAATTCCATCTAAGAGCAACAGACATATGCTTTCTAATTTCTACTTCGGTTA +CAACATATTGAGAGAAGTCACCTAAAACTATACCTTCGTCACCTGATAATTGCTCCATTA +TATTGACTTTATGACCAAATATTACAGGAGTGCCATCAGATGTCCATGAAAGCCACGGAT +TAGTTTTTGTATCATCAACTAGATCCGTAATATCATTCCAATTCTCCTTAGAAAAATACC +ATTCAGCCTTTTTTGAGTTTGCAGGAGCTATTTTCTTCTCAAAATTTCTTAAAACGGCTA +ATGTTAATGGATCCGCAGAAGCAGCACCTATAACTCCATTCGCACCTGCAC +>contig15080 +GAACTTGTAGAAGAAGCAGAACTTTCACTTGTAGAAGAAGCAGAACTTTCACTTGTAGAA +CTTAAGCTGCTCTCGGAAACAGAACTCTCACTCGTAGAAGAAGCAGAACTCTCACTTAAG +CTACTCTCAGAAAGACTTGAACTCTCAGAAACACTTGAACTACTCTTAGAACTACTTGAA +CTCTCGGAAACGCTTGAACTGGAACTACTTACAGAACTTGAACTTGAAGAAGAAGCAGAC +GAAGCCGAACTTGCACTTGATGTTGAACTTGAACTTGAAGAAGAACTTGAAGCAGAAGAC +GTTGAACTAGATGAAGCAGAACTTGTAGAACTAGACGAAGCAGAAGATGTACTTGAACTG +CTCCTTGAACTTGTAGAAGAATACGAAGAgAggCTtTCTGTAATTGAACTTGTAGAAGAA +CTATAACTcTCTGTTACACTaCTACTgGAACTATACTCAAATATCTCAGGAGCCTTTATG +CCAAGTAAtAAaACCTCTATaTGATGAGACATTCGGTTgCATTTGTCAATATACTTTATG +CCATACCAATGTCCTTTTATATAAACAAGATTGGTACTTTTGAGATGTCTTATATCACAA +AAAAGCCTGTGAGTAGCAACAATATTCTGTTTACCAAAGGCTTTTCGTTCATCAGCAGAA +AGAAGAGTAAAATAGCAAGGTATATTTGAGGCAATTAGAGCAGCAGTACGAATGATGCCG +CCCATATTATCCCGGCCAGTAATTTCATAACTGTATAAACTGTATTTGGACCAGTATAAA +TTATTGATGCTTCCAGCCACACAAATTATTTCCTTAAGTTTGCTTTTTTACAAACGGCCA +TAACGAGTCTGCATATCCATCTAATATGTTCTTTAATAATAAAGTATCCGCATATGTAAT +AGAGTAATTTGTAATAGTTTGACTCTTTATTAAACCAATATCAGGTAACTTACTCTTTGC +CAACATGTCCTTAATAATATTTGCACAAACATTCTGTAAAGCATCTGGCATATCTGCATT +TGTATAACCAGCATTCCAAATAATATAAAGGTTCTCTGGAAAATAAAAGTCAATGTTATA +CGAGAAAACACTATCTTCCGCAAACTTTAATGTTCTTTCTGTACCATCCTCAATTAAAGC +ATGACAGTCAACTCTAGTAGCAATAGTCCATGTTAAACCAACACAAGGACGTAACATATT +TGAAGAAGTTGTCTCGTAACCACTTACAATTGCGACAGTTATAGCAGGATAGTCATCTTC +TATTTCTGTTTTTAATGCAGTTAGAGTAGTGTTATCTGCAAACAAGTAGTCTGTAGCAGC +aTAGTTTATATTTGTAACATCAATTACAGTAACCCTATCCGTTTTAACCTGTATCGTATA +GTCAAAGGCACTGTCAATAGTTATGTTTGCAGCAGTTACAGGAGAGCCAATAAATACTAT +GGTGTTAAcAGGATATTCAGGCAGTAAAACTCTTCTGTACGGAGTAAATTTGAACCATTG +CTTGTAGTTTGCAGCATC +>contig07253 +AGTCCAATACCAATACCAACAATTACACCTGAGACCACAAACTCACTAATTGTAATTATT +GCCACACAAAGCGCAGCGAATAAAACATTTTCCAATTATAGCATTACTACTGAGAATCCA +AGCTGGACAGAACGATTTGATATACAAGGTTCTATTGCCGCTAATGGTACTTTTGCAATG +GGAACCGGTCCAAGAGCATCAGCAGCGGCAACCGGAACTGGATATGTAAGTACAGCACCG +GTCGCTGGCTTTCCTTCTGCAGCTTTGTTCTCTTTGAATGGAAGTTAAAAAGTTAATAAT +ATAATTTAATATGAGGCCAATATGTTACTTACACAACAGGTTTTAAGACTAATCTTCGCC +AAACTAGGTGGCTTGATAACTGAAGGCACCATTACAGGCGTATATCCGTATATGGCTCCT +GATGAGGCTGTATATCCATTTGTAGTAGTAATTCCTGTTGGTCTGGATATGGACTACGCC +TTCACCAAAGACTACGAATTAATAGATGTTCAATTTAGTGTTTTTGATAGCAATCCAGAA +CATATATCAACTCTTTTAATTCTAAACGAAATTGAAGAAATATTTCACAGAGCACATATG +GAATTCTATGATACCGATAATGCTAAACATCTAGTGTGTATTGCTAAAACTAATGAAAAA +ATTGAATATATGGACGAAGATCACTATTGGCATGGTATTGGAGAATATGACTTTAGATGT +CAGAAAGATGCTGGAACAACTAGAAGTAGCTCCTCAAGTAGTATAACAGAAAGCCTGAGT +TCTGCCTCTACAAGCAGTTCCACGAGCTCGTCTACATCTTCTATAAGTTCTAATAGTTCT +TCAAGTAGTTCAAGTCGTAGCTCCTCAAGCACAAGCCAGACAAGCGAAAGTTCTAAGAGT +AGCTCAAGTACATCCTCGAGTAGCGCAGAACCTTCAACTTCTTCACAGAGTACCACAAGT +GAAAGTTCTAAGAGTAGTTCAAGTGAGTCTCTAAGTAGTGCGGAACCTTCTACTTCTTCA +CAAAGTACAACAAGTGAAAGTTCTAGAAGTAGTTCAAGCCAGTCTCTAAGTAGCGGAGAG +CCTTCAACTTCTTCACAGAGCACAACAAGTGAAAGTTCCAGAAGTAGCTCAAGTAATTCT +TCAAGTAGTGCAGAGCCTTCAACTTCTTCACAAAGTACAACAAGTGAAAGTTCTAGAAGT +AGTTCAAGCCAGTCTCTAAGTAGCGGAGAGCCTTCAACTTCTTCACAGAGCACAACAAGT +GAAAGTTCCAGAAGTAGCTCAAGTAATTCTTCAAGTAGTGCAGAGCCTTCAACTTCTTCA +CAGAGCACCACAAGCGAAAGTTCTAAGAGTAGTTCAAGTAATTCCTCAAGTAGTGCAGAG +CCTTCAACCAGTTCGCAAAGTACAACAAGTGAAAGTTCCAGAAGCAGCCTAAGCACATCT +TCAAGTAGCGCGGAACCTTCTACTTCTTCACAAAGTACCACAAGTGAAAGTTCTAAGAGT +AGTTCAAGCCAGTCTCTAAGTAGCGGAGAACCTTCAACTTCTTCACAAAGTACTACAAGC +GAAAGTTCTGGAAGTAGTTCAAGCGAATCAATGAGTAGCCGTAGTAGCTCTTCTACAAGC +GAAAGTTCTACATCTTCTGCAAGTTCTGTAAGTAATTCAAGTGTAAGTTCTTCGTCTACA +AGCAGTTATAGCGGTTCAAGTAGTTCAACAGGAAGTTCTGAAAGTTCTGTAAGTGAAAGT +TCTGTAAGTAATTCAAGCGAGTCGTCAAATTCAAGTAGCAACTCTTCTTCTAGTAGTCAC +AGTAGTTCTTCTGATAGCACAATGTCAAGTAGCTCTACATCTAGCGCAAGTTCAAATAGT +TCCAGTAGTTCTTCTATAAGCACTCCTTCTTCGGAAAGTTCTGAAAGCTCTAGTAGTTCT +GTTGAGTTTAGTTCTAGTAGTTCTTTAAGTTCTGAAAGCGAAGGAAATACTTCTAGCAGT +TCAACAGGTTCGTCTTTATCAACACAGAGTGAAAGTAGCAGTTCAACATTATCAAGTGAA +AGTTCTGTAAGCGAAAGTTCTGAAAGTTCTGCAAGTGAAAGTTCTGCAAGTACACAAAGT +AGTAGCTCCTCAAGTCTATATGATGCTTGCGATATGCTACCGGTTATGACAAGCAATACA +ACTCCTAAACCTTATGTAACATCGGCCGGTTATGATACTATACTCGGATACGCTTGGCAG +GCTACTACTATTGCTGGATGGTACTTATGGCAACCTGGCGGCAATGAGTGGGGCTGGTGG +ATAATTGACTACTCAGAAGAGAAGCAAATTGTTAAGAGATATGGATACTATGGCGTTTCT +GTAGTTGACTATCCTACAACTTGGTACTTCTATGGTTCAATGCACGGCGACGACTGGACG +CAACTAGAGGGTTACCCAAGACAAGGCGCTCCTACACTTGGACAATGGAACAACTTTGAT +ATTGAAAATGATACTGCATATAGATATTACAAACTGTATATACCTAATGTTTCTACTGAT +AACTGTACGATGCGGCTACGCTTCTGCGGAATAACTGAATTGTATAGTAGCTCAAGTAGT +TTTTCTAATAGCTCTAGTAGTTCTGTAATTGAGTCTAGAAGCTCAGCAAGTACAGGAAGT +AGCGAAAGTACAGTTAGTGAAAGTTCTGTAAGCTCTGATAGCTCGCCTTAAAATACCATG +AACTATTACGATCTCAATCCAGGACAAGGCAGGATTAAATGGCAGTGGCATATCGAAGAA +TTCTTGCTTAAACTCGAACCTAAAATAACTGAGGCCTTAGAAGACTCTATTGAAATGATG +GCTGATAGTGCAAAAGACAAGGCACCTGTGAAAACTGGACGACTAAAGAACAGTATATAT +ACTGAGAGTTTTCATCCTGATAAATGCTCTTGGATAGGAAGAGTAATATCACCTGTACCT +TATACACAGTGTGTTGAaTATGGAACCAGGAAGAGATCGGCTAAACCGTTTATGAGGCCT +GCTTTTAGAGGTACCTGGAGTAAGGTACTAAGTAGATTTAGAAATATTATAGGCTAA +>contig18116 +AAAGTGCCTATCACAGTAATATTCTACTTGAGATTGCACAACCGGCAGAAGCGATGTTAT +GTAAGCATTAAAACCATCAGCCGCAGTGGTATTTGTCAGCGTTCTATATTGCGCCAGCGT +TAAAATACTCATTCCGATACTCCTTTTACATCATCGGTATCGGAATTTAGTCTAACGATG +ATGTAGAACTCTTAGAACTTTCCGAGCTTTCCGATTGTGAAGAATAACTTTCCGGAGTTG +ACGAAGAACTACTTTCACTTACAGAACTTTCCGATTGCGAACTGTTTGTTGATCTACTTG +ATGCCGAACTATGCGACTCTTCTTCTGAGCTTGTAGACGAAACAGAACTTTCGCTTACAG +TACTTTCACTTACAGAACTTTCAGAAGTTTCAGAACTTTCAGAAGTTTCAGTACTTTCAG +AAGTTTCAGAAGTTGAACTATGAGTGCTTTCGCTTACAGTGCTTTCGCTTACAGAACTTT +CCGATTGCGAACTTCCAGTACTAGCAGAACTCTGACTTACCGTACTTGCAGAACTCTGGC +TTACAGTACTAGCAGAACTCTGGCTCTTAGACGAAGAACTACTTGAACTTACAGAACTTG +CACTCGATGTTGAACTGTCATATATTTCAGTACTCAAGCTTTCCGAACTATCAGAACTCA +AGCTTACAACACTCTGAGAACTCAACGAAGAGGAACTTTCAGAACTATGCGTAATTTCAG +AGCTTGCCGAAGATGTGCTTGCCGAAGATGTAGAACTTGAAGAAACATTACCGGCACTTT +CAGAACTTGAAGAAGAACTGACAGTAGGACCAGTACCTTCAGCTATTACGAAAGGCGCAA +CTTGCTCACCATCATCCATTGTATATACATTACCATAAGAGCATCCGCCGAAACGAACTT +CTAATATTAACTCTTCTTCATTATAATTCCATCTAAGAGCAACAGACATATGCTTTCTAA +TTTCTACTTCGGTTACAACATATTGAGAGAAGTCACCTAAAACTATACCTTCGTCACCTG +ATAATTGCTCCATTATATTGACTTTATGACCAAATATTACAGGAGTGCCATCAGATGTCC +ATGAAAGCCACGGATTAGTTTTTGTATCATCAACTAGATCCGTAATATCATTCCAATTCT +CCTTAGAAAAATACCATTCAGCCTTTTTTGAGTTTGCAGGAGCTATTTTCTTCTCAAAAT +TTCTTAAAACGGCTAATGTTAATGGATCCGCAGAAGCAGCACCTATAACTCCATTTGCAC +CAATACTAAAAATACCTTCA diff --git a/scripts/tests/test_data/bins/sample1_gt1000_bin99.fa b/scripts/tests/test_data/bins/sample1_gt1000_bin99.fa new file mode 100644 index 0000000..bff9596 --- /dev/null +++ b/scripts/tests/test_data/bins/sample1_gt1000_bin99.fa @@ -0,0 +1,44 @@ +>contig06860 +TTATAGCCGGTTTAGCCCCGTGCTTACGGGGAACAGCTTTAGCTTTTGCAATGCTTCTCC +GTCACTGTCGGTTTAGCCCCGTGCTTACGGGGAACAGTAGCGGCTCTTTCGGCCCTTCCA +GCTTTTCGACGGTTTAGCCCCGTGCTTACGGGGAACAGGCGTCTACATCAATGCGCGATT +GAACCAGCGCCGGTTTAGCCCCGTGCTTACGGGGAACAGGATTCATCGTATTTCGTAGGT +CTAGCCACAGGCGGTTTAGCCCCGTGCTTACGGGGAACAGCTACCTAATGCGCCAAGGTA +AATCACTGGTAGCGGTTTAGCCCCGTGCTTACGGGGAACAGGCCAAGATTTCCAAGCTGC +ATAAGTCTGGTTTGCGGTTTAGCCCCGTGCTTACGGGGAACAGTTTCAACTGGCAGCCAT +TTAAGCGCCTGCCCGCGGTTTAGCCCCGTGCTTACGGGGAACAGCTAAAATAAGATAGCG +CTCTACATCTGTATGCCGGTTTAGCCCCGTGCTTACGGGGAACAGAAGGCTAACGGCGTG +AACATTTGTTATGCTTACGGTTTAGCCCCGTGCTTACGGGGAACAGCATCCTGTAATGTC +TAAAATCTGATTAGCTAACGGTTTAGCCCCGTGCTTACGGGGAACAGAGTATCCAGCCAT +ATCATCTCAATATAGTTAGCGGTTTAGCCCCGTGCTTACGGGGAACAGATTATTTAAATT +ATTTTCTATTTCAATATATTCGGTTTAGCCCCGTGCTTACGGGGAACAGTCAAAATCAAT +CTGAGACATTCCAGCAAAGTACGGTTTAGCCCCGTGCTTACGGGGAACAGTTGTTGAGTC +AATCACGTTTTGCCACCTGTTGCGGTTTAGCCCCGTGCTTACGGGGAACAGTTCCTGAAT +GACTCTGTGAATGCAGACAGAAACGGTTTAGCCCCGTGCTTACGGGGAACAGCTAATAAT +GCGATCCATTATTTACCGCCTTTGCGGTTTAGCCCCGTGCTTACGGGGAACAGCGCAGAT +TCCGTACTGTTTCCGAGCCGTTCCGCGGTTTAGCCCCGTGCTTACGGGGAACAGAAGACC +AACTATTTCTAAAGTGACGGGTTTACCGGTTTAGCCCCGTGCTTACGGGGAACAGGTCAG +GGCAGGTTGCTGGACACGTAGCGGGATCGGTTTAGCCCCGTGCTTACGGGGAACAGAAAA +ACTTTTGTATCTCAGGAAGATTTATAGACGGTTTAGCCCCGTGCTTACGGGGAACAGTCA +GGGCATCCAAGCTACTTGGACCCAGGAGGCGGTTTAGCCCCGTGCTTACGGGGAACAGAC +GCAAAGTTTTCATCTGGAAGTGACCCTATGCGGTTTAGCCCCGTGCTTACGGGGAACAGT +AGCAATGGCTGAAACTGTCACTATTGAACACCGGTTTAGCCCCGTGCTTACGGGGAACAG +ACGTTTTAATTTGTCTGACTTAAAAGAGTGTTCGGTTTAGCCCCGTGCTTACGGGGAACA +GTCCACAAGTACCAAGACGGTGACGACAACCTACGGTTTAGCCCCGTGCTTACGGGGAAC +AGGTTTTTCCATCCGTCAGCACTGACAAGGGGCGCGGTTTAGCCCCGTGCTTACGGGGAA +CAGGCCAAAGACGCCAATGGAGCAGGCTCAGTATGCGGTTTAGCCCCGTGCTTACGGGGA +ACAGTCTATTTCACTGACAGCGGCTTTATGTGCTCGCGGTTTAGCCCCGTGCTTACGGGG +AACAGTGGCGTTAATCTTTACCCGAACACTCCACGTCCGGTTTAGCCCCGTGCTTACGGG +GAACAGTCTCGGAATGGCTTCAGTGTCTGTTCCGTTAACGGTTTAGCCCCGTGCTTACGG +GGAACAGTAAATGCGGTTAAGTTAAGGTTGACAACCTCGCGGTTTAGCCCCGTGCTTACG +GGGAACAGCCTTGCTGCCAAACTGGAAATGACGCAAACGACGGTTTAGCCCCGTGCTTAC +GGGGAACAGATCAAAGTCGTTTGGCGCATCAAATGTGCCTACGGTTTAGCCCCGTGCTTA +CGGGGAACAGCGCCACCTTCTAACCGTTGAACTGAACTCAGACGGTTTAGCCCCGTGCTT +ACGGGGAACAGTATCGGTATGGCTCTCAAGTCCTGCGCTGAGCCGGTTTAGCCCCGTGCT +TACGGGGAACAGTCTGCCGCAAAAGCTCTTAACTGCCCGACCGTCGGTTTAGCCCCGTGC +TTACGGGGAACAGTCGATGCCCGGATTCGCTTTAGGTGGGTTAGACGGTTTAGCCCCGTG +CTTACGGGGAACAGCCAAAGACGCCAATGGAGCAGGCTCAGTATGCCGGTTTAGCCCCGT +GCTTACGGGGAACAGATCTGGCATCAATTTTAAATGTGTTGGTGTTTCGGTTTAGCCCCG +TGCTTACGGGGAACAGGAACGCAGCCGCTGCCATTGCAGCCAAGACAACGGTTTAGCCCC +GTGCTTACGGGGAACAGTAGCCGTAATAACCAAGGTCGTAACGTTTGAGCGGTTTAGCCC +CGTGCTTACGGGGAACAGGCGCTACCGCCCCCA diff --git a/scripts/tests/test_dnadiff_dist_matrix.py b/scripts/tests/test_dnadiff_dist_matrix.py index cd3a6fe..daa6c10 100644 --- a/scripts/tests/test_dnadiff_dist_matrix.py +++ b/scripts/tests/test_dnadiff_dist_matrix.py @@ -126,9 +126,12 @@ def test_plot_dist_matrix(self): delimiter="\t") heatmap = ospj(TMP_BASENAME_DIR, "hclust_heatmap.pdf") dendrogram = ospj(TMP_BASENAME_DIR, "hclust_dendrogram.pdf") - dnadiff_dist_matrix.plot_dist_matrix(matrix, names, heatmap, dendrogram) + clustering = ospj(TMP_BASENAME_DIR, "clustering.tsv") + clustering_threshold = 0.05 + dnadiff_dist_matrix.plot_dist_matrix(matrix, names, heatmap, dendrogram, clustering_threshold, clustering) ok_(os.path.exists(heatmap)) ok_(os.path.exists(dendrogram)) + ok_(os.path.exists(clustering)) def test_plot_dist_matrix_88_bins(self): """Plot a distance matrix with 88 samples""" @@ -139,9 +142,12 @@ def test_plot_dist_matrix_88_bins(self): delimiter="\t") heatmap = ospj(TMP_BASENAME_DIR, "hclust_heatmap.pdf") dendrogram = ospj(TMP_BASENAME_DIR, "hclust_dendrogram.pdf") - dnadiff_dist_matrix.plot_dist_matrix(matrix, names, heatmap, dendrogram) + clustering = ospj(TMP_BASENAME_DIR, "clustering.tsv") + clustering_threshold = 0.05 + dnadiff_dist_matrix.plot_dist_matrix(matrix, names, heatmap, dendrogram, clustering_threshold, clustering) ok_(os.path.exists(heatmap)) ok_(os.path.exists(dendrogram)) + ok_(os.path.exists(clustering)) def test_write_fasta_names(self): names = [ diff --git a/setup.py b/setup.py index 35dabb2..4f1262d 100644 --- a/setup.py +++ b/setup.py @@ -2,13 +2,17 @@ from setuptools import setup, find_packages import sys, os from distutils.core import Extension +import numpy as np -version = '0.4.2' +try: + from Cython.Distutils import build_ext +except ImportError: + print("You need to have Cython installed on your system to run setup.py. Sorry!") + sys.exit() -module1 = Extension('vbgmm', - libraries =['gsl', 'gslcblas'], - include_dirs = ['c-concoct'], - sources = ['c-concoct/vbgmmmodule.c']) +version = '1.0.0' + +include_dirs_for_concoct = [np.get_include(), '/opt/local/include/'] setup(name='concoct', version=version, @@ -26,10 +30,15 @@ url='https://github.com/BinPro/CONCOCT', license='FreeBSD', packages=find_packages(exclude=['ez_setup', 'examples', 'tests']), - scripts=["bin/concoct"], + scripts=["bin/concoct","bin/concoct_refine", "scripts/cut_up_fasta.py", "scripts/concoct_coverage_table.py", + "scripts/merge_cutup_clustering.py", "scripts/extract_fasta_bins.py"], include_package_data=True, zip_safe=False, - ext_modules=[module1], + cmdclass = {'build_ext': build_ext}, + ext_modules = [ + Extension("vbgmm", sources=["./c-concoct/vbgmm.pyx", "./c-concoct/c_vbgmm_fit.c"], + libraries =['gsl', 'gslcblas','gomp'], include_dirs=include_dirs_for_concoct, extra_compile_args = ['-fopenmp','-O3','-std=c99']) + ], install_requires=['cython>=0.19.1', 'numpy>=1.7.1', 'scipy>=0.12.0', diff --git a/tests/test_integration.py b/tests/test_integration.py index d43813e..10abe99 100644 --- a/tests/test_integration.py +++ b/tests/test_integration.py @@ -65,10 +65,10 @@ def md5sum(self,fh): infile = open("filename", 'rb') content = infile.read() infile.close() - m = hashlib.md5() + m = hashlib.md5() m.update(content) return m.hexdigest() - + def test_no_errors(self): self.run_command() assert_equal(self.c,0, @@ -79,7 +79,7 @@ def test_directory_creation(self): assert_true(isdir(tmp_basename_dir), msg = "Temporary directory not created") m_time_first = os.path.getmtime(tmp_basename_dir+'/clustering_gt1000.csv') - + # Rerun the concoct and see that the directory is overwritten self.run_command() m_time_second = os.path.getmtime(tmp_basename_dir+'/clustering_gt1000.csv') @@ -94,7 +94,7 @@ def test_directory_creation(self): assert_true(isfile(tmp_basename_file+'_clustering_gt1000.csv'), msg = "Clustering file is not created, when file is used as basename") L = listdir(tmp_basename_dir) - assert_true(len(L) == 26, + assert_true(len(L) == 6, msg = "Wrong number of output files, observed {0}".format(L)) def test_prior_to_clustering(self): @@ -109,7 +109,7 @@ def test_prior_to_clustering(self): assert_true(isfile(d_p+ '/PCA_transformed_data_gt1000.csv'), msg="PCA transformed data file is not created") - + def test_output_files_creation(self): # dir as basename self.run_command() @@ -118,27 +118,6 @@ def test_output_files_creation(self): isfile(d_p+ '/clustering_gt1000.csv'), msg='Large contigs clustering file is not created' ) - assert_true( - isfile(d_p+ '/pca_means_gt1000.csv'), - msg='Large contigs cluster pca means file is not created' - ) - assert_true( - isfile(d_p+ '/pca_variances_gt1000_dim1.csv'), - msg='Large contigs cluster pca variances file is not created' - ) - assert_true( - isfile(d_p+ '/means_gt1000.csv'), - msg='Large contigs cluster means file is not created' - ) - - assert_true( - isfile(d_p+ '/variances_gt1000_dim1.csv'), - msg='Large contigs cluster variance file is not created' - ) - assert_true( - isfile(d_p+ '/responsibilities.csv'), - msg='Large contigs responsibilities file is not created' - ) assert_true( isfile(d_p+ '/PCA_transformed_data_gt1000.csv'), msg='PCA file is not created' @@ -158,27 +137,6 @@ def test_output_files_creation(self): isfile(d_p+ 'clustering_gt1000.csv'), msg='Large contigs clustering file is not created' ) - assert_true( - isfile(d_p+ 'pca_means_gt1000.csv'), - msg='Large contigs cluster means file is not created' - ) - assert_true( - isfile(d_p+ 'pca_variances_gt1000_dim1.csv'), - msg='Large contigs cluster variances file is not created' - ) - assert_true( - isfile(d_p+ 'means_gt1000.csv'), - msg='Large contigs cluster means file is not created' - ) - - assert_true( - isfile(d_p+ 'variances_gt1000_dim1.csv'), - msg='Large contigs cluster variance file is not created' - ) - assert_true( - isfile(d_p+ 'responsibilities.csv'), - msg='Large contigs responsibilities file is not created' - ) assert_true( isfile(d_p+ 'PCA_transformed_data_gt1000.csv'), msg='PCA file is not created' @@ -191,7 +149,7 @@ def test_output_files_creation(self): isfile(d_p+ 'log.txt'), msg='Log file is not created' ) - + def test_threshold_functionality(self): self.run_command() d_p = tmp_basename_dir @@ -199,7 +157,7 @@ def test_threshold_functionality(self): clust_gt_1 = d_p+'/clustering_gt1000.csv' odl_1 = self.file_len(od_1) clust_gtl_1= self.file_len(clust_gt_1) - + self.run_command(comp_file='composition_some_shortened.fa', basename=tmp_basename_dir2+'/') d_p2 = tmp_basename_dir2 @@ -207,7 +165,7 @@ def test_threshold_functionality(self): clust_gt_2 = d_p2+'/clustering_gt1000.csv' odl_2 = self.file_len(od_2) clust_gtl_2= self.file_len(clust_gt_2) - + assert_true(odl_1!=odl_2, msg='Original data have the same lengths') assert_true(clust_gtl_1!=clust_gtl_2, @@ -219,7 +177,7 @@ def test_logging(self): log_content = log.read() assert_true(len(log_content)>10, "Log content is too small") - pca_report = filter(lambda row: 'Performed PCA, resulted in ' in row, log_content.split('\n'))[0] + pca_report = [row for row in log_content.split('\n') if 'Performed PCA, resulted in ' in row][0] pca_dimensions_log = int(pca_report.split()[-2]) with open(tmp_basename_dir+'/PCA_transformed_data_gt1000.csv', 'r') as pca_comps: header = pca_comps.readlines()[0] @@ -235,7 +193,7 @@ def test_seed(self): first_time = os.path.getmtime(tmp_basename_dir+'/clustering_gt1000.csv') with open(tmp_basename_dir+'/clustering_gt1000.csv','r') as clustering: first_file=clustering.read() - + self.run_command() second_time = os.path.getmtime(tmp_basename_dir+'/clustering_gt1000.csv') with open(tmp_basename_dir+'/clustering_gt1000.csv','r') as clustering: @@ -246,10 +204,10 @@ def test_seed(self): msg='Clustering outcomes were not the same with same seeds') #Should be equal to both above since default seed is 11 - self.run_command(tags=["-f","11"]) + self.run_command(tags=["-f","11"]) first_time = os.path.getmtime(tmp_basename_dir+'/clustering_gt1000.csv') with open(tmp_basename_dir+'/clustering_gt1000.csv','r') as clustering: - first_file=clustering.read() + first_file=clustering.read() assert_true(not (first_time==second_time), msg='clustering_gt1000.csv did not change') assert_true(first_file == second_file, @@ -261,7 +219,7 @@ def test_seed(self): with open(tmp_basename_dir+'/clustering_gt1000.csv','r') as clustering: first_file=clustering.read() - + #Should give random clustering self.run_command(tags=['-f','0']) second_time = os.path.getmtime(tmp_basename_dir+'/clustering_gt1000.csv') @@ -279,7 +237,7 @@ def test_seed(self): first_time = os.path.getmtime(tmp_basename_dir+'/clustering_gt1000.csv') with open(tmp_basename_dir+'/clustering_gt1000.csv','r') as clustering: first_file=clustering.read() - + #Should give clustering 3 self.run_command(tags=['-f','3']) second_time = os.path.getmtime(tmp_basename_dir+'/clustering_gt1000.csv') @@ -295,7 +253,7 @@ def test_log_coverage(self): original_coverage_data_path = os.path.join(tmp_basename_dir,'original_data_gt1000.csv') df = p.io.parsers.read_table(original_coverage_data_path,index_col=0,sep=',') - true_pseudo_cov = -1.3143 + true_pseudo_cov = -1.3143 calc_pseudo_cov = df.sample_1[0] assert_almost_equal(true_pseudo_cov,calc_pseudo_cov,places=4) @@ -304,20 +262,20 @@ def test_log_coverage_no_cov_normalization(self): original_coverage_data_path = os.path.join(tmp_basename_dir,'original_data_gt1000.csv') df = p.io.parsers.read_table(original_coverage_data_path,index_col=0,sep=',') - true_pseudo_cov = -1.8107 + true_pseudo_cov = -1.8107 calc_pseudo_cov = df.sample_1[0] assert_almost_equal(true_pseudo_cov,calc_pseudo_cov,places=4) def test_big_file_validation(self): - """ Run Validate.pl on the result files after running a larger input + """ Run Validate.pl on the result files after running a larger input file and make sure the statistics are good enough. """ - self.run_command(cov_file='large_contigs/coverage_table.tsv', + self.run_command(cov_file='large_contigs/coverage_table.tsv', comp_file='large_contigs/contigs.fa', basename=os.path.join(tmp_dir_path, 'large_contigs/')) validate_path = os.path.join(test_dir_path, '..', 'scripts', 'Validate.pl') - clustering_reference = os.path.join(test_dir_path, 'test_data', 'large_contigs', + clustering_reference = os.path.join(test_dir_path, 'test_data', 'large_contigs', 'clustering_gt1000_taxassign.csv') clustering_file = os.path.join(tmp_dir_path,'large_contigs', 'clustering_gt1000.csv') @@ -325,23 +283,23 @@ def test_big_file_validation(self): assert_true(isfile(validate_path)) assert_true(isfile(clustering_reference)) assert_true(isfile(clustering_file)) - validate_so = subprocess.check_output(['perl', validate_path, + validate_so = subprocess.check_output(['perl', validate_path, '--sfile={}'.format(clustering_reference), '--cfile={}'.format(clustering_file) ]) - print "Results for large clustering file: " - print validate_so - - headers = validate_so.split('\n')[0].split('\t') - stats = validate_so.split('\n')[1].split('\t') - stats_dict = dict(zip(headers, stats)) - - assert_true(float(stats_dict['AdjRand']) > 0.85, + print("Results for large clustering file: ") + print(validate_so) + + headers = validate_so.split(b'\n')[0].split(b'\t') + stats = validate_so.split(b'\n')[1].split(b'\t') + stats_dict = dict(list(zip(headers, stats))) + + assert_true(float(stats_dict[b'AdjRand']) > 0.85, msg=("Insufficient adjusted rand index " "reached, requires > 0.85")) - assert_true(float(stats_dict['Prec.']) > 0.95, + assert_true(float(stats_dict[b'Prec.']) > 0.95, msg=("Insufficient precision reached, " - "requires > 0.95")) - assert_true(float(stats_dict['Rec.']) > 0.90, + "requires > /0.95")) + assert_true(float(stats_dict[b'Rec.']) > 0.90, msg=("Insufficient recall reached, " "requires > 0.90")) diff --git a/tests/test_unittest_input.py b/tests/test_unittest_input.py index 147c9cb..312e6a5 100644 --- a/tests/test_unittest_input.py +++ b/tests/test_unittest_input.py @@ -25,7 +25,7 @@ def test_normalize_per_samples(self): def test_generate_feature_mapping(self): feature_mapping, counter = generate_feature_mapping(2) assert_equal(counter, 10) - assert_equal(len(feature_mapping.keys()), 16) + assert_equal(len(list(feature_mapping.keys())), 16) assert_true(('A', 'A') in feature_mapping) def test_load_composition(self): @@ -58,21 +58,21 @@ def test__calculate_composition(self): seq_strings = {} for i, s in enumerate(seqs): - seq_strings[s.id] = s.seq.tostring().upper() + seq_strings[s.id] = str(s.seq).upper() composition, contig_lengths = _calculate_composition(f, 0, 4) # Make sure the count is correct for one specific kmer kmer_s = ('A', 'C', 'G', 'T') - for seq_id, s in seq_strings.iteritems(): + for seq_id, s in seq_strings.items(): c = count_substrings(s, "".join(kmer_s)) assert_equal(composition.ix[seq_id, feature_mapping[kmer_s]], c+1) # Check that non palindromic kmers works as well: kmer_s = ('A', 'G', 'G', 'G') reverse_kmer_s = ('C', 'C', 'C', 'T') - for seq_id, s in seq_strings.iteritems(): + for seq_id, s in seq_strings.items(): c_1 = count_substrings(s, "".join(kmer_s)) c_2 = count_substrings(s, "".join(reverse_kmer_s)) assert_equal(composition.ix[seq_id, feature_mapping[kmer_s]], c_1 + c_2 + 1)