当前位置: 首页 > news >正文

3D基因组工具(HiC可视化)trackc--bioinfomatics tools 35

01 3D genome data analysis guides

茶树三维基因组-文献精读19

https://trackc.readthedocs.io/en/latest/install.html    #官网
https://github.com/seqyuan/trackc           #官网https://trackc.readthedocs.io/en/latest/analysis_guide/index.html   #HiC可视化案例
GridSpec

在基因组区域中可视化多组学数据通常需要结合多个轨迹(tracks)。为了创建适合发表的高质量图像,精细调整每个轨迹的比例非常重要。快速调整轨迹比例以及轻松添加或移除轨迹的能力是一个重要问题。

trackc 提供了两种方法来绘制布局:

  1. trackc.tenon

  2. trackc.make_spec

这些函数为用户提供了一种快速灵活的方法,用于调整每个轨迹的比例,同时方便地在多组学可视化布局中添加或移除轨迹。

1. trackc.tenon
  • trackc.tenon 返回一个对象。例如:

    ten = trackc.tenon(width=5, height=1)

    在此示例中,ten 是一个表示虚拟图形的对象,其宽度为 5,高度为 1。用户可以通过以下方法向该图形添加轨迹:

    ten.add(pos='bottom', height=4, hspace=0.1)
    • height 参数 表示新添加轨迹的相对高度。例如,如果虚拟图形的高度为 1,而新轨迹的高度为 4,则子图的实际高度将为 1 * 4。

    • 使用 ten.add 方法 类似于搭建积木,用户可以通过 pos 参数 选择将新轨迹添加到顶部(top)或底部(bottom)。

    • hspace=0.1 参数 控制新轨迹与相邻轨迹之间的间距。

2. trackc.make_spec
  • trackc.make_spec 定义整个图像的大小,允许用户从上到下或从左到右设置一组子图,可以通过 height_ratioswidth_ratios 控制各部分的比例。

可用轨迹

本节包括多个快速教程,展示了使用 trackc 进行组学数据可视化的功能。

  • GridSpec
    • trackc.tenon
    • trackc.make_spec
  • scale
    • trackc.pl.scale_track
    • trackc.pl.multi_scale_track
  • mapC
    • Get test data
  • mapc_markline
  • Virtual4C
    • Get test Data
  • gene
    • convert GTF to BED12
    • trackc.pl.scale_track
  • bigwig
    • Get test data
  • bed
    • bed styles
  • bedGraphMatrix
  • links
    • Get test data
  • zoomin
  • highlight line
02 安装

trackc 运行需要 Python 版本 >= 3.8。

通过 PyPI 安装

使用以下命令安装 trackc:pip install trackc
更新 trackc 的命令:pip install --upgrade trackc
指定版本和安装源的命令:pip install -i https://pypi.org/simple trackc==版本号

开发版本

从 GitHub 安装 trackc 的命令:pip install git+https://github.com/seqyuan/trackc@main
03 heatmap
conf-hicmap_1.yml等很多
trackc:- ax: t1height: 2track_type: hicmaptrack_para:mat:method: extractContactRegionsclr: /path/GSM4417639_SK-N-DZ_C6BC81F2_b38d5.mcool::/resolutions/5120000row_regions:- chr6- chr8mapC:cmap: plasma
运行
trackc cli conf-hicmap_1.yml -s 4,1 -o chr6_chr8.pdf

conf-hicmap_4.yml

trackc:- ax: t1height: 1track_type: hicmaptrack_para:mat:method: extractCisContactclr: ./github/seqyuan/trackc_data/examples/HPDE6C7.chr18.mcool::/resolutions/25000mapC:map_type: triheight: 50label: tri- ax: t2height: 1hspace: 0.3track_type: hicmaptrack_para:mat2:method: extractCisContactclr: ./github/seqyuan/trackc_data/examples/HPDE6C7.chr18.mcool::/resolutions/25000mapC:map_type: triheight: 50label: tri-mat2- ax: t3height: 2hspace: 0.3track_type: hicmaptrack_para:mat:method: extractCisContactclr: ./github/seqyuan/trackc_data/examples/HPDE6C7.chr18.mcool::/resolutions/25000mapC:map_type: triheight: 50label: tri-symmetricsymmetric: True- ax: t4height: 1hspace: 0.3track_type: hicmaptrack_para:mat:method: extractCisContactclr:./github/seqyuan/trackc_data/examples/BxPC3.chr18.mcool::/resolutions/25000extend: 50mapC:cmap: PuBumap_type: recheight: 50label: rec- ax: t5height: 1hspace: 0.3track_type: hicmaptrack_para:mat2:method: extractCisContactclr: ./github/seqyuan/trackc_data/examples/BxPC3.chr18.mcool::/resolutions/25000extend: 50mapC:cmap: cividismap_type: recheight: 50label: rec-mat2- ax: t6height: 2hspace: 0.3track_type: hicmaptrack_para:mat2:method: extractCisContactclr: ./github/seqyuan/trackc_data/examples/BxPC3.chr18.mcool::/resolutions/25000extend: 50mapC:cmap: magmamap_type: recheight: 50symmetric: Truelogdata: Truelabel: rec-symmetric- ax: t1track_type: scale_tracktrack_para:scale_adjust: Mbtick_pos: topratio2ax: 1

运行

trackc cli conf-hicmap_4.yml -r 18:10000000-14500000

 

04 rearranged_interactions

ectopic_interactions.yaml

trackc:- ax: t1height: 2track_type: hicmaptrack_para:mat:method: extractContactRegionsclr: ./github/seqyuan/trackc_data/examples/BxPC3.chr18.mcool::/resolutions/50000balance: Falserow_regions: 18:45000000-78077248mapC:map_type: trilabel: tumor res=50kcmap: PuBumaxrange: 70ax_on: False- ax: t1track_type: scale_tracktrack_para:region: 18:45000000-78077248scale_adjust: Mbtick_pos: topratio2ax: 0.3space: 0.01tick_fontsize: 6label_fontsize: 7- ax: t2height: 0.2track_type: zoomintrack_para:raw_regions: 18:45000000-78077248zoomin_regions:- 18:47340000-50370000- 18:61140000-63630000- 18:74030000-77560000line_on: Falsefill: Truealpha: 0.5- ax: t3height: 0.4track_type: multi_scale_tracktrack_para:regions:- 18:47340000-50370000- 18:61140000-63630000- 18:74030000-77560000scale_adjust: Mbintervals: 2tick_fontsize: 7- ax: t4height: 2track_type: hicmaptrack_para:mat2:method: extractContactRegionsclr: ./github/seqyuan/trackc_data/examples/BxPC3.chr18.mcool::/resolutions/25000balance: Falserow_regions:- 18:47340000-50370000- 18:61140000-63630000- 18:74030000-77560000mapC:map_type: trilabel: ectopic interactionscmap: PuBuax_on: Falsemaxrange: 100- ax: t5height: 0.2track_type: zoomintrack_para:raw_regions:- 18:47340000-50370000- 18:61140000-63630000- 18:74030000-77560000zoomin_regions:- 18:47400000-48280000- 18:75280000-74030000line_on: Falsefill: Truealpha: 0.5- ax: t6height: 0.4track_type: multi_scale_tracktrack_para:regions:- 18:47400000-48280000- 18:75280000-74030000scale_adjust: Mbintervals: 2tick_fontsize: 7- ax: t7height: 1.25track_type: hicmaptrack_para:mat:method: extractContactRegionsclr: ./github/seqyuan/trackc_data/examples/BxPC3.chr18.mcool::/resolutions/25000balance: Falserow_regions:- 18:47400000-48280000- 18:75280000-74030000mapC:map_type: trilabel: neo tadcmap: PuBuheight: 40ax_on: Falsemaxrange: 200minrange: 10- ax: t8height: 0.5track_type: bw_tracktrack_para:bw: ./github/seqyuan/trackc_data/examples/GSM3178671_BxPC3_H3K27ac.bigwigregions:- 18:47400000-48280000- 18:75280000-74030000label: H3K27acbinsize: 2000color:- '#5B7695'- ax: t9height: 2.8track_type: gene_tracktrack_para:bed12: ./github/seqyuan/trackc_data/examples/hg19_chr18.gene.bed12regions:- 18:47400000-48280000- 18:75280000-74030000line: 12gene_fontszie: 8

运行

trackc cli ectopic_interactions.yaml -s 5,1


 

05 Virtual 4C

4C.yaml

