Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
9f472565
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22017
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
9f472565
编写于
5月 04, 2023
作者:
S
slzhou
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
enhance: finish python udf docs
上级
ba344f7b
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
23 addition
and
23 deletion
+23
-23
docs/zh/07-develop/09-udf.md
docs/zh/07-develop/09-udf.md
+23
-23
未找到文件。
docs/zh/07-develop/09-udf.md
浏览文件 @
9f472565
...
@@ -19,7 +19,7 @@ TDengine 支持通过 C/Python 语言进行 UDF 定义。接下来结合示例
...
@@ -19,7 +19,7 @@ TDengine 支持通过 C/Python 语言进行 UDF 定义。接下来结合示例
接口函数的名称是 UDF 名称,或者是 UDF 名称和特定后缀(_start, _finish, _init, _destroy)的连接。列表中的scalarfn,aggfn, udf需要替换成udf函数名。
接口函数的名称是 UDF 名称,或者是 UDF 名称和特定后缀(_start, _finish, _init, _destroy)的连接。列表中的scalarfn,aggfn, udf需要替换成udf函数名。
## 实现标量函数
##
C UDF
实现标量函数
标量函数实现模板如下
标量函数实现模板如下
```
c
```
c
#include "taos.h"
#include "taos.h"
...
@@ -51,7 +51,7 @@ int32_t scalarfn_destroy() {
...
@@ -51,7 +51,7 @@ int32_t scalarfn_destroy() {
```
```
scalarfn 为函数名的占位符,需要替换成函数名,如bit_and。
scalarfn 为函数名的占位符,需要替换成函数名,如bit_and。
## 实现聚合函数
##
C UDF
实现聚合函数
聚合函数的实现模板如下
聚合函数的实现模板如下
```
c
```
c
...
@@ -102,7 +102,7 @@ int32_t aggfn_destroy() {
...
@@ -102,7 +102,7 @@ int32_t aggfn_destroy() {
```
```
aggfn为函数名的占位符,需要修改为自己的函数名,如l2norm。
aggfn为函数名的占位符,需要修改为自己的函数名,如l2norm。
## 接口函数定义
##
C UDF
接口函数定义
接口函数的名称是 udf 名称,或者是 udf 名称和特定后缀(_start, _finish, _init, _destroy)的连接。以下描述中函数名称中的 scalarfn,aggfn, udf 需要替换成udf函数名。
接口函数的名称是 udf 名称,或者是 udf 名称和特定后缀(_start, _finish, _init, _destroy)的连接。以下描述中函数名称中的 scalarfn,aggfn, udf 需要替换成udf函数名。
...
@@ -110,7 +110,7 @@ aggfn为函数名的占位符,需要修改为自己的函数名,如l2norm。
...
@@ -110,7 +110,7 @@ aggfn为函数名的占位符,需要修改为自己的函数名,如l2norm。
接口函数参数类型见数据结构定义。
接口函数参数类型见数据结构定义。
### 标量接口函数
###
C UDF
标量接口函数
`int32_t scalarfn(SUdfDataBlock* inputDataBlock, SUdfColumn *resultColumn)`
`int32_t scalarfn(SUdfDataBlock* inputDataBlock, SUdfColumn *resultColumn)`
...
@@ -120,7 +120,7 @@ aggfn为函数名的占位符,需要修改为自己的函数名,如l2norm。
...
@@ -120,7 +120,7 @@ aggfn为函数名的占位符,需要修改为自己的函数名,如l2norm。
-
inputDataBlock: 输入的数据块
-
inputDataBlock: 输入的数据块
-
resultColumn: 输出列
-
resultColumn: 输出列
### 聚合接口函数
###
C UDF
聚合接口函数
`int32_t aggfn_start(SUdfInterBuf *interBuf)`
`int32_t aggfn_start(SUdfInterBuf *interBuf)`
...
@@ -137,7 +137,7 @@ aggfn为函数名的占位符,需要修改为自己的函数名,如l2norm。
...
@@ -137,7 +137,7 @@ aggfn为函数名的占位符,需要修改为自己的函数名,如l2norm。
-
result:最终结果。
-
result:最终结果。
### UDF 初始化和销毁
###
C
UDF 初始化和销毁
`int32_t udf_init()`
`int32_t udf_init()`
`int32_t udf_destroy()`
`int32_t udf_destroy()`
...
@@ -145,7 +145,7 @@ aggfn为函数名的占位符,需要修改为自己的函数名,如l2norm。
...
@@ -145,7 +145,7 @@ aggfn为函数名的占位符,需要修改为自己的函数名,如l2norm。
其中 udf 是函数名的占位符。udf_init 完成初始化工作。 udf_destroy 完成清理工作。如果没有初始化工作,无需定义udf_init函数。如果没有清理工作,无需定义udf_destroy函数。
其中 udf 是函数名的占位符。udf_init 完成初始化工作。 udf_destroy 完成清理工作。如果没有初始化工作,无需定义udf_init函数。如果没有清理工作,无需定义udf_destroy函数。
## UDF 数据结构
##
C
UDF 数据结构
```
c
```
c
typedef
struct
SUdfColumnMeta
{
typedef
struct
SUdfColumnMeta
{
int16_t
type
;
int16_t
type
;
...
@@ -203,7 +203,7 @@ typedef struct SUdfInterBuf {
...
@@ -203,7 +203,7 @@ typedef struct SUdfInterBuf {
为了更好的操作以上数据结构,提供了一些便利函数,定义在 taosudf.h。
为了更好的操作以上数据结构,提供了一些便利函数,定义在 taosudf.h。
## 编译 UDF
## 编译
C
UDF
用户定义函数的 C 语言源代码无法直接被 TDengine 系统使用,而是需要先编译为 动态链接库,之后才能载入 TDengine 系统。
用户定义函数的 C 语言源代码无法直接被 TDengine 系统使用,而是需要先编译为 动态链接库,之后才能载入 TDengine 系统。
...
@@ -215,9 +215,9 @@ gcc -g -O0 -fPIC -shared bit_and.c -o libbitand.so
...
@@ -215,9 +215,9 @@ gcc -g -O0 -fPIC -shared bit_and.c -o libbitand.so
这样就准备好了动态链接库 libbitand.so 文件,可以供后文创建 UDF 时使用了。为了保证可靠的系统运行,编译器 GCC 推荐使用 7.5 及以上版本。
这样就准备好了动态链接库 libbitand.so 文件,可以供后文创建 UDF 时使用了。为了保证可靠的系统运行,编译器 GCC 推荐使用 7.5 及以上版本。
## 示例代码
##
C UDF
示例代码
### 标量函数示例 [bit_and](https://github.com/taosdata/TDengine/blob/develop/tests/script/sh/bit_and.c)
###
C UDF
标量函数示例 [bit_and](https://github.com/taosdata/TDengine/blob/develop/tests/script/sh/bit_and.c)
bit_add 实现多列的按位与功能。如果只有一列,返回这一列。bit_add 忽略空值。
bit_add 实现多列的按位与功能。如果只有一列,返回这一列。bit_add 忽略空值。
...
@@ -230,7 +230,7 @@ bit_add 实现多列的按位与功能。如果只有一列,返回这一列。
...
@@ -230,7 +230,7 @@ bit_add 实现多列的按位与功能。如果只有一列,返回这一列。
</details>
</details>
### 聚合函数示例1 返回值为数值类型 [l2norm](https://github.com/taosdata/TDengine/blob/develop/tests/script/sh/l2norm.c)
###
C UDF
聚合函数示例1 返回值为数值类型 [l2norm](https://github.com/taosdata/TDengine/blob/develop/tests/script/sh/l2norm.c)
l2norm 实现了输入列的所有数据的二阶范数,即对每个数据先平方,再累加求和,最后开方。
l2norm 实现了输入列的所有数据的二阶范数,即对每个数据先平方,再累加求和,最后开方。
...
@@ -243,7 +243,7 @@ l2norm 实现了输入列的所有数据的二阶范数,即对每个数据先
...
@@ -243,7 +243,7 @@ l2norm 实现了输入列的所有数据的二阶范数,即对每个数据先
</details>
</details>
### 聚合函数示例2 返回值为字符串类型 [max_vol](https://github.com/taosdata/TDengine/blob/develop/tests/script/sh/max_vol.c)
###
C UDF
聚合函数示例2 返回值为字符串类型 [max_vol](https://github.com/taosdata/TDengine/blob/develop/tests/script/sh/max_vol.c)
max_vol 实现了从多个输入的电压列中找到最大电压,返回由设备ID + 最大电压所在(行,列)+ 最大电压值 组成的组合字符串值
max_vol 实现了从多个输入的电压列中找到最大电压,返回由设备ID + 最大电压所在(行,列)+ 最大电压值 组成的组合字符串值
...
@@ -275,7 +275,7 @@ select max_vol(vol1,vol2,vol3,deviceid) from battery;
...
@@ -275,7 +275,7 @@ select max_vol(vol1,vol2,vol3,deviceid) from battery;
-
聚合函数需要实现聚合接口函数 start ,reduce ,finish。
-
聚合函数需要实现聚合接口函数 start ,reduce ,finish。
-
如果需要初始化,实现 init;如果需要清理工作,实现 destroy。
-
如果需要初始化,实现 init;如果需要清理工作,实现 destroy。
## 实现标量函数
##
Python UDF
实现标量函数
标量函数实现模版如下
标量函数实现模版如下
```
Python
```
Python
...
@@ -289,7 +289,7 @@ def process(input: datablock) -> tuple[output_type]:
...
@@ -289,7 +289,7 @@ def process(input: datablock) -> tuple[output_type]:
# return tuple object consisted of object of type outputtype
# return tuple object consisted of object of type outputtype
```
```
## 实现聚合函数
##
Python UDF
实现聚合函数
聚合函数实现模版如下
聚合函数实现模版如下
```
Python
```
Python
...
@@ -309,16 +309,16 @@ def finish(buf: bytes) -> output_type:
...
@@ -309,16 +309,16 @@ def finish(buf: bytes) -> output_type:
#return obj of type outputtype
#return obj of type outputtype
```
```
## 接口函数定义
##
Python UDF
接口函数定义
### 标量接口函数
###
Python UDF
标量接口函数
```
Python
```
Python
def process(input: datablock) -> tuple[output_type]:
def process(input: datablock) -> tuple[output_type]:
```
```
-
input:datablock 类似二维矩阵,通过成员方法 data(row,col)返回位于 row 行,col 列的 python 对象
-
input:datablock 类似二维矩阵,通过成员方法 data(row,col)返回位于 row 行,col 列的 python 对象
-
返回值是一个 Python 对象元组,每个元素类型为输出类型。
-
返回值是一个 Python 对象元组,每个元素类型为输出类型。
### 聚合接口函数
###
Python UDF
聚合接口函数
```
Python
```
Python
def start() -> bytes:
def start() -> bytes:
def reduce(inputs: datablock, buf: bytes) -> bytes
def reduce(inputs: datablock, buf: bytes) -> bytes
...
@@ -328,7 +328,7 @@ def finish(buf: bytes) -> output_type:
...
@@ -328,7 +328,7 @@ def finish(buf: bytes) -> output_type:
首先调用 start 生成最初结果 buffer,然后输入数据会被分为多个行数据块,对每个数据块 inputs 和当前中间结果 buf 调用 reduce,得到新的中间结果,最后再调用 finish 从中间结果 buf 产生最终输出,最终输出只能含 0 或 1 条数据。
首先调用 start 生成最初结果 buffer,然后输入数据会被分为多个行数据块,对每个数据块 inputs 和当前中间结果 buf 调用 reduce,得到新的中间结果,最后再调用 finish 从中间结果 buf 产生最终输出,最终输出只能含 0 或 1 条数据。
### UDF 初始化和销毁
###
Python
UDF 初始化和销毁
```
Python
```
Python
def init()
def init()
def destroy()
def destroy()
...
@@ -353,12 +353,12 @@ def destroy()
...
@@ -353,12 +353,12 @@ def destroy()
pip
install
taospyudf
pip
install
taospyudf
lddconfig
lddconfig
```
```
2.
如果 Python UDF 程序执行时,
引用其它的包,PYTHONPATH 环境变量可以通过在 taos.cfg 的 UdfdLdLibPath 变量配置
2.
如果 Python UDF 程序执行时,
通过 PYTHONPATH 引用其它的包,可以设置 taos.cfg 的 UdfdLdLibPath 变量为PYTHONPATH的内容
## 示例代码
##
Python UDF
示例代码
### 标量函数示例 [pybitand](https://github.com/taosdata/TDengine/blob/develop/tests/script/sh/pybitand.py)
###
Python UDF
标量函数示例 [pybitand](https://github.com/taosdata/TDengine/blob/develop/tests/script/sh/pybitand.py)
bit_add 实现多列的按位与功能。如果只有一列,返回这一列。bit_ad
d 忽略空值。
pybitand 实现多列的按位与功能。如果只有一列,返回这一列。pybitan
d 忽略空值。
<details>
<details>
<summary>
pybitand.py
</summary>
<summary>
pybitand.py
</summary>
...
@@ -369,7 +369,7 @@ bit_add 实现多列的按位与功能。如果只有一列,返回这一列。
...
@@ -369,7 +369,7 @@ bit_add 实现多列的按位与功能。如果只有一列,返回这一列。
</details>
</details>
### 聚合函数示例 [pyl2norm](https://github.com/taosdata/TDengine/blob/develop/tests/script/sh/pyl2norm.py)
###
Python UDF
聚合函数示例 [pyl2norm](https://github.com/taosdata/TDengine/blob/develop/tests/script/sh/pyl2norm.py)
pyl2norm 实现了输入列的所有数据的二阶范数,即对每个数据先平方,再累加求和,最后开方。
pyl2norm 实现了输入列的所有数据的二阶范数,即对每个数据先平方,再累加求和,最后开方。
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录