diff --git a/Capstone_Design.sln b/Capstone_Design.sln
index 3ae904f..7d52f13 100644
--- a/Capstone_Design.sln
+++ b/Capstone_Design.sln
@@ -61,6 +61,10 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "ch09", "ch09", "{2BBACE58-D
EndProject
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "edge_detection", "ch09\edge_detection\edge_detection.vcxproj", "{F7126457-CC07-433A-B762-C4DFB352653C}"
EndProject
+Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "edge", "Homework\edge\edge.vcxproj", "{85DBF128-C338-4C43-B575-87C1B8CD2EFA}"
+EndProject
+Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "YCbCrHist", "Homework\YCbCrHist\YCbCrHist.vcxproj", "{2DB82859-6BEC-40B4-A8CA-BFA2C60145B0}"
+EndProject
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "ch11", "ch11", "{94FE4669-77AC-4D41-8E24-F5DEDEAC930F}"
EndProject
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "thershhold", "ch11\thershhold\thershhold.vcxproj", "{12A25565-0007-412B-9490-9AA28305272D}"
@@ -245,6 +249,22 @@ Global
{F7126457-CC07-433A-B762-C4DFB352653C}.Release|x64.Build.0 = Release|x64
{F7126457-CC07-433A-B762-C4DFB352653C}.Release|x86.ActiveCfg = Release|Win32
{F7126457-CC07-433A-B762-C4DFB352653C}.Release|x86.Build.0 = Release|Win32
+ {85DBF128-C338-4C43-B575-87C1B8CD2EFA}.Debug|x64.ActiveCfg = Debug|x64
+ {85DBF128-C338-4C43-B575-87C1B8CD2EFA}.Debug|x64.Build.0 = Debug|x64
+ {85DBF128-C338-4C43-B575-87C1B8CD2EFA}.Debug|x86.ActiveCfg = Debug|Win32
+ {85DBF128-C338-4C43-B575-87C1B8CD2EFA}.Debug|x86.Build.0 = Debug|Win32
+ {85DBF128-C338-4C43-B575-87C1B8CD2EFA}.Release|x64.ActiveCfg = Release|x64
+ {85DBF128-C338-4C43-B575-87C1B8CD2EFA}.Release|x64.Build.0 = Release|x64
+ {85DBF128-C338-4C43-B575-87C1B8CD2EFA}.Release|x86.ActiveCfg = Release|Win32
+ {85DBF128-C338-4C43-B575-87C1B8CD2EFA}.Release|x86.Build.0 = Release|Win32
+ {2DB82859-6BEC-40B4-A8CA-BFA2C60145B0}.Debug|x64.ActiveCfg = Debug|x64
+ {2DB82859-6BEC-40B4-A8CA-BFA2C60145B0}.Debug|x64.Build.0 = Debug|x64
+ {2DB82859-6BEC-40B4-A8CA-BFA2C60145B0}.Debug|x86.ActiveCfg = Debug|Win32
+ {2DB82859-6BEC-40B4-A8CA-BFA2C60145B0}.Debug|x86.Build.0 = Debug|Win32
+ {2DB82859-6BEC-40B4-A8CA-BFA2C60145B0}.Release|x64.ActiveCfg = Release|x64
+ {2DB82859-6BEC-40B4-A8CA-BFA2C60145B0}.Release|x64.Build.0 = Release|x64
+ {2DB82859-6BEC-40B4-A8CA-BFA2C60145B0}.Release|x86.ActiveCfg = Release|Win32
+ {2DB82859-6BEC-40B4-A8CA-BFA2C60145B0}.Release|x86.Build.0 = Release|Win32
{12A25565-0007-412B-9490-9AA28305272D}.Debug|x64.ActiveCfg = Debug|x64
{12A25565-0007-412B-9490-9AA28305272D}.Debug|x64.Build.0 = Debug|x64
{12A25565-0007-412B-9490-9AA28305272D}.Debug|x86.ActiveCfg = Debug|Win32
@@ -341,6 +361,8 @@ Global
{E0970C66-807B-4090-83C4-C71227BD2AFF} = {610D1B36-71E3-4C3D-B0CE-2C563B0504A6}
{F920D051-F9B5-43C2-ACF7-C5DE9B18B20C} = {E583E257-9FCE-4A4B-A554-8514F982D1BF}
{F7126457-CC07-433A-B762-C4DFB352653C} = {2BBACE58-DAC1-4D1E-85FC-3A3E9F789D9B}
+ {85DBF128-C338-4C43-B575-87C1B8CD2EFA} = {E583E257-9FCE-4A4B-A554-8514F982D1BF}
+ {2DB82859-6BEC-40B4-A8CA-BFA2C60145B0} = {E583E257-9FCE-4A4B-A554-8514F982D1BF}
{12A25565-0007-412B-9490-9AA28305272D} = {94FE4669-77AC-4D41-8E24-F5DEDEAC930F}
{8F873187-A5F8-4D02-ABE9-BF652FE53BC3} = {94FE4669-77AC-4D41-8E24-F5DEDEAC930F}
{9BD9A147-29ED-4F6C-8BFD-71F03E56332C} = {94FE4669-77AC-4D41-8E24-F5DEDEAC930F}
diff --git a/Homework/YCbCrHist/YCbCrHist.vcxproj b/Homework/YCbCrHist/YCbCrHist.vcxproj
new file mode 100644
index 0000000..e8b8ea3
--- /dev/null
+++ b/Homework/YCbCrHist/YCbCrHist.vcxproj
@@ -0,0 +1,144 @@
+
+
+
+
+ Debug
+ Win32
+
+
+ Release
+ Win32
+
+
+ Debug
+ x64
+
+
+ Release
+ x64
+
+
+
+ 17.0
+ Win32Proj
+ {2db82859-6bec-40b4-a8ca-bfa2c60145b0}
+ YCbCrHist
+ 10.0
+
+
+
+ Application
+ true
+ v143
+ Unicode
+
+
+ Application
+ false
+ v143
+ true
+ Unicode
+
+
+ Application
+ true
+ v143
+ Unicode
+
+
+ Application
+ false
+ v143
+ true
+ Unicode
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Level3
+ true
+ WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ true
+
+
+ Console
+ true
+
+
+
+
+ Level3
+ true
+ true
+ true
+ WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ true
+
+
+ Console
+ true
+ true
+ true
+
+
+
+
+ Level3
+ true
+ _DEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ true
+
+
+ Console
+ true
+
+
+
+
+ Level3
+ true
+ true
+ true
+ NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ true
+
+
+ Console
+ true
+ true
+ true
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/Homework/YCbCrHist/YCbCrHist.vcxproj.filters b/Homework/YCbCrHist/YCbCrHist.vcxproj.filters
new file mode 100644
index 0000000..894934a
--- /dev/null
+++ b/Homework/YCbCrHist/YCbCrHist.vcxproj.filters
@@ -0,0 +1,33 @@
+
+
+
+
+ {4FC737F1-C7A5-4376-A066-2A32D752A2FF}
+ cpp;c;cc;cxx;c++;cppm;ixx;def;odl;idl;hpj;bat;asm;asmx
+
+
+ {93995380-89BD-4b04-88EB-625FBE52EBFB}
+ h;hh;hpp;hxx;h++;hm;inl;inc;ipp;xsd
+
+
+ {67DA6AB6-F800-4c08-8B7A-83BB121AAD01}
+ rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms
+
+
+
+
+ 소스 파일
+
+
+
+
+ 리소스 파일
+
+
+ 리소스 파일
+
+
+ 리소스 파일
+
+
+
\ No newline at end of file
diff --git a/Homework/YCbCrHist/YCbCrHist.zip b/Homework/YCbCrHist/YCbCrHist.zip
new file mode 100644
index 0000000..edf3b32
Binary files /dev/null and b/Homework/YCbCrHist/YCbCrHist.zip differ
diff --git a/Homework/YCbCrHist/fallback.png b/Homework/YCbCrHist/fallback.png
new file mode 100644
index 0000000..c5af037
--- /dev/null
+++ b/Homework/YCbCrHist/fallback.png
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:ade64a87d544c41ee9688ecac95201dcd2a695d96ca8dccf2537830353215ce2
+size 4822729
diff --git a/Homework/YCbCrHist/main.cpp b/Homework/YCbCrHist/main.cpp
new file mode 100644
index 0000000..139b54d
--- /dev/null
+++ b/Homework/YCbCrHist/main.cpp
@@ -0,0 +1,86 @@
+#include "opencv2/opencv.hpp"
+#include
+using namespace cv;
+using namespace std;
+
+Mat getCbCrHist(const Mat& src, const int* channels);
+Mat getHSVHist(const Mat& src, const int* channels);
+void cvtCartesian2PolarCV_32F(const Mat& src, Mat& dst);
+
+int main(int argc, char* argv[]) {
+ Mat src;
+ if (argc > 1)
+ src = imread(argv[1], IMREAD_COLOR);
+ else
+ src = imread("fallback.png", IMREAD_COLOR);
+ if (src.empty()) {
+ cerr << "Image load failed" << endl;
+ return -1;
+ }
+
+ Mat ycrcb(src.rows, src.cols, src.type());
+ Mat hsv(src.rows, src.cols, src.type());
+ cvtColor(src, ycrcb, COLOR_BGR2YCrCb);
+ cvtColor(src, hsv, COLOR_BGR2HSV);
+
+ int channels_Cb_Cr[] = { 1, 2 };
+ Mat Cb_CrHist = getCbCrHist(ycrcb, channels_Cb_Cr);
+ int channels_HSV[] = { 1, 0 };
+ Mat HSHist = getHSVHist(hsv, channels_HSV);
+ Mat HSPolar(src.rows, src.cols, src.type());
+ cvtCartesian2PolarCV_32F(HSHist, HSPolar);
+
+ imshow("src", src);
+ Cb_CrHist.convertTo(Cb_CrHist, CV_8U);
+ imshow("Histogram in Cb-Cr cartesian coordinates", Cb_CrHist);
+ HSHist.convertTo(HSHist, CV_8U);
+ // resize(HSHist, HSHist, Size(512, 512));
+ imshow("Histogram in H-S cartesian coordinates", HSHist);
+ HSPolar.convertTo(HSPolar, CV_8U);
+ imshow("Histogram in H-S polar coordinates", HSPolar);
+
+ waitKey();
+ destroyAllWindows();
+
+ return 0;
+}
+
+Mat getCbCrHist(const Mat& src, const int *channels) {
+ Mat hist;
+ int cr_bins = 512, cb_bins = 512;
+ int histSize[] = { cr_bins, cb_bins };
+ float cr_range[] = { 0, 256 };
+ float cb_range[] = { 0, 256 };
+ const float* ranges[] = { cr_range, cb_range };
+ calcHist(&src, 1, channels, noArray(), hist, 2, histSize, ranges);
+
+ return hist;
+}
+
+Mat getHSVHist(const Mat& src, const int* channels) {
+ Mat hist;
+ int x_bins = 256, y_bins = 180;
+ int histSize[] = { x_bins, y_bins };
+ float x_range[] = { 0, 256 };
+ float y_range[] = { 0, 180 };
+ const float* ranges[] = { x_range, y_range };
+ calcHist(&src, 1, channels, noArray(), hist, 2, histSize, ranges);
+
+ return hist;
+}
+
+void cvtCartesian2PolarCV_32F(const cv::Mat& src, cv::Mat& dst) {
+ int max = std::max(src.rows, src.cols);
+ dst = cv::Mat::zeros(max * 2, max * 2, src.type());
+
+ for (int h = 0; h < src.rows; ++h) {
+ for (int s = 0; s < src.cols; ++s) {
+ float theta = (s / (float)src.cols) * 2.f * CV_PI;
+
+ int x = static_cast(max + h * std::cos(theta));
+ int y = static_cast(max + h * std::sin(theta) * -1); // opencv y Ǿ Ƿ
+
+ dst.at(y, x) = src.at(h, s);
+ }
+ }
+}
\ No newline at end of file
diff --git a/Homework/YCbCrHist/스크린샷 2025-04-27 014722.png b/Homework/YCbCrHist/스크린샷 2025-04-27 014722.png
new file mode 100644
index 0000000..5b03961
--- /dev/null
+++ b/Homework/YCbCrHist/스크린샷 2025-04-27 014722.png
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:20d75c06a244760b274b76068ce8d4f557de5e95f182e1fcbbf1800b1effe9fa
+size 3051800
diff --git a/Homework/edge/edge.vcxproj b/Homework/edge/edge.vcxproj
new file mode 100644
index 0000000..ed9a0b6
--- /dev/null
+++ b/Homework/edge/edge.vcxproj
@@ -0,0 +1,139 @@
+
+
+
+
+ Debug
+ Win32
+
+
+ Release
+ Win32
+
+
+ Debug
+ x64
+
+
+ Release
+ x64
+
+
+
+ 17.0
+ Win32Proj
+ {85dbf128-c338-4c43-b575-87c1b8cd2efa}
+ edge
+ 10.0
+
+
+
+ Application
+ true
+ v143
+ Unicode
+
+
+ Application
+ false
+ v143
+ true
+ Unicode
+
+
+ Application
+ true
+ v143
+ Unicode
+
+
+ Application
+ false
+ v143
+ true
+ Unicode
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Level3
+ true
+ WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ true
+
+
+ Console
+ true
+
+
+
+
+ Level3
+ true
+ true
+ true
+ WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ true
+
+
+ Console
+ true
+ true
+ true
+
+
+
+
+ Level3
+ true
+ _DEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ true
+
+
+ Console
+ true
+
+
+
+
+ Level3
+ true
+ true
+ true
+ NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ true
+
+
+ Console
+ true
+ true
+ true
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/Homework/edge/edge.vcxproj.filters b/Homework/edge/edge.vcxproj.filters
new file mode 100644
index 0000000..2c1b3dc
--- /dev/null
+++ b/Homework/edge/edge.vcxproj.filters
@@ -0,0 +1,22 @@
+
+
+
+
+ {4FC737F1-C7A5-4376-A066-2A32D752A2FF}
+ cpp;c;cc;cxx;c++;cppm;ixx;def;odl;idl;hpj;bat;asm;asmx
+
+
+ {93995380-89BD-4b04-88EB-625FBE52EBFB}
+ h;hh;hpp;hxx;h++;hm;inl;inc;ipp;xsd
+
+
+ {67DA6AB6-F800-4c08-8B7A-83BB121AAD01}
+ rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms
+
+
+
+
+ 소스 파일
+
+
+
\ No newline at end of file
diff --git a/Homework/edge/main.cpp b/Homework/edge/main.cpp
new file mode 100644
index 0000000..2a45e04
--- /dev/null
+++ b/Homework/edge/main.cpp
@@ -0,0 +1,41 @@
+#include
+#include "opencv2/opencv.hpp"
+
+int main() {
+ cv::VideoCapture camera(0);
+ if (!camera.isOpened()) {
+ std::cerr << "isOpened()" << std::endl;
+ return EXIT_FAILURE;
+ }
+ std::uint32_t fps = camera.get(cv::CAP_PROP_FPS);
+ cv::Mat src;
+
+ while (cv::waitKey(1000 / fps) != 27) {
+ camera >> src;
+ if (src.empty()) break;
+ cv::imshow("preview", src);
+ }
+ cv::cvtColor(src, src, cv::COLOR_BGR2GRAY);
+
+ cv::Mat dx, dy, fmag, mag, phase;
+
+ cv::Sobel(src, dx, CV_32FC1, 1, 0);
+ cv::Sobel(src, dy, CV_32FC1, 0, 1);
+
+ cv::magnitude(dx, dy, fmag);
+ fmag.convertTo(mag, CV_8UC1);
+
+ cv::phase(dx, dy, phase, true);
+ cv::normalize(phase, phase, 0, 255, cv::NORM_MINMAX);
+ phase.convertTo(phase, CV_8UC1);
+
+ cv::Mat edge = mag > 150;
+
+ cv::imshow("src", src);
+ cv::imshow("mag", mag);
+ cv::imshow("edge", edge);
+ cv::imshow("phase", phase);
+
+ cv::waitKey();
+ cv::destroyAllWindows();
+}
\ No newline at end of file
diff --git a/ch05/brightness/main.cpp b/ch05/brightness/main.cpp
index c7654e6..973ee66 100644
--- a/ch05/brightness/main.cpp
+++ b/ch05/brightness/main.cpp
@@ -99,8 +99,6 @@ int mosaic() {
return 1;
}
- const
-
Mat dst(src.rows, src.cols, src.type());
for (int j = 0; j < src.rows; j++) {