trackc:- ax: t1height: 4track_type: hicmaptrack_para:mat:method: extractContactRegionsclr: ./github/seqyuan/trackc_data/tutorials/4C/GSM4604287_1360.sub.coolbalance: FalsemapC:map_type: trilabel: AML 1360cmap: PuBumaxrange: 6minrange: -6- ax: t2height: 0.7track_type: gene_tracktrack_para:bed12: ./github/seqyuan/trackc_data/tutorials/4C/GRCh38.gene.chr8chr14.bed12line: 3gene_fontszie: 10show_label:- MYC- ax: t3height: 0.7track_type: bw_tracktrack_para:bw: ./github/seqyuan/trackc_data/tutorials/4C/GSM4604189_H3K27ac.bwmaxrange: 10label: H3K27acbinsize: 10000invert_y: False- ax: t4height: 0.6track_type: virtual4Ctrack_para:clr: ./github/seqyuan/trackc_data/tutorials/4C/GSM4604287_1360.sub.coolmaxrange: 10label: Virtual 4Ctarget_color: tab:redtrack_type: linetarget: chr8:127735434-127735435- ax: t5height: 0.6track_type: multi_scale_tracktrack_para:scale_adjust: Mbintervals: 1tick_fontsize: 8

运行

trackc cli 4C.yaml -s 6,0.75 -r 'chr8:127000000-129200000 chr14:96500000-99300000'

06 常用命令行
import trackc as tcten = tc.tenon(figsize=(8,1))
ten.add(pos='bottom', height=3.6)
ten.add(pos='bottom', height=1)chr6_len = clr.chromsizes['chr6']
chr8_len = clr.chromsizes['chr8']mat = tc.tl.extractContactRegions(clr='GSM4417639_SK-N-DZ_C6BC81F2_b38d5.mcool::/resolutions/5120000', row_regions=['chr6', 'chr8'])
tc.pl.mapC(ax=ten.axs(0), mat=mat.cmat, map_type='triangle', maxrange=5000)tc.pl.multi_scale_track(ax=ten.axs(1), regions=['chr6:0-{0}'.format(chr6_len), 'chr8:0-{0}'.format(chr8_len)],scale_adjust='Mb', intervals=2, tick_rotation=0)
# tc.savefig('hicmap.pdf')

相关文章:

3D基因组工具(HiC可视化)trackc--bioinfomatics tools 35

01 3D genome data analysis guides 茶树三维基因组-文献精读19 https://trackc.readthedocs.io/en/latest/install.html #官网 https://github.com/seqyuan/trackc #官网https://trackc.readthedocs.io/en/latest/analysis_guide/index.html #HiC可视化案例 …...

【大模型微调】图片转pdf

有时候图片需要转成pdf https://www.bilibili.com/opus/982151156821131282 https://help.pdf24.org/ https://www.bilibili.com/video/BV163v2eyEWo/?vd_source=8318f88fcdf4948d2b21fae7c9cf3184 2024最新!小白如何安装破解版的 Acrobat https://www.32r.com/zt/dgyjzzrj/ …...

Linux-Ubuntu16.04摄像头 客户端抓取帧并保存为PNG

1.0&#xff1a;client.c抓取帧并保存为PNG #include <stdio.h> // 标准输入输出库 #include <stdlib.h> // 标准库&#xff0c;包含内存分配等函数 #include <string.h> // 字符串操作库 #include <linux/videodev2.h> // V4L2 视频设备…...

手机ip地址取决于什么?可以随便改吗

手机IP地址是指手机在连接到互联网时所获得的唯一网络地址&#xff0c;这个地址由一串数字组成&#xff0c;用于在网络中标识和定位设备。每个设备在连接到网络时都会被分配一个IP地址&#xff0c;它可以帮助数据包在网络中准确地找到目标设备。那么&#xff0c;手机IP地址究竟…...

计算机网络:TCP/IP协议的五大重要特性介绍

目录 一、逻辑编址 二、路由选择 三、名称解析 四、错误控制和流量控制 五、多应用支持 今天给大家聊聊TCP/IP协议中五大重要特性相关的知识,希望对大家深入了解该协议提供一些帮助! 一、逻辑编址 首先要了解什么是物理地址、逻辑地址。 ●...

Java与AWS S3的文件操作

从零开始&#xff1a;Java与AWS S3的文件操作 一、什么是 AWS S3&#xff1f;AWS S3 的特点AWS S3 的应用场景 二、Java整合S3方法使用 MinIO 客户端操作 S3使用 AWS SDK 操作 S3 &#xff08;推荐使用&#xff09; 三、总结 一、什么是 AWS S3&#xff1f; Amazon Simple Sto…...

详解 YOLOv5 模型运行参数含义以及设置及在 PyCharm 中的配置方法

详解 YOLOv5 模型运行参数含义以及设置及在 PyCharm 中的配置方法 这段代码中使用的命令行参数允许用户在运行 YOLOv5 模型时自定义多种行为和设置。以下是各个参数的详细说明和使用示例&#xff0c;以及如何在 PyCharm 中设置这些参数以确保正确运行带有参数的脚本。 命令行…...

