onnxruntime源码解析之C接口实现
onnxruntime的C接口,位置为include/onnxruntime/core/session/onnxruntime_c_api.h。
上述文件包含了C函数的声明,对应的实现在onnxruntime/core/session/onnxruntime_c_api.cc内。
与定义的时候类似,实现的函数使用宏ORT_API_STATUS_IMPL进行定义。
一、OrtEnv
OrtEnv在onnxruntime_c_api.h中声明,通过宏ORT_RUNTIME_CLASS(Env)。
在头文件中,只会用到OrtEnv的指针,不会用到实现,因此不会发生编译错误。
OrtEnv的实现在onnxruntime_c_api.cc中,这里的实现用的是class,但是声明为struct。
这在C++中是允许的,因为C++不区分class和struct,两者只有默认访问权限的区别。
// struct与class混用
#include <iostream>
struct A;
void my_print(A* a);
class A {
public:
void print() {
std::cout << "Hello\n";
}
};
void my_print(A* a) {
a->print();
};
int main() {
A x;
my_print(&x);
return 0;
}
OrtEnv实现了一个单例类,主要负责日志和会话间共享分配器的管理。
OrtEnv实际上只是对onnxruntime::Environment的简单封装,日志管理和分配器的管理都在onnxruntime::Environment中实现。
OrtEnv相当于一个中间层,或者说,充当C接口与C++实现的兼容的中间类。
onnxruntime的C接口中的,其他一些类也与OrtEnv类相似。
引用计数
可以注意到,这里的OrtEnv作为一个单例,与通常设计模式的单例,稍有区别。
主要添加了一个引用计数ref_count_。
当GetInstance()时,如果还没有创建局部静态对象OrtEnv,那么创建一个OrtEnv,用p_instance_保存。
如果已经创建了p_instance_,那么只要ref_count_加一,返回p_instance_。
Release()释放时,检查ref_count_即可。
线程间互斥锁
OrtEnv是被全局共享的,不同的会话session在不同的线程。因此需要mutex。
onnxruntime使用OrtMutex代替std::mutex。说明如下,
// Q: Why OrtMutex is better than std::mutex
// A: OrtMutex supports static initialization but std::mutex doesn't. Static initialization helps us prevent the "static
// initialization order problem". // Q: Why std::mutex can't make it?
// A: VC runtime has to support Windows XP at ABI level. But we don't have such requirement. // Q: Is OrtMutex faster than std::mutex?
// A: Sure
二、onnxruntime::Environment
前面说到OrtEnv只是对onnxruntime::Enviroonment的简单封装。
Environment里面主要包含了,1个日志管理器,1个会话间共享的分配器,2个线程池(分别用于Op内和Op间)。
Environment类通过静态函数Create去创建自己,类似工厂方法;而不是直接在构造函数内进行初始化。
这样可以更好的控制对象的初始化,在初始化过程做更多的操作。在Initialize函数内实现。
Initialize函数内,主要做了3件事。
1. 传入一个日志管理器。
2. 创建2个线程池。
3. 根据不同的编译选项,注册各组的Op
onnxruntime源码解析之C接口实现的更多相关文章
- identityserver4源码解析_2_元数据接口
目录 identityserver4源码解析_1_项目结构 identityserver4源码解析_2_元数据接口 identityserver4源码解析_3_认证接口 identityserver4 ...
- identityserver4源码解析_3_认证接口
目录 identityserver4源码解析_1_项目结构 identityserver4源码解析_2_元数据接口 identityserver4源码解析_3_认证接口 identityserver4 ...
- Spring源码解析 - AbstractBeanFactory 实现接口与父类分析
我们先来看类图吧: 除了BeanFactory这一支的接口,AbstractBeanFactory主要实现了AliasRegistry和SingletonBeanRegistry接口. 这边主要提供了 ...
- Java基础——集合源码解析 List List 接口
今天我们来学习集合的第一大体系 List. List 是一个接口,定义了一组元素是有序的.可重复的集合. List 继承自 Collection,较之 Collection,List 还添加了以下操作 ...
- IdentityServer4源码解析_4_令牌发放接口
目录 identityserver4源码解析_1_项目结构 identityserver4源码解析_2_元数据接口 identityserver4源码解析_3_认证接口 identityserver4 ...
- IdentityServer4源码解析_5_查询用户信息接口
协议简析 UserInfo接口是OAuth2.0中规定的需要认证访问的接口,可以返回认证用户的声明信息.请求UserInfo接口需要使用通行令牌.响应报文通常是json数据格式,包含了一组claim键 ...
- IdentityServer4源码解析_1_项目结构
目录 IdentityServer4源码解析_1_项目结构 IdentityServer4源码解析_2_元数据接口 IdentityServer4源码解析_3_认证接口 IdentityServer4 ...
- Spring-cloud & Netflix 源码解析:Eureka 服务注册发现接口 ****
http://www.idouba.net/spring-cloud-source-eureka-client-api/?utm_source=tuicool&utm_medium=refer ...
- MyBatis源码解析【7】接口式编程
前言 这个分类比较连续,如果这里看不懂,或者第一次看,请回顾之前的博客 http://www.cnblogs.com/linkstar/category/1027239.html 修改例子 在我们实际 ...
- 2) 接口规范 原生django接口、单查群查 postman工具 CBV源码解析
内容了解 """ .接口:什么是接口.restful接口规范 .CBV生命周期源码 - 基于restful规范下的CBV接口 .请求组件.解析组件.响应组件 .序列化组件 ...
随机推荐
- MySQL 查询常用操作(0) —— 查询语句的执行顺序
MySQL中明确查询语句的执行顺序极其重要,了解执行顺序才不至于犯一些简单错误,例如having 后面是否可以使用 select 中重命名的列名等问题.另外SQL中实际使用最频繁的就是查询(Quein ...
- EMQ X 系统调优和性能压测
前言 如果使用 EMQ 来承载百万级别的用户连接可以吗?毕竟在 MQTT 官方介绍上说 EMQ X 可以处理千万并发客户端,而 EMQ X 自己官方称 4.x 版本 MQTT 连接压力测试一台 8 核 ...
- TypeError: unsupported operand type(s) for |=: 'dict' and 'dict'
原因:python3.9 支持对 dict 类型使用 |, 而较老的版本不支持 解决方案 :1. 用更新的 python 2. 把 | 操作替换成 {**d1, **d2} 来源:https://st ...
- org.elasticsearch.ElasticsearchException: not all primary shards of [.geoip_databases] index are active解决办法
解决办法 在配置elasticsearch.yml中加上 ingest.geoip.downloader.enabled: false
- PO培训
30M 的step by step.带notes 这个文档把常用的包含java都有 不止是配置,反正各种处理都有.. 各种高清无码截图,还不算附件内容
- 关于xtr的一些基础
Q&A 如何找到QSEQ方式的xtt呢? 我们可以去版本的代码中寻找,具体位置在:(modem_proc/rf/rftarget_denali/mtp/xtt/etc/QSEQ/) 在QSEQ ...
- nginx 更改配置client_max_body_size nginx.conf 修改默认限制上传附件大小
Nginx 上传大文件超时解决办法 情况如下:用nginx作代理服务器,上传大文件时(测试上传50m的文件),提示上传超时或文件过大. 原因是nginx对上传文件大小有限制,而且默认是1M.另外,若上 ...
- 华为MA5626和S2700重置密码
MA5626和S2700交换机,初始化密码遇到的问题. 主要目的把两台设备改成普通二层交换机. 一.MA5626交换机 1.进入设备,发现有密码. 帐号:root 密码:mduadmin 2.使用空配 ...
- flask相关
app使用flask_session pip install flask_session from flask_session import Session app = Flask(__name__) ...
- C语言中的malloc、new、memset函数解析
1. malloc 在window下,malloc的函数原型: extern void *malloc(unsigned int num_bytes); 头文件: #include<malloc ...