{
  "schema_version": "2.0",
  "metadata": {
    "diagram_id": "tflm_riscv_fpga_stack_01"
  },
  "global_properties": {
    "topic": "TensorFlow Lite Micro on RISC-V FPGA Stack",
    "purpose": "architecture_overview",
    "target_audience": "engineer",
    "complexity_level": "publication_quality",
    "domain": "Embedded Systems",
    "visual_format": "block_diagram",
    "diagram_type": "architecture_diagram",
    "layout_grid": "3-tier_vertical",
    "style_theme": "professional_light",
    "background_color": "#FFFFFF",
    "font_family": "Helvetica, Arial, sans-serif",
    "title": {
      "text": "TensorFlow Lite Micro on RISC-V FPGA Stack",
      "is_present": true
    }
  },
  "components": [
    {
      "id": "container_software_stack",
      "type": "group_container",
      "label": "",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D2E4F6",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "solid"
      }
    },
    {
      "id": "c_test_code",
      "type": "shape_node",
      "label": "Custom Test Code",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#C7E6B0",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "c_models_data",
      "type": "shape_node",
      "label": "Models and Test Data",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#B3C7F6",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "c_perf_measure",
      "type": "shape_node",
      "label": "Performance Measurement",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#B3C7F6",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "c_custom_tflm_ops",
      "type": "shape_node",
      "label": "Custom TfLM Ops",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#C7E6B0",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "c_common_libs",
      "type": "shape_node",
      "label": "Common Libraries",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#B3C7F6",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "c_tflm_micro",
      "type": "shape_node",
      "label": "Tensorflow Lite for Microcontrollers",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#B3C7F6",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "c_riscv_compiler",
      "type": "shape_node",
      "label": "RISCV Compiler",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#B3C7F6",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "container_litex_soc",
      "type": "group_container",
      "label": "LiteX SoC",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D2E4F6",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "solid"
      }
    },
    {
      "id": "c_vexriscv_cpu",
      "type": "shape_node",
      "label": "VexRiscV CPU",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#B3C7F6",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "c_custom_func_unit",
      "type": "shape_node",
      "label": "Custom Function Unit",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#C7E6B0",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "dashed"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "c_symbiflow",
      "type": "shape_node",
      "label": "Symbiflow",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#B3C7F6",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    },
    {
      "id": "c_fpga",
      "type": "shape_node",
      "label": "Xilinx Artix 7 35T\n(Arty A7)",
      "geometry": {
        "shape": "rounded_rectangle"
      },
      "styling": {
        "fill_color": "#D2E4F6",
        "border_color": "#000000",
        "border_width": 2,
        "border_style": "solid"
      },
      "text_properties": {
        "font_weight": "normal",
        "text_color": "#000000"
      }
    }
  ],
  "connections": [
    {
      "id": "conn1",
      "from_id": "c_riscv_compiler",
      "to_id": "container_litex_soc",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    },
    {
      "id": "conn2",
      "from_id": "container_litex_soc",
      "to_id": "c_fpga",
      "label": {
        "text": "",
        "position": "middle_above",
        "text_color": "#000000"
      },
      "line_properties": {
        "type": "straight",
        "style": "solid",
        "color": "#000000",
        "width": 2
      },
      "arrowhead": {
        "start_type": "none",
        "end_type": "solid_triangle",
        "size": "medium"
      }
    }
  ],
  "layout_constraints": [
    {
      "type": "containment",
      "container_id": "container_software_stack",
      "element_ids": [
        "c_test_code",
        "c_models_data",
        "c_perf_measure",
        "c_custom_tflm_ops",
        "c_common_libs",
        "c_tflm_micro",
        "c_riscv_compiler"
      ],
      "padding": "medium"
    },
    {
      "type": "containment",
      "container_id": "container_litex_soc",
      "element_ids": [
        "c_vexriscv_cpu",
        "c_custom_func_unit",
        "c_symbiflow"
      ],
      "padding": "medium"
    },
    {
      "type": "relative_arrangement",
      "element_ids": [
        "container_software_stack",
        "container_litex_soc",
        "c_fpga"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "horizontal_center",
      "element_ids": [
        "container_software_stack",
        "container_litex_soc",
        "c_fpga"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "top_edge",
      "element_ids": [
        "c_test_code",
        "c_models_data"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "top_edge",
      "element_ids": [
        "c_perf_measure",
        "c_custom_tflm_ops"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "top_edge",
      "element_ids": [
        "c_common_libs",
        "c_tflm_micro"
      ]
    },
    {
      "type": "alignment",
      "alignment_type": "top_edge",
      "element_ids": [
        "c_vexriscv_cpu",
        "c_custom_func_unit"
      ]
    }
  ]
}