First, we utilized the images of of synthetic spherical surfaces that are illuminated by a far away point source.
data:image/s3,"s3://crabby-images/02e31/02e31f5bdae78dca3a0847704b1b619a0b256b7c" alt=""
data:image/s3,"s3://crabby-images/52ddf/52ddfe9ca96827ed0c78d9946323df6522f43df9" alt=""
data:image/s3,"s3://crabby-images/ab825/ab8250751ba5d18ec17b4d83cc6ae50f481fb93e" alt=""
data:image/s3,"s3://crabby-images/5bece/5bece7e4e71b6b6294540665a2377d9b0d808b69" alt=""
data:image/s3,"s3://crabby-images/2a3d1/2a3d163419cc1c5dc1345bbc0c2ed61925ac30a5" alt=""
data:image/s3,"s3://crabby-images/4b9ec/4b9ece4e9535a34920c0a00fce05526c4000f37b" alt=""
The surface normals (nx, ny, nz) obtained using photometric stereo are related to the partial derivative of f(x,y) as
data:image/s3,"s3://crabby-images/1198a/1198a01ec2f56da124b0ccec23e24965c0002224" alt=""
data:image/s3,"s3://crabby-images/8206c/8206ce47edba96732e99601648ee714a3286e541" alt=""
data:image/s3,"s3://crabby-images/d34d3/d34d36eab234ec849c9b22a5640ff0cc3c466efc" alt=""
The Scilab code used in this activity was shown below. I want to acknowledge the help of Gilbert in working on this activity.
loadmatfile('Photos.mat');
// intensity captured by camera at point (x,y)
I1 = matrix(I1, 1, size(I1, 1)*size(I1, 2));
I2 = matrix(I2, 1, size(I2, 1)*size(I2, 2));
I3 = matrix(I3, 1, size(I3, 1)*size(I3, 2));
I4 = matrix(I4, 1, size(I4, 1)*size(I4, 2));
I = [I1; I2; I3; I4];
// location of the point sources
V1 = [0.085832, 0.17365, 0.98106];
V2 = [0.085832, -0.17365, 0.98106];
V3 = [0.17365, 0, 0.98481];
V4 = [0.16318, -0.34202, 0.92542];
V = [V1; V2; V3; V4];
// calculation of surface normal vector
g = inv(V'*V)*V'*I;
magnitude = sqrt((g(1,:).^2) + (g(2,:).^2) + (g(3,:).^2))+.0001;
n = [];
for i = 1:3
n(i,:) = g(i,:)./magnitude;
end
// computation for the elevation z = f(x,y)
nx = n(1,:);
ny = n(2,:);
nz = n(3,:) + 0.0001;
dfx = -nx./nz;
dfy = -ny./nz;
z1 = matrix(dfx,128,128);
z2 = matrix(dfy,128,128);
Z1 = cumsum(z1,2); // integration from 0 to u
Z2 = cumsum(z2,1); // integration from 0 to v
z = Z1 + Z2;
scf(0);
plot3d(1:128, 1:128, z);
No comments:
Post a Comment