在 MATLAB 中更改 seqlogo 图形的 x 轴
我正在制作大量 seqlogo 以编程方式。它们有数百列宽,因此运行 seqlogo
通常会创建太细而看不见的字母。我注意到我只关心其中的一些列(不一定是连续的列)......大多数都是噪音,但有些是高度保守的。
我使用类似以下代码片段的内容:
wide_seqs = cell2mat(arrayfun(@randseq, repmat(200, [500 1]), 'uniformoutput', false));
wide_seqs(:, [17,30, 55,70,130]) = repmat(['ATCGG'], [500 1])
conserve_cell = seqlogo(wide_seqs, 'displaylogo', false);
high_bit_cols = any(conserve_cell{2}>1.0,1);
[~, handle] = seqlogo(wide_seqs(:,high_bit_cols ));
尽管当我这样做时,我丢失了有关数据来自哪些列的信息。
通常我只会更改 seqlogo 的 x 轴。然而,seqlogo
是某种疯狂的基于 java 的对象,并且调用如下:
set(handle, 'xticklabel', num2str(find(high_bit_cols)))
不起作用。任何帮助将不胜感激。
谢谢, 将
编辑:
在赏金上,我愿意接受任何类型的更改轴标签的疯狂方法,包括(但不限于):使用图像处理工具箱在保存后修改图像,使用文本框创建新的 seqlogo 函数、修改java代码(如果可能的话)等。我不愿意接受诸如“使用python”、“使用这个R库”或任何其他类型的非Matlab解决方案之类的东西。
I'm making a large number of seqlogos programmatically. They are hundreds of columns wide and so running a seqlogo
normally creates letters that are too thin to see. I've noticed that I only care about a few of these columns (not necessarily consecutive columns) ... most are noise but some are highly conserved.
I use something like this snippet:
wide_seqs = cell2mat(arrayfun(@randseq, repmat(200, [500 1]), 'uniformoutput', false));
wide_seqs(:, [17,30, 55,70,130]) = repmat(['ATCGG'], [500 1])
conserve_cell = seqlogo(wide_seqs, 'displaylogo', false);
high_bit_cols = any(conserve_cell{2}>1.0,1);
[~, handle] = seqlogo(wide_seqs(:,high_bit_cols ));
Although when I do this I lose the information about which columns the data came from.
Normally I would just change the x-axis of the seqlogo
. However, seqlogo
's are some sort of crazy java-based object and calls like:
set(handle, 'xticklabel', num2str(find(high_bit_cols)))
don't work. Any help would be greatly appreciated.
Thanks,
Will
EDIT:
On the bounty I'm willing to accept any kind of crazy method for changing the axis labels include (but not limited to): Using the image-processing toolbox to modify the image after saving, creating a new seqlogo function using textboxes, modifying the java-code (if possible), etc. I'm NOT willing to accept things like "use python", "use this R library" or any other sort of non-Matlab solution.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(5)
好吧,我因为这个问题浪费了几个小时。看来您无法将任何 MATLAB 对象(轴或文本框)放置在该 hgjavacomponent 对象的顶部。当然,我无法修改java代码。所以我找到的唯一可行的解决方案是从头开始创建图形。
我不想重写代码来计算权重矩阵(符号高度),你已经这样做了。但如果您根本不想使用 MATLAB 的 seqlogo,这是可以做到的。所以我稍微改变了你的最后一行来获取矩阵:
文本符号的问题是你无法精确控制它们的大小,无法将符号适合文本框。这可能就是 MATLAB 决定使用 java 图形对象的原因。但我们可以创建符号图像并处理它们。
下面是创建字母图像的代码:
然后我们使用这些图像绘制新的 seqlogo 图:
这是结果:
alt text http://img716.imageshack.us/img716/2073/seqlogoexample.png
代码和当然,数字还可以进一步提高,但我希望这是你可以开始工作的东西。如果我错过了什么,请告诉我。
OK, I killed a few hours with this problem. It appears that you cannot place any MATLAB object (axes or textbox) on the top of that hgjavacomponent object. And I couldn't modified the java code, of course. So the only feasible solution I found is to create the figure from scratch.
I didn't want to rewrite the code to calculate weight matrices (symbols heights), you already did that. But it can be done, if you don't want to use MATLAB's seqlogo at all. So I've changed your last line a little to get the matrix:
The problem with text symbols is that you cannot exactly control their size, cannot fit the symbol to textbox. This is probably why MATLAB decided to go with java graphic object. But we can create symbols images and deal with them.
Here is code to create images of letters:
Then we use those images to draw new seqlogo plot:
Here is the result:
alt text http://img716.imageshack.us/img716/2073/seqlogoexample.png
The code and figure can be further improved, of course, but I hope this is something you can start working with. Let me know if I miss something.
我遇到了同样的问题yuk做了 尝试修改 SEQLOGO,所以这是我尝试自己的版本来模仿它的外观。这是一个函数
seqlogo_new.m
,您可以提供两个参数:您的序列和可选的最小位值。它需要一个图像文件ACGT.jpg
,可以在 在此链接。以下是该函数的代码:
以下是其用法的一些示例:
< img src="https://i37.photobucket.com/albums/e77/kpeaton/example_2.jpg" alt="替代文字">
I ran into the same problems yuk did trying to modify the figure from SEQLOGO, so here's my attempt at my own version to mimic its appearance. It's a function
seqlogo_new.m
that you give two arguments: your sequence and an optional minimum bit value. It requires an image fileACGT.jpg
that can be found at this link.Here's the code for the function:
And here are a few examples of its usage:
所以我使用 yuk 和 gnovice 的解决方案创建了另一个解决方案。当我研究该解决方案时,我意识到我真的很希望能够将输出用作“子图”,并且能够任意更改字母的颜色。
由于 yuk 使用以编程方式放置嵌入字母的坐标区对象,因此修改他的代码以绘制到任意坐标区对象会非常烦人(尽管并非不可能)。由于 gnovice 的解决方案从预先创建的文件中读取字母,因此很难修改代码以针对任意配色方案或字母选择运行。所以我的解决方案使用了 yuk 解决方案中的“字母生成”代码和 gnovice 解决方案中的“图像叠加”方法。
还有大量的参数解析和检查。下面是我的组合解决方案......我只是为了完整性而将其包括在内,显然我无法赢得自己的赏金。我将让社区决定奖项,并将赏金给予在时限结束时评分最高的人……如果出现平局,我会将其给予代表最低的人(他们可能更“需要”它)。
我已将其提交给 Mathworks FileExchange ...获得批准后,我将发布一个链接。
我唯一烦恼的是,当它创建字母图像时,它会快速显示小图形窗口。如果有人知道可以避免的技巧,我很想听听。
编辑:Mathworks 已批准我提交的文件...您可以在 FileExchange 上下载:http: //www.mathworks.com/matlabcentral/fileexchange/27124
So I've created another solution using pieces of both yuk and gnovice's solution. As I played around with the solution I realized I would really like to be able to use the output as "subplots" and be able to change the color of letters arbitrarily.
Since yuk used programitically placed axes objects with the letter embedded it would have been very annoying (although not impossible) to modify his code to plot into an arbitrary axes object. Since gnovice's solution read the letters from a pre-created file it would have been difficult to modify the code to run against arbitrary color schemes or letter choices. So my solution uses the "letter generation" code from yuk's solution and the "image superimposing" method from gnovice's solution.
There is also a significant amount of argument parsing and checking. Below is my combined solution ... I'm including it only for completeness, I obviously can't win my own bounty. I'll let the community decide the award and give the bounty to whoever has the highest rating at the end of the time-limit ... in the event of a tie I'll give it to the person with the lowest rep (they probably "need" it more).
I've submitted this to the Mathworks FileExchange ... when its approved I'll post a link.
The only nagging annoyance I have is that as it creates the letter images it displays little figure windows in rapid speed. If anyone knows a trick that could get avoid that I'd love to hear it.
EDIT: Mathworks has approved my submitted file ... you can download it at the FileExchange here: http://www.mathworks.com/matlabcentral/fileexchange/27124
关于 x 轴,该图似乎不包含标准轴(
findobj(handle,'type','axes')
为空),而是类 com. mathworks.toolbox.bioinfo.sequence.SequenceLogo ...在不相关的注释中,您可以用更简单的调用替换第一行:
About the x-axis, it seems that the figure contains no standard axis (
findobj(handle,'type','axes')
is empty), rather a custom object of class com.mathworks.toolbox.bioinfo.sequence.SequenceLogo ...On an unrelated note, you can replace your first line with a simpler call to:
如果轴是 java 对象,那么您可能需要使用 uiinspect。这可能会让您知道应该编辑什么以获得您想要的行为(不幸的是,我没有工具箱,所以我无法为您查找)。
If the axes are a java object, then you may want to have a look at its methods and properties with uiinspect. This might give you an idea what you should edit to get the behavior you want (unfortunately, I don't have the toolbox, so I can't look it up for you).