- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这比这更复杂,但简而言之,我正在尝试为序列族创建一个共识序列(仅由 A、C、G 和 T 字符组成的字符串),并且我无法识别在哪里我做的功能失败了。这是:
SEQUENCE calculate_cons(FAMILY FAM)
{
SEQUENCE cons;
int maxlenght=seq_with_max_char(FAM);
for(int i=0; i<maxlenght; i++)
{
int nA=0;
int nC=0;
int nG=0;
int nT=0;
for(int j=0; j<FAM.size; j++)
{
if(FAM.seq[j].c[i]=='A')
{
nA++;
}
if(FAM.seq[j].c[i]=='C')
{
nC++;
}
if(FAM.seq[j].c[i]=='G')
{
nG++;
}
if(FAM.seq[j].c[i]=='T')
{
nT++;
}
}
if((nA==nC) || (nA==nG) || (nA==nT))
{
cons.c[i]='.';
}
else
{
if((nA>nC) && (nA>nG) && (nA>nT))
{
cons.c[i]='A';
}
if((nC>nA) && (nC>nG) && (nC>nT))
{
cons.c[i]='C';
}
if((nG>nA) && (nG>nC) && (nG>nT))
{
cons.c[i]='G';
}
if((nT>nA) && (nT>nC) && (nT>nG))
{
cons.c[i]='T';
}
}
}
cons.lenght=maxlenght;
cons.ispartfam=true;
return cons;
}
问题:使用此代码,共识序列仅由“A”和“.”组成。例如,如果一个系列包含:
TCCTATGGAATCTTTTTA
TTCTATGGAATCTTTTTA
共识序列将是:
...A...AA.......A
该函数写入“.”当不存在2次A时,否则写“A”。它失败的行可能是 if((nA==nC) || (nA==nG) || (nA==nT)) 因为如果我与 nC 进行比较,共识族将只包含 'C' 和 ' .'.
编辑:您将在下面找到一个最小的繁殖示例。在保持清晰的同时,我不能比这更简约了。
#include <stdio.h>
int main()
{
int nbseq=2;
int seqsize=5;
char tseq[nbseq][seqsize];
char cons[seqsize];
tseq[0][0]='A';
tseq[0][1]='C';
tseq[0][2]='A';
tseq[0][3]='T';
tseq[0][4]='A';
tseq[1][0]='G';
tseq[1][1]='A';
tseq[1][2]='A';
tseq[1][3]='A';
tseq[1][4]='G';
for(int i=0; i<seqsize; i++)
{
int nA=0;
int nC=0;
int nG=0;
int nT=0;
for(int j=0; j<nbseq; j++)
{
if(tseq[j][i]=='A')
{
nA++;
}
if(tseq[j][i]=='C')
{
nC++;
}
if(tseq[j][i]=='G')
{
nG++;
}
if(tseq[j][i]=='T')
{
nT++;
}
}
if((nA==nC) || (nA==nG) || (nA==nT))
{
cons[i]='.';
}
else
{
if((nA>nC) && (nA>nG) && (nA>nT))
{
cons[i]='A';
}
if((nC>nA) && (nC>nG) && (nC>nT))
{
cons[i]='C';
}
if((nG>nA) && (nG>nC) && (nG>nT))
{
cons[i]='G';
}
if((nT>nA) && (nT>nC) && (nT>nG))
{
cons[i]='T';
}
}
}
for(int i=0; i<nbseq; i++)
{
for(int j=0; j<seqsize; j++)
{
printf("%c", tseq[i][j]);
}
printf("\n\n");
}
for(int i=0; i<seqsize; i++)
{
printf("%c", cons[i]);
}
return 0;
}
最佳答案
我同意有问题的路线是
if((nA==nC) || (nA==nG) || (nA==nT))
我认为这种逻辑背后的想法应该是,您需要在给定位置上有一个唯一的最大碱基数才能达成共识,因此必须拒绝平局。不幸的是,这个想法既有缺陷,也有错误的实现。
它是有缺陷的,因为平局在一般情况下并不重要,而只有在给定位置存在最大计数的平局时才是重要的。特别注意,如果给定位置的每个碱基都是 A,那么这些条件都不成立,但如果每个碱基都是其他碱基中的任何一个,那么其中两个都将评估为 true,形式为 0 == 0
.
它的实现不正确,因为您没有测试所有对。有六种不同的方法可以从一组四个不同的元素中形成对,但您只提供了三种。缺少的可能是 nC==nG
、nC==nT
和 nG==nT
。如果您也包含了这些内容,那么您的输出将仅包含“.”,但您恰好省略了允许共识 A 通过的内容。
更糟糕的是,这个特定的部分毫无意义。您不需要预先检查关系,因为尝试识别唯一最大值的部分无论如何都会排除关系(对于最大值)。那么,更有效的方法就是简单地设置“.”,而不是预先检查关系。当没有满足真正的共识条件时作为后备。有多种方法可以做到这一点,例如:
# Skip the explicit tie-checking altogether, and just do this ...
if ((nA > nC) && (nA > nG) && (nA > nT)) {
cons.c[i] = 'A';
} else if ((nC > nA) && (nC > nG) && (nC > nT)) {
cons.c[i] = 'C';
} else if ((nG > nA) && (nG > nC) && (nG > nT)) {
cons.c[i] = 'G';
} else if ((nT > nA) && (nT > nC) && (nT > nG)) {
cons.c[i] = 'T';
} else {
cons.c[i] = '.';
}
关于C : Unidentified if evaluation issue,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59620790/
我不知道我做了什么来破坏我的 QtCreator,但是“突然”我所有的编译器问题(警告/错误)不再显示在问题面板中,而是只显示在“编译输出”面板中(我在那里不能使用它们通过单击跳转到错误代码)。 在“
我正在制作游戏作为自学。 我的目标是在鼠标指针后面有一条轨迹。(这有效)但是,当我在 chrome 上打开并运行它时。在达到一定的高度和宽度后,轨迹保留在 Canvas 上而不是被擦掉。谁能帮我解决这
我希望通过在我的HTML文件中适当地格式化我的网站上的文本来增强它的外观。具体地说,我希望确保我的HTML文件中的代码在网站上显示得很好。此外,我正在寻求帮助实现我的网站导航栏。,我希望和其他内容显示
我希望通过在我的HTML文件中适当地格式化我的网站上的文本来增强它的外观。具体地说,我希望确保我的HTML文件中的代码在网站上显示得很好。此外,我正在寻求帮助实现我的网站导航栏。,我希望和其他内容显示
我希望通过在我的HTML文件中适当地格式化我的网站上的文本来增强它的外观。具体地说,我希望确保我的HTML文件中的代码在网站上显示得很好。此外,我正在寻求帮助实现我的网站导航栏。,我希望和其他内容显示
我一直在尝试将背景图像添加到 html 文档中元素的边框: 你可以在这里看到:HTML: Something CSS: a { border-width:10px; border-co
我即将开始一个连接两个程序的项目,一个用c#,一个用c++。我已经有一个可以工作的 c# 程序,它能够与自身的其他版本对话。在开始使用c++版本之前,我想到了一些问题: 1) 我正在使用 protob
我正在尝试线程优先级的影响,当 run 方法中的 println 保留在注释中时,两个线程同时结束,我不理解这种行为,你能解释一下吗?谢谢。 主类 public class Main { public
jQuery 1.4: $('#menu li:last:not(.ignore)').addClass('last'); HTML: item 1 ite
当我创建或查看问题时,我想从Mantis问题跟踪系统中删除选择配置文件及其所有随附字段,因为这些问题与我要创建的任何问题都不相关。 其中包括配置文件部分随附的“平台”,“操作系统”和“操作系统版本”字
我不在Master分支上工作。我正在开发另一种newFeature,该功能也发布在github上。 我知道在处理Master分支时如何解决问题:Closes #XXX。 但是,这仅在我在Master分
我需要在一些UICollectionViewCell中画一个圆圈。具有不同颜色边框和背景颜色的圆圈。我的代码。 UICollectionViewController - (UICollectionVi
我们将Trac用于我正在从事的开源项目。我想将所有公开票导出到Github的Issues。我已经找到了一些可能的小型脚本,但是我想知道是否有人这样做并提出了建议。 理想情况下,它将trac的描述语法转
我对 iOS 编程还比较陌生,但在其他语言(主要是 C# 和 Java)方面拥有丰富的编程经验。 我正在尝试为 iPad 设备的某些产品制作一个类似图片库的东西,其中包含指定的类别。用户界面非常简单,
我已经在中间人中激活了 I18n,如下所示: activate :i18n, mount_at_root: :de 现在我想自动从 / 重定向到 /de。这可能吗? 另外,我想知道为什么中间人使用 p
我已经成功编写了一个程序,可以从 Excel 文件中读取数据并将它们存储在 mysql 的表中。我的程序读取每个文件的第一行,创建表的字段,并将其余数据存储为每列中的值。正是因为这种情况以编程方式发生
这是我的代码。 function m1() { return new Promise(function(resolve, reject) { var files = $('#aws-upl
谁能告诉我这是怎么回事? #include #include #include #include #include class writeManager { std::vector
compile 'com.github.RogaLabs:social-login:1.2.1' compile 'com.github.mukeshsolanki:social-login-help
我有一个巨大的 csv 文件,其中包含 149 列 和 25K+ 行,可以在 MySQL 中上传该文件> 我正在使用MySQL LOAD DATA 查询 表我的查询是: LOAD DATA local
我是一名优秀的程序员,十分优秀!