Spaces:
Runtime error
Runtime error
Update UI
Browse files- .idea/workspace.xml +12 -7
- demo.py +11 -7
- evaluator.py +9 -5
.idea/workspace.xml
CHANGED
|
@@ -6,11 +6,8 @@
|
|
| 6 |
<component name="ChangeListManager">
|
| 7 |
<list default="true" id="d7806539-b6d6-42e7-bb45-1565f5d54891" name="Changes" comment="Update UI">
|
| 8 |
<change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
|
| 9 |
-
<change beforePath="$PROJECT_DIR$/Dockerfile" beforeDir="false" afterPath="$PROJECT_DIR$/Dockerfile" afterDir="false" />
|
| 10 |
<change beforePath="$PROJECT_DIR$/demo.py" beforeDir="false" afterPath="$PROJECT_DIR$/demo.py" afterDir="false" />
|
| 11 |
<change beforePath="$PROJECT_DIR$/evaluator.py" beforeDir="false" afterPath="$PROJECT_DIR$/evaluator.py" afterDir="false" />
|
| 12 |
-
<change beforePath="$PROJECT_DIR$/tests/coco8.zip" beforeDir="false" afterPath="$PROJECT_DIR$/tests/coco8.zip" afterDir="false" />
|
| 13 |
-
<change beforePath="$PROJECT_DIR$/yolo_dataset.py" beforeDir="false" afterPath="$PROJECT_DIR$/yolo_dataset.py" afterDir="false" />
|
| 14 |
</list>
|
| 15 |
<option name="SHOW_DIALOG" value="false" />
|
| 16 |
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
|
@@ -236,7 +233,7 @@
|
|
| 236 |
<workItem from="1705812482464" duration="711000" />
|
| 237 |
<workItem from="1705845330999" duration="11089000" />
|
| 238 |
<workItem from="1706104589422" duration="517000" />
|
| 239 |
-
<workItem from="1706105118954" duration="
|
| 240 |
</task>
|
| 241 |
<task id="LOCAL-00001" summary="init commit">
|
| 242 |
<option name="closed" value="true" />
|
|
@@ -422,7 +419,15 @@
|
|
| 422 |
<option name="project" value="LOCAL" />
|
| 423 |
<updated>1705850745341</updated>
|
| 424 |
</task>
|
| 425 |
-
<
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 426 |
<servers />
|
| 427 |
</component>
|
| 428 |
<component name="TypeScriptGeneratedFilesManager">
|
|
@@ -478,7 +483,7 @@
|
|
| 478 |
</line-breakpoint>
|
| 479 |
<line-breakpoint enabled="true" suspend="THREAD" type="python-line">
|
| 480 |
<url>file://$PROJECT_DIR$/evaluator.py</url>
|
| 481 |
-
<line>
|
| 482 |
<option name="timeStamp" value="17" />
|
| 483 |
</line-breakpoint>
|
| 484 |
</breakpoints>
|
|
@@ -488,7 +493,7 @@
|
|
| 488 |
<SUITE FILE_PATH="coverage/detector$yolo_dataset.coverage" NAME="yolo_dataset Coverage Results" MODIFIED="1705852113469" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" />
|
| 489 |
<SUITE FILE_PATH="coverage/detector$evaluator.coverage" NAME="evaluator Coverage Results" MODIFIED="1706107083258" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" />
|
| 490 |
<SUITE FILE_PATH="coverage/detector$demo.coverage" NAME="demo Coverage Results" MODIFIED="1706108414052" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" />
|
| 491 |
-
<SUITE FILE_PATH="coverage/detector$streamlit.coverage" NAME="streamlit Coverage Results" MODIFIED="
|
| 492 |
<SUITE FILE_PATH="coverage/detector$extract.coverage" NAME="yolo_dataset Coverage Results" MODIFIED="1705764465837" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" />
|
| 493 |
</component>
|
| 494 |
</project>
|
|
|
|
| 6 |
<component name="ChangeListManager">
|
| 7 |
<list default="true" id="d7806539-b6d6-42e7-bb45-1565f5d54891" name="Changes" comment="Update UI">
|
| 8 |
<change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
|
|
|
|
| 9 |
<change beforePath="$PROJECT_DIR$/demo.py" beforeDir="false" afterPath="$PROJECT_DIR$/demo.py" afterDir="false" />
|
| 10 |
<change beforePath="$PROJECT_DIR$/evaluator.py" beforeDir="false" afterPath="$PROJECT_DIR$/evaluator.py" afterDir="false" />
|
|
|
|
|
|
|
| 11 |
</list>
|
| 12 |
<option name="SHOW_DIALOG" value="false" />
|
| 13 |
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
|
|
|
| 233 |
<workItem from="1705812482464" duration="711000" />
|
| 234 |
<workItem from="1705845330999" duration="11089000" />
|
| 235 |
<workItem from="1706104589422" duration="517000" />
|
| 236 |
+
<workItem from="1706105118954" duration="5313000" />
|
| 237 |
</task>
|
| 238 |
<task id="LOCAL-00001" summary="init commit">
|
| 239 |
<option name="closed" value="true" />
|
|
|
|
| 419 |
<option name="project" value="LOCAL" />
|
| 420 |
<updated>1705850745341</updated>
|
| 421 |
</task>
|
| 422 |
+
<task id="LOCAL-00024" summary="Update UI">
|
| 423 |
+
<option name="closed" value="true" />
|
| 424 |
+
<created>1706108912066</created>
|
| 425 |
+
<option name="number" value="00024" />
|
| 426 |
+
<option name="presentableId" value="LOCAL-00024" />
|
| 427 |
+
<option name="project" value="LOCAL" />
|
| 428 |
+
<updated>1706108912066</updated>
|
| 429 |
+
</task>
|
| 430 |
+
<option name="localTasksCounter" value="25" />
|
| 431 |
<servers />
|
| 432 |
</component>
|
| 433 |
<component name="TypeScriptGeneratedFilesManager">
|
|
|
|
| 483 |
</line-breakpoint>
|
| 484 |
<line-breakpoint enabled="true" suspend="THREAD" type="python-line">
|
| 485 |
<url>file://$PROJECT_DIR$/evaluator.py</url>
|
| 486 |
+
<line>81</line>
|
| 487 |
<option name="timeStamp" value="17" />
|
| 488 |
</line-breakpoint>
|
| 489 |
</breakpoints>
|
|
|
|
| 493 |
<SUITE FILE_PATH="coverage/detector$yolo_dataset.coverage" NAME="yolo_dataset Coverage Results" MODIFIED="1705852113469" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" />
|
| 494 |
<SUITE FILE_PATH="coverage/detector$evaluator.coverage" NAME="evaluator Coverage Results" MODIFIED="1706107083258" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" />
|
| 495 |
<SUITE FILE_PATH="coverage/detector$demo.coverage" NAME="demo Coverage Results" MODIFIED="1706108414052" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" />
|
| 496 |
+
<SUITE FILE_PATH="coverage/detector$streamlit.coverage" NAME="streamlit Coverage Results" MODIFIED="1706110239818" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="" />
|
| 497 |
<SUITE FILE_PATH="coverage/detector$extract.coverage" NAME="yolo_dataset Coverage Results" MODIFIED="1705764465837" SOURCE_PROVIDER="com.intellij.coverage.DefaultCoverageFileProvider" RUNNER="coverage.py" COVERAGE_BY_TEST_ENABLED="true" COVERAGE_TRACING_ENABLED="false" WORKING_DIRECTORY="$PROJECT_DIR$" />
|
| 498 |
</component>
|
| 499 |
</project>
|
demo.py
CHANGED
|
@@ -51,14 +51,18 @@ def evaluate(model: YoloModel):
|
|
| 51 |
# Slider for changing confidence
|
| 52 |
confidence = st.slider('Confidence Threshold', 0, 100, 30)
|
| 53 |
yolo_dataset = YoloDataset.from_zip_file(ZipFile(buffer))
|
| 54 |
-
|
| 55 |
-
|
| 56 |
-
|
| 57 |
-
with
|
|
|
|
|
|
|
| 58 |
st.json(metrics.speed)
|
| 59 |
-
st.
|
| 60 |
-
|
| 61 |
-
|
|
|
|
|
|
|
| 62 |
|
| 63 |
|
| 64 |
def detect(model: YoloModel):
|
|
|
|
| 51 |
# Slider for changing confidence
|
| 52 |
confidence = st.slider('Confidence Threshold', 0, 100, 30)
|
| 53 |
yolo_dataset = YoloDataset.from_zip_file(ZipFile(buffer))
|
| 54 |
+
capture_output(evaluator.coco_evaluate)(model=model.model,
|
| 55 |
+
dataset=yolo_dataset,
|
| 56 |
+
confidence_threshold=confidence / 100.0)
|
| 57 |
+
with evaluator.yolo_evaluator(model, yolo_dataset) as metrics:
|
| 58 |
+
st.subheader("Metrics:")
|
| 59 |
+
st.write("Speed: ")
|
| 60 |
st.json(metrics.speed)
|
| 61 |
+
st.write("Results: ")
|
| 62 |
+
st.json(metrics.results_dict)
|
| 63 |
+
for pic in os.listdir(metrics.save_dir):
|
| 64 |
+
st.write(pic)
|
| 65 |
+
st.image(os.path.join(metrics.save_dir, pic), use_column_width=True)
|
| 66 |
|
| 67 |
|
| 68 |
def detect(model: YoloModel):
|
evaluator.py
CHANGED
|
@@ -11,7 +11,7 @@ from yolo_model import YoloModel
|
|
| 11 |
image_loader = Callable[[str], Image]
|
| 12 |
|
| 13 |
|
| 14 |
-
def
|
| 15 |
coco_gt = dataset.to_coco()
|
| 16 |
# initialize evaluator with ground truth (gt)
|
| 17 |
evaluator = CocoEvaluator(coco_gt=coco_gt, iou_types=["bbox"])
|
|
@@ -30,10 +30,13 @@ def evaluate(model: YoloModel, dataset: YoloDataset, confidence_threshold=0.6):
|
|
| 30 |
|
| 31 |
if len(evaluator.eval_imgs["bbox"]) == 0:
|
| 32 |
print("No detections!")
|
| 33 |
-
|
| 34 |
-
|
| 35 |
-
|
| 36 |
-
|
|
|
|
|
|
|
|
|
|
| 37 |
return Metrics(model=model, material=dataset.to_material())
|
| 38 |
|
| 39 |
|
|
@@ -45,6 +48,7 @@ class Metrics:
|
|
| 45 |
|
| 46 |
def __enter__(self):
|
| 47 |
if self.val is None:
|
|
|
|
| 48 |
self.val = self.model.model.val(data=self.material.yaml)
|
| 49 |
return self.val
|
| 50 |
|
|
|
|
| 11 |
image_loader = Callable[[str], Image]
|
| 12 |
|
| 13 |
|
| 14 |
+
def coco_evaluate(model: YoloModel, dataset: YoloDataset, confidence_threshold=0.6):
|
| 15 |
coco_gt = dataset.to_coco()
|
| 16 |
# initialize evaluator with ground truth (gt)
|
| 17 |
evaluator = CocoEvaluator(coco_gt=coco_gt, iou_types=["bbox"])
|
|
|
|
| 30 |
|
| 31 |
if len(evaluator.eval_imgs["bbox"]) == 0:
|
| 32 |
print("No detections!")
|
| 33 |
+
else:
|
| 34 |
+
evaluator.synchronize_between_processes()
|
| 35 |
+
evaluator.accumulate()
|
| 36 |
+
evaluator.summarize()
|
| 37 |
+
|
| 38 |
+
|
| 39 |
+
def yolo_evaluator(model: YoloModel, dataset: YoloDataset):
|
| 40 |
return Metrics(model=model, material=dataset.to_material())
|
| 41 |
|
| 42 |
|
|
|
|
| 48 |
|
| 49 |
def __enter__(self):
|
| 50 |
if self.val is None:
|
| 51 |
+
self.material.__enter__()
|
| 52 |
self.val = self.model.model.val(data=self.material.yaml)
|
| 53 |
return self.val
|
| 54 |
|