[3D CV 연구] 3DGS COLMAP depth unit
COLMAP의 real-world scales를 알 수는 없습니다.
COLMAP의 real-world scales를 알 수는 없습니다.
3dgs scene.cameras_extent
Monodepth를 COLMAP coordinate로 rescaling하는 법을 알아봅시다.
각 pixel에 대한 gaussian points를 얻는 방법
HDR Plenoxel에서는 coarse-to-fine으로 spherical harmonics를 학습시킵니다.
3dgs spherical harmonics
self.xyz_gradient_accum 설명
fovx에 해당하는 camera_angle_x만 있으면 image의 height, width로 fovy도 계산이 가능합니다.
optimizer.param_groups로 파라미터별로 다른 lr 설정이 가능합니다.
3D Gaussian들의 properties를 initilize하는 법을 정리합니다.
3DGS SuGaR sugar_model.py _covert_vertex_colors_to_texture
surface_mesh_to_bind = o3d_mesh & n_points = len(triangles * n_gaussians_per_triangle
3DGS SH2RGB
3DGG affine apprximiation of the projective transformation
3DGS alpha blending & inaccurate surface edge & Modeling sharp surface edges
3DGS SuGaR sugar_model.py extract_texture_image_and_uv_from_gaussians
3DGS Gaussian Surfels Poisson Reconstruction
3DGS SuGaR Troublshooting Mesh Issues & Poisson Surface Reconstruction
3DGS SuGaR Adapt the scale and the bounding box of the scene
3DGS Tips for using SuGaR regularization sdf or density
3DGS Tips for using SuGaR your custom data and obtain better reconstructions
3DGS SuGaR benchmark dataset 360_v2 experiments
3DGS SuGaR Rendering, composition and animation
3DGS Tips for using COLMAP
3DGS SuGaR video capture & custom dataset
3DGS SuGaR synthetic datasets
3DGS SuGaR sdf estimation
3DGS SuGaR position_lr_init & spatial_lr_scale
3DGS SuGaR position_lr_init & spatial_lr_scale
3DGS SuGaR how to improve rendering result of simple object in monochrome background
3DGS SuGaR implementation details of coarse mesh extraction and joint refinement
3DGS SuGaR joint refinement of mesh and gaussians
3DGS SuGaR equations
3DGS SuGaR equations
3DGS SuGaR entropy loss
3DGS scene size & scene complexity and spatial learning rate
3DGS Loss not going down and renders look bad, scene에 따른 learning rate 조절
3DGS human rendering ideas
3DGS input & output .ply properties & Meshlab Vert & Spherical Harmonics (SH) & Mesh
3DGS tile ID와 depth keys 기반 sorting을 .cu 파일에서 합니다.
3DGS submodules 설치방법
3DGS spatial_lr_scale
3DGS rasterization은 cuda를 사용합니다.
3DGS random shuffling으로 input images들을 shuffle하지 않으면 performance가 하락합니다.
3DGS positional gradient는 NDC/view space에서 계산됩니다.
3DGS How can I get the points’ indices which contribute to the pixels?
3DGS output .ply파일은 spherical harmonics를 추가 속성으로 포함합니다.
3DGS opacity activation은 sigmoid를 사용합니다.
3DGS The number of points is decreasing when training large-scale scenes
3DGS jacobian w2c matrix
3DGS는 float32를 사용하는데, float16로 바꿔서 실험해봐도 됩니다.
3DGS densify_until_iter
3DGS point cloud coordinate systems
3DGS batch rendering using gaussian rasterizer
3DGS add_densification_stats accumulates the gradient to every Gaussian in the visible frustum
3DGS 결과 비디오 만드는 방법
3DGS original code has a bug for big gaussians culling
3DGS far plane, gaussian pruning, scene extent & learning rate
3DGS background color removal & RGBA
Transformer의 Attention을 시각적으로 이해해봅시다.
GAN 발전동향 정리
PSNR, SSIM, LPIPS, MSE metrics.py
camera calibration
DBSCAN(밀도 기반 클러스터링)에 대해 알아봅시다.
Thin Plate Splines (TPS)에 대해 알아봅시다.
Barycentric Coordinates with Applications in Mesh Deformation
Point cloud로부터 Delaunay triangulation로 surface mesh를 추출하는 방법 및 코드
Nearest Neighbors (Brute force, KD Tree, Ball Tree) 정리
Delaunay triangulation 정리
Rodrigues’ Rotation Formula로 현 카메라를 기준으로 가까운 카메라를 고르는 법을 알아봅시다.
poses에서 자주 나오는 viewmatrix, poses_avg를 알아봅시다.
Dense Matching으로 2개의 views 사이에서 매칭되는 pixels p,q를 찾을 수 있습니다.
COLMAP의 Structure from Motion (SfM) 알고리즘 설명
2D image coordinates에 대한 z value를 알면, 각 픽셀들을 3D로 backprojection한 point clouds를 얻을 수 있습니다.
Depth map visualize는 inverse depth로 표현합니다.
COLMAP의 focal length 단위는 pixel 단위입니다.
Sparse View setting에서 카메라 포즈는 전체 이미지를 COLMAP으로 돌려서 얻습니다.
COLMAP 사용법 & 3DGS COLMAP Data 구성
3DGS에서 test 이미지 골라내는 법
the smallest scale axis in 3D Gaussian becomes a normal
Monocular Depth Estimation
World Space Rotation undo and do
NeRF, 3dgs에서 viewing direction d의 의미
Marching Cubes 정리
마할라노비스 거리 정리
Poisson Reconstruction 정리
가우시안 함수 정리
Level Set 정리
Depth map & Normal map 정리
NeRF, 3dgs C2W, W2C 카메라 포즈 변환 & Coordinate system & 카메라변환 batch matrix multplication 연산 정리글
Lie Algebra & Lie Group 세부 정리
Lie Algebra & Lie Group 정리
COLMAP의 coordinate system은 w2c이고, NeRF의 coordinate system은 c2w입니다.
RANSAC 정리
Epipolar Geometry 정리
Inverse depth maps compress the dynamic range of depth values, reducing the disparity between the binocular and rendered depth maps
Left image만 input으로 하여, left, right disparity를 예측하고, 예측된 두 disparity로부터 camera focal length와 두 카메라 간의 baseline distance로 계산하여 depth map을 복원할 수 있습니다.
Cost volume의 channel 수는 disparity hypothesis의 수와 관련이 있습니다.
Probability volume, depth map inference, per-pixel depth estimation, estimation confidence
transient objects, highly unlikely to be collected in a single caputre under consistent conditions, variance in both scene geometry and appearance
3D reconstruction pipeline: Extract 2D features, matche features across different images, jointly optimize a set of 3D points and camera poses to be consiste...
Matching 2D image correspondences: SuperGlue, Predator, REGTR
global feature-extracting strategy
Relative Rotation Error (RRE), Relative Translation Error (RTE), Relative Scale Error (RSE), Relative Depth Error (RDE), Absolute Translational Error (ATE)
Kabsch-Umeyama algorithm
Kernel Point Convolution (KPConv) is used to obtain the downsampled voxel points
규칙 기반의 특징 점 매칭은 결국 특징점의 디스크립터간의 관계를 파악하는 구조에서 그칩니다.
Rigid point cloud registration refers to the problem of finding the optimal rotation and translation parameters that align two point clouds.
Point cloud registration is a fundamental problem for large-scale 3D scene scanning and reconstruction
MagicPoint는 interest points 검출에 초점을 맞춘 모델입니다.
Interest point detection은 이미지에서 특징이 되는 부분, 즉 keypoint를 찾는 과정입니다.
Image substructures는 이미지 내에서 의미 있는 부분이나 영역을 나타내는 개념입니다.
Homography Estimation과 Homographic Adaptation은 관련은 있지만 다른 개념입니다.
Homographic adaptation은 다양한 호모그래피 변환을 적용한 이미지들에서 관심점을 검출하고 이를 원본 이미지로 역변환하여 pseudo ground truth를 생성하는 자기 지도 학습 기법입니다.
이미지에서 일반적으로 가장 중요하고 구분하기 쉬운 특징점들은 코너와 엣지입니다.
Descriptors는 특징점(keypoint)의 고유한 특성을 수치화한 벡터입니다.
Speeded Up Robust Features (SURF)는 SIFT 알고리즘을 기반으로 사용
the Scale-Invariant Feature Transform, or SIFT, is still probably the most well-known traditional local feature descriptor in computer vision.
LIFT(Learned Invariant Feature Transform)는 딥러닝 기반의 특징점 추출 및 매칭 기법입니다.
Harris 코너 검출 알고리즘은 이미지에서 코너를 추출 하는 알고리즘의 대표적인 예입니다.
HLoc = SuperPoint(as feature extractor) + SuperGlue(as feature matcher)
Features from Accelerated Segment Test (FAST)의 경우 실시간 특징점 추출을 고려하여 만들어진 알고리즘
downsample the input point clouds into superpoints and then match them through examining whether their local neighborhood (patch) overlaps.
Repeatable keypoints, putative correspondences
Global & Local Registartion
weights는 vertex groups과 같은 말이고, weights를 조절하여 함께 움직일 vertex groups를 만듭니다.
subsurface scattering
fk는 parent bone이 child bone에 영향을, ik는 child bone이 parent bone에 역으로 영향을 미칩니다.
Vertex Normal은 인접한 Surface Normal의 평균으로 계산됩니다.
diffuse map(=color map), roughness map, normal map, metallic map을 baking 해봅시다.
Surface Normal, Face Normal, Flat Shading, Smooth Shading, Gouraud Shading, Phong Shading
Blender Texture Painting Experiment
Blender Phong Shading & Normals
BASICS of Material Shading
Baking은 3D 그래픽스에서 복잡한 계산을 미리 수행하여 텍스처 맵에 저장하는 과정입니다.
Shader Fundamentals & Normal mapping & PBR (Physically Based Rendering) texture
3DGS SuGaR UV map texturing with Blender
Blender donut tutorial
Blender animation
o3d poisson reconstruction
Surface Reconstruction, SDF (Signed Distance Function)과 Eikonal Equation의 관계
load_obj, verts, faces_idx, verts_rgb
Surface Reconstruction, multi-view depth maps and normal maps, screened Poisson Reconstruction
SuGaR triangle(face), n vertices for gaussian, TexturesUV, TexturesVertex
Chamfer distance
open3d로 TriangleMesh를 만들고, read_triangle_mesh로 불러오는 법 정리
SuGaR에서 coarse mesh와 refined mesh를 extraction하는 방법
UV map & Texture map (Diffuse(Color) map, Normal map, Specular map, Displacement map, Ambient Occlusion map, Metalness map, Roughness map)
SuGaR에서 coarse mesh와 refined mesh를 extraction하는 방법
SuGaR에서 Gaussians이 어떻게 Primitives (diamond 또는 square(=qaud))로 변형되는지 알아봅시다.
Primitives (Point, Line, Triangle, Quad, Polygon, Diamond)
CUDA_HOME error
Pytorch c++/cuda extension diff-gaussian-rasterization
Pytorch c++/cuda extension tutorial 6
Pytorch c++/cuda extension tutorial 5
Pytorch c++/cuda extension tutorial 4
Pytorch c++/cuda extension tutorial 3
Pytorch c++/cuda extension tutorial 2
Pytorch c++/cuda extension tutorial 1
diff-gaussian-rasterization/cuda_rasterizer/forward.cu
CUDA Rasterization, from . import _C
Github group project
Github repository를 로컬 프로젝트에 내려받기
Git merge 충돌 해결
VSCode, CursorAI 에디터 Extension 추천
git@github.com: Permission denied (publickey) 에러 해결
GitHub를 활용하여 코드를 공유하며 프로젝트를 진행하는 방법을 알아봅시다.
requirements.txt를 설치할 때, 미리 설치한 torch가 uninstall되버리고 다른 버전의 torch로 설치되는 문제 해결법
GitHub에서 메인 레포지토리의 서브모듈을 특정 커밋(커밋 해시)에 맞게 설치하는 법을 알아봅시다.
[논문리뷰] 4D Gaussian Splatting for Real-Time Dynamic Scene Rendering
[논문리뷰] Deblurring 3D Gaussian Splatting
[논문리뷰] High-quality Surface Reconstruction using Gaussian Surfels
[논문리뷰] SuGaR: Surface-Aligned Gaussian Splatting for Efficient 3D Mesh Reconstruction and High-Quality Mesh Rendering
triplane feature vector, optical flow, marching cube
Scan‐specific robust artificial‐neural‐networks for k‐space interpolation (RAKI) reconstruction: Database‐free deep learning for fast imaging
ESPIRiT—An Eigenvalue Approach to AutocalibratingParallel MRI: Where SENSE Meets GRAPPA
fastMRI & skm-tea Real & Simulation 데이터셋 정리
fastMRI & skm-tea Real & Simulation 데이터셋 정리
CT Projection toolbox TIGRE
fastMRI & skm-tea
컴퓨터 그래픽스 전체 프로세스를 설명하는 최고의 영상
Monocular Normal Priors can mitigate specular reflections
Pytorch3D 소개 2
Pytorch3D 소개
SuGaR에서 3D mesh를 load하고 Phong Shading을 사용하여 Rendering하는 전체 프로세스
conda env create –file environment.yml
Docker container를 VScode에 attach하는 법을 알아봅시다.
Docker로 pytorch와 cuda버전을 맞춰서 container를 생성해봅시다.
Docker 사용법에 대해 알아봅시다.
Geometric constraint in 3DGS
Geometric constraint in 3DGS
optical flow 기반 stereo depth estimation model인 RAFT로 surgical scene에 대한 stereo depth를 얻습니다.
이미지를 빠르게 바둑판으로 분할하는 법
Inkscape을 사용하여 svg 벡터 이미지 파일을 그릴 수 있습니다.
How to be happy
How to be happy
4D Gaussian Splatting Dataset