1. 09 6月, 2023 1 次提交
  2. 31 5月, 2023 1 次提交
  3. 30 5月, 2023 5 次提交
    • D
      Merge pull request #23597 from dmatveev:dm/gapi_onnx_py_integration · fc5d412b
      Dmitry Matveev 提交于
      G-API: Integration branch for ONNX & Python-related changes #23597
      
      # Changes overview
      
      ## 1. Expose ONNX backend's Normalization and Mean-value parameters in Python
      
      * Since Python G-API bindings rely on `Generic` infer to express Inference, the `Generic` specialization of `onnx::Params` was extended with new methods to control normalization (`/255`) and mean-value; these methods were exposed in the Python bindings
      * Found some questionable parts in the existing API which I'd like to review/discuss (see comments)
      
      UPD:
      1. Thanks to @TolyaTalamanov normalization inconsistencies have been identified with `squeezenet1.0-9` ONNX model itself; tests using these model were updated to DISABLE normalization and NOT using mean/value.
      2. Questionable parts were removed and tests still pass.
      
      ### Details (taken from @TolyaTalamanov's comment):
      
      `squeezenet1.0.*onnx` - doesn't require scaling to [0,1] and mean/std because the weights of the first convolution already scaled. ONNX documentation is broken. So the correct approach to use this models is:
      
      1. ONNX: apply preprocessing from the documentation: https://github.com/onnx/models/blob/main/vision/classification/imagenet_preprocess.py#L8-L44 but without normalization step:
      ```
      # DON'T DO IT:
      # mean_vec = np.array([0.485, 0.456, 0.406])
      # stddev_vec = np.array([0.229, 0.224, 0.225])
      # norm_img_data = np.zeros(img_data.shape).astype('float32')
      # for i in range(img_data.shape[0]):
      #     norm_img_data[i,:,:] = (img_data[i,:,:]/255 - mean_vec[i]) / stddev_vec[i]
      #     # add batch channel
      #     norm_img_data = norm_img_data.reshape(1, 3, 224, 224).astype('float32')
      #     return norm_img_data
      
      # INSTEAD
      return img_data.reshape(1, 3, 224, 224)
      ```
      
      2. G-API: Convert image from BGR to RGB and then pass to `apply` as-is with configuring parameters:
      ```
      net = cv.gapi.onnx.params('squeezenet', model_filename)
      net.cfgNormalize('data_0', False)
      ```
      **Note**: Results might be difference because `G-API` doesn't apply central crop but just do resize to model resolution.
      
      ---
      
      `squeezenet1.1.*onnx` - requires scaling to [0,1] and mean/std - onnx documentation is correct.
      1. ONNX: apply preprocessing from the documentation: https://github.com/onnx/models/blob/main/vision/classification/imagenet_preprocess.py#L8-L44
      2. G-API: Convert image from BGR to RGB and then pass to `apply` as-is with configuring parameters:
      ```
      net = cv.gapi.onnx.params('squeezenet', model_filename)
      net.cfgNormalize('data_0', True) // default
      net.cfgMeanStd('data_0', [0.485, 0.456, 0.406], [0.229, 0.224, 0.225])
      ```
      **Note**: Results might be difference because `G-API` doesn't apply central crop but just do resize to model resolution.
      
      ## 2. Expose Fluid & kernel package-related functionality in Python
      
      * `cv::gapi::combine()`
      * `cv::GKernelPackage::size()` (mainly for testing purposes)
      * `cv::gapi::imgproc::fluid::kernels()`
      
      Added a test for the above.
      
      ## 3. Fixed issues with Python stateful kernel handling
      
      Fixed error message when `outMeta()` of custom python operation fails.
      
      ## 4. Fixed various issues in Python tests
      
      1. `test_gapi_streaming.py` - fixed behavior of Desync test to avoid sporadic issues
      2. `test_gapi_infer_onnx.py` - fixed model lookup (it was still using the ONNX Zoo layout but was NOT using the proper env var we use to point to one).
      
      ### Pull Request Readiness Checklist
      
      See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request
      
      - [x] I agree to contribute to the project under Apache 2 License.
      - [x] To the best of my knowledge, the proposed patch is not based on a code under GPL or another license that is incompatible with OpenCV
      - [x] The PR is proposed to the proper branch
      - [x] There is a reference to the original bug report and related work
      - [x] There is accuracy test, performance test and test data in opencv_extra repository, if applicable
            Patch to opencv_extra has the same branch name.
      - [x] The feature is well documented and sample code can be built with the project CMake
      fc5d412b
    • P
      Merge pull request #23690 from chacha21:rotatedRectangleIntersection_precision · 93d49021
      Pierre Chatelier 提交于
      better accuracy for _rotatedRectangleIntersection() (proposal for #23546) #23690
      
      _rotatedRectangleIntersection() can be (statically) customized to use double instead of float for better accuracy
      this is a proposal for experimentation around #23546
      
      for better accuracy, _rotatedRectangleIntersection() could use double. It will still return cv::Point2f list for backward compatibility, but the inner computations are controlled by a typedef
      
      - [X] I agree to contribute to the project under Apache 2 License.
      - [X] To the best of my knowledge, the proposed patch is not based on a code under GPL or another license that is incompatible with OpenCV
      - [X] The PR is proposed to the proper branch
      - [X] There is a reference to the original bug report and related work
      - [x] There is accuracy test, performance test and test data in opencv_extra repository, if applicable
            Patch to opencv_extra has the same branch name.
      - [x] The feature is well documented and sample code can be built with the project CMake
      93d49021
    • A
      Merge pull request #23707 from Orange-OpenSource:ONNX_Squeeze_negative_index_for_the_axes_attribute · c55aee1e
      Alexander Smorkalov 提交于
      Addition of normalize_axis to ONNXImporter::parseSqueeze
      c55aee1e
    • O
      Addition of normalize_axis to ONNXImporter::parseSqueeze to support negative... · 0442c6fa
      Olivier Hotel 提交于
      Addition of normalize_axis to ONNXImporter::parseSqueeze to support negative values for the axes attribut.
      
      Negative values are part of the ONNX optset>=11.
      Signed-off-by: NOlivier Hotel <olivier.hotel@orange.com>
      0442c6fa
    • A
      Merge pull request #23703 from Abdurrahheem:ash/graph_simplifier · 14573207
      Alexander Smorkalov 提交于
      Added missing index for skipping subgraph simplification 
      14573207
  4. 29 5月, 2023 5 次提交
  5. 27 5月, 2023 4 次提交
  6. 26 5月, 2023 11 次提交
  7. 25 5月, 2023 8 次提交
  8. 24 5月, 2023 3 次提交
  9. 23 5月, 2023 2 次提交