added sobel kernel for image gradient calcualtion
This commit is contained in:
		
							
								
								
									
										16
									
								
								.vscode/c_cpp_properties.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								.vscode/c_cpp_properties.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| { | ||||
|     "configurations": [ | ||||
|         { | ||||
|             "name": "Linux", | ||||
|             "includePath": [ | ||||
|                 "${workspaceFolder}/**" | ||||
|             ], | ||||
|             "defines": [], | ||||
|             "compilerPath": "/usr/bin/gcc", | ||||
|             "cStandard": "c11", | ||||
|             "cppStandard": "c++14", | ||||
|             "intelliSenseMode": "clang-x64" | ||||
|         } | ||||
|     ], | ||||
|     "version": 4 | ||||
| } | ||||
							
								
								
									
										
											BIN
										
									
								
								.vscode/ipch/778a17e566a4909e/mmap_address.bin
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								.vscode/ipch/778a17e566a4909e/mmap_address.bin
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								.vscode/ipch/ccf983af1f87ec2b/mmap_address.bin
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								.vscode/ipch/ccf983af1f87ec2b/mmap_address.bin
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								.vscode/ipch/e40aedd19a224f8d/mmap_address.bin
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								.vscode/ipch/e40aedd19a224f8d/mmap_address.bin
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										6
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| { | ||||
|     "files.associations": { | ||||
|         "core": "cpp", | ||||
|         "sparsecore": "cpp" | ||||
|     } | ||||
| } | ||||
| @@ -168,6 +168,11 @@ struct Feature { | ||||
|                   const CameraCalibration& cam, | ||||
|                   Eigen::Vector3d& in_p) const; | ||||
|  | ||||
|   double Kernel( | ||||
|             const cv::Point2f pose, | ||||
|             const cv::Mat frame, | ||||
|             std::string type) const; | ||||
|  | ||||
|   /* | ||||
|   * @brief IrradianceAnchorPatch_Camera returns irradiance values | ||||
|   *        of the Anchor Patch position in a camera frame | ||||
| @@ -387,6 +392,31 @@ bool Feature::checkMotion(const CamStateServer& cam_states) const | ||||
|   else return false; | ||||
| } | ||||
|  | ||||
| double Feature::Kernel( | ||||
|                 const cv::Point2f pose, | ||||
|                 const cv::Mat frame, | ||||
|                 std::string type) const | ||||
| { | ||||
| Eigen::Matrix<double, 3, 3> kernel = Eigen::Matrix<double, 3, 3>::Zero(); | ||||
| if(type == "Sobel_x") | ||||
|   kernel  << -1., 0., 1.,-2., 0., 2. , -1., 0., 1.; | ||||
| else if(type == "Sobel_y") | ||||
|   kernel << -1., -2., -1., 0., 0., 0., 1., 2., 1.; | ||||
|  | ||||
| double delta = 0; | ||||
| int offs = (int)(kernel.rows()-1)/2; | ||||
| for(int i = 0; i < kernel.rows(); i++){ | ||||
|  | ||||
|   for(int j = 0; j < kernel.cols(); j++) | ||||
|   {  | ||||
|     std::cout << "i: " << i << ":" << "j: " << j << ":" << kernel(i,j) << std::endl; | ||||
|     std::cout <<"pose: " << pose.y+i-offs << " : " << pose.x+j-offs << std::endl; | ||||
|     delta += ((float)frame.at<uint8_t>(pose.y+i-offs , pose.x+j-offs))/255 * (float)kernel(i,j); | ||||
|   } | ||||
| } | ||||
| std::cout << "delta  " << delta << std::endl; | ||||
| return delta; | ||||
| } | ||||
| bool Feature::estimate_FrameIrradiance( | ||||
|                   const CAMState& cam_state, | ||||
|                   const StateIDType& cam_state_id, | ||||
|   | ||||
| @@ -24,7 +24,7 @@ | ||||
|       <param name="PrintImages" value="true"/> | ||||
|       <param name="GroundTruth" value="false"/> | ||||
|  | ||||
|       <param name="patch_size_n" value="7"/> | ||||
|       <param name="patch_size_n" value="1"/> | ||||
|       <!-- Calibration parameters --> | ||||
|       <rosparam command="load" file="$(arg calibration_file)"/> | ||||
|  | ||||
|   | ||||
| @@ -1312,8 +1312,13 @@ void MsckfVio::PhotometricMeasurementJacobian( | ||||
|  | ||||
|     // calculate derivation for anchor frame, use position for derivation calculation | ||||
|     // frame derivative calculated convoluting with kernel [-1, 0, 1] | ||||
|     dx = feature.PixelIrradiance(cv::Point2f(p_in_anchor.x+1, p_in_anchor.y), anchor_frame) - feature.PixelIrradiance(cv::Point2f(p_in_anchor.x-1, p_in_anchor.y), anchor_frame); | ||||
|     dy = feature.PixelIrradiance(cv::Point2f(p_in_anchor.x, p_in_anchor.y+1), anchor_frame) - feature.PixelIrradiance(cv::Point2f(p_in_anchor.x, p_in_anchor.y-1), anchor_frame); | ||||
|  | ||||
|     dx = feature.Kernel(p_in_anchor, anchor_frame, "Sobel_x"); | ||||
|     dy = feature.Kernel(p_in_anchor, anchor_frame, "Sobel_y"); | ||||
|      | ||||
|     // dx = feature.PixelIrradiance(cv::Point2f(p_in_anchor.x+1, p_in_anchor.y), anchor_frame) - feature.PixelIrradiance(cv::Point2f(p_in_anchor.x-1, p_in_anchor.y), anchor_frame); | ||||
|     // dy = feature.PixelIrradiance(cv::Point2f(p_in_anchor.x, p_in_anchor.y+1), anchor_frame) - feature.PixelIrradiance(cv::Point2f(p_in_anchor.x, p_in_anchor.y-1), anchor_frame); | ||||
|      | ||||
|     dI_dhj(0, 0) = dx/(pixelDistance.x); | ||||
|     dI_dhj(0, 1) = dy/(pixelDistance.y); | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user