123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621 |
- //
- // This file is auto-generated. Please don't modify it!
- //
- #pragma once
- #ifdef __cplusplus
- //#import "opencv.hpp"
- #import "opencv2/ml.hpp"
- #else
- #define CV_EXPORTS
- #endif
- #import <Foundation/Foundation.h>
- #import "StatModel.h"
- @class Double2;
- @class Mat;
- @class TermCriteria;
- // C++: enum EMTypes (cv.ml.EM.Types)
- typedef NS_ENUM(int, EMTypes) {
- EM_COV_MAT_SPHERICAL NS_SWIFT_NAME(COV_MAT_SPHERICAL) = 0,
- EM_COV_MAT_DIAGONAL NS_SWIFT_NAME(COV_MAT_DIAGONAL) = 1,
- EM_COV_MAT_GENERIC NS_SWIFT_NAME(COV_MAT_GENERIC) = 2,
- EM_COV_MAT_DEFAULT NS_SWIFT_NAME(COV_MAT_DEFAULT) = EM_COV_MAT_DIAGONAL
- };
- NS_ASSUME_NONNULL_BEGIN
- // C++: class EM
- /**
- * The class implements the Expectation Maximization algorithm.
- *
- * @see REF: ml_intro_em
- *
- * Member of `Ml`
- */
- CV_EXPORTS @interface EM : StatModel
- #ifdef __cplusplus
- @property(readonly)cv::Ptr<cv::ml::EM> nativePtrEM;
- #endif
- #ifdef __cplusplus
- - (instancetype)initWithNativePtr:(cv::Ptr<cv::ml::EM>)nativePtr;
- + (instancetype)fromNative:(cv::Ptr<cv::ml::EM>)nativePtr;
- #endif
- #pragma mark - Class Constants
- @property (class, readonly) int DEFAULT_NCLUSTERS NS_SWIFT_NAME(DEFAULT_NCLUSTERS);
- @property (class, readonly) int DEFAULT_MAX_ITERS NS_SWIFT_NAME(DEFAULT_MAX_ITERS);
- @property (class, readonly) int START_E_STEP NS_SWIFT_NAME(START_E_STEP);
- @property (class, readonly) int START_M_STEP NS_SWIFT_NAME(START_M_STEP);
- @property (class, readonly) int START_AUTO_STEP NS_SWIFT_NAME(START_AUTO_STEP);
- #pragma mark - Methods
- //
- // int cv::ml::EM::getClustersNumber()
- //
- /**
- * @see `-setClustersNumber:`
- */
- - (int)getClustersNumber NS_SWIFT_NAME(getClustersNumber());
- //
- // void cv::ml::EM::setClustersNumber(int val)
- //
- /**
- * getClustersNumber @see `-getClustersNumber:`
- */
- - (void)setClustersNumber:(int)val NS_SWIFT_NAME(setClustersNumber(val:));
- //
- // int cv::ml::EM::getCovarianceMatrixType()
- //
- /**
- * @see `-setCovarianceMatrixType:`
- */
- - (int)getCovarianceMatrixType NS_SWIFT_NAME(getCovarianceMatrixType());
- //
- // void cv::ml::EM::setCovarianceMatrixType(int val)
- //
- /**
- * getCovarianceMatrixType @see `-getCovarianceMatrixType:`
- */
- - (void)setCovarianceMatrixType:(int)val NS_SWIFT_NAME(setCovarianceMatrixType(val:));
- //
- // TermCriteria cv::ml::EM::getTermCriteria()
- //
- /**
- * @see `-setTermCriteria:`
- */
- - (TermCriteria*)getTermCriteria NS_SWIFT_NAME(getTermCriteria());
- //
- // void cv::ml::EM::setTermCriteria(TermCriteria val)
- //
- /**
- * getTermCriteria @see `-getTermCriteria:`
- */
- - (void)setTermCriteria:(TermCriteria*)val NS_SWIFT_NAME(setTermCriteria(val:));
- //
- // Mat cv::ml::EM::getWeights()
- //
- /**
- * Returns weights of the mixtures
- *
- * Returns vector with the number of elements equal to the number of mixtures.
- */
- - (Mat*)getWeights NS_SWIFT_NAME(getWeights());
- //
- // Mat cv::ml::EM::getMeans()
- //
- /**
- * Returns the cluster centers (means of the Gaussian mixture)
- *
- * Returns matrix with the number of rows equal to the number of mixtures and number of columns
- * equal to the space dimensionality.
- */
- - (Mat*)getMeans NS_SWIFT_NAME(getMeans());
- //
- // void cv::ml::EM::getCovs(vector_Mat& covs)
- //
- /**
- * Returns covariation matrices
- *
- * Returns vector of covariation matrices. Number of matrices is the number of gaussian mixtures,
- * each matrix is a square floating-point matrix NxN, where N is the space dimensionality.
- */
- - (void)getCovs:(NSMutableArray<Mat*>*)covs NS_SWIFT_NAME(getCovs(covs:));
- //
- // float cv::ml::EM::predict(Mat samples, Mat& results = Mat(), int flags = 0)
- //
- /**
- * Returns posterior probabilities for the provided samples
- *
- * @param samples The input samples, floating-point matrix
- * @param results The optional output `$$ nSamples \times nClusters$$` matrix of results. It contains
- * posterior probabilities for each sample from the input
- * @param flags This parameter will be ignored
- */
- - (float)predict:(Mat*)samples results:(Mat*)results flags:(int)flags NS_SWIFT_NAME(predict(samples:results:flags:));
- /**
- * Returns posterior probabilities for the provided samples
- *
- * @param samples The input samples, floating-point matrix
- * @param results The optional output `$$ nSamples \times nClusters$$` matrix of results. It contains
- * posterior probabilities for each sample from the input
- */
- - (float)predict:(Mat*)samples results:(Mat*)results NS_SWIFT_NAME(predict(samples:results:));
- /**
- * Returns posterior probabilities for the provided samples
- *
- * @param samples The input samples, floating-point matrix
- * posterior probabilities for each sample from the input
- */
- - (float)predict:(Mat*)samples NS_SWIFT_NAME(predict(samples:));
- //
- // Vec2d cv::ml::EM::predict2(Mat sample, Mat& probs)
- //
- /**
- * Returns a likelihood logarithm value and an index of the most probable mixture component
- * for the given sample.
- *
- * @param sample A sample for classification. It should be a one-channel matrix of
- * `$$1 \times dims$$` or `$$dims \times 1$$` size.
- * @param probs Optional output matrix that contains posterior probabilities of each component
- * given the sample. It has `$$1 \times nclusters$$` size and CV_64FC1 type.
- *
- * The method returns a two-element double vector. Zero element is a likelihood logarithm value for
- * the sample. First element is an index of the most probable mixture component for the given
- * sample.
- */
- - (Double2*)predict2:(Mat*)sample probs:(Mat*)probs NS_SWIFT_NAME(predict2(sample:probs:));
- //
- // bool cv::ml::EM::trainEM(Mat samples, Mat& logLikelihoods = Mat(), Mat& labels = Mat(), Mat& probs = Mat())
- //
- /**
- * Estimate the Gaussian mixture parameters from a samples set.
- *
- * This variation starts with Expectation step. Initial values of the model parameters will be
- * estimated by the k-means algorithm.
- *
- * Unlike many of the ML models, %EM is an unsupervised learning algorithm and it does not take
- * responses (class labels or function values) as input. Instead, it computes the *Maximum
- * Likelihood Estimate* of the Gaussian mixture parameters from an input sample set, stores all the
- * parameters inside the structure: `$$p_{i,k}$$` in probs, `$$a_k$$` in means , `$$S_k$$` in
- * covs[k], `$$\pi_k$$` in weights , and optionally computes the output "class label" for each
- * sample: `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most
- * probable mixture component for each sample).
- *
- * The trained model can be used further for prediction, just like any other classifier. The
- * trained model is similar to the NormalBayesClassifier.
- *
- * @param samples Samples from which the Gaussian mixture model will be estimated. It should be a
- * one-channel matrix, each row of which is a sample. If the matrix does not have CV_64F type
- * it will be converted to the inner matrix of such type for the further computing.
- * @param logLikelihoods The optional output matrix that contains a likelihood logarithm value for
- * each sample. It has `$$nsamples \times 1$$` size and CV_64FC1 type.
- * @param labels The optional output "class label" for each sample:
- * `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most probable
- * mixture component for each sample). It has `$$nsamples \times 1$$` size and CV_32SC1 type.
- * @param probs The optional output matrix that contains posterior probabilities of each Gaussian
- * mixture component given the each sample. It has `$$nsamples \times nclusters$$` size and
- * CV_64FC1 type.
- */
- - (BOOL)trainEM:(Mat*)samples logLikelihoods:(Mat*)logLikelihoods labels:(Mat*)labels probs:(Mat*)probs NS_SWIFT_NAME(trainEM(samples:logLikelihoods:labels:probs:));
- /**
- * Estimate the Gaussian mixture parameters from a samples set.
- *
- * This variation starts with Expectation step. Initial values of the model parameters will be
- * estimated by the k-means algorithm.
- *
- * Unlike many of the ML models, %EM is an unsupervised learning algorithm and it does not take
- * responses (class labels or function values) as input. Instead, it computes the *Maximum
- * Likelihood Estimate* of the Gaussian mixture parameters from an input sample set, stores all the
- * parameters inside the structure: `$$p_{i,k}$$` in probs, `$$a_k$$` in means , `$$S_k$$` in
- * covs[k], `$$\pi_k$$` in weights , and optionally computes the output "class label" for each
- * sample: `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most
- * probable mixture component for each sample).
- *
- * The trained model can be used further for prediction, just like any other classifier. The
- * trained model is similar to the NormalBayesClassifier.
- *
- * @param samples Samples from which the Gaussian mixture model will be estimated. It should be a
- * one-channel matrix, each row of which is a sample. If the matrix does not have CV_64F type
- * it will be converted to the inner matrix of such type for the further computing.
- * @param logLikelihoods The optional output matrix that contains a likelihood logarithm value for
- * each sample. It has `$$nsamples \times 1$$` size and CV_64FC1 type.
- * @param labels The optional output "class label" for each sample:
- * `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most probable
- * mixture component for each sample). It has `$$nsamples \times 1$$` size and CV_32SC1 type.
- * mixture component given the each sample. It has `$$nsamples \times nclusters$$` size and
- * CV_64FC1 type.
- */
- - (BOOL)trainEM:(Mat*)samples logLikelihoods:(Mat*)logLikelihoods labels:(Mat*)labels NS_SWIFT_NAME(trainEM(samples:logLikelihoods:labels:));
- /**
- * Estimate the Gaussian mixture parameters from a samples set.
- *
- * This variation starts with Expectation step. Initial values of the model parameters will be
- * estimated by the k-means algorithm.
- *
- * Unlike many of the ML models, %EM is an unsupervised learning algorithm and it does not take
- * responses (class labels or function values) as input. Instead, it computes the *Maximum
- * Likelihood Estimate* of the Gaussian mixture parameters from an input sample set, stores all the
- * parameters inside the structure: `$$p_{i,k}$$` in probs, `$$a_k$$` in means , `$$S_k$$` in
- * covs[k], `$$\pi_k$$` in weights , and optionally computes the output "class label" for each
- * sample: `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most
- * probable mixture component for each sample).
- *
- * The trained model can be used further for prediction, just like any other classifier. The
- * trained model is similar to the NormalBayesClassifier.
- *
- * @param samples Samples from which the Gaussian mixture model will be estimated. It should be a
- * one-channel matrix, each row of which is a sample. If the matrix does not have CV_64F type
- * it will be converted to the inner matrix of such type for the further computing.
- * @param logLikelihoods The optional output matrix that contains a likelihood logarithm value for
- * each sample. It has `$$nsamples \times 1$$` size and CV_64FC1 type.
- * `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most probable
- * mixture component for each sample). It has `$$nsamples \times 1$$` size and CV_32SC1 type.
- * mixture component given the each sample. It has `$$nsamples \times nclusters$$` size and
- * CV_64FC1 type.
- */
- - (BOOL)trainEM:(Mat*)samples logLikelihoods:(Mat*)logLikelihoods NS_SWIFT_NAME(trainEM(samples:logLikelihoods:));
- /**
- * Estimate the Gaussian mixture parameters from a samples set.
- *
- * This variation starts with Expectation step. Initial values of the model parameters will be
- * estimated by the k-means algorithm.
- *
- * Unlike many of the ML models, %EM is an unsupervised learning algorithm and it does not take
- * responses (class labels or function values) as input. Instead, it computes the *Maximum
- * Likelihood Estimate* of the Gaussian mixture parameters from an input sample set, stores all the
- * parameters inside the structure: `$$p_{i,k}$$` in probs, `$$a_k$$` in means , `$$S_k$$` in
- * covs[k], `$$\pi_k$$` in weights , and optionally computes the output "class label" for each
- * sample: `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most
- * probable mixture component for each sample).
- *
- * The trained model can be used further for prediction, just like any other classifier. The
- * trained model is similar to the NormalBayesClassifier.
- *
- * @param samples Samples from which the Gaussian mixture model will be estimated. It should be a
- * one-channel matrix, each row of which is a sample. If the matrix does not have CV_64F type
- * it will be converted to the inner matrix of such type for the further computing.
- * each sample. It has `$$nsamples \times 1$$` size and CV_64FC1 type.
- * `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most probable
- * mixture component for each sample). It has `$$nsamples \times 1$$` size and CV_32SC1 type.
- * mixture component given the each sample. It has `$$nsamples \times nclusters$$` size and
- * CV_64FC1 type.
- */
- - (BOOL)trainEM:(Mat*)samples NS_SWIFT_NAME(trainEM(samples:));
- //
- // bool cv::ml::EM::trainE(Mat samples, Mat means0, Mat covs0 = Mat(), Mat weights0 = Mat(), Mat& logLikelihoods = Mat(), Mat& labels = Mat(), Mat& probs = Mat())
- //
- /**
- * Estimate the Gaussian mixture parameters from a samples set.
- *
- * This variation starts with Expectation step. You need to provide initial means `$$a_k$$` of
- * mixture components. Optionally you can pass initial weights `$$\pi_k$$` and covariance matrices
- * `$$S_k$$` of mixture components.
- *
- * @param samples Samples from which the Gaussian mixture model will be estimated. It should be a
- * one-channel matrix, each row of which is a sample. If the matrix does not have CV_64F type
- * it will be converted to the inner matrix of such type for the further computing.
- * @param means0 Initial means `$$a_k$$` of mixture components. It is a one-channel matrix of
- * `$$nclusters \times dims$$` size. If the matrix does not have CV_64F type it will be
- * converted to the inner matrix of such type for the further computing.
- * @param covs0 The vector of initial covariance matrices `$$S_k$$` of mixture components. Each of
- * covariance matrices is a one-channel matrix of `$$dims \times dims$$` size. If the matrices
- * do not have CV_64F type they will be converted to the inner matrices of such type for the
- * further computing.
- * @param weights0 Initial weights `$$\pi_k$$` of mixture components. It should be a one-channel
- * floating-point matrix with `$$1 \times nclusters$$` or `$$nclusters \times 1$$` size.
- * @param logLikelihoods The optional output matrix that contains a likelihood logarithm value for
- * each sample. It has `$$nsamples \times 1$$` size and CV_64FC1 type.
- * @param labels The optional output "class label" for each sample:
- * `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most probable
- * mixture component for each sample). It has `$$nsamples \times 1$$` size and CV_32SC1 type.
- * @param probs The optional output matrix that contains posterior probabilities of each Gaussian
- * mixture component given the each sample. It has `$$nsamples \times nclusters$$` size and
- * CV_64FC1 type.
- */
- - (BOOL)trainE:(Mat*)samples means0:(Mat*)means0 covs0:(Mat*)covs0 weights0:(Mat*)weights0 logLikelihoods:(Mat*)logLikelihoods labels:(Mat*)labels probs:(Mat*)probs NS_SWIFT_NAME(trainE(samples:means0:covs0:weights0:logLikelihoods:labels:probs:));
- /**
- * Estimate the Gaussian mixture parameters from a samples set.
- *
- * This variation starts with Expectation step. You need to provide initial means `$$a_k$$` of
- * mixture components. Optionally you can pass initial weights `$$\pi_k$$` and covariance matrices
- * `$$S_k$$` of mixture components.
- *
- * @param samples Samples from which the Gaussian mixture model will be estimated. It should be a
- * one-channel matrix, each row of which is a sample. If the matrix does not have CV_64F type
- * it will be converted to the inner matrix of such type for the further computing.
- * @param means0 Initial means `$$a_k$$` of mixture components. It is a one-channel matrix of
- * `$$nclusters \times dims$$` size. If the matrix does not have CV_64F type it will be
- * converted to the inner matrix of such type for the further computing.
- * @param covs0 The vector of initial covariance matrices `$$S_k$$` of mixture components. Each of
- * covariance matrices is a one-channel matrix of `$$dims \times dims$$` size. If the matrices
- * do not have CV_64F type they will be converted to the inner matrices of such type for the
- * further computing.
- * @param weights0 Initial weights `$$\pi_k$$` of mixture components. It should be a one-channel
- * floating-point matrix with `$$1 \times nclusters$$` or `$$nclusters \times 1$$` size.
- * @param logLikelihoods The optional output matrix that contains a likelihood logarithm value for
- * each sample. It has `$$nsamples \times 1$$` size and CV_64FC1 type.
- * @param labels The optional output "class label" for each sample:
- * `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most probable
- * mixture component for each sample). It has `$$nsamples \times 1$$` size and CV_32SC1 type.
- * mixture component given the each sample. It has `$$nsamples \times nclusters$$` size and
- * CV_64FC1 type.
- */
- - (BOOL)trainE:(Mat*)samples means0:(Mat*)means0 covs0:(Mat*)covs0 weights0:(Mat*)weights0 logLikelihoods:(Mat*)logLikelihoods labels:(Mat*)labels NS_SWIFT_NAME(trainE(samples:means0:covs0:weights0:logLikelihoods:labels:));
- /**
- * Estimate the Gaussian mixture parameters from a samples set.
- *
- * This variation starts with Expectation step. You need to provide initial means `$$a_k$$` of
- * mixture components. Optionally you can pass initial weights `$$\pi_k$$` and covariance matrices
- * `$$S_k$$` of mixture components.
- *
- * @param samples Samples from which the Gaussian mixture model will be estimated. It should be a
- * one-channel matrix, each row of which is a sample. If the matrix does not have CV_64F type
- * it will be converted to the inner matrix of such type for the further computing.
- * @param means0 Initial means `$$a_k$$` of mixture components. It is a one-channel matrix of
- * `$$nclusters \times dims$$` size. If the matrix does not have CV_64F type it will be
- * converted to the inner matrix of such type for the further computing.
- * @param covs0 The vector of initial covariance matrices `$$S_k$$` of mixture components. Each of
- * covariance matrices is a one-channel matrix of `$$dims \times dims$$` size. If the matrices
- * do not have CV_64F type they will be converted to the inner matrices of such type for the
- * further computing.
- * @param weights0 Initial weights `$$\pi_k$$` of mixture components. It should be a one-channel
- * floating-point matrix with `$$1 \times nclusters$$` or `$$nclusters \times 1$$` size.
- * @param logLikelihoods The optional output matrix that contains a likelihood logarithm value for
- * each sample. It has `$$nsamples \times 1$$` size and CV_64FC1 type.
- * `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most probable
- * mixture component for each sample). It has `$$nsamples \times 1$$` size and CV_32SC1 type.
- * mixture component given the each sample. It has `$$nsamples \times nclusters$$` size and
- * CV_64FC1 type.
- */
- - (BOOL)trainE:(Mat*)samples means0:(Mat*)means0 covs0:(Mat*)covs0 weights0:(Mat*)weights0 logLikelihoods:(Mat*)logLikelihoods NS_SWIFT_NAME(trainE(samples:means0:covs0:weights0:logLikelihoods:));
- /**
- * Estimate the Gaussian mixture parameters from a samples set.
- *
- * This variation starts with Expectation step. You need to provide initial means `$$a_k$$` of
- * mixture components. Optionally you can pass initial weights `$$\pi_k$$` and covariance matrices
- * `$$S_k$$` of mixture components.
- *
- * @param samples Samples from which the Gaussian mixture model will be estimated. It should be a
- * one-channel matrix, each row of which is a sample. If the matrix does not have CV_64F type
- * it will be converted to the inner matrix of such type for the further computing.
- * @param means0 Initial means `$$a_k$$` of mixture components. It is a one-channel matrix of
- * `$$nclusters \times dims$$` size. If the matrix does not have CV_64F type it will be
- * converted to the inner matrix of such type for the further computing.
- * @param covs0 The vector of initial covariance matrices `$$S_k$$` of mixture components. Each of
- * covariance matrices is a one-channel matrix of `$$dims \times dims$$` size. If the matrices
- * do not have CV_64F type they will be converted to the inner matrices of such type for the
- * further computing.
- * @param weights0 Initial weights `$$\pi_k$$` of mixture components. It should be a one-channel
- * floating-point matrix with `$$1 \times nclusters$$` or `$$nclusters \times 1$$` size.
- * each sample. It has `$$nsamples \times 1$$` size and CV_64FC1 type.
- * `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most probable
- * mixture component for each sample). It has `$$nsamples \times 1$$` size and CV_32SC1 type.
- * mixture component given the each sample. It has `$$nsamples \times nclusters$$` size and
- * CV_64FC1 type.
- */
- - (BOOL)trainE:(Mat*)samples means0:(Mat*)means0 covs0:(Mat*)covs0 weights0:(Mat*)weights0 NS_SWIFT_NAME(trainE(samples:means0:covs0:weights0:));
- /**
- * Estimate the Gaussian mixture parameters from a samples set.
- *
- * This variation starts with Expectation step. You need to provide initial means `$$a_k$$` of
- * mixture components. Optionally you can pass initial weights `$$\pi_k$$` and covariance matrices
- * `$$S_k$$` of mixture components.
- *
- * @param samples Samples from which the Gaussian mixture model will be estimated. It should be a
- * one-channel matrix, each row of which is a sample. If the matrix does not have CV_64F type
- * it will be converted to the inner matrix of such type for the further computing.
- * @param means0 Initial means `$$a_k$$` of mixture components. It is a one-channel matrix of
- * `$$nclusters \times dims$$` size. If the matrix does not have CV_64F type it will be
- * converted to the inner matrix of such type for the further computing.
- * @param covs0 The vector of initial covariance matrices `$$S_k$$` of mixture components. Each of
- * covariance matrices is a one-channel matrix of `$$dims \times dims$$` size. If the matrices
- * do not have CV_64F type they will be converted to the inner matrices of such type for the
- * further computing.
- * floating-point matrix with `$$1 \times nclusters$$` or `$$nclusters \times 1$$` size.
- * each sample. It has `$$nsamples \times 1$$` size and CV_64FC1 type.
- * `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most probable
- * mixture component for each sample). It has `$$nsamples \times 1$$` size and CV_32SC1 type.
- * mixture component given the each sample. It has `$$nsamples \times nclusters$$` size and
- * CV_64FC1 type.
- */
- - (BOOL)trainE:(Mat*)samples means0:(Mat*)means0 covs0:(Mat*)covs0 NS_SWIFT_NAME(trainE(samples:means0:covs0:));
- /**
- * Estimate the Gaussian mixture parameters from a samples set.
- *
- * This variation starts with Expectation step. You need to provide initial means `$$a_k$$` of
- * mixture components. Optionally you can pass initial weights `$$\pi_k$$` and covariance matrices
- * `$$S_k$$` of mixture components.
- *
- * @param samples Samples from which the Gaussian mixture model will be estimated. It should be a
- * one-channel matrix, each row of which is a sample. If the matrix does not have CV_64F type
- * it will be converted to the inner matrix of such type for the further computing.
- * @param means0 Initial means `$$a_k$$` of mixture components. It is a one-channel matrix of
- * `$$nclusters \times dims$$` size. If the matrix does not have CV_64F type it will be
- * converted to the inner matrix of such type for the further computing.
- * covariance matrices is a one-channel matrix of `$$dims \times dims$$` size. If the matrices
- * do not have CV_64F type they will be converted to the inner matrices of such type for the
- * further computing.
- * floating-point matrix with `$$1 \times nclusters$$` or `$$nclusters \times 1$$` size.
- * each sample. It has `$$nsamples \times 1$$` size and CV_64FC1 type.
- * `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most probable
- * mixture component for each sample). It has `$$nsamples \times 1$$` size and CV_32SC1 type.
- * mixture component given the each sample. It has `$$nsamples \times nclusters$$` size and
- * CV_64FC1 type.
- */
- - (BOOL)trainE:(Mat*)samples means0:(Mat*)means0 NS_SWIFT_NAME(trainE(samples:means0:));
- //
- // bool cv::ml::EM::trainM(Mat samples, Mat probs0, Mat& logLikelihoods = Mat(), Mat& labels = Mat(), Mat& probs = Mat())
- //
- /**
- * Estimate the Gaussian mixture parameters from a samples set.
- *
- * This variation starts with Maximization step. You need to provide initial probabilities
- * `$$p_{i,k}$$` to use this option.
- *
- * @param samples Samples from which the Gaussian mixture model will be estimated. It should be a
- * one-channel matrix, each row of which is a sample. If the matrix does not have CV_64F type
- * it will be converted to the inner matrix of such type for the further computing.
- * @param probs0 the probabilities
- * @param logLikelihoods The optional output matrix that contains a likelihood logarithm value for
- * each sample. It has `$$nsamples \times 1$$` size and CV_64FC1 type.
- * @param labels The optional output "class label" for each sample:
- * `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most probable
- * mixture component for each sample). It has `$$nsamples \times 1$$` size and CV_32SC1 type.
- * @param probs The optional output matrix that contains posterior probabilities of each Gaussian
- * mixture component given the each sample. It has `$$nsamples \times nclusters$$` size and
- * CV_64FC1 type.
- */
- - (BOOL)trainM:(Mat*)samples probs0:(Mat*)probs0 logLikelihoods:(Mat*)logLikelihoods labels:(Mat*)labels probs:(Mat*)probs NS_SWIFT_NAME(trainM(samples:probs0:logLikelihoods:labels:probs:));
- /**
- * Estimate the Gaussian mixture parameters from a samples set.
- *
- * This variation starts with Maximization step. You need to provide initial probabilities
- * `$$p_{i,k}$$` to use this option.
- *
- * @param samples Samples from which the Gaussian mixture model will be estimated. It should be a
- * one-channel matrix, each row of which is a sample. If the matrix does not have CV_64F type
- * it will be converted to the inner matrix of such type for the further computing.
- * @param probs0 the probabilities
- * @param logLikelihoods The optional output matrix that contains a likelihood logarithm value for
- * each sample. It has `$$nsamples \times 1$$` size and CV_64FC1 type.
- * @param labels The optional output "class label" for each sample:
- * `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most probable
- * mixture component for each sample). It has `$$nsamples \times 1$$` size and CV_32SC1 type.
- * mixture component given the each sample. It has `$$nsamples \times nclusters$$` size and
- * CV_64FC1 type.
- */
- - (BOOL)trainM:(Mat*)samples probs0:(Mat*)probs0 logLikelihoods:(Mat*)logLikelihoods labels:(Mat*)labels NS_SWIFT_NAME(trainM(samples:probs0:logLikelihoods:labels:));
- /**
- * Estimate the Gaussian mixture parameters from a samples set.
- *
- * This variation starts with Maximization step. You need to provide initial probabilities
- * `$$p_{i,k}$$` to use this option.
- *
- * @param samples Samples from which the Gaussian mixture model will be estimated. It should be a
- * one-channel matrix, each row of which is a sample. If the matrix does not have CV_64F type
- * it will be converted to the inner matrix of such type for the further computing.
- * @param probs0 the probabilities
- * @param logLikelihoods The optional output matrix that contains a likelihood logarithm value for
- * each sample. It has `$$nsamples \times 1$$` size and CV_64FC1 type.
- * `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most probable
- * mixture component for each sample). It has `$$nsamples \times 1$$` size and CV_32SC1 type.
- * mixture component given the each sample. It has `$$nsamples \times nclusters$$` size and
- * CV_64FC1 type.
- */
- - (BOOL)trainM:(Mat*)samples probs0:(Mat*)probs0 logLikelihoods:(Mat*)logLikelihoods NS_SWIFT_NAME(trainM(samples:probs0:logLikelihoods:));
- /**
- * Estimate the Gaussian mixture parameters from a samples set.
- *
- * This variation starts with Maximization step. You need to provide initial probabilities
- * `$$p_{i,k}$$` to use this option.
- *
- * @param samples Samples from which the Gaussian mixture model will be estimated. It should be a
- * one-channel matrix, each row of which is a sample. If the matrix does not have CV_64F type
- * it will be converted to the inner matrix of such type for the further computing.
- * @param probs0 the probabilities
- * each sample. It has `$$nsamples \times 1$$` size and CV_64FC1 type.
- * `$$\texttt{labels}_i=\texttt{arg max}_k(p_{i,k}), i=1..N$$` (indices of the most probable
- * mixture component for each sample). It has `$$nsamples \times 1$$` size and CV_32SC1 type.
- * mixture component given the each sample. It has `$$nsamples \times nclusters$$` size and
- * CV_64FC1 type.
- */
- - (BOOL)trainM:(Mat*)samples probs0:(Mat*)probs0 NS_SWIFT_NAME(trainM(samples:probs0:));
- //
- // static Ptr_EM cv::ml::EM::create()
- //
- /**
- * Creates empty %EM model.
- * The model should be trained then using StatModel::train(traindata, flags) method. Alternatively, you
- * can use one of the EM::train\* methods or load it from file using Algorithm::load\<EM\>(filename).
- */
- + (EM*)create NS_SWIFT_NAME(create());
- //
- // static Ptr_EM cv::ml::EM::load(String filepath, String nodeName = String())
- //
- /**
- * Loads and creates a serialized EM from a file
- *
- * Use EM::save to serialize and store an EM to disk.
- * Load the EM from this file again, by calling this function with the path to the file.
- * Optionally specify the node for the file containing the classifier
- *
- * @param filepath path to serialized EM
- * @param nodeName name of node containing the classifier
- */
- + (EM*)load:(NSString*)filepath nodeName:(NSString*)nodeName NS_SWIFT_NAME(load(filepath:nodeName:));
- /**
- * Loads and creates a serialized EM from a file
- *
- * Use EM::save to serialize and store an EM to disk.
- * Load the EM from this file again, by calling this function with the path to the file.
- * Optionally specify the node for the file containing the classifier
- *
- * @param filepath path to serialized EM
- */
- + (EM*)load:(NSString*)filepath NS_SWIFT_NAME(load(filepath:));
- @end
- NS_ASSUME_NONNULL_END
|