This repository has been archived on 2021-02-05. You can view files and clone it, but cannot push or open issues or pull requests.
ipcv/julia_notebook/geometric.ipynb

545 lines
5.3 MiB
Plaintext
Raw Normal View History

2019-05-14 22:37:19 +07:00
{
"cells": [
{
"cell_type": "code",
"execution_count": 2,
"metadata": {},
"outputs": [],
"source": [
"using FileIO\n",
"using Images, ImageView\n",
"using Formatting"
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"roundAround (generic function with 1 method)"
]
},
"execution_count": 3,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"function roundAround(x, low, high)\n",
" if x < low\n",
" low\n",
" elseif x > high\n",
" high\n",
" else\n",
" round(Int32, x)\n",
" end\n",
"end"
]
},
{
"cell_type": "code",
"execution_count": 99,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"forwardTransform (generic function with 2 methods)"
]
},
"execution_count": 99,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"function forwardTransform(M, P, outSize=nothing)\n",
" rows, cols = size(P)\n",
" if outSize == nothing\n",
" outSize = size(P)\n",
" end\n",
" out = zeros(eltype(P), outSize)\n",
" for index in CartesianIndices(P)\n",
" y, x = Tuple(index)\n",
" newindex = M * [x; y; 1]\n",
" newindex ./= newindex[end]\n",
" x1 = roundAround(newindex[1], 1, cols)\n",
" y1 = roundAround(newindex[2], 1, rows)\n",
" out[y1, x1] = P[index]\n",
" end\n",
" out\n",
"end"
]
},
{
"cell_type": "code",
"execution_count": 92,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"backwardTransform (generic function with 2 methods)"
]
},
"execution_count": 92,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"function backwardTransform(algo, M, P, outSize=nothing)\n",
" M = inv(M)\n",
" rows, cols = size(P)\n",
" if outSize == nothing\n",
" outSize = size(P)\n",
" end\n",
" out = zeros(eltype(P), outSize)\n",
"\n",
" for index in CartesianIndices(out)\n",
" y, x = Tuple(index)\n",
" sourceIndex = M * [x; y; 1]\n",
" sourceIndex ./= sourceIndex[end]\n",
" x1, y1 = round.(Int32, sourceIndex)\n",
" if (x1 < 1 || y1 < 1 || x1 > cols || y1 > rows)\n",
" continue\n",
" end\n",
" out[index] = P[y1, x1]\n",
" end\n",
" out\n",
"end"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"genMatrix (generic function with 1 method)"
]
},
"execution_count": 6,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"function genMatrix(what, params...)\n",
" M = zeros(Float32, (3,3))\n",
" M[3, 3] = 1\n",
"\n",
" if what == \"scale\"\n",
" if length(params) < 2\n",
" error(\"Scale requires two parameter (x, y)\")\n",
" end\n",
" x, y = params\n",
" printfmt(\"Scale with x = {}; y = {}\\n\", x, y)\n",
" M[1, 1] = x\n",
" M[2, 2] = y\n",
" elseif what == \"translate\"\n",
" if length(params) < 2\n",
" error(\"Translate requires two parameter (dx, dy)\")\n",
" end\n",
" dx, dy = params\n",
" M[1, 1] = 1\n",
" M[2, 2] = 1\n",
" M[1, 3] = dx\n",
" M[2, 3] = dy\n",
" elseif what == \"rotate\"\n",
" if length(params) < 2\n",
" error(\"Rotate requires one parameter (theta, isRadian)\")\n",
" end\n",
" theta = params[1]\n",
" isRadian = 1\n",
" if length(params) >= 2\n",
" isRadian = params[2]\n",
" end\n",
"\n",
" if isRadian == 1\n",
" M[1, 1] = cos(theta)\n",
" M[1, 2] = -sin(theta)\n",
" M[2, 1] = sin(theta)\n",
" M[2, 2] = cos(theta)\n",
" else\n",
" M[1, 1] = cosd(theta)\n",
" M[1, 2] = -sind(theta)\n",
" M[2, 1] = sind(theta)\n",
" M[2, 2] = cosd(theta)\n",
" end\n",
" elseif what == \"shear\"\n",
" if length(params) < 4\n",
" error(\"Rotate requires four parameter (a, b, c, d)\")\n",
" end\n",
" a,b,c,d = params\n",
" M[1, 1] = a\n",
" M[1, 2] = b\n",
" M[2, 1] = c\n",
" M[2, 2] = d\n",
" else\n",
" error(printfmt(\"Matrix of {} is unknown\\n\", what))\n",
" end\n",
" M\n",
"end"
]
},
{
"cell_type": "code",
"execution_count": 100,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"3×3 Array{Float32,2}:\n",
" 0.707107 -0.707107 500.0 \n",
" 0.707107 0.707107 -207.107\n",
" 0.0 0.0 1.0 "
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"image/png": "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
"text/plain": [
"720×1280 Array{RGB{N0f8},2} with eltype RGB{Normed{UInt8,8}}:\n",
" RGB{N0f8}(0.027,0.125,0.212) … RGB{N0f8}(0.02,0.114,0.224) \n",
" RGB{N0f8}(0.024,0.129,0.212) RGB{N0f8}(0.02,0.114,0.224) \n",
" RGB{N0f8}(0.024,0.129,0.212) RGB{N0f8}(0.02,0.114,0.224) \n",
" RGB{N0f8}(0.024,0.125,0.216) RGB{N0f8}(0.02,0.114,0.224) \n",
" RGB{N0f8}(0.024,0.125,0.216) RGB{N0f8}(0.02,0.114,0.224) \n",
" RGB{N0f8}(0.027,0.129,0.22) … RGB{N0f8}(0.02,0.114,0.224) \n",
" RGB{N0f8}(0.027,0.129,0.22) RGB{N0f8}(0.02,0.114,0.224) \n",
" RGB{N0f8}(0.027,0.129,0.22) RGB{N0f8}(0.02,0.114,0.224) \n",
" RGB{N0f8}(0.024,0.129,0.212) RGB{N0f8}(0.031,0.114,0.235)\n",
" RGB{N0f8}(0.024,0.129,0.212) RGB{N0f8}(0.031,0.114,0.235)\n",
" RGB{N0f8}(0.024,0.129,0.212) … RGB{N0f8}(0.024,0.114,0.235)\n",
" RGB{N0f8}(0.024,0.129,0.212) RGB{N0f8}(0.024,0.114,0.235)\n",
" RGB{N0f8}(0.024,0.125,0.216) RGB{N0f8}(0.02,0.122,0.227) \n",
" ⋮ ⋱ \n",
" RGB{N0f8}(0.067,0.063,0.086) RGB{N0f8}(0.016,0.125,0.18) \n",
" RGB{N0f8}(0.075,0.063,0.098) RGB{N0f8}(0.016,0.129,0.192)\n",
" RGB{N0f8}(0.071,0.067,0.098) … RGB{N0f8}(0.02,0.133,0.196) \n",
" RGB{N0f8}(0.059,0.071,0.098) RGB{N0f8}(0.02,0.133,0.196) \n",
" RGB{N0f8}(0.043,0.063,0.075) RGB{N0f8}(0.02,0.133,0.196) \n",
" RGB{N0f8}(0.059,0.051,0.106) RGB{N0f8}(0.016,0.129,0.192)\n",
" RGB{N0f8}(0.063,0.055,0.098) RGB{N0f8}(0.02,0.125,0.192) \n",
" RGB{N0f8}(0.047,0.067,0.082) … RGB{N0f8}(0.016,0.125,0.18) \n",
" RGB{N0f8}(0.043,0.059,0.094) RGB{N0f8}(0.016,0.125,0.18) \n",
" RGB{N0f8}(0.071,0.075,0.094) RGB{N0f8}(0.016,0.125,0.18) \n",
" RGB{N0f8}(0.059,0.063,0.078) RGB{N0f8}(0.016,0.122,0.188)\n",
" RGB{N0f8}(0.067,0.063,0.125) RGB{N0f8}(0.016,0.122,0.188)"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"image/png": "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
"text/plain": [
"720×1280 Array{RGB{N0f8},2} with eltype RGB{Normed{UInt8,8}}:\n",
" RGB{N0f8}(0.0,0.0,0.0) … RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) … RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) … RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" ⋮ ⋱ \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.02,0.125,0.231) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.02,0.125,0.231) \n",
" RGB{N0f8}(0.0,0.0,0.0) … RGB{N0f8}(0.02,0.125,0.231) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.02,0.125,0.231) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.02,0.125,0.231) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.02,0.125,0.239) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.02,0.125,0.239) \n",
" RGB{N0f8}(0.0,0.0,0.0) … RGB{N0f8}(0.024,0.129,0.235)\n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.024,0.129,0.235)\n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.024,0.129,0.235)\n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.024,0.129,0.235)\n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.031,0.137,0.243)"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"image/png": "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
"text/plain": [
"720×1280 Array{RGB{N0f8},2} with eltype RGB{Normed{UInt8,8}}:\n",
" RGB{N0f8}(0.0,0.0,0.0) … RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) … RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) … RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.0,0.0,0.0) \n",
" ⋮ ⋱ \n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.027,0.176,0.329)\n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.031,0.169,0.325)\n",
" RGB{N0f8}(0.0,0.0,0.0) … RGB{N0f8}(0.031,0.169,0.325)\n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.031,0.169,0.325)\n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.031,0.169,0.325)\n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.031,0.169,0.325)\n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.031,0.169,0.325)\n",
" RGB{N0f8}(0.0,0.0,0.0) … RGB{N0f8}(0.031,0.169,0.325)\n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.031,0.169,0.318)\n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.031,0.169,0.318)\n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.031,0.169,0.318)\n",
" RGB{N0f8}(0.0,0.0,0.0) RGB{N0f8}(0.031,0.169,0.318)"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"img = load(\"../images/f124074.jpg\")\n",
"Matrixes = [\n",
" # do last\n",
" genMatrix(\"translate\", 500, 500),\n",
" genMatrix(\"rotate\", 45, false),\n",
" genMatrix(\"translate\", -500, -500) \n",
" # do first\n",
"]\n",
"\n",
"M = *(Matrixes...)\n",
"display(M)\n",
"\n",
"display(img)\n",
"\n",
"forward = forwardTransform(M, img)\n",
"display(forward)\n",
"\n",
"backward = backwardTransform(\"zero\", M, img)\n",
"display(backward)"
]
},
{
"cell_type": "code",
"execution_count": 102,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"projectiveTransform (generic function with 1 method)"
]
},
"execution_count": 102,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"function createProjectiveMatrix(points)\n",
" if length(points) != 4\n",
" error(\"Not correct number of point\")\n",
" end\n",
"\n",
" A = zeros(Int64, 2*length(points), 8)\n",
" B = zeros(Int64, 2*length(points), 1)\n",
" for i in 1:length(points)\n",
" x, y, x1, y1 = points[i]\n",
" A[2*i - 1,:] = [x y 1 0 0 0 -x*x1 -x1*y]\n",
" A[2*i,:] = [0 0 0 x y 1 -x*y1 -y*y1]\n",
" B[2*i - 1] = x1\n",
" B[2*i] = y1\n",
" end\n",
"\n",
" H = vcat(A\\B, 1)\n",
" M = reshape(H, (3,3))'\n",
" \n",
" # display(M)\n",
" M\n",
"end\n",
"\n",
"function projectiveTransform(picture, points, outSize)\n",
" M = createProjectiveMatrix(points)\n",
" backwardTransform(\"zero\", M, picture, outSize)\n",
"end"
]
},
{
"cell_type": "code",
"execution_count": 104,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"8×8 Array{Int64,2}:\n",
" 55 187 1 0 0 0 -55 -187\n",
" 0 0 0 55 187 1 -55 -187\n",
" 1276 619 1 0 0 0 -1919104 -930976\n",
" 0 0 0 1276 619 1 -1276 -619\n",
" 1447 1761 1 0 0 0 -2176288 -2648544\n",
" 0 0 0 1447 1761 1 -2917152 -3550176\n",
" 166 1819 1 0 0 0 -166 -1819\n",
" 0 0 0 166 1819 1 -334656 -3667104"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"text/plain": [
"8×1 Array{Int64,2}:\n",
" 1\n",
" 1\n",
" 1504\n",
" 1\n",
" 1504\n",
" 2016\n",
" 1\n",
" 2016"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"text/plain": [
"3×3 LinearAlgebra.Adjoint{Float64,Array{Float64,2}}:\n",
" 0.886982 -0.060257 -36.5144\n",
" -0.500302 1.41336 -235.78 \n",
" -0.000275854 8.95484e-5 1.0 "
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"image/png": "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
"text/plain": [
"2016×1504 Array{RGB{N0f8},2} with eltype RGB{Normed{UInt8,8}}:\n",
" RGB{N0f8}(0.267,0.22,0.125) … RGB{N0f8}(0.341,0.278,0.22) \n",
" RGB{N0f8}(0.267,0.22,0.125) RGB{N0f8}(0.337,0.275,0.216)\n",
" RGB{N0f8}(0.267,0.22,0.125) RGB{N0f8}(0.337,0.275,0.216)\n",
" RGB{N0f8}(0.267,0.22,0.125) RGB{N0f8}(0.329,0.267,0.208)\n",
" RGB{N0f8}(0.267,0.22,0.125) RGB{N0f8}(0.325,0.263,0.204)\n",
" RGB{N0f8}(0.267,0.22,0.125) … RGB{N0f8}(0.322,0.259,0.2) \n",
" RGB{N0f8}(0.267,0.22,0.125) RGB{N0f8}(0.318,0.255,0.196)\n",
" RGB{N0f8}(0.267,0.22,0.125) RGB{N0f8}(0.314,0.251,0.192)\n",
" RGB{N0f8}(0.263,0.216,0.122) RGB{N0f8}(0.325,0.263,0.204)\n",
" RGB{N0f8}(0.263,0.216,0.122) RGB{N0f8}(0.325,0.263,0.204)\n",
" RGB{N0f8}(0.259,0.212,0.118) … RGB{N0f8}(0.325,0.263,0.204)\n",
" RGB{N0f8}(0.259,0.212,0.118) RGB{N0f8}(0.325,0.263,0.204)\n",
" RGB{N0f8}(0.259,0.212,0.118) RGB{N0f8}(0.325,0.263,0.204)\n",
" ⋮ ⋱ \n",
" RGB{N0f8}(0.024,0.031,0.02) RGB{N0f8}(0.0,0.004,0.012) \n",
" RGB{N0f8}(0.024,0.031,0.02) … RGB{N0f8}(0.0,0.004,0.012) \n",
" RGB{N0f8}(0.024,0.031,0.02) RGB{N0f8}(0.0,0.004,0.012) \n",
" RGB{N0f8}(0.024,0.031,0.02) RGB{N0f8}(0.0,0.004,0.012) \n",
" RGB{N0f8}(0.024,0.031,0.02) RGB{N0f8}(0.0,0.004,0.012) \n",
" RGB{N0f8}(0.024,0.031,0.02) RGB{N0f8}(0.0,0.004,0.012) \n",
" RGB{N0f8}(0.024,0.031,0.02) … RGB{N0f8}(0.0,0.004,0.012) \n",
" RGB{N0f8}(0.024,0.031,0.02) RGB{N0f8}(0.0,0.004,0.012) \n",
" RGB{N0f8}(0.024,0.031,0.02) RGB{N0f8}(0.0,0.004,0.012) \n",
" RGB{N0f8}(0.024,0.031,0.02) RGB{N0f8}(0.0,0.004,0.012) \n",
" RGB{N0f8}(0.024,0.031,0.02) RGB{N0f8}(0.0,0.004,0.012) \n",
" RGB{N0f8}(0.024,0.031,0.02) … RGB{N0f8}(0.0,0.004,0.012) "
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"image/png": "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
"text/plain": [
"2016×1504 Array{RGB{N0f8},2} with eltype RGB{Normed{UInt8,8}}:\n",
" RGB{N0f8}(0.467,0.467,0.427) … RGB{N0f8}(0.02,0.016,0.0) \n",
" RGB{N0f8}(0.416,0.416,0.376) RGB{N0f8}(0.016,0.016,0.0) \n",
" RGB{N0f8}(0.416,0.416,0.376) RGB{N0f8}(0.016,0.016,0.0) \n",
" RGB{N0f8}(0.384,0.384,0.345) RGB{N0f8}(0.039,0.039,0.008)\n",
" RGB{N0f8}(0.38,0.38,0.341) RGB{N0f8}(0.039,0.039,0.008)\n",
" RGB{N0f8}(0.376,0.376,0.337) … RGB{N0f8}(0.11,0.11,0.078) \n",
" RGB{N0f8}(0.376,0.376,0.337) RGB{N0f8}(0.11,0.11,0.078) \n",
" RGB{N0f8}(0.388,0.388,0.349) RGB{N0f8}(0.09,0.09,0.059) \n",
" RGB{N0f8}(0.388,0.38,0.333) RGB{N0f8}(0.09,0.09,0.059) \n",
" RGB{N0f8}(0.4,0.392,0.345) RGB{N0f8}(0.118,0.118,0.086)\n",
" RGB{N0f8}(0.4,0.392,0.345) … RGB{N0f8}(0.118,0.118,0.086)\n",
" RGB{N0f8}(0.443,0.435,0.388) RGB{N0f8}(0.18,0.18,0.141) \n",
" RGB{N0f8}(0.427,0.42,0.373) RGB{N0f8}(0.18,0.18,0.141) \n",
" ⋮ ⋱ \n",
" RGB{N0f8}(0.427,0.392,0.325) RGB{N0f8}(0.439,0.4,0.353) \n",
" RGB{N0f8}(0.427,0.392,0.325) … RGB{N0f8}(0.439,0.4,0.353) \n",
" RGB{N0f8}(0.427,0.392,0.325) RGB{N0f8}(0.439,0.4,0.353) \n",
" RGB{N0f8}(0.427,0.392,0.325) RGB{N0f8}(0.439,0.4,0.353) \n",
" RGB{N0f8}(0.427,0.392,0.325) RGB{N0f8}(0.439,0.4,0.353) \n",
" RGB{N0f8}(0.427,0.392,0.325) RGB{N0f8}(0.439,0.4,0.353) \n",
" RGB{N0f8}(0.427,0.392,0.325) … RGB{N0f8}(0.443,0.404,0.365)\n",
" RGB{N0f8}(0.427,0.392,0.325) RGB{N0f8}(0.443,0.404,0.365)\n",
" RGB{N0f8}(0.427,0.392,0.325) RGB{N0f8}(0.443,0.404,0.365)\n",
" RGB{N0f8}(0.42,0.384,0.318) RGB{N0f8}(0.443,0.404,0.365)\n",
" RGB{N0f8}(0.42,0.384,0.318) RGB{N0f8}(0.443,0.404,0.365)\n",
" RGB{N0f8}(0.42,0.384,0.318) … RGB{N0f8}(0.443,0.4,0.329) "
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"img = load(\"../images/aaa.jpg\")\n",
"row, col = size(img)\n",
"points = [\n",
" # [x y x1 y1],\n",
" [55 187 1 1],\n",
" [1276 619 col 1],\n",
" [1447 1761 col row],\n",
" [166 1819 1 row]\n",
"]\n",
"\n",
"# out = projectiveTransform(img,points)\n",
"\n",
"M = createProjectiveMatrix()\n",
"out = backwardTransform(\"zero\", M, picture)\n",
"\n",
"display(img)\n",
"display(out)"
]
}
],
"metadata": {
"kernelspec": {
"display_name": "Julia 1.2.0-DEV",
"language": "julia",
"name": "julia-1.2"
},
"language_info": {
"file_extension": ".jl",
"mimetype": "application/julia",
"name": "julia",
"version": "1.2.0"
}
},
"nbformat": 4,
"nbformat_minor": 2
}