def draw_position_grid(directions, sample_size=False, width=8, height=8, title_space=1.1, axis_font_size=20, tick_font_size=10, ylim=None): """docstring for draw_position_grid""" f, axes = pyplot.subplots(4, 4, sharex=True, sharey=True, figsize=(width, height)) bases = list('CTAG') positions = None plottables = [] adaptive_y = 0 for direction in directions: data = directions[direction] if positions is None: positions = list(data.keys()) positions.sort() number = data[positions[0]]['stats']["count"].sum() // 2 heights, characters, indices = get_plot_data(data, positions) adaptive_y = max(adaptive_y, logo.est_ylim(heights)) plottables.append([direction, heights, characters, indices, number]) if ylim is None: ylim = adaptive_y for direction, heights, characters, indices, number in plottables: fr, to = list(map(bases.index, direction.split('to'))) ax = axes[fr, to] fig = logo.draw_multi_position(heights, characters=characters, position_indices=indices, ylim=ylim, ax=ax, figwidth=width, verbose=False) if sample_size: y = ax.get_ylim()[1] ax.text(0.2, y * 0.85, "N={:,}".format(number), fontsize=10) xformat = FuncFormatter(format_float(1e-3, float_places=2)) for i in range(4): top_ax = axes[0, i] top_ax.set_title( bases[i], fontsize=axis_font_size, weight="bold", y=1.1) lft_ax = axes[i, 0] for yticklabel in lft_ax.get_yticklabels(): yticklabel.set_fontsize(tick_font_size) yticklabel.set_rotation(0) lft_ax.yaxis.set_major_formatter(FuncFormatter(xformat)) lft_ax.set_ylabel(bases[i], rotation=0, fontsize=axis_font_size, weight="bold") lft_ax.yaxis.labelpad = axis_font_size btm_ax = axes[-1, i] for xticklabel in btm_ax.get_xticklabels(): xticklabel.set_fontsize(tick_font_size) xticklabel.set_rotation(0) f.tight_layout() return f
def get_four_position_fig(four_pos_results, positions, figsize, group_label=None, group_ref=None, figwidth=None, xtick_fontsize=14, ytick_fontsize=14): position_sets = list(combinations(positions, 4)) assert len(position_sets) == 1 rel_entropies = [four_pos_results[position_sets[0]]['rel_entropy']] ylim = logo.est_ylim(rel_entropies) rel_entropy = rel_entropies[0] fig = pyplot.figure(figsize=figsize) ax = fig.gca() num_pos = len(positions) + 1 mid_pos = num_pos // 2 position_re = numpy.zeros((num_pos,), float) characters = numpy.zeros((num_pos, 256), str) rets = numpy.zeros((256, num_pos), float) indices = list(range(4)) # now adjust indices to reflect position along sequence for i in range(len(indices)): if indices[i] >= mid_pos: indices[i] += 1 position_re.put(indices, rel_entropy) stats = four_pos_results[position_sets[0]]['stats'] mut_stats = stats[ get_selected_indices(stats, group_label=group_label, group_ref=group_ref)][['base1', 'base2', 'base3', 'base4', 'ret']] mut_stats = mut_stats.sort_values(by='ret') characters[indices[0]] = list(mut_stats['base1']) characters[indices[1]] = list(mut_stats['base2']) characters[indices[2]] = list(mut_stats['base3']) characters[indices[3]] = list(mut_stats['base4']) for index in indices: rets[:, index] = mut_stats['ret'] heights = get_re_char_heights(rets, re_positionwise=position_re) logo.draw_multi_position(char_heights=heights.T, characters=characters, position_indices=indices, ax=ax, ylim=ylim, xtick_fontsize=xtick_fontsize, ytick_fontsize=ytick_fontsize) return fig
def grid(fig_config, figpath, format, no_type3): """draws an arbitrary shaped grid of mutation motifs based on fig_config""" # we read in the config file and determine number of rows and columns # paths, headings, etc .. # then create the figure and axes and call the mutation_motif drawing code args = locals() if no_type3: util.exclude_type3_fonts() if not figpath: dirname = os.path.dirname(fig_config.name) figpath = os.path.join(dirname, "drawn_array.%s" % format) log_file_path = os.path.join(dirname, "drawn_array.log") else: figpath = util.abspath(figpath) log_file_path = "%s.log" % ".".join(figpath.split(".")[:-1]) util.makedirs(os.path.dirname(figpath)) LOGGER.log_file_path = log_file_path LOGGER.log_message(str(args), label='vars') ncols, nrows, figsize, col_labels, row_labels, paths, axis_cfg = \ read_plot_array_config(fig_config) print("ncols:", ncols) print("nrows:", nrows) print("figsize:", figsize) print("col_labels:", col_labels) print("row_labels:", row_labels) print("paths:", paths) print("axis_cfg:", axis_cfg) #TODO: Convert below into Cogent3 Plotly #-Plotly layout = UnionDict(shapes=[]) adaptive_y = 0 plottable = {} for coord in paths: data = util.load_loglin_stats(paths[coord]) positions = list(data) positions.sort() heights, characters, indices = get_plot_data(data, positions) adaptive_y = max(adaptive_y, logo.est_ylim(heights)) plottable[coord] = dict(char_heights=heights, characters=characters, position_indices=indices) ylim = axis_cfg.get("ylim", adaptive_y) for coord in plottable: kwargs = plottable[coord] kwargs["ax"] = coord kwargs["ylim"] = ylim r = logo.draw_multi_position_cogent3(**kwargs) for key in r: if key == "shapes": layout.shapes.extend(r.shapes) else: layout[key] = r[key] for i in range(0, ncols): xaxis = "xaxis" + str(i + 1 if i != 0 else "") layout[xaxis]["domain"] = [ 0.0 + (i * (1 / ncols)), (i * (1 / ncols)) + (1 / ncols) ] print(layout) MARGININCHES = 0 PPI = 100 fig = Drawable(layout=layout, width=(figsize[0] - MARGININCHES) * PPI, height=(figsize[1] - MARGININCHES) * PPI) #export fig.write(path=figpath) click.secho("Wrote Cogent3 %s" % figpath, fg="green") """
def grid(fig_config, figpath, format, no_type3): """draws an arbitrary shaped grid of mutation motifs based on fig_config""" # we read in the config file and determine number of rows and columns # paths, headings, etc .. # then create the figure and axes and call the mutation_motif drawing code args = locals() if no_type3: util.exclude_type3_fonts() if not figpath: dirname = os.path.dirname(fig_config.name) figpath = os.path.join(dirname, "drawn_array.%s" % format) log_file_path = os.path.join(dirname, "drawn_array.log") else: figpath = util.abspath(figpath) log_file_path = "%s.log" % ".".join(figpath.split(".")[:-1]) util.makedirs(os.path.dirname(figpath)) LOGGER.log_file_path = log_file_path LOGGER.log_message(str(args), label='vars') ncols, nrows, figsize, col_labels, row_labels, paths, axis_cfg = \ read_plot_array_config(fig_config) fig, axes = pyplot.subplots(nrows=nrows, ncols=ncols, figsize=figsize, sharex=True, sharey=True) figwidth = fig.get_figwidth() try: axes[0] except TypeError: axes = numpy.array([[axes]]) if len(axes.shape) == 1: # required for indexing of appropriate axis axes = numpy.vstack(axes) if nrows == 1: axes = axes.T adaptive_y = 0 plottable = {} for coord in paths: data = util.load_loglin_stats(paths[coord]) positions = list(data) positions.sort() heights, characters, indices = get_plot_data(data, positions) adaptive_y = max(adaptive_y, logo.est_ylim(heights)) plottable[coord] = dict(char_heights=heights, characters=characters, position_indices=indices, figwidth=figwidth, verbose=False) ylim = axis_cfg.get("ylim", adaptive_y) for coord in plottable: kwargs = plottable[coord] kwargs["ax"] = axes[coord] kwargs["ylim"] = ylim fig = logo.draw_multi_position(**kwargs) xformat = FuncFormatter(format_float(1e-3, float_places=2)) for col in range(ncols): top_ax = axes[0, col] top_ax.set_title(col_labels[col], fontsize=axis_cfg["xlabel_fontsize"], weight="bold", y=1.1) btm_ax = axes[-1, col] for xticklabel in btm_ax.get_xticklabels(): xticklabel.set_fontsize(axis_cfg["xtick_fontsize"]) xticklabel.set_rotation(0) btm_ax.set_xlabel("Position", fontsize=axis_cfg["xlabel_fontsize"], weight="bold") btm_ax.xaxis.labelpad = axis_cfg['xlabel_pad'] for row in range(nrows): lft_ax = axes[row, 0] for yticklabel in lft_ax.get_yticklabels(): yticklabel.set_fontsize(axis_cfg["ytick_fontsize"]) yticklabel.set_rotation(0) lft_ax.yaxis.set_major_formatter(FuncFormatter(xformat)) lft_ax.yaxis.labelpad = axis_cfg['ylabel_pad'] lft_ax.set_ylabel(row_labels[row], rotation=0, fontsize=axis_cfg['ylabel_fontsize'], weight="bold") fig.tight_layout() fig.savefig(figpath) click.secho("Wrote %s" % figpath, fg="green")
def get_three_position_fig(three_pos_results, positions, figsize, group_label=None, group_ref=None, figwidth=None, xtick_fontsize=14, ytick_fontsize=14): position_sets = list(combinations(positions, 3)) array_coords = get_resized_array_coordinates3(positions, position_sets) coords = list(array_coords.values()) xdim = max(v[0] for v in coords) + 1 ydim = max(v[1] for v in coords) + 1 fig, axarr = pyplot.subplots(xdim, ydim, figsize=figsize, sharex=True, sharey=True) for i in range(xdim): for j in range(ydim): if (i, j) in coords: continue ax = axarr[i, j] ax.set_frame_on(False) ax.get_xaxis().set_visible(False) ax.get_yaxis().set_visible(False) num_pos = len(positions) + 1 mid_pos = num_pos // 2 rel_entropies = [] for position_set in position_sets: rel_entropies.append(three_pos_results[position_set]['rel_entropy']) ylim = logo.est_ylim(rel_entropies) position_re = numpy.zeros((num_pos,), float) multi_positions = {} characters = numpy.zeros((num_pos, 64), str) for motif in combinations(positions, 3): rets = numpy.zeros((64, num_pos), float) indices = list(map(positions.index, motif)) row, col = array_coords[motif] ax = axarr[row, col] # now adjust indices to reflect position along sequence for i in range(len(indices)): if indices[i] >= mid_pos: indices[i] += 1 position_re.put(indices, three_pos_results[motif]['rel_entropy']) stats = three_pos_results[motif]['stats'] mut_stats = stats[ get_selected_indices(stats, group_label=group_label, group_ref=group_ref)][['base1', 'base2', 'base3', 'ret']] mut_stats = mut_stats.sort_values(by='ret') characters[indices[0]] = list(mut_stats['base1']) characters[indices[1]] = list(mut_stats['base2']) characters[indices[2]] = list(mut_stats['base3']) for index in indices: rets[:, index] = mut_stats['ret'] heights = get_re_char_heights(rets, re_positionwise=position_re) multi_positions[motif] = dict(rets=rets, indices=indices, characters=characters, heights=heights) logo.draw_multi_position(char_heights=heights.T, characters=characters, position_indices=indices, ax=ax, ylim=ylim, xtick_fontsize=xtick_fontsize, ytick_fontsize=ytick_fontsize) return fig