Форум программистов, компьютерный форум CyberForum.ru

Программа с opencv жрет память - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Указатель на функцию http://www.cyberforum.ru/cpp/thread1697800.html
Доброго времени суток! Кто может посоветовать способ присвоить указателю на функцию значение, т.е. имя функции, если мы не будем указывать его явно в коде, а задади имя функции как std::string. Можно, наверное, через ассоциативный контейнер - ключ - имя функции в формате std::string, значение указатель на функцию, вот только функции разные, и придется много map-ов организовывать. Какие есть еще...
C++ Замер времени работы участка кода Сразу скажу что меня не интересуют стандартные замеры времени роботы участка кода, так как они показывают время роботы данного участка кода + время роботы других процессов (до момента завершения участка кода) -- это я говорю исходя из роботы планировщиков задач (если я не прав прошу поправте меня). Вопрос состоит в следующем, как замереть время роботы только данного процесса (определенный... http://www.cyberforum.ru/cpp/thread1696528.html
C++ Кроссплатформенный способ переноса файлов
Есть какой-нибудь легальный способ кроссплатформенного переноса папок/файлов в C++? Желательно именно способы переноса, а не copy/remove, т.к. внутри одного диска простой перенос будет моментальным.
OpenCV преобразовать изображение в полутоновое C++
На просторах интернета нашел код на c#: Bitmap BMP = (Bitmap)pictureBox1.Image; IplImage Img = new IplImage(); Img = BMP.ToIplImage(); IplImage Gray = new IplImage(Img.GetSize(), BitDepth.U8, 1); IplImage R = new IplImage(Img.GetSize(), BitDepth.U8, 1); IplImage G = new IplImage(Img.GetSize(), BitDepth.U8, 1); ...
C++ Какая форма записи вам ближе? http://www.cyberforum.ru/cpp/thread1696010.html
Какая форма записи вам ближе 1 if ( !valid ) или 2 if ( valid == 0 )
C++ Техническое зрение, нейронные сети А есть книги по техническому(машинному) зрению, нейронным сетям, касающиеся С++? Также не помешала бы литература например по OpenCV на С++ и подобное. Может кто найти? подробнее

Показать сообщение отдельно
kn0w
3 / 3 / 0
Регистрация: 09.10.2012
Сообщений: 72

Программа с opencv жрет память - C++

29.03.2016, 21:21. Просмотров 223. Ответов 2
Метки (Все метки)

Вообщем есть программа, после каждой итерации очищаю память, но все-равно почему то буквально за 2-3 цикла по j, программа падает из-за того что виртуальная память заполняется до отказа. Кто что может подсказать?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
for (int i = 0; i < 10; i++)
    {
        _itoa(i + 1, f1, 10);
        
        for (int j = i; j < 10; j++)
        {
            _itoa(j + 4, f2, 10);
            
            string path_to_pair2 = path_to_pair + f1 + "-" + f2 + "\";
            CreateDirectoryA(path_to_pair2.c_str(), NULL);
            for (int k = 0; k < 2000; k++)
            {
                _itoa(k + 1, fileName, 10);
                string path2 = workDirectory + f1 + "-" + f2 +"\"+ fileName + ".png";
 
                IplImage* workimage = cvLoadImage(path2.c_str(), CV_LOAD_IMAGE_GRAYSCALE);
                IplImage* bin = cvLoadImage(path2.c_str(), CV_LOAD_IMAGE_GRAYSCALE);
                IplImage* contour = cvCreateImage(cvGetSize(workimage), 8, 1);
                IplImage* buff = cvCreateImage(cvGetSize(workimage), 8, 1);
                IplImage* temp_bin_for_contours = cvCreateImage(cvGetSize(workimage), 8, 1);
                cvSet(contour, cvScalar(255));
                cvThreshold(workimage, bin, 0, 255, CV_THRESH_OTSU);
                cvNot(bin, temp_bin_for_contours);
                CvMemStorage* c_storage = cvCreateMemStorage();
                CvSeq* c_first;
                cvFindContours(temp_bin_for_contours, c_storage, &c_first, sizeof(CvContour), 0, CV_CHAIN_APPROX_NONE);
 
                int angle = findDiagonal(c_first);
 
                // рассчёт матрицы вращения
                CvPoint2D32f center = cvPoint2D32f(workimage->width / 2, workimage->height / 2);
                double scale = 1;             // масштаб
 
                // клонируем изображение
                buff = cvCloneImage(workimage);
 
                CvMat* rot_mat = cvCreateMat(2, 3, CV_32FC1);
                cv2DRotationMatrix(center, angle, scale, rot_mat);
 
                // выполняем вращение
                cvWarpAffine(workimage, buff, rot_mat, CV_WARP_FILL_OUTLIERS | CV_INTER_NN, cvScalar(255));
                                
                string normDir = path_to_pair2 + fileName + ".png";
                cvSaveImage(normDir.c_str(), buff);
                
                cvReleaseImage(&workimage);
                cvReleaseImage(&bin);
                cvReleaseImage(&contour);
                cvReleaseImage(&buff);
                cvReleaseImage(&temp_bin_for_contours);
                cvReleaseMat(&rot_mat);
                cvReleaseMemStorage(&c_storage);
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru