2013-05-12 22:17:37 +00:00
|
|
|
/*
|
|
|
|
* ***** BEGIN GPL LICENSE BLOCK *****
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*
|
|
|
|
* The Original Code is Copyright (C) 2013 Blender Foundation.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s): Blender Foundation,
|
|
|
|
* Sergey Sharybin
|
|
|
|
*
|
|
|
|
* ***** END GPL LICENSE BLOCK *****
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef WITH_LIBMV
|
|
|
|
|
|
|
|
#include "libmv-capi.h"
|
|
|
|
|
|
|
|
#include <cstdlib>
|
|
|
|
#include <cstring>
|
|
|
|
|
|
|
|
/* ************ Logging ************ */
|
|
|
|
|
|
|
|
void libmv_initLogging(const char * /*argv0*/)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void libmv_startDebugLogging(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void libmv_setLoggingVerbosity(int /*verbosity*/)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ************ Planar tracker ************ */
|
|
|
|
|
|
|
|
/* TrackRegion (new planar tracker) */
|
2013-07-31 13:48:12 +00:00
|
|
|
int libmv_trackRegion(const libmv_TrackRegionOptions * /*options*/,
|
2013-05-12 22:17:37 +00:00
|
|
|
const float * /*image1*/, int /*image1_width*/, int /*image1_height*/,
|
|
|
|
const float * /*image2*/, int /*image2_width*/, int /*image2_height*/,
|
|
|
|
const double *x1, const double *y1,
|
2013-07-31 13:48:12 +00:00
|
|
|
libmv_TrackRegionResult *result,
|
2013-05-12 22:17:37 +00:00
|
|
|
double *x2, double *y2)
|
|
|
|
{
|
|
|
|
/* Convert to doubles for the libmv api. The four corners and the center. */
|
|
|
|
for (int i = 0; i < 5; ++i) {
|
|
|
|
x2[i] = x1[i];
|
|
|
|
y2[i] = y1[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
result->termination = -1;
|
|
|
|
result->termination_reason = "Built without libmv support";
|
|
|
|
result->correlation = 0.0;
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2014-04-10 15:14:36 +00:00
|
|
|
void libmv_samplePlanarPatch(const float * /*image*/,
|
|
|
|
int /*width*/, int /*height*/, int /*channels*/,
|
|
|
|
const double * /*xs*/, const double * /*ys*/,
|
|
|
|
int /*num_samples_x*/, int /*num_samples_y*/,
|
|
|
|
const float * /*mask*/,
|
|
|
|
float * /*patch*/,
|
2014-04-10 18:59:03 +00:00
|
|
|
double * /*warped_position_x*/, double * /*warped_position_y*/)
|
2014-04-10 15:14:36 +00:00
|
|
|
{
|
|
|
|
/* TODO(sergey): implement */
|
|
|
|
}
|
|
|
|
|
2014-04-10 19:00:54 +00:00
|
|
|
void libmv_samplePlanarPatchByte(const unsigned char * /*image*/,
|
2014-04-10 15:14:36 +00:00
|
|
|
int /*width*/, int /*height*/, int /*channels*/,
|
|
|
|
const double * /*xs*/, const double * /*ys*/,
|
|
|
|
int /*num_samples_x*/, int /*num_samples_y*/,
|
|
|
|
const float * /*mask*/,
|
|
|
|
unsigned char * /*patch*/,
|
2014-04-10 18:59:03 +00:00
|
|
|
double * /*warped_position_x*/, double * /*warped_position_y*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
/* TODO(sergey): implement */
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ************ Tracks ************ */
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
struct libmv_Tracks *libmv_tracksNew(void)
|
|
|
|
{
|
2013-05-12 22:17:37 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
void libmv_tracksInsert(struct libmv_Tracks * /*libmv_tracks*/, int /*image*/,
|
2013-10-26 13:22:38 +00:00
|
|
|
int /*track*/, double /*x*/, double /*y*/, double /*weight*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
void libmv_tracksDestroy(struct libmv_Tracks * /*libmv_tracks*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ************ Reconstruction solver ************ */
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
struct libmv_Reconstruction *libmv_solveReconstruction(const struct libmv_Tracks * /*libmv_tracks*/,
|
|
|
|
const libmv_CameraIntrinsicsOptions * /*libmv_camera_intrinsics_options*/,
|
|
|
|
libmv_ReconstructionOptions * /*libmv_reconstruction_options*/,
|
|
|
|
reconstruct_progress_update_cb /*progress_update_callback*/,
|
|
|
|
void * /*callback_customdata*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2013-05-14 03:06:58 +00:00
|
|
|
struct libmv_Reconstruction *libmv_solveModal(const struct libmv_Tracks * /*libmv_tracks*/,
|
2013-07-31 13:48:12 +00:00
|
|
|
const libmv_CameraIntrinsicsOptions * /*libmv_camera_intrinsics_options*/,
|
|
|
|
const libmv_ReconstructionOptions * /*libmv_reconstruction_options*/,
|
|
|
|
reconstruct_progress_update_cb /*progress_update_callback*/,
|
|
|
|
void * /*callback_customdata*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
int libmv_reprojectionPointForTrack(const struct libmv_Reconstruction * /*libmv_reconstruction*/,
|
2013-05-12 22:17:37 +00:00
|
|
|
int /*track*/, double /*pos*/[3])
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
double libmv_reprojectionErrorForTrack(const struct libmv_Reconstruction * /*libmv_reconstruction*/, int /*track*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
return 0.0;
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
double libmv_reprojectionErrorForImage(const struct libmv_Reconstruction * /*libmv_reconstruction*/, int /*image*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
return 0.0;
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
int libmv_reprojectionCameraForImage(const struct libmv_Reconstruction * /*libmv_reconstruction*/, int /*image*/,
|
2013-05-12 22:17:37 +00:00
|
|
|
double /*mat*/[4][4])
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
double libmv_reprojectionError(const struct libmv_Reconstruction * /*libmv_reconstruction*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
return 0.0;
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
void libmv_reconstructionDestroy(struct libmv_Reconstruction * /*libmv_reconstruction*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ************ feature detector ************ */
|
|
|
|
|
2013-10-08 13:53:59 +00:00
|
|
|
struct libmv_Features *libmv_detectFeaturesByte(const unsigned char */*image_buffer*/,
|
|
|
|
int /*width*/, int /*height*/, int /*channels*/,
|
|
|
|
libmv_DetectOptions */*options*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2013-10-08 13:53:59 +00:00
|
|
|
struct libmv_Features *libmv_detectFeaturesFloat(const float */*image_buffer*/,
|
|
|
|
int /*width*/, int /*height*/, int /*channels*/,
|
|
|
|
libmv_DetectOptions */*options*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2013-05-14 03:06:58 +00:00
|
|
|
int libmv_countFeatures(const struct libmv_Features * /*libmv_features*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2013-05-14 03:06:58 +00:00
|
|
|
void libmv_getFeature(const struct libmv_Features * /*libmv_features*/, int /*number*/,
|
2013-05-12 22:17:37 +00:00
|
|
|
double *x, double *y, double *score, double *size)
|
|
|
|
{
|
|
|
|
*x = 0.0;
|
|
|
|
*y = 0.0;
|
|
|
|
*score = 0.0;
|
|
|
|
*size = 0.0;
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
void libmv_featuresDestroy(struct libmv_Features * /*libmv_features*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ************ camera intrinsics ************ */
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
struct libmv_CameraIntrinsics *libmv_reconstructionExtractIntrinsics(
|
|
|
|
struct libmv_Reconstruction * /*libmv_reconstruction*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
struct libmv_CameraIntrinsics *libmv_cameraIntrinsicsNew(
|
|
|
|
const libmv_CameraIntrinsicsOptions * /*libmv_camera_intrinsics_options*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
struct libmv_CameraIntrinsics *libmv_cameraIntrinsicsCopy(const libmv_CameraIntrinsics * /*libmvIntrinsics*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
void libmv_cameraIntrinsicsDestroy(struct libmv_CameraIntrinsics * /*libmvIntrinsics*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
void libmv_cameraIntrinsicsUpdate(const libmv_CameraIntrinsicsOptions * /*libmv_camera_intrinsics_options*/,
|
|
|
|
struct libmv_CameraIntrinsics * /*libmv_intrinsics*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
void libmv_cameraIntrinsicsSetThreads(struct libmv_CameraIntrinsics * /*libmv_intrinsics*/, int /*threads*/)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2014-02-20 13:41:05 +00:00
|
|
|
void libmv_cameraIntrinsicsExtractOptions(
|
|
|
|
const libmv_CameraIntrinsics */*libmv_intrinsics*/,
|
2014-04-17 12:53:11 +00:00
|
|
|
libmv_CameraIntrinsicsOptions *camera_intrinsics_options)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
2014-02-20 13:41:05 +00:00
|
|
|
memset(camera_intrinsics_options, 0, sizeof(libmv_CameraIntrinsicsOptions));
|
|
|
|
camera_intrinsics_options->focal_length = 1.0;
|
2013-05-12 22:17:37 +00:00
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
void libmv_cameraIntrinsicsUndistortByte(const struct libmv_CameraIntrinsics * /*libmv_intrinsics*/,
|
|
|
|
unsigned char *src, unsigned char *dst, int width, int height,
|
|
|
|
float overscan, int channels)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
memcpy(dst, src, channels * width * height * sizeof(unsigned char));
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
void libmv_cameraIntrinsicsUndistortFloat(const struct libmv_CameraIntrinsics * /*libmvIntrinsics*/,
|
|
|
|
float *src, float *dst, int width, int height, float overscan, int channels)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
memcpy(dst, src, channels * width * height * sizeof(float));
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
void libmv_cameraIntrinsicsDistortByte(const struct libmv_CameraIntrinsics *libmvIntrinsics,
|
|
|
|
unsigned char *src, unsigned char *dst, int width, int height,
|
|
|
|
float overscan, int channels)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
memcpy(dst, src, channels * width * height * sizeof(unsigned char));
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
void libmv_cameraIntrinsicsDistortFloat(const struct libmv_CameraIntrinsics *libmvIntrinsics,
|
|
|
|
float *src, float *dst, int width, int height, float overscan, int channels)
|
2013-05-12 22:17:37 +00:00
|
|
|
{
|
|
|
|
memcpy(dst, src, channels * width * height * sizeof(float));
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ************ utils ************ */
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
void libmv_cameraIntrinsicsApply(const libmv_CameraIntrinsicsOptions *libmv_camera_intrinsics_options,
|
2013-05-12 22:17:37 +00:00
|
|
|
double x, double y, double *x1, double *y1)
|
|
|
|
{
|
|
|
|
double focal_length = libmv_camera_intrinsics_options->focal_length;
|
|
|
|
double principal_x = libmv_camera_intrinsics_options->principal_point_x;
|
|
|
|
double principal_y = libmv_camera_intrinsics_options->principal_point_y;
|
|
|
|
|
|
|
|
*x1 = x * focal_length + principal_x;
|
|
|
|
*y1 = y * focal_length + principal_y;
|
|
|
|
}
|
|
|
|
|
2013-07-31 13:48:12 +00:00
|
|
|
void libmv_cameraIntrinsicsInvert(const libmv_CameraIntrinsicsOptions *libmv_camera_intrinsics_options,
|
2013-05-12 22:17:37 +00:00
|
|
|
double x, double y, double *x1, double *y1)
|
|
|
|
{
|
|
|
|
double focal_length = libmv_camera_intrinsics_options->focal_length;
|
|
|
|
double principal_x = libmv_camera_intrinsics_options->principal_point_x;
|
|
|
|
double principal_y = libmv_camera_intrinsics_options->principal_point_y;
|
|
|
|
|
|
|
|
*x1 = (x - principal_x) / focal_length;
|
|
|
|
*y1 = (y - principal_y) / focal_length;
|
|
|
|
}
|
|
|
|
|
2013-09-30 09:35:04 +00:00
|
|
|
void libmv_homography2DFromCorrespondencesEuc(double (* /* x1 */)[2], double (* /* x2 */)[2], int /* num_points */,
|
|
|
|
double H[3][3])
|
Merge plane track feature from tomato branch
This commit includes all the changes made for plane tracker
in tomato branch.
Movie clip editor changes:
- Artist might create a plane track out of multiple point
tracks which belongs to the same track (minimum amount of
point tracks is 4, maximum is not actually limited).
When new plane track is added, it's getting "tracked"
across all point tracks, which makes it stick to the same
plane point tracks belong to.
- After plane track was added, it need to be manually adjusted
in a way it covers feature one might to mask/replace.
General transform tools (G, R, S) or sliding corners with
a mouse could be sued for this. Plane corner which
corresponds to left bottom image corner has got X/Y axis
on it (red is for X axis, green for Y).
- Re-adjusting plane corners makes plane to be "re-tracked"
for the frames sequence between current frame and next
and previous keyframes.
- Kayframes might be removed from the plane, using Shit-X
(Marker Delete) operator. However, currently manual
re-adjustment or "re-track" trigger is needed.
Compositor changes:
- Added new node called Plane Track Deform.
- User selects which plane track to use (for this he need
to select movie clip datablock, object and track names).
- Node gets an image input, which need to be warped into
the plane.
- Node outputs:
* Input image warped into the plane.
* Plane, rasterized to a mask.
Masking changes:
- Mask points might be parented to a plane track, which
makes this point deforming in a way as if it belongs
to the tracked plane.
Some video tutorials are available:
- Coder video: http://www.youtube.com/watch?v=vISEwqNHqe4
- Artist video: https://vimeo.com/71727578
This is mine and Keir's holiday code project :)
2013-08-16 09:46:30 +00:00
|
|
|
{
|
2013-09-13 03:49:11 +00:00
|
|
|
memset(H, 0, sizeof(double[3][3]));
|
2013-08-16 12:43:37 +00:00
|
|
|
H[0][0] = 1.0f;
|
|
|
|
H[1][1] = 1.0f;
|
|
|
|
H[2][2] = 1.0f;
|
Merge plane track feature from tomato branch
This commit includes all the changes made for plane tracker
in tomato branch.
Movie clip editor changes:
- Artist might create a plane track out of multiple point
tracks which belongs to the same track (minimum amount of
point tracks is 4, maximum is not actually limited).
When new plane track is added, it's getting "tracked"
across all point tracks, which makes it stick to the same
plane point tracks belong to.
- After plane track was added, it need to be manually adjusted
in a way it covers feature one might to mask/replace.
General transform tools (G, R, S) or sliding corners with
a mouse could be sued for this. Plane corner which
corresponds to left bottom image corner has got X/Y axis
on it (red is for X axis, green for Y).
- Re-adjusting plane corners makes plane to be "re-tracked"
for the frames sequence between current frame and next
and previous keyframes.
- Kayframes might be removed from the plane, using Shit-X
(Marker Delete) operator. However, currently manual
re-adjustment or "re-track" trigger is needed.
Compositor changes:
- Added new node called Plane Track Deform.
- User selects which plane track to use (for this he need
to select movie clip datablock, object and track names).
- Node gets an image input, which need to be warped into
the plane.
- Node outputs:
* Input image warped into the plane.
* Plane, rasterized to a mask.
Masking changes:
- Mask points might be parented to a plane track, which
makes this point deforming in a way as if it belongs
to the tracked plane.
Some video tutorials are available:
- Coder video: http://www.youtube.com/watch?v=vISEwqNHqe4
- Artist video: https://vimeo.com/71727578
This is mine and Keir's holiday code project :)
2013-08-16 09:46:30 +00:00
|
|
|
}
|
|
|
|
|
2013-05-12 22:17:37 +00:00
|
|
|
#endif // ifndef WITH_LIBMV
|