Contents¶
Web Visualizer Module¶
Web Visualizer ia a web based app to view the classified images/metadata coming out of Open Edge Insights for Industrial (Open EII).
Note
In this document, you will find labels of ‘Edge Insights for Industrial (EII)’ for file names, paths, code snippets, and so on. Consider the references of EII as Open EII. This is due to the product name change of EII as Open EII.
Steps to Build and Run Web Visualizer¶
Refer to the following sections to build and launch Web Visualizer service:
For more details, refer to the Open EII core README
- Running WebVisualizer in a browser - WebVisualizer is tested on chrome browser, so it’s recommended to use the Chrome browser. 
- WebVisualizer currently supports only 6 parallel streams in the Chrome browser per instance. 
- Running in DEV mode: - Go to browser
- http://< host ip >:5001 
 
 
- Running in PROD mode: - copy ‘cacert.pem’ from ‘[WORK_DIR]/IEdgeInsights/build/Certificates/rootca’ to home directory ‘~/’ and give appropriate permissions to it as shown below: - sudo cp [WORK_DIR]/IEdgeInsights/build/Certificates/rootca/cacert.pem ~ sudo chmod 0755 ~/cacert.pem 
- Import ‘cacert.pem’ from home Directory ‘~/’ to your Browser Certificates. - Steps to Import Certificates - Goto Settings in Chrome 
- Search Manage Certificates Under Privacy & Security 
- Select Manage Certificates Option 
- Under Authorities Tab Click Import Button 
- With Import Wizard navigate to home directory 
- Select cacert.pem file 
- Select All CheckBoxes and Click Import Button. 
 
- Now in Browser
- https://< host ip >:5000 
 
- Login Page
- You should use your defined username & password in etcd config. 
 
 
 
Note
- The admin has to make sure all the necessary config is set in etcd before starting the web visualizer. 
- Clear the - browsers cachewhile switching from- prodmode to- devmode on running- WebVisualizerin browser.
Using Labels¶
In order to have the web visualizer label each of the defects on the image, labels in JSON format(with mapping between topic subscribed text to be displayed) has to be provided in config.json(
[WORK_DIR]/IEdgeInsights/WebVisualizer/config.json) file and run the builder.py([WORK_DIR]/IEdgeInsights/build/builder.py) script using the below command.
   python3 builder.py
An example of what this JSON value should look like is shown below. In this case
it is assumed that the classification types are ``0`` and ``1`` and the text labels
to be displayed are ``MISSING`` and ``SHORT`` respectively.
{
    "0": "MISSING",
    "1": "SHORT"
}
Note
These labels are the mapping for the PCB demo provided in EII’s web visualizer directory. Currently camera1_stream_results consists of pcb demo labeling and camera2_stream_results consists of safety demo labeling.
Hence, in config.json([WORK_DIR]/IEdgeInsights/WebVisualizer/config.json), mapping of all the subscribed topics has to be done with pcb demo labeling and safety demo labeling respectively.
"/WebVisualizer/config": {
        "dev_port": 5001,
        "port": 5000,
        "labels" : {
            "camera1_stream": {
                "0": "MISSING",
                "1": "SHORT"
            },
            "native_safety_gear_stream_results": {
                "1": "safety_helmet",
                "2": "safety_jacket",
                "3": "Safe",
                "4": "Violation"
            },
            "py_safety_gear_stream_results": {
                "1": "safety_helmet",
                "2": "safety_jacket",
                "3": "Safe",
                "4": "Violation"
            },
            "gva_safety_gear_stream_results": {
                "1": "safety_helmet",
                "2": "safety_jacket",
                "3": "Safe",
                "4": "Violation"
            }
        }
    }
Metadata Structure¶
Open EII WebVisualizer app can decode certain types of mete-data formats for drawing the defects on the image. Any application wanting to use Open EII WebVisualizer need to comply with the meta-data format as described below:
- For Ingestor’s Non-GVA type, metadata structure sample is : 
{
 "channels": 3,
 "encoding_type": "jpeg",
 "height": 1200,
 "defects": [
     {"type": 0, "tl": [1019, 644], "br": [1063, 700]},
     {"type": 0, "tl": [1297, 758], "br": [1349, 796]}
    ],
"display_info": [{"info":"good", "priority":0}],
"img_handle": "348151d424",
"width": 1920,
"encoding_level": 95
}
where in defects and display_info is a list of dicts.
Each entry in defects list is a dictionary that should contain following keys:
- type: value given to type will be the label id
- tl: value is the top-left- xand- yco-ordinate of the defect in the image.
- br: value is the bottom-right- xand- yco-ordinate of the defect in the image.
Each entry in display_info list is a dictionary that should contain following keys:
- info: value given will be displayed on the image.
- priority: Based on the priority level (0, 1, or 2), info will be displayed in either green, orange or red.- 0 : Low priority, info will be displayed in green. 
- 1 : Medium priority, info will be displayed in orange. 
- 2 : High priority, info will be displayed in red. 
 
- For Ingestor’s GVA type, metadata structure sample is : 
{
    "channels": 3,
    "gva_meta": [
        {"x": 1047, "height": 86, "y": 387, "width": 105, "tensor": [{"label": "", "label_id": 1, "confidence":0.8094226121902466, "attribute":"detection"}]},
        {"x": 1009, "height": 341, "y": 530, "width": 176, "tensor": [{"label": "", "label_id": 2, "confidence": 0.9699158668518066, "attribute": "detection"}]}
        ],
    "encoding_type": "jpeg",
    "height": 1080,
    "img_handle": "7247149a0d",
    "width": 1920,
    "encoding_level": 95
}
where in gva_meta is a list of dicts.
Note
- Any data with in the list, tuple or dict of meta data should be of primitive data type (int, float, string, bool). Refer the examples given above. 
- If user needs to remove the bounding box:
- Set the value of draw_results in config.json as false for both Visualiser and WebVisualiser. 
 
```sh
draw_results: "false"
```