diff --git a/contrib/face.go b/contrib/face.go index 7ac7e575..04fda122 100644 --- a/contrib/face.go +++ b/contrib/face.go @@ -11,18 +11,22 @@ import ( "gocv.io/x/gocv" ) +// PredictResponse represents a predicted label and associated confidence. type PredictResponse struct { Label int32 `json:"label"` Confidence float32 `json:"confidence"` } +// LBPHFaceRecognizer is a wrapper for the OpenCV Local Binary Patterns +// Histograms face recognizer. type LBPHFaceRecognizer struct { p C.LBPHFaceRecognizer } -// Create new LBPH Recognizer model +// NewLBPHFaceRecognizer creates a new LBPH Recognizer model. // -// see https://docs.opencv.org/master/df/d25/classcv_1_1face_1_1LBPHFaceRecognizer.html +// For further information, see: +// https://docs.opencv.org/master/df/d25/classcv_1_1face_1_1LBPHFaceRecognizer.html // func NewLBPHFaceRecognizer() *LBPHFaceRecognizer { return &LBPHFaceRecognizer{p: C.CreateLBPHFaceRecognizer()} @@ -53,9 +57,10 @@ func (fr *LBPHFaceRecognizer) Train(images []gocv.Mat, labels []int) { C.LBPHFaceRecognizer_Train(fr.p, matsVector, labelsVector) } -// update existing trained model with new images and labels +// Update updates the existing trained model with new images and labels. // -// see https://docs.opencv.org/master/dd/d65/classcv_1_1face_1_1FaceRecognizer.html#a8a4e73ea878dcd0c235d0487189d25f3 +// For further information, see: +// https://docs.opencv.org/master/dd/d65/classcv_1_1face_1_1FaceRecognizer.html#a8a4e73ea878dcd0c235d0487189d25f3 // func (fr *LBPHFaceRecognizer) Update(newImages []gocv.Mat, newLabels []int) { cparams := []C.int{} @@ -78,9 +83,11 @@ func (fr *LBPHFaceRecognizer) Update(newImages []gocv.Mat, newLabels []int) { C.LBPHFaceRecognizer_Update(fr.p, matsVector, labelsVector) } -// predict image for trained model, retun label for correctly predicted image, return -1 if not found +// Predict predicts a label for a given input image. It returns the label for +// correctly predicted image or -1 if not found. // -// see https://docs.opencv.org/master/dd/d65/classcv_1_1face_1_1FaceRecognizer.html#aa2d2f02faffab1bf01317ae6502fb631 +// For further information, see: +// https://docs.opencv.org/master/dd/d65/classcv_1_1face_1_1FaceRecognizer.html#aa2d2f02faffab1bf01317ae6502fb631 // func (fr *LBPHFaceRecognizer) Predict(sample gocv.Mat) int { label := C.LBPHFaceRecognizer_Predict(fr.p, (C.Mat)(sample.Ptr())) @@ -88,9 +95,12 @@ func (fr *LBPHFaceRecognizer) Predict(sample gocv.Mat) int { return int(label) } -// the same as above but returns some more info +// PredictExtendedResponse returns a label and associated confidence (e.g. +// distance) for a given input image. It is the extended version of +// `Predict()`. // -// see https://docs.opencv.org/master/dd/d65/classcv_1_1face_1_1FaceRecognizer.html#ab0d593e53ebd9a0f350c989fcac7f251 +// For further information, see: +// https://docs.opencv.org/master/dd/d65/classcv_1_1face_1_1FaceRecognizer.html#ab0d593e53ebd9a0f350c989fcac7f251 // func (fr *LBPHFaceRecognizer) PredictExtendedResponse(sample gocv.Mat) PredictResponse { respp := C.LBPHFaceRecognizer_PredictExtended(fr.p, (C.Mat)(sample.Ptr())) @@ -102,26 +112,31 @@ func (fr *LBPHFaceRecognizer) PredictExtendedResponse(sample gocv.Mat) PredictRe return resp } -// set Threshold value +// SetThreshold sets the threshold value of the model, i.e. the threshold +// applied in the prediction. // -// see https://docs.opencv.org/master/dd/d65/classcv_1_1face_1_1FaceRecognizer.html#a3182081e5f8023e658ad8ab96656dd63 +// For further information, see: +// https://docs.opencv.org/master/dd/d65/classcv_1_1face_1_1FaceRecognizer.html#a3182081e5f8023e658ad8ab96656dd63 // func (fr *LBPHFaceRecognizer) SetThreshold(threshold float32) { C.LBPHFaceRecognizer_SetThreshold(fr.p, (C.double)(threshold)) } -// set Neighbors +// SetNeighbors sets the neighbors value of the model, i.e. the number of +// sample points to build a Circular Local Binary Pattern from. Note that wrong +// neighbors can raise OpenCV exception! // -// see https://docs.opencv.org/master/df/d25/classcv_1_1face_1_1LBPHFaceRecognizer.html#ab225f7bf353ce8697a506eda10124a92 -// wrong neighbors can raise opencv exception! +// For further information, see: +// https://docs.opencv.org/master/df/d25/classcv_1_1face_1_1LBPHFaceRecognizer.html#ab225f7bf353ce8697a506eda10124a92 // func (fr *LBPHFaceRecognizer) SetNeighbors(neighbors int) { C.LBPHFaceRecognizer_SetNeighbors(fr.p, (C.int)(neighbors)) } -// get Neighbors +// GetNeighbors returns the neighbors value of the model. // -// see https://docs.opencv.org/master/df/d25/classcv_1_1face_1_1LBPHFaceRecognizer.html#a50a3e2ca6e8464166e153c9df84b0a77 +// For further information, see: +// https://docs.opencv.org/master/df/d25/classcv_1_1face_1_1LBPHFaceRecognizer.html#a50a3e2ca6e8464166e153c9df84b0a77 // func (fr *LBPHFaceRecognizer) GetNeighbors() int { n := C.LBPHFaceRecognizer_GetNeighbors(fr.p) @@ -129,17 +144,20 @@ func (fr *LBPHFaceRecognizer) GetNeighbors() int { return int(n) } -// set Radius +// SetRadius sets the radius used for building the Circular Local Binary +// Pattern. // -// see https://docs.opencv.org/master/df/d25/classcv_1_1face_1_1LBPHFaceRecognizer.html#a62d94c75cade902fd3b487b1ef9883fc +// For further information, see: +// https://docs.opencv.org/master/df/d25/classcv_1_1face_1_1LBPHFaceRecognizer.html#a62d94c75cade902fd3b487b1ef9883fc // func (fr *LBPHFaceRecognizer) SetRadius(radius int) { C.LBPHFaceRecognizer_SetRadius(fr.p, (C.int)(radius)) } -// save trained model data to file +// SaveFile saves the trained model data to file. // -// see https://docs.opencv.org/master/dd/d65/classcv_1_1face_1_1FaceRecognizer.html#a2adf2d555550194244b05c91fefcb4d6 +// For further information, see: +// https://docs.opencv.org/master/dd/d65/classcv_1_1face_1_1FaceRecognizer.html#a2adf2d555550194244b05c91fefcb4d6 // func (fr *LBPHFaceRecognizer) SaveFile(fname string) { cName := C.CString(fname) @@ -147,9 +165,10 @@ func (fr *LBPHFaceRecognizer) SaveFile(fname string) { C.LBPHFaceRecognizer_SaveFile(fr.p, cName) } -// load traned model data from file +// LoadFile loads a trained model data from file. // -// see https://docs.opencv.org/master/dd/d65/classcv_1_1face_1_1FaceRecognizer.html#acc42e5b04595dba71f0777c7179af8c3 +// For further information, see: +// https://docs.opencv.org/master/dd/d65/classcv_1_1face_1_1FaceRecognizer.html#acc42e5b04595dba71f0777c7179af8c3 // func (fr *LBPHFaceRecognizer) LoadFile(fname string) { cName := C.CString(fname)