mirror of
				https://github.com/hybridgroup/gocv
				synced 2025-08-25 08:41:04 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			214 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			214 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package gocv
 | |
| 
 | |
| /*
 | |
| #include <stdlib.h>
 | |
| #include "objdetect.h"
 | |
| */
 | |
| import "C"
 | |
| import (
 | |
| 	"image"
 | |
| 	"reflect"
 | |
| 	"unsafe"
 | |
| )
 | |
| 
 | |
| // CascadeClassifier is a cascade classifier class for object detection.
 | |
| //
 | |
| // For further details, please see:
 | |
| // http://docs.opencv.org/3.3.1/d1/de5/classcv_1_1CascadeClassifier.html
 | |
| //
 | |
| type CascadeClassifier struct {
 | |
| 	p C.CascadeClassifier
 | |
| }
 | |
| 
 | |
| // NewCascadeClassifier returns a new CascadeClassifier.
 | |
| func NewCascadeClassifier() CascadeClassifier {
 | |
| 	return CascadeClassifier{p: C.CascadeClassifier_New()}
 | |
| }
 | |
| 
 | |
| // Close deletes the CascadeClassifier's pointer.
 | |
| func (c *CascadeClassifier) Close() error {
 | |
| 	C.CascadeClassifier_Close(c.p)
 | |
| 	c.p = nil
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // Load cascade classifier from a file.
 | |
| //
 | |
| // For further details, please see:
 | |
| // http://docs.opencv.org/3.3.1/d1/de5/classcv_1_1CascadeClassifier.html#a1a5884c8cc749422f9eb77c2471958bc
 | |
| //
 | |
| func (c *CascadeClassifier) Load(name string) bool {
 | |
| 	cName := C.CString(name)
 | |
| 	defer C.free(unsafe.Pointer(cName))
 | |
| 	return C.CascadeClassifier_Load(c.p, cName) != 0
 | |
| }
 | |
| 
 | |
| // DetectMultiScale detects objects of different sizes in the input Mat image.
 | |
| // The detected objects are returned as a slice of image.Rectangle structs.
 | |
| //
 | |
| // For further details, please see:
 | |
| // http://docs.opencv.org/3.3.1/d1/de5/classcv_1_1CascadeClassifier.html#aaf8181cb63968136476ec4204ffca498
 | |
| //
 | |
| func (c *CascadeClassifier) DetectMultiScale(img Mat) []image.Rectangle {
 | |
| 	ret := C.CascadeClassifier_DetectMultiScale(c.p, img.p)
 | |
| 	defer C.Rects_Close(ret)
 | |
| 
 | |
| 	cArray := ret.rects
 | |
| 	length := int(ret.length)
 | |
| 	hdr := reflect.SliceHeader{
 | |
| 		Data: uintptr(unsafe.Pointer(cArray)),
 | |
| 		Len:  length,
 | |
| 		Cap:  length,
 | |
| 	}
 | |
| 	s := *(*[]C.Rect)(unsafe.Pointer(&hdr))
 | |
| 
 | |
| 	rects := make([]image.Rectangle, length)
 | |
| 	for i, r := range s {
 | |
| 		rects[i] = image.Rect(int(r.x), int(r.y), int(r.x+r.width), int(r.y+r.height))
 | |
| 	}
 | |
| 	return rects
 | |
| }
 | |
| 
 | |
| // DetectMultiScaleWithParams calls DetectMultiScale but allows setting parameters
 | |
| // to values other than just the defaults.
 | |
| //
 | |
| // For further details, please see:
 | |
| // http://docs.opencv.org/3.3.1/d1/de5/classcv_1_1CascadeClassifier.html#aaf8181cb63968136476ec4204ffca498
 | |
| //
 | |
| func (c *CascadeClassifier) DetectMultiScaleWithParams(img Mat, scale float64,
 | |
| 	minNeighbors, flags int, minSize, maxSize image.Point) []image.Rectangle {
 | |
| 
 | |
| 	minSz := C.struct_Size{
 | |
| 		height: C.int(minSize.X),
 | |
| 		width:  C.int(minSize.Y),
 | |
| 	}
 | |
| 
 | |
| 	maxSz := C.struct_Size{
 | |
| 		height: C.int(maxSize.X),
 | |
| 		width:  C.int(maxSize.Y),
 | |
| 	}
 | |
| 
 | |
| 	ret := C.CascadeClassifier_DetectMultiScaleWithParams(c.p, img.p, C.double(scale),
 | |
| 		C.int(minNeighbors), C.int(flags), minSz, maxSz)
 | |
| 	defer C.Rects_Close(ret)
 | |
| 
 | |
| 	cArray := ret.rects
 | |
| 	length := int(ret.length)
 | |
| 	hdr := reflect.SliceHeader{
 | |
| 		Data: uintptr(unsafe.Pointer(cArray)),
 | |
| 		Len:  length,
 | |
| 		Cap:  length,
 | |
| 	}
 | |
| 	s := *(*[]C.Rect)(unsafe.Pointer(&hdr))
 | |
| 
 | |
| 	rects := make([]image.Rectangle, length)
 | |
| 	for i, r := range s {
 | |
| 		rects[i] = image.Rect(int(r.x), int(r.y), int(r.x+r.width), int(r.y+r.height))
 | |
| 	}
 | |
| 	return rects
 | |
| }
 | |
| 
 | |
| // HOGDescriptor is a Histogram Of Gradiants (HOG) for object detection.
 | |
| //
 | |
| // For further details, please see:
 | |
| // https://docs.opencv.org/3.3.1/d5/d33/structcv_1_1HOGDescriptor.html#a723b95b709cfd3f95cf9e616de988fc8
 | |
| //
 | |
| type HOGDescriptor struct {
 | |
| 	p C.HOGDescriptor
 | |
| }
 | |
| 
 | |
| // NewHOGDescriptor returns a new HOGDescriptor.
 | |
| func NewHOGDescriptor() HOGDescriptor {
 | |
| 	return HOGDescriptor{p: C.HOGDescriptor_New()}
 | |
| }
 | |
| 
 | |
| // Close deletes the HOGDescriptor's pointer.
 | |
| func (h *HOGDescriptor) Close() error {
 | |
| 	C.HOGDescriptor_Close(h.p)
 | |
| 	h.p = nil
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // DetectMultiScale detects objects in the input Mat image.
 | |
| // The detected objects are returned as a slice of image.Rectangle structs.
 | |
| //
 | |
| // For further details, please see:
 | |
| // https://docs.opencv.org/3.3.1/d5/d33/structcv_1_1HOGDescriptor.html#a660e5cd036fd5ddf0f5767b352acd948
 | |
| //
 | |
| func (h *HOGDescriptor) DetectMultiScale(img Mat) []image.Rectangle {
 | |
| 	ret := C.HOGDescriptor_DetectMultiScale(h.p, img.p)
 | |
| 	defer C.Rects_Close(ret)
 | |
| 
 | |
| 	cArray := ret.rects
 | |
| 	length := int(ret.length)
 | |
| 	hdr := reflect.SliceHeader{
 | |
| 		Data: uintptr(unsafe.Pointer(cArray)),
 | |
| 		Len:  length,
 | |
| 		Cap:  length,
 | |
| 	}
 | |
| 	s := *(*[]C.Rect)(unsafe.Pointer(&hdr))
 | |
| 
 | |
| 	rects := make([]image.Rectangle, length)
 | |
| 	for i, r := range s {
 | |
| 		rects[i] = image.Rect(int(r.x), int(r.y), int(r.x+r.width), int(r.y+r.height))
 | |
| 	}
 | |
| 	return rects
 | |
| }
 | |
| 
 | |
| // DetectMultiScaleWithParams calls DetectMultiScale but allows setting parameters
 | |
| // to values other than just the defaults.
 | |
| //
 | |
| // For further details, please see:
 | |
| // https://docs.opencv.org/3.3.1/d5/d33/structcv_1_1HOGDescriptor.html#a660e5cd036fd5ddf0f5767b352acd948
 | |
| //
 | |
| func (h *HOGDescriptor) DetectMultiScaleWithParams(img Mat, hitThresh float64,
 | |
| 	winStride, padding image.Point, scale, finalThreshold float64, useMeanshiftGrouping bool) []image.Rectangle {
 | |
| 	wSz := C.struct_Size{
 | |
| 		height: C.int(winStride.X),
 | |
| 		width:  C.int(winStride.Y),
 | |
| 	}
 | |
| 
 | |
| 	pSz := C.struct_Size{
 | |
| 		height: C.int(padding.X),
 | |
| 		width:  C.int(padding.Y),
 | |
| 	}
 | |
| 
 | |
| 	ret := C.HOGDescriptor_DetectMultiScaleWithParams(h.p, img.p, C.double(hitThresh),
 | |
| 		wSz, pSz, C.double(scale), C.double(finalThreshold), C.bool(useMeanshiftGrouping))
 | |
| 	defer C.Rects_Close(ret)
 | |
| 
 | |
| 	cArray := ret.rects
 | |
| 	length := int(ret.length)
 | |
| 	hdr := reflect.SliceHeader{
 | |
| 		Data: uintptr(unsafe.Pointer(cArray)),
 | |
| 		Len:  length,
 | |
| 		Cap:  length,
 | |
| 	}
 | |
| 	s := *(*[]C.Rect)(unsafe.Pointer(&hdr))
 | |
| 
 | |
| 	rects := make([]image.Rectangle, length)
 | |
| 	for i, r := range s {
 | |
| 		rects[i] = image.Rect(int(r.x), int(r.y), int(r.x+r.width), int(r.y+r.height))
 | |
| 	}
 | |
| 	return rects
 | |
| }
 | |
| 
 | |
| // HOGDefaultPeopleDetector returns a new Mat with the HOG DefaultPeopleDetector.
 | |
| //
 | |
| // For further details, please see:
 | |
| // https://docs.opencv.org/3.3.1/d5/d33/structcv_1_1HOGDescriptor.html#a660e5cd036fd5ddf0f5767b352acd948
 | |
| //
 | |
| func HOGDefaultPeopleDetector() Mat {
 | |
| 	return Mat{p: C.HOG_GetDefaultPeopleDetector()}
 | |
| }
 | |
| 
 | |
| // SetSVMDetector sets the data for the HOGDescriptor.
 | |
| //
 | |
| // For further details, please see:
 | |
| // https://docs.opencv.org/3.3.1/d5/d33/structcv_1_1HOGDescriptor.html#a09e354ad701f56f9c550dc0385dc36f1
 | |
| //
 | |
| func (h *HOGDescriptor) SetSVMDetector(det Mat) error {
 | |
| 	C.HOGDescriptor_SetSVMDetector(h.p, det.p)
 | |
| 	return nil
 | |
| }
 | 
