当Jelly Bean 4.2在一个月前宣布时,Filterscript也宣布了。它似乎是一种语言,是Renderscript的下标,具有不同的文件扩展名。这就是我对语言的全部了解。
我已经在整个互联网上阅读了有关Filterscript的两个段落,并创建了一个带.fs
的小pragma rs_fp_relaxed
文件,但ADT构建器并没有像普通.rs
那样获取它。 {1}}文件位于同一位置。
我的ADT是最新的公共版本(21.0.0),对于Filterscript来说似乎太低了。 tools.android.com似乎有21.0.1 Preview,但在发行说明中没有提到Filterscript(实际上它只是一个bug修复版本)。在任何地方都没有文档!
我如何使用Filterscript?它的文件在哪里?
我尝试过:
https://www.google.com/search?q=filterscript+site:android.com&tbs=li:1
http://developer.android.com/about/versions/android-4.2.html#Renderscript
http://developer.android.com/tools/sdk/eclipse-adt.html#notes
答案 0 :(得分:17)
我还没有找到任何文件,但也许我可以提供一些有关我迄今为止所调查内容的有用信息:
__attribute__((kernel))
否则编译器会发疯并且需要指针类型,这是非法的我在阅读sources of the llvm-rs-cc compiler时发现了以下大部分信息。任何进一步的信息或指向Filtercript的真实文档的链接将不胜感激!
在Filterscript中,您没有输出分配的参数。而是将值返回到当前位置(这是全局线程标识x
和y
):
uchar4 __attribute__((kernel)) root(uint32_t x, uint32_t y)
生成:
public void forEach_root(Allocation aout)
您可以选择将输入分配作为参数移交:
uchar4 __attribute__((kernel)) root(const uchar4 in, uint32_t x, uint32_t y)
生成:
public void forEach_root(Allocation ain, Allocation aout)
仅在极少数情况下(例如点操作符)才有用,因为您只能在当前位置访问输入分配。
如果您想在输入分配中进行随机访问,则需要进行全局分配。以下是使用适合我的全局分配的窗口运算符的一个小例子。
<强> blur.fs:强>
#pragma version(1)
#pragma rs java_package_name(com.example.myproject)
rs_allocation in;
uint32_t width;
uint32_t height;
uchar4 __attribute__((kernel)) root(uint32_t x, uint32_t y) {
uint4 sum = 0;
uint count = 0;
for (int yi = y-1; yi <= y+1; ++yi) {
for (int xi = x-1; xi <= x+1; ++xi) {
if (xi >= 0 && xi < width && yi >= 0 && yi < height) {
sum += convert_uint4(rsGetElementAt_uchar4(in, xi, yi));
++count;
}
}
}
return convert_uchar4(sum/count);
}
<强> MainActivity.java:强>
...
mRS = RenderScript.create(this);
mInAllocation = Allocation.createFromBitmap(mRS, mBitmapIn,
Allocation.MipmapControl.MIPMAP_NONE,
Allocation.USAGE_SCRIPT);
mOutAllocation = Allocation.createTyped(mRS, mInAllocation.getType());
mScript = new ScriptC_blur(mRS, getResources(), R.raw.blur);
mScript.set_in(mInAllocation);
mScript.set_width(mBitmapIn.getWidth());
mScript.set_height(mBitmapIn.getHeight());
mScript.forEach_root(mOutAllocation);
mOutAllocation.copyTo(mBitmapOut);
...
答案 1 :(得分:10)
在这里结识:
是的,我们落后于文档。我们知道,我们一直很忙。这是我不久的将来的议程。
FS旨在作为RS的限制性更强的变体,为编译器后端提供额外的优化机会。我们今天的CPU后端中没有任何这些不能从等效的RS文件中获得,但OEM可能会提高其文件与FS文件和通用RS文件的性能。通常,它需要__attribute__((kernel))
,没有指针,没有联合,文件类型暗示了fp_relaxed。
主机端API完全相同;唯一的区别在于我们实际传递的内核二进制文件。
对ofp答案的一些小修正:
答案 2 :(得分:-3)
这里是过滤脚本和大量演示的完整介绍。 http://developer.android.com/guide/topics/renderscript/compute.html