Vue根据Div内容的高度给其Div设置style height

在 Vue.js 中&#xff0c;你可以使用 JavaScript 来动态地根据 div 的内容高度来设置其 style 的 height 属性。这通常是在组件挂载或更新时完成的&#xff0c;因为这时你已经有了实际的 DOM 元素可以操作。 以下是一个简单的例子&#xff0c;展示了如何实现这一点&#xff1a…...

驱动篇的开端

准备 在做之后的动作前&#xff0c;因为win7及其以上的版本默认是不支持DbgPrint&#xff08;大家暂时理解为内核版的printf&#xff09;的打印&#xff0c;所以&#xff0c;为了方便我们的调试&#xff0c;我们先要修改一下注册表 创建一个reg文件然后运行 Windows Registr…...

OpenSSL 自建CA 以及颁发证书(网站部署https双向认证)

前言 1、前面写过一篇 阿里云免费ssl证书申请与部署&#xff0c;大家可以去看下 一、openssl 安装说明 1、这部分就不再说了&#xff0c;我使用centos7.9&#xff0c;是自带 openssl的&#xff0c;window的话&#xff0c;要去下载安装 二、CA机构 CA机构&#xff0c;全称为…...

吾杯网络安全技能大赛WP(部分)

吾杯网络安全技能大赛WP(部分) MISC Sign 直接16进制解码即可 原神启动 将图片用StegSolve打开 找到了压缩包密码 将解出docx文件改为zip 找到了一张图片和zip 再把图片放到stegSlove里找到了img压缩包的密码 然后在document.xml里找到了text.zip压缩包密码 然后就出来fl…...

按vue组件实例类型实现非侵入式国际化多语言翻译

#vue3##国际化##本地化##international# web界面国际化&#xff0c;I18N&#xff08;Internationalization&#xff0c;国际化&#xff09;&#xff0c;I11L(International&#xff0c;英特纳雄耐尔)&#xff0c;L10N&#xff08;Localization&#xff0c;本地化&#xff09;&…...

Java入门:22.集合的特点,List,Set和Map集合的使用

1 什么是集合 本质就是容器的封装&#xff0c;可以存储多个元素 数组一旦创建&#xff0c;长度就不能再改变了。 数组一旦创建&#xff0c;存储内容的类型不能改变。 数组可以存储基本类型&#xff0c;也可以存储引用类型。 数组可以通过length获得容量的大小&#xff0c;但…...

重生之我在异世界学编程之C语言:深入指针篇(下)

大家好&#xff0c;这里是小编的博客频道 小编的博客&#xff1a;就爱学编程 很高兴在CSDN这个大家庭与大家相识&#xff0c;希望能在这里与大家共同进步&#xff0c;共同收获更好的自己&#xff01;&#xff01;&#xff01; 目录 题集&#xff08;1&#xff09;指针笔试题1&a…...

理解Parquet文件和Arrow格式:从Hugging Face数据集的角度出发

parquet发音&#xff1a;美 [pɑrˈkeɪ] 镶木地板&#xff1b;拼花木地板 理解Parquet文件和Arrow格式&#xff1a;从Hugging Face数据集的角度出发 引言 在机器学习和大数据处理中&#xff0c;数据的存储和传输格式对于性能至关重要。两种广泛使用的格式是 Parquet 和 Arr…...

下载 M3U8 格式的视频

要下载 M3U8 格式的视频&#xff08;通常是 HLS 视频流&#xff09;&#xff0c;可以尝试以下几种方法&#xff1a; 方法 1&#xff1a;使用下载工具&#xff08;推荐&#xff09; 1. IDM&#xff08;Internet Download Manager&#xff09;&#xff1a; 安装 IDM 并启用浏…...

Tomcat使用教程

下载地址&#xff1a;https://tomcat.apache.org/ 配置环境变量 变量名: CATALINA_HOME 变量值: D:\tools\apache-tomcat-9.0.97 Path: %CATALINA_HOME%\bin 启动Tomcat(打开命令提示符) startup.bat 解决乱码问题(打开conf\logging.properties) java.util.logging.Conso…...

LabVIEW氢气纯化控制系统

基于LabVIEW的氢气纯化控制系统满足氢气纯化过程中对精确控制的需求&#xff0c;具备参数设置、过程监控、数据记录和报警功能&#xff0c;体现了LabVIEW在复杂工业控制系统中的应用效能。 项目背景 在众多行业中&#xff0c;尤其是石油化工和航天航空领域&#xff0c;氢气作为…...

