data:image/s3,"s3://crabby-images/29384/2938451f023206b0a45631970c50f5f29bee3af5" alt="TensorFlow+Android经典模型从理论到实战(微课视频版)"
上QQ阅读APP看书,第一时间看更新
1.6 EfficientNetV2建模
参照EfficientNetV2论文公布的源码,本节完成EfficientNetV2-S/M/L三个模型的编程。官方程序用列表描述模型的参数结构,以EfficientNetV2-S模型为例,其结构描述如下。
v2_s_block = [ 'r2_k3_s1_e1_i24_o24_c1' 'r4_k3_s2_e4_i24_o48_c1' 'r4_k3_s2_e4_i48_o64_c1' 'r6_k3_s2_e4_i64_o128_se0 25' 'r9_k3_s1_e6_i128_o160_se0 25' 'r15_k3_s2_e6_i160_o256_se0 25' ]
参照表1.9对EfficientNetV2-S模型的定义,v2_s_block中的参数符号解读如下。
r:当前Stage中Operator重复的次数repeats。
k:卷积核尺寸kernel_size。
s:步长stride。
e:升维倍率因子expansion ratio。
i:当前Stage的输入通道数input channels。
o:当前Stage的输出通道数output channels。
c:卷积类型,0表示Fused-MBConv,1表示MBConv。
se:表示SE模块第一个全连接层的通道压缩因子se_ratio。
打开PyCharm,新建项目TensorFlow_to_Android,按照本节视频教程提示,配置项目虚拟环境,安装TensorFlow和相关库。新建文件夹EfficientNetV2,在其中创建model.py程序,完成程序源码P1.1的编程与测试工作。
data:image/s3,"s3://crabby-images/0d1b6/0d1b63300aad193bdfad24caeac32e599b6987ee" alt=""
data:image/s3,"s3://crabby-images/a16a8/a16a822bac9de2d73ccc71bdca1974c66dd29337" alt=""
data:image/s3,"s3://crabby-images/2191b/2191b57b8674bae7adba77a789fc68689e979b17" alt=""
data:image/s3,"s3://crabby-images/e821b/e821b51b3f4b60bc8b5479bcd2eacf192b7267b6" alt=""
data:image/s3,"s3://crabby-images/48d17/48d174215076199f22dc309cdccc7a99e41ed620" alt=""
data:image/s3,"s3://crabby-images/2aa15/2aa156e207c95cd1905468f7034786561f25839a" alt=""
data:image/s3,"s3://crabby-images/86c20/86c20ca5730115d4dcf40d697cbd54ae49a4ab55" alt=""
data:image/s3,"s3://crabby-images/02383/023839b156e5d78d662c7ebaadff61d1a2f650df" alt=""
程序model.py编码有些长,其中包含了EfficientNetV2-S/M/L三种模型的实现逻辑,该逻辑极其容易扩展到其他模型,包括EfficientNetV1的系列模型。
程序model.py编码优雅,面向对象的结构化设计,层层递进,值得学习和模仿。
程序设计细节、运行测试结果及详细解析参见本节微课视频。