Project Name | Stars | Downloads | Repos Using This | Packages Using This | Most Recent Commit | Total Releases | Latest Release | Open Issues | License | Language |
---|---|---|---|---|---|---|---|---|---|---|
Scs4onnx | 43 | 1 | 7 months ago | 19 | May 25, 2022 | mit | Python | |||
A very simple tool that compresses the overall size of the ONNX model by aggregating duplicate constant values as much as possible. | ||||||||||
Onnx2json | 18 | 2 months ago | mit | Python | ||||||
Exports the ONNX file to a JSON file and JSON dict. | ||||||||||
Mlflow Redisai | 18 | 2 years ago | 4 | apache-2.0 | Python | |||||
RedisAI integration for MLFlow | ||||||||||
Json2onnx | 13 | 7 months ago | mit | Python | ||||||
Converts a JSON file to an ONNX file. | ||||||||||
Scc4onnx | 13 | 1 | 7 months ago | 5 | May 25, 2022 | mit | Python | |||
Very simple NCHW and NHWC conversion tool for ONNX. Change to the specified input order for each and every input OP. Also, change the channel order of RGB and BGR. Simple Channel Converter for ONNX. | ||||||||||
Sne4onnx | 11 | 3 months ago | mit | Python | ||||||
A very simple tool for situations where optimization with onnx-simplifier would exceed the Protocol Buffers upper file size limit of 2GB, or simply to separate onnx files to any size you want. | ||||||||||
Snc4onnx | 8 | a month ago | mit | Python | ||||||
Simple tool to combine(merge) onnx models. Simple Network Combine Tool for ONNX. | ||||||||||
Onnx Opcounter | 8 | 2 years ago | n,ull | apache-2.0 | Python | |||||
Count number of parameters / MACs / FLOPS for ONNX models. | ||||||||||
Sio4onnx | 7 | 7 months ago | mit | Python | ||||||
Simple tool to change the INPUT and OUTPUT shape of ONNX. | ||||||||||
Snd4onnx | 6 | 7 months ago | mit | Python | ||||||
Simple node deletion tool for onnx. |
Simple node deletion tool for onnx. I only test very miscellaneous and limited patterns as a hobby. There are probably a large number of bugs. Pull requests are welcome.
PINTO0309/simple-onnx-processing-tools
### option
$ echo export PATH="~/.local/bin:$PATH" >> ~/.bashrc \
&& source ~/.bashrc
### run
$ pip install -U onnx \
&& python3 -m pip install -U onnx_graphsurgeon --index-url https://pypi.ngc.nvidia.com \
&& pip install -U snd4onnx
PINTO0309/simple-onnx-processing-tools
$ snd4onnx -h
usage:
snd4onnx [-h]
-rn REMOVE_NODE_NAMES [REMOVE_NODE_NAMES ...]
-if INPUT_ONNX_FILE_PATH
-of OUTPUT_ONNX_FILE_PATH
[-n]
optional arguments:
-h, --help
show this help message and exit.
-rn REMOVE_NODE_NAMES [REMOVE_NODE_NAMES ...], --remove_node_names REMOVE_NODE_NAMES [REMOVE_NODE_NAMES ...]
ONNX node name to be deleted.
-if INPUT_ONNX_FILE_PATH, --input_onnx_file_path INPUT_ONNX_FILE_PATH
Input onnx file path.
-of OUTPUT_ONNX_FILE_PATH, --output_onnx_file_path OUTPUT_ONNX_FILE_PATH
Output onnx file path.
-n, --non_verbose
Do not show all information logs. Only error logs are displayed.
>>> from snd4onnx import remove
>>> help(remove)
Help on function remove in module snd4onnx.onnx_remove_node:
remove(
remove_node_names: List[str],
input_onnx_file_path: Union[str, NoneType] = '',
output_onnx_file_path: Union[str, NoneType] = '',
onnx_graph: Union[onnx.onnx_ml_pb2.ModelProto, NoneType] = None,
non_verbose: Union[bool, NoneType] = False
) -> onnx.onnx_ml_pb2.ModelProto
Parameters
----------
remove_node_names: List[str]
List of OP names to be deleted.
e.g. remove_node_names = ['op_name1', 'op_name2', 'op_name3', ...]
input_onnx_file_path: Optional[str]
Input onnx file path.
Either input_onnx_file_path or onnx_graph must be specified.
output_onnx_file_path: Optional[str]
Output onnx file path.
If output_onnx_file_path is not specified, no .onnx file is output.
onnx_graph: Optional[onnx.ModelProto]
onnx.ModelProto.
Either input_onnx_file_path or onnx_graph must be specified.
onnx_graph If specified, ignore input_onnx_file_path and process onnx_graph.
non_verbose: Optional[bool]
Do not show all information logs. Only error logs are displayed.
Default: False
Returns
-------
removed_graph: onnx.ModelProto
OP removed onnx ModelProto.
$ snd4onnx \
--remove_node_names node_name_a node_name_b \
--input_onnx_file_path input.onnx \
--output_onnx_file_path output.onnx
from snd4onnx import remove
onnx_graph = remove(
remove_node_names=['node_name_a', 'node_name_b'],
input_onnx_file_path='input.onnx',
)
# or
onnx_graph = remove(
remove_node_names=['node_name_a', 'node_name_b'],
onnx_graph=graph,
)
Before | After |
---|---|
![]() |
![]() |
Before | After |
---|---|
![]() |
![]() |
Before | After |
---|---|
![]() |
![]() |
Before | After |
---|---|
![]() |
![]() |
Before | After |
---|---|
![]() |
![]() |
https://github.com/PINTO0309/simple-onnx-processing-tools/issues