[libcamera-devel] [PATCH v6 7/8] utils: raspberrypi: Add tuning file conversion script

Naushir Patuck naush at raspberrypi.com
Mon Jul 18 10:16:01 CEST 2022


Add a script to convert the Raspberry Pi camera tuning file format from version
1.0 to 2.0. This script also adds a root level version key set to 2.0 to the
config file, allowing the controller to distinguish between the two formats.

Signed-off-by: Naushir Patuck <naush at raspberrypi.com>
Reviewed-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
---
 utils/raspberrypi/ctt/convert_tuning.py | 46 +++++++++++++++++++++++++
 1 file changed, 46 insertions(+)
 create mode 100755 utils/raspberrypi/ctt/convert_tuning.py

diff --git a/utils/raspberrypi/ctt/convert_tuning.py b/utils/raspberrypi/ctt/convert_tuning.py
new file mode 100755
index 000000000000..a84dfa83b3b6
--- /dev/null
+++ b/utils/raspberrypi/ctt/convert_tuning.py
@@ -0,0 +1,46 @@
+#!/usr/bin/env python3
+#
+# SPDX-License-Identifier: BSD-2-Clause
+#
+# Script to convert version 1.0 Raspberry Pi camera tuning files to version 2.0.
+#
+# Copyright 2022 Raspberry Pi Ltd.
+
+import argparse
+import json
+import sys
+
+from ctt_pretty_print_json import pretty_print
+
+
+def convert_v2(in_json: dict) -> str:
+
+    if 'version' in in_json.keys() and in_json['version'] != 1.0:
+        print(f'The JSON config reports version {in_json["version"]} that is incompatible with this tool.')
+        sys.exit(-1)
+
+    converted = {
+        'version': 2.0,
+        'target': 'bcm2835',
+        'algorithms': [{algo: config} for algo, config in in_json.items()]
+    }
+
+    return pretty_print(converted)
+
+
+if __name__ == "__main__":
+    parser = argparse.ArgumentParser(formatter_class=argparse.RawTextHelpFormatter, description=
+                    'Convert the format of the Raspberry Pi camera tuning file from v1.0 to v2.0.\n')
+    parser.add_argument('input', type=str, help='Input tuning file.')
+    parser.add_argument('output', type=str, nargs='?',
+                        help='Output converted tuning file. If not provided, the input file will be updated in-place.',
+                        default=None)
+    args = parser.parse_args()
+
+    with open(args.input, 'r') as f:
+        in_json = json.load(f)
+
+    out_json = convert_v2(in_json)
+
+    with open(args.output if args.output is not None else args.input, 'w') as f:
+        f.write(out_json)
-- 
2.25.1



More information about the libcamera-devel mailing list