mirror of https://github.com/alibaba/MNN.git
6.9 KiB
6.9 KiB
其他模块编译
模型转换工具
- 相关编译选项
MNN_BUILD_CONVERTER是否编译模型转换工具MNN_BUILD_TORCH是否支持TorchScript模型转换,MacOS下需要安装pytorch,Linux下会下载libtorch
- 编译命令
cmake .. -DMNN_BUILD_CONVERTER=ON -DMNN_BUILD_TORCH=ON - 编译产物
MNNConvert模型转换工具TestConvertResult模型转换正确性测试工具,Windows下没有此产物,用MNNConvert对应功能替代TestPassManager模型转换工具测试用例MNNDump2Json模型转换为JsonMNNRevert2BufferJson转换为模型OnnxClipOnnx模型裁剪工具
训练框架
- 相关编译选项
MNN_BUILD_TRAIN是否编译训练框架MNN_BUILD_TRAIN_MINI对于移动端/嵌入式设备,建议设置MNN_BUILD_TRAIN_MINI=ON,不编译内置的Dataset,Models,这部分在移动端/嵌入式设备上一般有其他解决方案MNN_USE_OPENCV部分PC上的demo有用到,与Dataset处理相关
- 编译命令
mkdir build && cd build cmake .. -DMNN_BUILD_TRAIN=ON -DMNN_USE_OPENCV=ON make -j4 - 编译产物
MNNTrain训练框架库runTrainDemo.out运行训练框架demo的入口程序transformer训练模型转换器,将推理用的MNN模型转换为执行训练的MNN模型extractForInfer从执行训练的MNN模型中提取参数,对应更新推理用的MNN模型
生成式模型
- 相关编译选项
MNN_BUILD_DIFFUSION是否编译扩散模型推理示例MNN_BUILD_LLM是否编译大语言模型推理引擎MNN_SUPPORT_TRANSFORMER_FUSE是否支持transformer相关的融合算子,主要加速transformer模型
- 编译命令
- 编译扩散模型推理示例
mkdir build && cd build cmake .. -DMNN_BUILD_OPENCV=ON -DMNN_IMGCODECS=ON -DMNN_BUILD_DIFFUSION=ON -DMNN_SUPPORT_TRANSFORMER_FUSE=ON make -j4 - 编译大语言模型推理引擎
mkdir build && cd build cmake .. -DMNN_BUILD_LLM=ON -DMNN_SUPPORT_TRANSFORMER_FUSE=ON make -j4
- 编译扩散模型推理示例
- 编译产物
libllm.so大语言模型推理库llm_demo大语言模型推理示例程序diffusion_demo扩散模型示例程序llm_bench大语言模型测评工具
测试工具
- 相关编译选项
MNN_BUILD_TOOLS是否编译测试工具
- 编译命令
mkdir build && cd build cmake .. -DMNN_BUILD_TOOLS=ON make -j4 - 编译产物
GetMNNInfo获取MNN模型信息ModuleBasic.out使用V3 API对模型执行基础推理测试SequenceModuleTest.out测试Sequence模型推理MNNV2Basic.out使用V2 API对模型执行基础推理测试mobilenetTest.out测试mobilenet模型推理backendTest.out测试模型在指定后端上执行的结果是否与CPU一致modelCompare.out原始模型与量化模型推理结果比较testModel.out给定输入输出测试模型推理正确性testModel_expr.out给定输入输出测试模型推理正确性testModelWithDescribe.out给定输入输出和shape描述测试模型推理正确性getPerformance.out获取当前设备的CPU性能checkInvalidValue.out检测输出目录里的数据timeProfile.out测试模型在指定后端上执行的时间,并获取每层的执行时间占比testTrain.out测试训练功能checkDir.out测试两个文件夹是否一致checkFile.out测试两个文件是否一致winogradExample.outwinograd示例fuseTest测试 GPU 自定义算子的功能,目前仅支持 Vulkan Buffer 模式GpuInterTest.out测试 GPU 内存输入的功能,目前仅支持 OpenCL Buffer 模式与 OpenGL texture 模式,编译时需打开 MNN_OPENCL 与 MNN_OPENGLLoRA将LorA权重添加到模型权重中
Benchmark工具
- 相关编译选项
MNN_BUILD_BENCHMARK是否编译Benchmark工具
- 编译命令
mkdir build && cd build cmake .. -DMNN_BUILD_BENCHMARK=ON make -j4 - 编译产物
benchmark.outbenchmark工具benchmarkExprModels.out表达式构图模型测试benchmark工具
模型量化工具
- 相关编译选项
MNN_BUILD_QUANTOOLS是否编译模型量化工具
- 编译命令
mkdir build && cd build cmake .. -DMNN_BUILD_QUANTOOLS=ON make -j4 - 编译产物
quantized.out模型量化工具
评估工具
- 相关编译选项
MNN_EVALUATION是否编译图片分类结果评估工具
- 编译命令
mkdir build && cd build cmake .. -DMNN_EVALUATION=ON make -j4 - 编译产物
classficationTopkEval.out图片分类结果评估工具
MNN OpenCV库
- 相关编译选项
MNN_BUILD_OPENCV是否编译OpenCV函数接口MNN_IMGCODECS是否编译OpenCV图像编解码器MNN_OPENCV_TEST是否编译OpenCV单元测试MNN_OPENCV_BENCH是否编译OpenCV性能测试
- 编译命令
mkdir build && cd build cmake .. -DMNN_BUILD_OPENCV=ON -DMNN_IMGCODECS=ON -DMNN_OPENCV_TEST=ON -DMNN_OPENCV_BENCH=ON make -j4 - 编译产物
libMNNOpenCV.soMNN OpenCV函数库opencv_testMNN OpenCV单元测试opencv_benchMNN OpenCV性能测试
MNN Audio库
- 相关编译选项
MNN_BUILD_AUDIO是否编译Audio函数接口MNN_AUDIO_TEST是否编译Audio单元测试
- 编译命令
mkdir build && cd build cmake .. -MNN_BUILD_AUDIO=ON -MNN_AUDIO_TEST=ON make -j4 - 编译产物
libMNNAudio.soMNN Audio函数库audio_testMNN Audio单元测试
示例工程
- 相关编译选项
MNN_BUILD_DEMO是否编译MNN Demo
- 编译命令
mkdir build && cd build cmake .. -DMNN_BUILD_DEMO=ON make -j4 - 编译产物
pictureRecognition.outV2接口(Session)图片识别示例pictureRecognition_module.outV3接口(Module)图片识别示例pictureRecognition_batch.out自定义batchsize图片识别示例multithread_imgrecog.out多线程图片识别示例pictureRotate.out图片旋转示例multiPose.out姿态检测示例segment.out图像实例分割示例expressDemo.out表达式接口推理示例expressMakeModel.out使用表达式构建模型示例transformerDemo.outTransformer模型示例rasterDemo.outRaster示例nluDemo.outnlu模型示例mergeInplaceForCPU将模型中可以Inplace计算的算子改成Inplace计算,可以减少内存占用,但限定CPU后端运行OpenCLProgramBuildTest.out测试OpenCL后端的Program在设备上是否能编译成功
单元测试
- 相关编译选项
MNN_BUILD_TEST是否编译MNN单元测试
- 编译命令
mkdir build && cd build cmake .. -DMNN_BUILD_TEST=ON make -j4 - 编译产物
run_test.out单元测试程序