Skip to content

Latest commit

 

History

History
609 lines (429 loc) · 36.3 KB

CHANGELOG.md

File metadata and controls

609 lines (429 loc) · 36.3 KB

Changelog

All notable changes to this project will be documented in this file.

[v1.6.5]

Bug fixes

  • Fix labels names in hierarchical config (#3879)
  • Fix Learning Rate and Loss Handling in Tile Classifier MaskRCNN EfficientNet (#3873)
  • Pad tile to image size (512 x 512) (#3887)
  • Don't apply labels normalization on training (#3886)
  • Disable Tile Classifier in Rotated Detection (#3894)
  • Enhance Memeory Cache Handler with Complex Unique Keys (#3897)

[v1.6.4]

Bug fixes

  • Pad input image to square when tiling is enabled (#3844)
  • Fix confusion matrix calculation (#3857)

[v1.6.3]

Enhancements

  • Improve Vitens Kiemgetal OTX 1.6.x (#3671)
  • Update dependencies (#3750)

Bug fixes

  • Fix rotated detection data pipeline (#3627)

[v1.6.2]

Enhancements

  • Add augmentation details page to the docs (#3533)

Bug fixes

  • Pin OTX version to requirements.txt file for the exportable package (#3555)

[v1.6.1]

Enhancements

  • Replace the default model for rotated_det/ins_seg task from resnet50_maskrcnn to efficientnetb2b_maskrcnn (#3478)
  • Update pymongo version to 4.6.3 for resolving CVE-2024-21506 (#3396)
  • Use torchvision in MRCNN on CUDA (#3347)
  • Update IPEX version in installation guide documentation (#3343)
  • Update benchmark (#3338)
  • Bump idan version to 3.7 (#3332)
  • Support benchmark history summary (#3307)
  • Pin pymongo version to 4.5.0 (#3316)
  • Upgrade MAPI (#3304)
  • Add NMS iou threshold configurable parameter (#3287)
  • Remedy some medium/low severity bandit issues (#3208)
  • Update documentations (#3280)
  • Add perf benchmark test cases for action and visual prompting (#3292)

Bug fixes

  • Explicitly cast incorrect output type in OV model (#3395)
  • Update QAT configs for rotated detection (#3375)
  • Hotfix 🔧 Bypass ClsIncrSampler for tiling (#3374)
  • [NNCF] Dynamic shape datasets WA (#3355)
  • [Hotfix] 🔥 Fixing detection oriented OV inferencer (#3351)
  • Revert adaptive batch size (#3340)
  • Fix e2e tests for XPU (#3305)
  • Remove torch.xpu.optimize for semantic_segmentation task (#3172)

[v1.6.0]

New features

  • Add zero-shot visual prompting (#2616, #2706, #2753)
  • Add support for the training and validation on the XPU devices (#3058)
  • Add a new configurable parameter nms_iou_thresold to control iou threshold of NMS post processing (#3287)
  • Add support for the training and validation on the Intel Max GPU devices (#3058)

Enhancements

  • Upgrade OpenVINO to 2023.3 (#2879)
  • Automate performance benchmark (#2742)
  • Bump ONNX version to 1.16.0 to resolve CVE-2022-25882 (#3205)

[v1.5.2]

NOTES

OpenVINO™ Training Extension v1.5.2 does not include the latest functional and security updates. OpenVINO™ Training Extension v1.6.0 is targeted to be released in April 2024 and will include additional functional and security updates. Customers should update to the latest version as it becomes available.

Bug fixes

  • Remove polygon clipping code (#2926)
  • Hotfix default memcache size to 100MB (#2990)

[v1.5.0]

New features

  • Enable configurable confidence threshold for otx eval and export (#2388)
  • Add YOLOX variants as new object detector models (#2402)
  • Enable FeatureVectorHook to support action tasks (#2408)
  • Add ONNX metadata to detection, instance segmentation, and segmentation models (#2418)
  • Add a new feature to configure input size (#2420)
  • Introduce the OTXSampler and AdaptiveRepeatDataHook to achieve faster training at the small data regime (#2428)
  • Add a new object detector Lite-DINO (#2457)
  • Add Semi-SL Mean Teacher algorithm for Instance Segmentation task (#2444)
  • Official supports for YOLOX-X, YOLOX-L, YOLOX-S, ResNeXt101-ATSS (#2485)
  • Add new argument to track resource usage in train command (#2500)
  • Add Self-SL for semantic segmentation of SegNext families (#2215)
  • Adapt input size automatically based on dataset statistics (#2499)

Enhancements

  • Refine input data in-memory caching (#2416)
  • Adapt timeout value of initialization for distributed training (#2422)
  • Optimize data loading by merging load & resize operations w/ caching support for cls/det/iseg/sseg (#2438, #2453, #2460)
  • Support torch==2.0.1 (#2465)
  • Set "Auto" as default input size mode (#2515)

Bug fixes

  • Fix F1 auto-threshold to choose best largest confidence (#2371)
  • Fix IBLoss enablement with DeiT-Tiny when class incremental training (#2594)

Known issues

  • OpenVINO(==2023.0) IR inference is not working well on 2-stage models (e.g. Mask-RCNN) exported from torch>=1.13.1
  • NNCF QAT optimization is disabled for MaskRCNN models due to CUDA runtime error in ROIAlign kernel on torch==2.0.1

[v1.4.5]

Bug fixes

  • Filter invalid polygon shapes (#2795)
  • 🐞 Bugfix: Set reverseinput_channels to True in OpenVINO models (#2848

Misc

  • Remove dependency of protobuf to omit vulnerability issue (#2851)

[v1.4.4]

Enhancements

  • Update ModelAPI configuration(#2564)
  • Add Anomaly modelAPI changes (#2563)
  • Update Image numpy access (#2586)
  • Make max_num_detections configurable (#2647)

Bug fixes

  • Fix IBLoss enablement with DeiT-Tiny when class incremental training (#2595)
  • Fix mmcls bug not wrapping model in DataParallel on CPUs (#2601)
  • Fix h-label loss normalization issue w/ exclusive label group of singe label (#2604)
  • Fix division by zero in class incremental learning for classification (#2606)
  • Fix saliency maps calculation issue for detection models (#2609)
  • Fix h-label bug of missing parent labels in output (#2626)

[v1.4.3]

Enhancements

  • Re-introduce adaptive scheduling for training (#2541)

[v1.4.2]

Enhancements

  • Upgrade nncf version to 2.6.0 (#2459)
  • Bump datumaro version to 1.5.0 (#2470, #2502)
  • Set tox version constraint (#2472)
  • Add model category attributes to model template (#2439)

Bug fixes

  • Bug fix for albumentations (#2467)
  • Add workaround for the incorrect meta info M-RCNN (used for XAI) (#2437)
  • Fix label list order for h-label classification (#2440)
  • Modified fq numbers for lite HRNET e2e tests (#2445)

[v1.4.1]

Enhancements

  • Update the README file in exportable code (#2411)

Bug fixes

  • Fix broken links in documentation (#2405)

[v1.4.0]

New features

  • Support encrypted dataset training (#2209)
  • Add custom max iou assigner to prevent CPU OOM when large annotations are used (#2228)
  • Auto train type detection for Semi-SL, Self-SL and Incremental: "--train-type" now is optional (#2195)
  • Add per-class XAI saliency maps for Mask R-CNN model (#2227)
  • Add new object detector Deformable DETR (#2249)
  • Add new object detector DINO (#2266)
  • Add new visual prompting task (#2203, #2274, #2311, #2354, #2318)
  • Add new object detector ResNeXt101-ATSS (#2309)

Enhancements

  • Introduce channel_last parameter to improve the performance (#2205)
  • Decrease time for making a workspace (#2223)
  • Set persistent_workers and pin_memory as True in detection task (#2224)
  • New algorithm for Semi-SL semantic segmentation based on metric learning via class prototypes (#2156)
  • Self-SL for classification now can recieve just folder with any images to start contrastive pretraining (#2219)
  • Update OpenVINO version to 2023.0, and NNCF verion to 2.5 (#2090)
  • Improve XAI saliency map generation for tiling detection and tiling instance segmentation (#2240)
  • Remove CenterCrop from Classification test pipeline and editing missing docs link(#2375)
  • Switch to PTQ for sseg (#2374)

Bug fixes

  • Fix the bug that auto adapt batch size is unavailable with IterBasedRunner (#2182)
  • Fix the bug that learning rate isn't scaled when multi-GPU trianing is enabled(#2254)
  • Fix the bug that label order is misaligned when model is deployed from Geti (#2369)
  • Fix NNCF training on CPU (#2373)
  • Fix H-label classification (#2377)
  • Fix invalid import structures in otx.api (#2383)
  • Add for async inference calculating saliency maps from predictions (Mask RCNN IR) (#2395)

Known issues

  • OpenVINO(==2023.0) IR inference is not working well on 2-stage models (e.g. Mask-RCNN) exported from torch==1.13.1

[v1.3.1]

Enhancements

  • n/a

Bug fixes

  • Fix a bug that auto adapt batch size doesn't work with cls incr case (#2199)
  • Fix a bug that persistent worker is True even if num_workers is zero (#2208)

Known issues

  • OpenVINO(==2022.3) IR inference is not working well on 2-stage models (e.g. Mask-RCNN) exported from torch==1.13.1 (working well up to torch==1.12.1) (#1906)

[v1.3.0]

New features

  • Support direct annotation input for COCO format (#1921)
  • Action task supports multi GPU training. (#2057)
  • Support storage cache in Apache Arrow using Datumaro for action tasks (#2087)
  • Add a simplified greedy labels postprocessing for hierarchical classification (#2064).
  • Support auto adapting batch size (#2119)
  • Support auto adapting num_workers (#2165)
  • Support noisy label detection for detection tasks (#2109, #2115, #2123, #2183)

Enhancements

  • Make semantic segmentation OpenVINO models compatible with ModelAPI (#2029).
  • Support label hierarchy through LabelTree in LabelSchema for classification task (#2149, #2152).
  • Enhance exportable code file structure, video inference and default value for demo (#2051).
  • Speedup OpenVINO inference in image classificaiton, semantic segmentation, object detection and instance segmentation tasks (#2105).
  • Refactoring of ONNX export functionality (#2155).
  • SSD detector Optimization(#2197)

Bug fixes

  • Fix async mode inference for demo in exportable code (#2154)
  • Fix a bug that auto adapt batch size doesn't work with cls incr case (#2199)

Known issues

  • OpenVINO(==2022.3) IR inference is not working well on 2-stage models (e.g. Mask-RCNN) exported from torch==1.13.1 (working well up to torch==1.12.1) (#1906)

[v1.2.3]

Bug fixes

  • Return raw anomaly map instead of colormap as metadata to prevent applying colormap conversion twice (#2217)
  • Hotfix: use 0 confidence threshold when computing best threshold based on F1

[v1.2.2]

Enhancements

  • Improve warning message for tiling configurable parameter

Known issues

  • OpenVINO(==2022.3) IR inference is not working well on 2-stage models (e.g. Mask-RCNN) exported from torch==1.13.1 (working well up to torch==1.12.1) (#1906)

[v1.2.1]

Enhancements

  • Upgrade mmdeploy==0.14.0 from official PyPI (#2047)
  • Integrate new ignored loss in semantic segmentation (#2065, #2111)
  • Optimize YOLOX data pipeline (#2075)
  • Tiling Spatial Concatenation for OpenVINO IR (#2052)
  • Optimize counting train & inference speed and memory consumption (#2172)

Bug fixes

  • Bug fix: value of validation variable is changed after auto decrease batch size (#2053)
  • Fix tiling 0 stride issue in parameter adapter (#2078)
  • Fix Tiling NNCF (#2081)
  • Do not skip full img tile classifier + Fix Sequencial Export Issue (#2174)

[v1.2.0]

New features

  • Add generating feature cli_report.log in output for otx training (#1959)
  • Support multiple python versions up to 3.10 (#1978)
  • Support export of onnx models (#1976)
  • Add option to save images after inference in OTX CLI demo together with demo in exportable code (#2005)
  • Support storage cache in Apache Arrow using Datumaro for cls, det, seg tasks (#2009)
  • Add noisy label detection for multi-class classification task (#1985, #2034)
  • Add DeiT template for classification tasks as experimental template (<#2093)

Enhancements

  • Clean up and refactor the output of the OTX CLI (#1946)
  • Enhance DetCon logic and SupCon for semantic segmentation(#1958)
  • Detection task refactoring (#1955)
  • Classification task refactoring (#1972)
  • Extend OTX explain CLI (#1941)
  • Segmentation task refactoring (#1977)
  • Action task refactoring (#1993)
  • Optimize data preprocessing time and enhance overall performance in semantic segmentation (#2020)
  • Support automatic batch size decrease when there is no enough GPU memory (#2022)
  • Refine HPO usability (#2175)

Bug fixes

  • Fix backward compatibility with OpenVINO SSD-like detection models from OTE 0.5 (#1970)

Known issues

  • OpenVINO(==2022.3) IR inference is not working well on 2-stage models (e.g. Mask-RCNN) exported from torch==1.13.1 (working well up to torch==1.12.1) (#1906)

[v1.1.2]

Bug fixes

  • Fix exception -> warning for anomaly dump_feature option
  • Remove dataset.with_empty_annotations() to keep original input structure (#1964)
  • Fix OV batch inference (saliency map generation) (#1965)
  • Replace EfficentNetB0 model download logic by pytorchcv to resolve zip issue (#1967)

[v1.1.1]

Bug fixes

  • Add missing OpenVINO dependency in exportable code requirement

[v1.1.0]

New features

  • Add FP16 IR export support (#1683)
  • Add in-memory caching in dataloader (#1694)
  • Add MoViNet template for action classification (#1742)
  • Add Semi-SL multilabel classification algorithm (#1805)
  • Integrate multi-gpu training for semi-supervised learning and self-supervised learning (#1534)
  • Add train-type parameter to otx train (#1874)
  • Add embedding of inference configuration to IR for classification (#1842)
  • Enable VOC dataset in OTX (#1862)
  • Add mmcls.VisionTransformer backbone support (#1908)

Enhancements

  • Parametrize saliency maps dumping in export (#1888)
  • Bring mmdeploy to action recognition model export & Test optimization of action tasks (#1848)
  • Update backbone lists (#1835)
  • Add explanation for XAI & minor doc fixes (#1923)
  • Refactor phase#1: MPA modules

Bug fixes

  • Handle unpickable update_progress_callback (#1892)
  • Dataset Adapter: Avoid duplicated annotation and permit empty image (#1873)
  • Arrange scale between bbox preds and bbox targets in ATSS (#1880)
  • Fix label mismatch of evaluation and validation with large dataset in semantic segmentation (#1851)
  • Fix packaging errors including cython module build / import issues (#1936)

Known issues

  • OpenVINO(==2022.3) IR inference is not working well on 2-stage models (e.g. Mask-RCNN) exported from torch==1.13.1 (working well up to torch==1.12.1) (#1906)

[v1.0.1]

Enhancements

  • Refine documents by proof review
  • Separate installation for each tasks
  • Improve POT efficiency by setting stat_requests_number parameter to 1
  • Introduce new tile classifier to enhance tiling inference performance in MaskRCNN.

Bug fixes

  • Fix missing classes in cls checkpoint
  • Fix action task sample codes
  • Fix label_scheme mismatch in classification
  • Fix training error when batch size is 1
  • Fix hang issue when tracing a stack in certain scenario
  • Fix pickling error by Removing mmcv cfg dump in ckpt

[v1.0.0]

NOTES

OpenVINO™ Training Extensions which version 1.0.0 has been updated to include functional and security updates. Users should update to the latest version.

New features

  • Adaptation of Datumaro component as a dataset interface
  • Integrate hyper-parameter optimizations
  • Support action recognition task
  • Self-supervised learning mode for representational training
  • Semi-supervised learning mode for better model quality

Enhancements

  • Installation via PyPI package
  • Enhance find command to find configurations of supported tasks / algorithms / models / backbones
  • Introduce build command to customize task or model configurations in isolated workspace
  • Auto-config feature to automatically select the right algorithm and default model for the train & build command by detecting the task type of given input dataset
  • Improve documentation
  • Improve training performance by introducing enhanced loss for the few-shot transfer

Bug fixes

  • Fixing configuration loading issue from the meta data of the model in OpenVINO task for the backward compatibility
  • Fixing some minor issues

[v0.5.0]

NOTES

OpenVINO Training Extension which version is equal or older then v0.5.0 does not include the latest functional and security updates. OTE Version 1.0.0 is targeted to be released in February 2023 and will include additional functional and security updates. Customers should update to the latest version as it becomes available.

Added

  • Add tiling in rotated detection (#1420)
  • Add Cythonize AugMixAugment (#1478)
  • Integrate ov-telemetry (#1568)

Changed

  • Update OpenVINO to 2022.3 release & nncf to the pre-2.4 version (#1393)

Fixed

  • Fixing h-label head output bug in OV inference (#1458)
  • Fixing deprecated np.bool issue from numpy==1.24.0 (#1455)
  • Fixing tiling OpenVINO backward compatibility (#1516)
  • Fixing indexing in hierarchical classification inference (#1551)
  • Copying feature vector to resolve duplication issue (#1511)
  • Fixing handling ignored samples in hierarchical head (#1599)
  • Some minor issues

[v0.4.0]

Added

  • Model Preparation Algorithm (MPA)
    • Better saliency map support
      • Replace current saliency map generation with Recipro-CAM for cls (#1363)
      • Class-wise saliency map generation for the detection task (#1402)
      • OTE Saliency Map Label (#1447)
    • Improve object counting algorithm for high-res images via image tiling
      • Add Tiling Module (#1200)
      • Fliter object less than 1 pixel (#1305)
      • Tiling deployment (#1387)
      • Enable tiling oriented detection for v0.4.0/geti1.1.0 (#1427)

Fixed

  • Hot-fix for Detection fix two stage error (#1433)
  • Fixing ZeroDivisionError in iteration counter for detection-classification project trainings (#1449)
  • Some minor issues

[v0.3.1]

Fixed

  • Neural Network Compression Framework (NNCF)

    • Fix CUDA OOM for NNCF optimization model MaskRCNN-EfficientNetB2B (#1319)
  • Model Preparation Algorithm (MPA)

    • Fix 'Shape out of bounds' error when accepting AI predictions for detection oriented (#1326)
    • Fix weird confidence behaviour issue on predictions for hierarchical classification (#1332)
    • Fix training failure issue for hierarchical classification (#1329)
    • Fix training failure issues for segmentation and instance segmentation during inference process (#1338)
    • Some minor issues

Security

  • Update vulnerable Python dependencies in OTE (#1303)

[v0.3.0]

Added

  • Model Preparation Algorithm (MPA)
    • Add new tasks / model templates for Class-Incremental Learning
      • Instance Segmentation (#1142)
      • Classification
      • SSD and YOLOX model template for Detection (#1156)
    • Saliency map support
    • NNCF (#1157) support
    • HPO (#1168) support
    • Balanced Sampler support for Classification (#1139)
    • Add Adaptive Training for Detection / Instance Segmentation (#1190)
  • Anomaly
    • Add real-life training tests (#898)
    • Add additional check for early stopping parameter (#1110)
    • Add DRAEM task implementation (#1203)

Changed

  • Model Preparation Algorithm (MPA)

    • Replace Class-Incremental Learning models as OTE default models (#1150)
    • Replace OTE ignored label support with external ignored label
    • Enable mixed precision for Classification / Detection / Segmentation (#1198)
    • Enhance training schedule for Classification (#1212)
    • Change Model optimization hyper-parameters for Classification / Detection (#1170)
    • Disable Obsolete test cases for OTE CI (#1220)
  • Anomaly

    • Extend conftest configuration for anomaly backend (#1097)
    • Expose more params to the UI (#1085)
    • Change directory structure for anomaly templates (#1105)
    • Use is_anomalous attribute instead of string matching (#1120)
    • Set nncf version (#1124)
    • Move to learning parameters (#1152)
    • Change OpenVINO MO Command (#1221)

Fixed

  • Model Preparation Algorithm (MPA)

    • Fix inference issues for Detection (#1167)
    • Fix model compatibility issue between SC1.1 and 1.2 in Segmentation (#1264)
    • Some minor issues
  • Anomaly

    • Fix non deterministic + sample.py (#1118)
    • Fix exportable code for anomaly tasks (#1113)
    • Fix local anomaly segmentation performance bug (#1219)
    • Fix progress bar (#1223)
    • Fix inference when model backbone changes (#1242)

[v0.2.0]

Added

  • Model Preparation Algorithm (MPA), a newly introduced OTE Algorithm backend for advanced transfer learning
    • Class-Incremental Learning support for OTE models
      • Image Classification
      • Object Detection
      • Semantic Segmentation
  • Object counting & Rotated object detection are added to Object Detection backend
  • Increased support for NNCF / FP16 / HPO
  • Ignored label support
  • Stop training on NaN losses

Changed

  • Major refactoring
    • Tasks & model templates had been moved to OTE repo from each OTE Algorithm backend

[v0.1.1]

Fixed

  • Some minor issues

[v0.1.0]

Added

  • OTE SDK, defines an interface which can be used by OTE CLI to access OTE Algorithms.
  • OTE CLI, contains set of commands needed to operate with deep learning models using OTE SDK Task interfaces.
  • OTE Algorithms, contains sub-projects implementing OTE SDK Task interfaces for different deep learning models.
    • Anomaly Classification
    • Image Classification
    • Object Detection
    • Semantic Segmentation