现在的电商风口已经很明显了

随着电商行业的不断发展&#xff0c;直播带货的热潮似乎正逐渐降温&#xff0c;而货架电商正成为新的焦点。抖音等平台越来越重视货架电商&#xff0c;强调搜索功能的重要性&#xff0c;预示着未来的电商中心将转向货架和搜索。 在这一转型期&#xff0c;AI技术与电商的结合为…...

Uniapp触底刷新

在你的代码中&#xff0c;使用了 scroll-view 来实现一个可滚动的评论区域&#xff0c;并且通过监听 scrolltolower 事件来触发 handleScrollToLower 函数&#xff0c;以实现“触底更新”或加载更多评论的功能。 关键部分分析&#xff1a; scroll-view 组件: scroll-view 是一…...

深入剖析AI大模型:大模型时代的 Prompt 工程全解析

今天聊的内容&#xff0c;我认为是AI开发里面非常重要的内容。它在AI开发里无处不在&#xff0c;当你对 AI 助手说 "用李白的风格写一首关于人工智能的诗"&#xff0c;或者让翻译模型 "将这段合同翻译成商务日语" 时&#xff0c;输入的这句话就是 Prompt。…...

基于FPGA的PID算法学习———实现PID比例控制算法

基于FPGA的PID算法学习 前言一、PID算法分析二、PID仿真分析1. PID代码2.PI代码3.P代码4.顶层5.测试文件6.仿真波形 总结 前言 学习内容&#xff1a;参考网站&#xff1a; PID算法控制 PID即&#xff1a;Proportional&#xff08;比例&#xff09;、Integral&#xff08;积分&…...

AI Agent与Agentic AI:原理、应用、挑战与未来展望

文章目录 一、引言二、AI Agent与Agentic AI的兴起2.1 技术契机与生态成熟2.2 Agent的定义与特征2.3 Agent的发展历程 三、AI Agent的核心技术栈解密3.1 感知模块代码示例&#xff1a;使用Python和OpenCV进行图像识别 3.2 认知与决策模块代码示例&#xff1a;使用OpenAI GPT-3进…...

376. Wiggle Subsequence

376. Wiggle Subsequence 代码 class Solution { public:int wiggleMaxLength(vector<int>& nums) {int n nums.size();int res 1;int prediff 0;int curdiff 0;for(int i 0;i < n-1;i){curdiff nums[i1] - nums[i];if( (prediff > 0 && curdif…...

华为OD机试-食堂供餐-二分法

import java.util.Arrays; import java.util.Scanner;public class DemoTest3 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseint a in.nextIn…...

Psychopy音频的使用

Psychopy音频的使用 本文主要解决以下问题&#xff1a; 指定音频引擎与设备&#xff1b;播放音频文件 本文所使用的环境&#xff1a; Python3.10 numpy2.2.6 psychopy2025.1.1 psychtoolbox3.0.19.14 一、音频配置 Psychopy文档链接为Sound - for audio playback — Psy…...

力扣-35.搜索插入位置

题目描述 给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c;并返回其索引。如果目标值不存在于数组中&#xff0c;返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 class Solution {public int searchInsert(int[] nums, …...

return this;返回的是谁

一个审批系统的示例来演示责任链模式的实现。假设公司需要处理不同金额的采购申请&#xff0c;不同级别的经理有不同的审批权限&#xff1a; // 抽象处理者&#xff1a;审批者 abstract class Approver {protected Approver successor; // 下一个处理者// 设置下一个处理者pub…...

Redis:现代应用开发的高效内存数据存储利器

一、Redis的起源与发展 Redis最初由意大利程序员Salvatore Sanfilippo在2009年开发&#xff0c;其初衷是为了满足他自己的一个项目需求&#xff0c;即需要一个高性能的键值存储系统来解决传统数据库在高并发场景下的性能瓶颈。随着项目的开源&#xff0c;Redis凭借其简单易用、…...

Kafka主题运维全指南:从基础配置到故障处理

#作者&#xff1a;张桐瑞 文章目录 主题日常管理1. 修改主题分区。2. 修改主题级别参数。3. 变更副本数。4. 修改主题限速。5.主题分区迁移。6. 常见主题错误处理常见错误1&#xff1a;主题删除失败。常见错误2&#xff1a;__consumer_offsets占用太多的磁盘。 主题日常管理 …...