2

这会很长,所以我提前道歉。但我想确保理解上下文,因为我已经阅读了很多关于这个主题的帖子。我发现没有一个可以解决基于未知数字范围计算数字的问题。

我试图确定一个集合中每个整数的总出现次数。我遇到的问题是,测试集是固定的,比如一个 10 个数字的数组,但每个数字的范围是未知的。提出的问题是,当尝试使用数组来计算总数时,数组范围在运行时不能是可变的。我使用 重试了此尝试vector<int> ArrayName,而我可以在运行时重新调整总计数组的大小,但使用vector<int>计算中的值遇到了错误。

我将介绍的代码OpenCV用于人脸检测。我研究并利用了各种样本中的代码来创建一个基本的检测程序,然后研究并移植了一些 Java 代码来处理人脸移动并更新到新位置时的跟踪。所有这些代码都在工作。

我想使用请求的信息的地方是,我想存储一个数组,例如10,检测到人脸的最后一个主题,并找到随着时间的推移检测到最多的主题,并将其视为主题。比方说,我们正在检测 10,最后十帧检测如下(-1 是未知人脸)-1, -1, 0, 0, 0, 3, 0, -1, 0, 2:。在计数之后,0出现最频繁,因此主题是0。Range 未知的原因是主题 ID 取决于训练的主题数量并且总是在变化。

这三个错误是(并用 //ERROR 表示):

invalid use of member (did you forget the '&' ?), 
no match for call to '(std::vector<int>) (int)', 
no match for call to '(std::vector<int>) (int)&'

这是代码:

    struct FaceStruct {
    private:
        static const int NewLife = 120; //Divide by FPS for Length in Time
        static const int TotalTrackedSubjects = 10;
        int Life;
        vector<int> Subjects;
    public:
        void Init( Rect, int );
        void addSubject( int );
        int Subject();
        Rect Location;
        bool Used;
        void Weaken();
        void Renew();
        bool Dead();
    };
    void FaceStruct::Init( Rect location, int subject = -1 ) {
        Location = location;
        Subjects.resize( TotalTrackedSubjects - 1 );
        for( int i = 0; TotalTrackedSubjects - 1; i++ ) {
            Subjects(i) = -1; //ERROR
        }
        Renew();
    }
    void FaceStruct::addSubject( int subject ) {
        for( int i = 0; TotalTrackedSubjects - 2; i++ ) {
            Subjects(i) = Subjects( i + 1 );  //ERROR
        }
        Subjects( TotalTrackedSubjects - 1 ) = subject;  //ERROR
    }
    int FaceStruct::Subject() {
        int count_range = -1;
        for( int i = 0; TotalTrackedSubjects - 1; i++ ) {
            if( Subjects(i) > count_range ) count_range = Subjects(i); //ERROR
        }
        if( count_range < 0 ) { //Subject Unknown
            return -1;
        } else if( count_range == 0 ) { //Subject is 0, Handle 0's
            int totals = 0;
            for( int i = 0; TotalTrackedSubjects - 1; i++ ) {
                if( Subjects(i) == 0 ) totals++; //ERROR
            }
            return totals;
        } else { //Use count_range
            vector<int> totals;
            int unknowns = 0;
            totals.resize( count_range );
            for( int i = 0; TotalTrackedSubjects - 1; i++ ) {
                if( Subjects(i) < 0 ) { //ERROR
                    unknowns++;
                } else {
                    totals( Subjects(i) ) = totals( Subjects(i) ) + 1; //ERROR
                }
            }
            int largest = -1;
            for( int i = 0; totals.size() - 1; i++ ) {
                if( totals(i) > largest ) largest = totals(i); //ERROR
            }
            return largest;
        }
    }
    void FaceStruct::Weaken() {
        Life--;
    }
    void FaceStruct::Renew() {
        Life = NewLife;
    }
    bool FaceStruct::Dead() {
        if( Life < 1 ) {
            return true;
        } else {
            return false;
        }
    }
4

4 回答 4

1

要访问数组中的项目,您应该使用 [] 而不是 ()

所以 Subjects(i)应该 Subjects[i]
totals( Subjects(i) ) = totals( Subjects(i) ) + 1; 应该是 totals[ Subjects[i] ] = totals[ Subjects[i] ] + 1;

于 2012-10-10T20:48:46.243 回答
1

听起来地图可以做得相当好......

#include <map>

int example_values[10] = {-1, -1, 0, 0, 0, 3, 0, -1, 0, 2};

map<int, int> counts;
for (int i = 0; i < 10; ++i) ++counts[example_values[i]];

for (map<int, int>::iterator i = counts.begin(); i != counts.end(); ++i)
    cout << i->first << ": " << i->second << endl;

输出:

-1: 3
0: 5
2: 1
3: 1

(它们可能不是那个顺序。我觉得它们会是,但我忘记了地图是如何排列它们的内容的。)

于 2012-10-10T20:48:57.427 回答
0

代码有几个问题:

1) 向量的数组访问使用数组下标运算符 [] 而不是函数运算符 ()

2) 方法和成员的命名使用不一致的样式,成员和方法应该仅根据名称来区分。让一个成员和方法只有一个容易错过的's'不同是自找麻烦。

3)考虑使用映射或优先级队列而不是向量,这应该会删除很多非算法细节。

于 2012-10-10T21:04:35.333 回答
0

你的循环条件看起来不对。

for( int i = 0; TotalTrackedSubjects - 1; i++ ) {

这相当于写:

int i = 0;
while(9){
  ...
  i++
}

for 循环结构的第二部分是退出条件。

我认为是:

for( int i = 0; i < TotalTrackedSubjects; i++ ) {

否则你的循环将永远不会停止。

于 2012-10-10T21:10:52.430 回答