对计算器中位点的Fst进行分析

2024-03-16 15:40

本文主要是介绍对计算器中位点的Fst进行分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

科普:Fst,群体间分化指数,用于群体间分化分析。
取值范围:[0, 1]
划分标准:
0~0.05:群体间遗传分化很小,可以不考虑;
0.05~0.15,群体间存在中等程度的遗传分化;
0.15~0.25,群体间遗传分化较大;
0.25以上,群体间有很大的遗传分化。
在这里,我们以三种计算器:K3,K12b,K47分别代表k数小、中、大的计算器来进行研究
计算方法:https://blog.csdn.net/q623928815/article/details/78627610?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522163905592216780357252120%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fall.%2522%257D&request_id=163905592216780357252120&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2allfirst_rank_ecpm_v1~rank_v31_ecpm-5-78627610.pc_search_result_cache&utm_term=%E7%BE%A4%E4%BD%93%E9%97%B4%E5%88%86%E5%8C%96%E6%8C%87%E6%95%B0&spm=1018.2226.3001.4187
Python代码实现:

import pandas as pd
import matplotlib.pyplot as plt
import numpy as npplt.rcParams['font.sans-serif'] = ['Arial Unicode MS']
df1 = pd.read_csv('k12b_fst.csv', index_col = 0, header = 0)
df2 = pd.read_csv('k47_fst.csv', index_col = 0, header = 0)
df3 = pd.read_csv('k3_fst.csv', index_col = 0, header = 0)a1 = df1[df1.Fst <= 0.05].shape[0]
b1 = df1[(0.05 < df1.Fst) & (df1.Fst <= 0.15)].shape[0]
c1 = df1[(0.15 < df1.Fst) & (df1.Fst <= 0.25)].shape[0]
d1 = df1[df1.Fst > 0.25].shape[0]a2 = df2[df2.Fst <= 0.05].shape[0]
b2 = df2[(0.05 < df2.Fst) & (df2.Fst <= 0.15)].shape[0]
c2 = df2[(0.15 < df2.Fst) & (df2.Fst <= 0.25)].shape[0]
d2 = df2[df2.Fst > 0.25].shape[0]a3 = df3[df3.Fst <= 0.05].shape[0]
b3 = df3[(0.05 < df3.Fst) & (df3.Fst <= 0.15)].shape[0]
c3 = df3[(0.15 < df3.Fst) & (df3.Fst <= 0.25)].shape[0]
d3 = df3[df3.Fst > 0.25].shape[0]plt.plot([1, 2, 3, 4], [a1, b1, c1, d1], c = plt.cm.get_cmap('Set3')(0), marker = 'o', markersize = 3)
plt.plot([1, 2, 3, 4], [a2, b2, c2, d2], c = plt.cm.get_cmap('Set3')(2), marker = 'o', markersize = 3)
plt.plot([1, 2, 3, 4], [a3, b3, c3, d3], c = plt.cm.get_cmap('Set3')(3), marker = 'o', markersize = 3)
plt.legend(['K12b', 'K47', 'LM-K3'])
plt.xticks([1, 2, 3, 4], ['分化很小', '中等程度', '分化较大', '分化很大'])
plt.title('三种计算器Fst值大小位点数')
plt.rcParams['savefig.dpi'] = 600
plt.tight_layout()
plt.savefig(f'plot_Fst.jpg', bbox_inches = 'tight')

三种计算器按照分类标准分类后折线图:
Fst
得出结论:

  1. Fst中等及以上位点数越多计算器越准确,注意是位点数而不是占比。
  2. 而且说明计算器位点数对于稳定性的影响可能是大于Fst值各部分占比对稳定性的影响,所以说明筛选计算器位点的时候可以适当放宽Fst标准然后增加位点数。
    这三个计算器单个位点Fst值对应情况在附件中,可供大家下载。

https://download.csdn.net/download/yhlhhhhh/76032290

这篇关于对计算器中位点的Fst进行分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/815939

相关文章

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

使用Python实现一个简易计算器的新手指南

《使用Python实现一个简易计算器的新手指南》计算器是编程入门的经典项目,它涵盖了变量、输入输出、条件判断等核心编程概念,通过这个小项目,可以快速掌握Python的基础语法,并为后续更复杂的项目打下... 目录准备工作基础概念解析分步实现计算器第一步:获取用户输入第二步:实现基本运算第三步:显示计算结果进

MySQL按时间维度对亿级数据表进行平滑分表

《MySQL按时间维度对亿级数据表进行平滑分表》本文将以一个真实的4亿数据表分表案例为基础,详细介绍如何在不影响线上业务的情况下,完成按时间维度分表的完整过程,感兴趣的小伙伴可以了解一下... 目录引言一、为什么我们需要分表1.1 单表数据量过大的问题1.2 分表方案选型二、分表前的准备工作2.1 数据评估

MySQL进行分片合并的实现步骤

《MySQL进行分片合并的实现步骤》分片合并是指在分布式数据库系统中,将不同分片上的查询结果进行整合,以获得完整的查询结果,下面就来具体介绍一下,感兴趣的可以了解一下... 目录环境准备项目依赖数据源配置分片上下文分片查询和合并代码实现1. 查询单条记录2. 跨分片查询和合并测试结论分片合并(Shardin

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

Linux中的HTTPS协议原理分析

《Linux中的HTTPS协议原理分析》文章解释了HTTPS的必要性:HTTP明文传输易被篡改和劫持,HTTPS通过非对称加密协商对称密钥、CA证书认证和混合加密机制,有效防范中间人攻击,保障通信安全... 目录一、什么是加密和解密?二、为什么需要加密?三、常见的加密方式3.1 对称加密3.2非对称加密四、

MySQL中读写分离方案对比分析与选型建议

《MySQL中读写分离方案对比分析与选型建议》MySQL读写分离是提升数据库可用性和性能的常见手段,本文将围绕现实生产环境中常见的几种读写分离模式进行系统对比,希望对大家有所帮助... 目录一、问题背景介绍二、多种解决方案对比2.1 原生mysql主从复制2.2 Proxy层中间件:ProxySQL2.3

SpringBoot结合Knife4j进行API分组授权管理配置详解

《SpringBoot结合Knife4j进行API分组授权管理配置详解》在现代的微服务架构中,API文档和授权管理是不可或缺的一部分,本文将介绍如何在SpringBoot应用中集成Knife4j,并进... 目录环境准备配置 Swagger配置 Swagger OpenAPI自定义 Swagger UI 底

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

Nginx进行平滑升级的实战指南(不中断服务版本更新)

《Nginx进行平滑升级的实战指南(不中断服务版本更新)》Nginx的平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法,这种升级方式确保了服务的高可用性,避免了因升... 目录一.下载并编译新版Nginx1.下载解压2.编译二.替换可执行文件,并平滑升级1.替换可执行文件