Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
35 / 35 / 10
Регистрация: 24.11.2011
Сообщений: 309

Не работает цикл

24.05.2012, 14:55. Показов 1992. Ответов 17
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, помогите разобраться. Главный цикл должен ходить по файлам и проводить расчеты с данными из них. почему-то используется только первый файл и программа выводит данные.

весь код:
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
void __fastcall TForm1::Button4Click(TObject *Sender)
{
//кнопка чтения из файла и сравнения с данными изображенями
std::vector<pair<float,int> > last;//для минимальных пар из каждого файла
String Path;      //задает переменную пути
for (size_t i=1;i<11;++i)    //ходим по файлам     /////////////////////
{
 Path="D:\\"+String(i)+".txt";
 std::fstream input(Path.c_str());  
    std::string line;
    std::vector<float> db;  //объявим вектор под значения из файла
    std::vector<float> sngl; //для одного изобр
    std::vector<pair<float,int> > cmp;  //для всех изобр. 1знач отклонения, 2 тип клетки
    pair<float,int> chain;   //создаем пару
    float single;  //сумма отклонений для одного угла
    float mini;    //минимальное из отклонений
 
    while(getline(input,line)) //цикл чтения из файла и расчеты в нем
    {
     std::stringstream ss(line.c_str());
     std::copy(std::istream_iterator<float> (ss), std::istream_iterator<float> (), std::back_inserter(db) );
     std::copy(db.begin(), db.end(), std::ostream_iterator<float> (std::cout)/* , "  |  ")*/ );
 
            unsigned int size=db.size();      //дублируем db
            for (unsigned int f=0; f<size; ++f)
            {
              db.push_back(db[f]);
            }
            if (rad.size()>size*1.5)
            {
               continue;//на след строку
            }
            else
            {           
            for (size_t s=0;s<size;++s)      //s - сдвиг
            {    single=0;
                 for (size_t z=0;z<rad.size();++z) //z - счетчик
                        {
                         single+=(db[z+s]-rad[z])*(db[z+s]-rad[z]);
                        }//конец сравнения под одним углом
                    single/=rad.size();     //делим сумму на кол-во элементов на границе клетки
                    sngl.push_back(single);
                }//конец сравнения с 1 изображением
 
             mini=sngl[0];
             for (size_t y=0;y<sngl.size();++y) //ищем минимальное отклонение с данным изобр
                 {
                    mini=min(mini,sngl[y]);
                 }
              chain=make_pair(mini,i); //добавляем пару где 2е знач - тип клетки (имя файла)
              cmp.push_back(chain);
              sngl.clear(); //очистка
              db.clear();
              }
    } //переход на след строку
    
    //ищем минимальное отклонение из всех строк
    pair<float,int> final;
    final=cmp[0];
    //finalmin=cmp[0].first;
    //int celltype;
    for (i=0;i<cmp.size(); i++)
    {
    if (final.first>cmp[i].first)
        {
         final=cmp[i];   //минимальное из всех для файла
        }
    last.push_back(final);
      //finalmin=min(finalmin,cmp[i].first);
 
    }
 
    
    // Memo1->Lines->Add(final.first); //      Memo1->Lines->Add(rad[i]);
    // ShowMessage ("отклонение равно" + FloatToStr(final.first)+ " тип клетки"+final.second);
 
}  //переход на следующий файл
    for (size_t i=0;i<last.size(); i++) //ищем минимальное из всех файлов
            { if (last[i].first<last[0].first)
                    {
                      last[0]=last[i];
                    }
 
            }
    ShowMessage ("отклонение равно" + FloatToStr(last[0].first)+ " тип клетки"+last[0].second);
}
отдельно код цикла (без внутренностей)
C++
1
2
3
4
5
6
7
String Path;      //задает переменную пути
for (size_t i=1;i<11;++i)    //ходим по файлам     /////////////////////
{
 Path="D:\\"+String(i)+".txt";
 std::fstream input(Path.c_str());
///тут все остальное
}
Файлы называются 1.txt ... 10.txt
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.05.2012, 14:55
Ответы с готовыми решениями:

Цикл: как работает цикл в цикле
Не могу понять как работает цикл в цикле например: repeat begin lalalala if что-то1&lt;&gt;100 then begin lalalala2 ...

На Главной странице не работает правильно вывод (неккоректно работает цикл)
Я создал тему с нуля. И мне нужно было чтоб на главной странице(Главная) http://www.wnero.esy.es/home/ и при заходе на сайт по...

Цикл работает неправильно, в то время как POST работает
Всем привет! Я хотел написать под php скрипт с авторизацией, брут, на своем сайте(подбор пароля). Написал код на загрузку словаря +...

17
 Аватар для BRcr
4043 / 2333 / 292
Регистрация: 03.02.2011
Сообщений: 5,066
Записей в блоге: 10
24.05.2012, 16:22
Зачем создавать объекты в теле цикла? Это неэффективно, нелогично и, как оказывается, еще и глючно.
Лучше создавать все вне тела цикла:
C++
1
2
3
4
5
6
7
8
String Path; 
std::fstream input( );     
for ( int i=1; i<11; ++i ) {
 Path="D:\\"+String(i)+".txt";
 input.open( Path.c_str( ) );
 // ...
 input.close( );
}
0
35 / 35 / 10
Регистрация: 24.11.2011
Сообщений: 309
24.05.2012, 16:27  [ТС]
не получается input так сделать:

[C++ Error] Unit1.cpp(138): E2294 Structure required on left side of . or .*
[C++ Error] Unit1.cpp(143): E2285 Could not find a match for 'getline<_Elem,_Traits,_Alloc>(fstream (*)(),string)'
[C++ Error] Unit1.cpp(210): E2294 Structure required on left side of . or .*
0
 Аватар для BRcr
4043 / 2333 / 292
Регистрация: 03.02.2011
Сообщений: 5,066
Записей в блоге: 10
24.05.2012, 16:50
Мне как, предлагается угадать, на каких строчках показывает ошибки?
0
35 / 35 / 10
Регистрация: 24.11.2011
Сообщений: 309
24.05.2012, 16:58  [ТС]
вот так)
Миниатюры
Не работает цикл   Не работает цикл   Не работает цикл  

0
 Аватар для BRcr
4043 / 2333 / 292
Регистрация: 03.02.2011
Сообщений: 5,066
Записей в блоге: 10
24.05.2012, 19:28
Компилятор решил, что был объявлен прототип функции fstream input( void );
Тогда объявление объекта input следует делать без явного вызова конструктора, вот так:
C++
1
std::fstream input;
будет вызван конструктор по умолчанию.
0
35 / 35 / 10
Регистрация: 24.11.2011
Сообщений: 309
24.05.2012, 19:34  [ТС]
BRcr, ошибок нет, но цикл по-прежнему дальше первого файла не идет.
0
 Аватар для BRcr
4043 / 2333 / 292
Регистрация: 03.02.2011
Сообщений: 5,066
Записей в блоге: 10
24.05.2012, 20:43
Ааа, вот где собака зарыта!
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
for (size_t i=1;i<11;++i)    
{
// ...
    for (i=0;i<cmp.size(); i++) // здесь надо примерно так: for (int i=0; i<cmp.size(); i++)
    {
    if (final.first>cmp[i].first)
        {
         final=cmp[i];  
        }
    last.push_back(final);   
    }
// ...
}
Итератор цикла прохода по файлам i у тебя инкрементируется внутренним циклом, аккуратнее надо...
0
35 / 35 / 10
Регистрация: 24.11.2011
Сообщений: 309
24.05.2012, 21:12  [ТС]
Цитата Сообщение от BRcr Посмотреть сообщение
Ааа, вот где собака зарыта!
да, спасибо, не заметил)

но все равно цикл не идет(

Добавлено через 16 минут
цикл идет, но данные с других файлов не получаются
0
35 / 35 / 10
Регистрация: 24.11.2011
Сообщений: 309
24.05.2012, 21:26  [ТС]
убрал
C++
1
2
3
4
5
6
7
        if (rad.size()>size*1.5)
            {
               continue;//на след строку
            }
            else {
//расчеты
}
появилась такая штука:
(1й файл проходит полностью, выскакивает когда идет работа со 2м насколько я понял)
Миниатюры
Не работает цикл   Не работает цикл  
0
35 / 35 / 10
Регистрация: 24.11.2011
Сообщений: 309
24.05.2012, 22:02  [ТС]
я думаю, что при расчетах
C++
1
2
3
4
5
6
7
8
9
    for (size_t s=0;s<size;++s)      //s - сдвиг
            {   single=0;
             for (size_t z=0;z<rad.size();++z) //z - счетчик
                    {
                         single+=(db[z+s]-rad[z])*(db[z+s]-rad[z]);
                    }//конец сравнения под одним углом
                    single/=rad.size();     //делим сумму на кол-во элементов на границе клетки
                    sngl.push_back(single);
            }
встречаются такие пары векторов где rad.size>db.size и идет обращение на какой-нибудь db[567], а их всего 300 например. вот и выскакивает все.

стояла проверка
C++
1
2
3
4
5
6
if (rad.size()>size*1.5)
            {
               continue;//на след строку
            }
            else {//расчеты
}
но видимо она не так работала как хотелось бы

подскажите как ее сделать нормально? нужно что бы при (rad.size()>size*1.5) расчеты не проводились, а сразу на след строку переходила программа

Добавлено через 9 минут
C++
1
2
3
4
5
6
while(getline(input,line)) //цикл чтения из файла и расчеты в нем
    {
     std::stringstream ss(line.c_str());
     std::copy(std::istream_iterator<float> (ss), std::istream_iterator<float> (), std::back_inserter(db) );
     std::copy(db.begin(), db.end(), std::ostream_iterator<float> (std::cout)/* , "  |  ")*/ );
}
сам цикл прохода по строкам, собственно
0
 Аватар для BRcr
4043 / 2333 / 292
Регистрация: 03.02.2011
Сообщений: 5,066
Записей в блоге: 10
24.05.2012, 23:35
db после дублирования имеет размер size*2, поэтому переменные z и s не должны давать в сумме более этого значения. Аналогично, rad.size() не должен быть меньше size. Смысл условия rad.size()>size*1.5 неясен, так как я не в курсе, кто такой rad и нафиг он нужен.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
            if ( rad.size() > size * 1.5 || rad.size() < size ) {
               continue;    //на след строку
            }
            else {           
              for ( size_t s = 0; s < size; ++s ) {     //s - сдвиг 
                 single = 0;
                 for ( size_t z = 0; z < size; ++z ) {    //z - счетчик
                         single += ( db[z+s] - rad[z] ) * ( db[z+s] - rad[z] );
                 }   //конец сравнения под одним углом
                 single /= rad.size();     //делим сумму на кол-во элементов на границе клетки
                 sngl.push_back( single );
              }   //конец сравнения с 1 изображением
              // ...
            }
1
35 / 35 / 10
Регистрация: 24.11.2011
Сообщений: 309
24.05.2012, 23:50  [ТС]
BRcr, что db дублируется я помню.
rad, так же как и db является набором радиусов, проведенных из центра клетки крови к каждой точке ее периметра. db - набор радиусов клетки известного типа, rad - неизвестного. Т.к. клетки могут быть разного размера и со всякими хвостиками и т.д. количество этих радиусов может быть больше чем db*2. вот зачем нужна проверка.
0
 Аватар для BRcr
4043 / 2333 / 292
Регистрация: 03.02.2011
Сообщений: 5,066
Записей в блоге: 10
25.05.2012, 17:15
Стало быть, анализ подобия форм, представленных наборами радиусов... занятненько.
Такой алгоритм, на мой взгляд, будет верно сравнивать исключительно клетки одного размера. И вот почему.
Если неизвестная форма большего размера, чем сравниваемый с нею образец, то она будет представлена большим количеством радиусов. Теперь допустим, что неизвестная-таки подобна нашему образцу. Что сделает такой алгоритм? Он будет сравнивать радиусы последовательно и моментально накопит систематическую ошибку из-за разницы в размерностях, которая даст ложный результат. И неважно, под каким углом алгоритм будет глядеть на форму, ошибка все равно будет.
Поэтому перед анализом необходимо выравнивать размерности наборов данных, которыми представлены формы. Если набор у неизвестной больше, чем у образца, то из него надо поудалять радиусы через регулярный шаг. Если же он меньше, то либо поудалять лишние из набора образца, либо добавить недостающие интерполяцией.
То бишь, образно говоря, неизвестную форму надо уменьшить или увеличить оптически и только после этого ее крутить на 360 в поисках совпадающих паттернов.
0
35 / 35 / 10
Регистрация: 24.11.2011
Сообщений: 309
25.05.2012, 21:56  [ТС]
BRcr, Вы правы, нормировка нужна.
Но сейчас я ее не буду делать по 2м причинам: 1-ая - нехватка времени до сдачи.
2-ая - ну очень большое время требуется что бы пройтись по базе (~650 изображений), где-то видимо не сбрасываю что-то и оно копится как ком. пока не нашел.

Добавлено через 15 минут
тормозило все из-за
C++
1
if ( rad.size() > size * 1.5 || rad.size() < size )
, сделал
C++
1
rad.size() > size * 1.5
(без лог. или )
опять дальше первого файла не проверяет, но сам счетчик идет
C++
1
if (i==6) {ShowMessage ("i=6");}
Добавлено через 3 часа 24 минуты
На данным момент цикл обрабатывает расчетами 1й файл, идет по остальным, но не обрабатывает их.
Выглядит так:
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
void __fastcall TForm1::Button4Click(TObject *Sender)
{
//кнопка чтения из файла и сравнения с данными изображенями
std::vector<float> db;  //объявим вектор под значения из файла
std::vector<float> sngl; //для одного изобр
std::vector<pair<float,int> > cmp;  //для всего и всех изобр. 1знач отклонения, 2 тип клетки
pair<float,int> chain;   //создаем пару
float single;  //сумма отклонений для одного угла
float mini;    //минимальное из отклонений
String Path;      //задает переменную пути
std::fstream input; //для обхода файлов
 
for (size_t i=1;i<11;++i)    //ходим по файлам     /////////////////////
{
 if (i==2) {ShowMessage ("i=6");}
     Path="D:\\"+String(i)+".txt";
     input.open(Path.c_str());
    
    std::string line;    ////
    while(getline(input,line)) //цикл чтения из файла и расчеты в нем
    {
     std::stringstream ss(line.c_str());
     std::copy(std::istream_iterator<float> (ss), std::istream_iterator<float> (), std::back_inserter(db) );
     std::copy(db.begin(), db.end(), std::ostream_iterator<float> (std::cout)/* , "  |  ")*/ );
 
            unsigned int size=db.size();      //дублируем db
            for (unsigned int f=0; f<size; ++f)
            {
              db.push_back(db[f]);
            }
            if ( rad.size() > size * 1.5/* || rad.size() < size*/ )
            {
               continue;    //на след строку
            }
            else
            {
 
            for (size_t s=0;s<size;++s)      //s - сдвиг
            {    single=0;
                 for (size_t z=0;z<rad.size();++z) //z - счетчик
                        {
                         single+=(db[z+s]-rad[z])*(db[z+s]-rad[z]);
                        }//конец сравнения под одним углом
                    single/=rad.size();     //делим сумму на кол-во элементов на границе клетки
                    sngl.push_back(single);
                }//конец сравнения с 1 изображением
 
             mini=sngl[0];
             for (size_t y=0;y<sngl.size();++y) //ищем минимальное отклонение с данным изобр
                 {
                    mini=min(mini,sngl[y]);
                 }
              chain=make_pair(mini,i); //добавляем пару где 2е знач - тип клетки (имя файла)
              cmp.push_back(chain);
              sngl.clear(); //очистка
              db.clear();
              }
    } //переход на след строку
 
    //ищем минимальное отклонение из всех строк
        
    input.close();         
    
}  //переход на следующий файл
 
    for (size_t p=0; p<cmp.size(); p++) //ищем минимальное из всех файлов
            { if (cmp[p].first<cmp[0].first)
                    {
                      cmp[0]=cmp[p];
                    }
            }
 
    ShowMessage ("отклонение равно " + FloatToStr(cmp[0].first)+ " тип клетки "+cmp[0].second);
}
0
 Аватар для BRcr
4043 / 2333 / 292
Регистрация: 03.02.2011
Сообщений: 5,066
Записей в блоге: 10
25.05.2012, 23:52
Трассировкой искать надо. Проверь, может, в потоке input ставится failbit и он не работает. Или проект выкладывай.
1
35 / 35 / 10
Регистрация: 24.11.2011
Сообщений: 309
27.05.2012, 20:46  [ТС]
Разобрался, все заработало. Вывод - нужно объявлять переменные там где их используешь.
Насчет логического или : надо () || () приоритет операций < ниже чем ||.
0
 Аватар для BRcr
4043 / 2333 / 292
Регистрация: 03.02.2011
Сообщений: 5,066
Записей в блоге: 10
27.05.2012, 21:36
Цитата Сообщение от Sor Посмотреть сообщение
Насчет логического или : надо () || () приоритет операций < ниже чем ||.
Хех, моя оплошность, каюсь
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
27.05.2012, 21:36
Помогаю со студенческими работами здесь

Создать программу по всем 3 видам циклов...цикл с параметром,цикл с условием,цикл,и цикл с предусловием...
Найти сумму чисел 1 в квадрате до 10 c квадрате...операцию возведению в степень не использовать учесть особенности получения квадратного...

Цикл for не работает
Всем привет. Почему данный цикл не работает: $arrayOfVoices = explode(&quot; &quot;, $text); //$text = 2 1 0 2 1 1 0 0 1 0 2 &lt;?php ... ...

Не работает цикл.
Не могу заставить работать цикл. Есть форма, в ней батоны. Если выбран первый - действие одно, второй - другое. Вывод батонов: ...

Не работает цикл
Здравствуйте! Пишу однослойный перцептрон, при этом методу отправляю наборы значений x, w, y, n для обработки и корректировки весовых коэф....

Не работает цикл
Задание к примеру ввожу матрицу 2х2 1 2 3 4 должно выдать 4 а выдаёт 2 в чём проблема?


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
18
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru