Я хочу использовать std::find_if с неравенством в условии для std::vector.
Например,
- здесь у меня есть матрица M в Matlab (в C++ я создал вектор векторов M[j], где i — столбец (вектор), а j — строка (векторы с элементами).
Тогда я хочу реализовать на C++ то, что у меня есть в Matlab:
for j = 2:(sz - 1) % (sz - 1) = M.size()
k1 = j - find(M(j, 1:j - 1) > L, 1, 'last'); % j - last one index in red frame
k2 = find(M(j, j + 1:end) > L, 1, 'first'); % first one index in blue frame
...
end
Здесь (M(j, 1:j - 1) относятся к красным кадрам, а M(j, j + 1:end) предназначены для синих рамок.
Я ищу k1 в красных фреймах и k2 в синих фреймах. Я пытаюсь найти k1 ( индекс последнего элемента выше 0), используя std::find_if, но я не могу понять почему:
Это работает только тогда, когда я пишу x < L вместо x > L
Сначала я получаю 0,2877, а не 0,4055. p>
Лучше ли создать два дополнительные векторы, например M1 и M2 для
(M(j, 1:j - 1) и M(j, j + 1:end)? Потому что в C++ нет оператора двоеточия. Или я могу получить то, что хочу, с помощью find_if?
Код C++:
...
for (unsigned int j = 1; j < M.size(); j++) {
auto it = std::find_if(M[j].rbegin(), M[j].rend(), [&](const double &x) -> bool {return x > L; }); // here without `j - ...`
auto f = *it2; // just for check what I get
}
...
Я хочу использовать std::find_if с неравенством в условии для std::vector.
Например, [img]https://i.sstatic.net/zEfcd.png[/img] - здесь у меня есть матрица M в Matlab (в C++ я создал вектор векторов M[i][j], где i — столбец (вектор), а j — строка (векторы с элементами). Тогда я хочу реализовать на C++ то, что у меня есть в Matlab:
for j = 2:(sz - 1) % (sz - 1) = M.size() k1 = j - find(M(j, 1:j - 1) > L, 1, 'last'); % j - last one index in red frame k2 = find(M(j, j + 1:end) > L, 1, 'first'); % first one index in blue frame ... end
Здесь (M(j, 1:j - 1) относятся к красным кадрам, а M(j, j + 1:end) предназначены для синих рамок.
Я ищу k1 в красных фреймах и k2 в синих фреймах. Я пытаюсь найти k1 ( индекс последнего элемента выше 0), используя std::find_if, но я не могу понять почему:
[list] [*]Это работает только тогда, когда я пишу x < L вместо x > L [*]Сначала я получаю 0,2877, а не 0,4055. p> [*]Лучше ли создать два дополнительные векторы, например M1 и M2 для (M(j, 1:j - 1) и M(j, j + 1:end)? Потому что в C++ нет оператора двоеточия. Или я могу получить то, что хочу, с помощью find_if? [/list]
Код C++:
... for (unsigned int j = 1; j < M.size(); j++) { auto it = std::find_if(M[j].rbegin(), M[j].rend(), [&](const double &x) -> bool {return x > L; }); // here without `j - ...` auto f = *it2; // just for check what I get } ...
Я пытаюсь загрузить 2 файла json в векторное хранилище помощников, используя официальную библиотеку python openAI. Я также хочу использовать определенную стратегию разбиения на фрагменты, отдельную для каждого файла.
Я обнаружил, что существует два...
Я пытаюсь загрузить 2 файла json в векторное хранилище помощников, используя официальную библиотеку python openAI. Я также хочу использовать определенную стратегию разбиения на фрагменты, отдельную для каждого файла.
Я обнаружил, что существует два...
У меня 16 3D -точек, 16 2D точек, матрица камеры и коэффициенты искажения. Используя эту информацию, я пытаюсь вычислить новые векторы вращения и векторы перевода. Вот используемый код.
success, rvec, tvec = cv2.solvePnP(points_3d, points_2d,...
У меня 16 3D -точек, 16 2D точек, матрица камеры и коэффициенты искажения. Используя эту информацию, я пытаюсь вычислить новые векторы вращения и векторы перевода. Вот используемый код.
success, rvec, tvec = cv2.solvePnP(points_3d, points_2d,...