继续上面MetaNeighbor 1的学习,我们做第二个测试数据,第二组场景的测试。
========测试数据2============
第二个数据集,基于已经训练好或者注释好的参考数据集,来衡量新数据集细胞类型注释的准确性。这个测试数据是采用的BICCN,一个小鼠初级运动皮层的细胞。可以去作者的paper链接中下载。
library(MetaNeighbor)
library(SingleCellExperiment)
biccn_data <- readRDS("full_biccn_hvg.rds")
colnames(colData(biccn_data))

table(biccn_data$study_id)

dim(biccn_data)

从数据集来看,BICCN数据包含7个不同sample的数据集,总共482,712个细胞。这个数据,作者已经鱼过滤,挑了319个高变异的基因了。
下面,使用trainModel函数通过训练来获得参考数据集,该函数具有与前面使用的MetaNeighborUS函数相同的参数。这里,我们利用两种不同的注释信息:一个是joint_subclass_label(中等分辨率,例如Vip中间神经元、L2/3 IT兴奋神经元)和joint_cluster_label(高分辨率,例如Chandelier细胞),其实就是一个注释的偏大类,一个注释到了小类。
pretrained_model <- MetaNeighbor::trainModel(var_genes = rownames(biccn_data),
dat = biccn_data,
study_id = biccn_data$study_id,
cell_type = biccn_data$joint_subclass_label)
write.table(pretrained_model,"pretrained_biccn_subclasses.txt")
pretrained_model <- MetaNeighbor::trainModel(var_genes = rownames(biccn_data),
dat = biccn_data,
study_id = biccn_data$study_id,
cell_type = biccn_data$joint_cluster_label)
write.table(pretrained_model,"pretrained_biccn_clusters.txt")
下面,我们就加载我们的测试数据,也是scRNAseq包中的一组数据。
library(scRNAseq)
tasic <- TasicBrainData(ensembl=FALSE)
colnames(colData(tasic))
tasic$study_id <- "tasic"
biccn_subclasses <- read.table("pretrained_biccn_subclasses.txt",check.names=FALSE)
biccn_clusters <- read.table("pretrained_biccn_clusters.txt",check.names=FALSE)
aurocs <- MetaNeighborUS(trained_model=biccn_subclasses,
dat = tasic,
study_id = tasic$study_id,
cell_type = tasic$primary_type,
fast_version=TRUE)
plotHeatmapPretrained(aurocs)
从图中可以看出,主要有3个大的block,根据细胞类型来看,主要是non-neurons (左上), inhibitory neurons (中间block) 和excitatory neurons (右下角)。同时也说明在三个大类型内部,可以相互很好的匹配和预测。其实大类里面还可以再继续细分小类,比如中间的inhibitory neurons。

进而,为了更加清晰的去发现inhibitory neurons 这个类型的详细信息,我们可以利用splitTrainClusters和splitTestClusters函数,来提取结果的子集重新显示。
gabaergic_tasic <- splitTestClusters(aurocs,k=4)[[2]]
gabaergic_biccn <- splitTrainClusters(aurocs[gabaergic_tasic,],k=4)[[4]]
full_label <- makeClusterName(tasic$study_id,tasic$primary_type)
tasic_subdata <- tasic[,full_label %in% gabaergic_tasic]
aurocs <- MetaNeighborUS(trained_model=biccn_subclasses[,gabaergic_biccn],
dat = tasic_subdata,
study_id = tasic_subdata$study_id,
cell_type = tasic_subdata$primary_type,
fast_version=TRUE)
plotHeatmapPretrained(aurocs,cex=0.7)
从结果来看,训练集中BICCN的Lamp5和测试数据的Igtp和Smad3高度一致同源。

上面的热图表明,所有Tasic细胞类型都可以与一个BICCN亚类相匹配。我们下面查看inhibitory neurons 的细胞是否在高分辨率细胞类型上能获得同样的结果。
aurocs <- MetaNeighborUS(trained_model=biccn_clusters,
dat = tasic_subdata,
study_id = tasic_subdata$study_id,
cell_type = tasic_subdata$primary_type,
fast_version=TRUE)
plotHeatmapPretrained(aurocs,cex=0.7)
因为BICCN的细胞类型过多,这个图就显得稍微复杂,我们也可以像前面一样,只显示最高hit的cell来显示。

best_hits<- MetaNeighborUS(trained_model=biccn_clusters,
dat = tasic_subdata,
study_id = tasic_subdata$study_id,
cell_type = tasic_subdata$primary_type,
fast_version=TRUE,
one_vs_best=TRUE)

给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru
我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..
我希望我的UserPrice模型的属性在它们为空或不验证数值时默认为0。这些属性是tax_rate、shipping_cost和price。classCreateUserPrices8,:scale=>2t.decimal:tax_rate,:precision=>8,:scale=>2t.decimal:shipping_cost,:precision=>8,:scale=>2endendend起初,我将所有3列的:default=>0放在表格中,但我不想要这样,因为它已经填充了字段,我想使用占位符。这是我的UserPrice模型:classUserPrice回答before_val
我有一个表单,其中有很多字段取自数组(而不是模型或对象)。我如何验证这些字段的存在?solve_problem_pathdo|f|%>... 最佳答案 创建一个简单的类来包装请求参数并使用ActiveModel::Validations。#definedsomewhere,atthesimplest:require'ostruct'classSolvetrue#youcouldevencheckthesolutionwithavalidatorvalidatedoerrors.add(:base,"WRONG!!!")unlesss
我可以得到Infinity和NaNn=9.0/0#=>Infinityn.class#=>Floatm=0/0.0#=>NaNm.class#=>Float但是当我想直接访问Infinity或NaN时:Infinity#=>uninitializedconstantInfinity(NameError)NaN#=>uninitializedconstantNaN(NameError)什么是Infinity和NaN?它们是对象、关键字还是其他东西? 最佳答案 您看到打印为Infinity和NaN的只是Float类的两个特殊实例的字符串
我不确定传递给方法的对象的类型是否正确。我可能会将一个字符串传递给一个只能处理整数的函数。某种运行时保证怎么样?我看不到比以下更好的选择:defsomeFixNumMangler(input)raise"wrongtype:integerrequired"unlessinput.class==FixNumother_stuffend有更好的选择吗? 最佳答案 使用Kernel#Integer在使用之前转换输入的方法。当无法以任何合理的方式将输入转换为整数时,它将引发ArgumentError。defmy_method(number)
我有一些非常大的模型,我必须将它们迁移到最新版本的Rails。这些模型有相当多的验证(User有大约50个验证)。是否可以将所有这些验证移动到另一个文件中?说app/models/validations/user_validations.rb。如果可以,有人可以提供示例吗? 最佳答案 您可以为此使用关注点:#app/models/validations/user_validations.rbrequire'active_support/concern'moduleUserValidationsextendActiveSupport:
当我的预订模型通过rake任务在状态机上转换时,我试图找出如何跳过对ActiveRecord对象的特定实例的验证。我想在reservation.close时跳过所有验证!叫做。希望调用reservation.close!(:validate=>false)之类的东西。仅供引用,我们正在使用https://github.com/pluginaweek/state_machine用于状态机。这是我的预订模型的示例。classReservation["requested","negotiating","approved"])}state_machine:initial=>'requested
我有一个服务模型/表及其注册表。在表单中,我几乎拥有服务的所有字段,但我想在验证服务对象之前自动设置其中一些值。示例:--服务Controller#创建Action:defcreate@service=Service.new@service_form=ServiceFormObject.new(@service)@service_form.validate(params[:service_form_object])and@service_form.saverespond_with(@service_form,location:admin_services_path)end在验证@ser
这里有一个很好的答案解释了如何在Ruby中下载文件而不将其加载到内存中:https://stackoverflow.com/a/29743394/4852737require'open-uri'download=open('http://example.com/image.png')IO.copy_stream(download,'~/image.png')我如何验证下载文件的IO.copy_stream调用是否真的成功——这意味着下载的文件与我打算下载的文件完全相同,而不是下载一半的损坏文件?documentation说IO.copy_stream返回它复制的字节数,但是当我还没有下