-
-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
19 changed files
with
140 additions
and
16 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
1 change: 1 addition & 0 deletions
1
Runtime/Prototyping/Observers/Camera/FloatArrayCameraObserver.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
1 change: 1 addition & 0 deletions
1
Runtime/Prototyping/Observers/Camera/Segmentation/SegmentationCameraObserver.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
1 change: 1 addition & 0 deletions
1
Runtime/Prototyping/Observers/Camera/StringAugmentedCameraObserver.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
// Upgrade NOTE: replaced 'mul(UNITY_MATRIX_MVP,*)' with 'UnityObjectToClipPos(*)' | ||
|
||
Shader "Excluded/OpticalFlow" | ||
{ | ||
Properties | ||
{ | ||
_Sensitivity("Sensitivity", Float) = 1 | ||
} | ||
SubShader | ||
{ | ||
// No culling or depth | ||
Cull Off ZWrite Off ZTest Always | ||
|
||
Pass | ||
{ | ||
CGPROGRAM | ||
#pragma vertex vert | ||
#pragma fragment frag | ||
|
||
#include "UnityCG.cginc" | ||
|
||
|
||
struct appdata | ||
{ | ||
float4 vertex : POSITION; | ||
float2 uv : TEXCOORD0; | ||
}; | ||
|
||
struct v2f | ||
{ | ||
float2 uv : TEXCOORD0; | ||
float4 vertex : SV_POSITION; | ||
}; | ||
|
||
float4 _CameraMotionVectorsTexture_ST; | ||
v2f vert (appdata v) | ||
{ | ||
v2f o; | ||
o.vertex = UnityObjectToClipPos(v.vertex); | ||
o.uv = TRANSFORM_TEX(v.uv, _CameraMotionVectorsTexture); | ||
return o; | ||
} | ||
|
||
sampler2D _CameraMotionVectorsTexture; | ||
|
||
float3 Hue(float H) | ||
{ | ||
float R = abs(H * 6 - 3) - 1; | ||
float G = 2 - abs(H * 6 - 2); | ||
float B = 2 - abs(H * 6 - 4); | ||
return saturate(float3(R,G,B)); | ||
} | ||
|
||
float3 HSVtoRGB(float3 HSV) | ||
{ | ||
return float3(((Hue(HSV.x) - 1) * HSV.y + 1) * HSV.z); | ||
} | ||
|
||
float _Sensitivity; | ||
float3 MotionVectorsToOpticalFlow(float2 motion) | ||
{ | ||
// Currently is based on HSV encoding from: | ||
// "Optical Flow in a Smart Sensor Based on Hybrid Analog-Digital Architecture" by P. Guzman et al | ||
// http://www.mdpi.com/1424-8220/10/4/2975 | ||
|
||
// Analogous to http://docs.opencv.org/trunk/d7/d8b/tutorial_py_lucas_kanade.html | ||
// but might need to swap or rotate axis! | ||
|
||
// @TODO: support other HSV encodings (using lookup texture) | ||
// https://www.microsoft.com/en-us/research/wp-content/uploads/2007/10/ofdatabase_iccv_07.pdf | ||
// https://people.csail.mit.edu/celiu/SIFTflow/ | ||
// some MATLAB code: https://github.com/suhangpro/epicflow/blob/master/utils/flow-code-matlab/computeColor.m | ||
|
||
float angle = atan2(-motion.y, -motion.x); | ||
float hue = angle / (UNITY_PI * 2.0) + 0.5; // convert motion angle to Hue | ||
float value = length(motion) * _Sensitivity; // convert motion strength to Value | ||
return HSVtoRGB(float3(hue, 1, value)); // HSV -> RGB | ||
} | ||
|
||
fixed4 frag (v2f i) : SV_Target | ||
{ | ||
float2 motion = tex2D(_CameraMotionVectorsTexture, i.uv).rg; | ||
float3 rgb = MotionVectorsToOpticalFlow(motion); | ||
return float4(rgb, 1); | ||
} | ||
ENDCG | ||
} | ||
} | ||
} |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
File renamed without changes.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters