diff --git a/20150422/48156511_README.md b/20150422/48156511_README.md
new file mode 100644
index 0000000..31d4c19
--- /dev/null
+++ b/20150422/48156511_README.md
@@ -0,0 +1,9 @@
+# homework20150422_48156511
+
+ - Open new terminal and execute command below:
+ ```bash
+roslaunch homework20150422 48156511_face_detect.launch
+```
+
+ - You can see 2 image_view (one shows raw image view, and another shows the edge of raw image.)
+ - You can regulate edge image by changing thresh1 and thresh2 in the py file.
diff --git a/20150422/README.md b/20150422/README.md
index 30f3a37..31d4c19 100644
--- a/20150422/README.md
+++ b/20150422/README.md
@@ -1,138 +1,9 @@
-# homework20150422
+# homework20150422_48156511
-1. execute `talker/listener` sample
-
- **Goal:** Comprehend node, topic, publish/subscriber and command line tools for ROS
-
- - Open new terminal and execute command below:
- ```bash
-# Terminal 1
-roscore
-```
- - Open new terminal and execute command below
- ```bash
- # Terminal 2
-rosrun homework20150422 talker.l
-```
- - Open new terminal and execute command below:
- ```bash
- # Terminal 3
-rosrun homework20150422 listener.l
-```
-
- - Open new terminal and execute commands below:
- ```bash
- # Terminal 4
-rostopic list # you can find all topics advertised
-rostopic info /chatter # you can see detail information of /chatter topic
-rostopic echo /chatter # you can also see the message published as /chatter topic
-```
-
-2. execute `turtlesim` sample
-
- **Goal:** Comprehend ros distributed system with multiple launguages, and its launching system called `roslaunch`
-
- - Open new terminal and execute commands below:
- ```bash
- # Terminal 1
-roslaunch homework20150422 turtlesim.launch
+ - Open new terminal and execute command below:
+ ```bash
+roslaunch homework20150422 48156511_face_detect.launch
```
- - Focus the terminal and push `up` `down` `right` `left` keys.
-
- - See what nodes are launching by `rosnode list`:
- ```bash
- # Terminal 2
-rosnode list # you can see what nodes are on ROS
-```
-
- - Now let's take a look at `turtlesim.launch`
- ```xml
-
-
-
-
-
-
-```
-
- - You can see 2 `` tags in launch file. This means these 2 nodes are launched.:
- ```xml
-
-```
- - `name` attribute: name of the node
-
- **NOTE** (each node name is already named in each nodes, but once you set name different from that written at original node, it will be overwriten (we call it `remapped`))
- - `pkg` attribute: package of the node
- - `type` attribute: program name of the node (we can use each independent node by `rosrun `)
-
- - Now let's look at next node example:
- ```xml
-
-
-
-```
- - `args` attribute (optional): arguments passed when launching node
- - `output` attribute (optional): when this has value `screen`, we can see output log of this node. (This is important when launching nodes on another machine, and need to transmit log output to your terminal)
- - ``: remapping topic name
- Detail: `turtlesim-teleop.l` has publisher of `cmd_vel`, so if you launch this node with `rosrun`, this node publishes `/cmd_vel` topic. But, if remapped `cmd_vel` to `/turtle1/cmd_vel` as described above, this node changes the topic name from `/cmd_vel` to `/turtle1/cmd_vel`.
- You can change subscribe/publish topic of the node without changing any code.
-
-
-3. execute `face_detector` sample:
-
- **GOAL** Comprehend nested `launch`, topic remapping
-
- - Open new terminal and execute command below:
- ```bash
-roslaunch homework20150422 camera.launch
-```
-
- - You can see the image captured from the camera of your PC
-
- - Press `Ctrl-C` to stop this launch
-
- - Open new terminal and execute command below:
- ```bash
-roslaunch homework20150422 face_detect.launch
-```
-
- - You can see 2 image_view (one shows raw image view, and another shows the image drawn rectangle over the detected face using OpenCV)
-
- ```xml
-
- ...
-
- ...
-```
-
- - You can use arguments in launch file
- - You can also set arguments when launches launch file
- e.g.: `roslaunch homework20150422 face_detect.launch show_debug_image:=false`
-
- ```xml
-
-```
- - You can include another `launch` files.
-
-4. Make your own image processing node
-
- - previous `face_detector` example has node doing 3 things:
- - Subscribe `sensor_msgs/Image` message
- - Processs image subscribed (detecting face, and draw rectangle on each image)
- - Publish processed image
- - Let's make your own node to process image, and visualize processed image
- - Please send pull request below:
- - your source codes of image processing that:
- - Subscribe `sensor_msgs/Image` message
- - Processs image subscribed (any processing is ok)
- - Publish processed image
- - make `launch` file to show following:
- - original camera image
- - processed image
- - add `README` which describes your node
+ - You can see 2 image_view (one shows raw image view, and another shows the edge of raw image.)
+ - You can regulate edge image by changing thresh1 and thresh2 in the py file.
diff --git a/20150422/image/edge_detect.png b/20150422/image/edge_detect.png
new file mode 100644
index 0000000..c12c6d5
Binary files /dev/null and b/20150422/image/edge_detect.png differ
diff --git a/20150422/launch/48156511_face_detect.launch b/20150422/launch/48156511_face_detect.launch
new file mode 100644
index 0000000..c57fc39
--- /dev/null
+++ b/20150422/launch/48156511_face_detect.launch
@@ -0,0 +1,16 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/20150422/scripts/48156511_face_detect_mono.py b/20150422/scripts/48156511_face_detect_mono.py
new file mode 100755
index 0000000..540c3b7
--- /dev/null
+++ b/20150422/scripts/48156511_face_detect_mono.py
@@ -0,0 +1,115 @@
+#!/usr/bin/env python
+# -*- coding: utf-8 -*-
+# Author: Yuki Furuta
+
+# 1. import rospy to enable ROS feature of python
+import rospy
+
+# 2. import message files for python
+# cf. you can find what contains in a message by executing `rosmsg show `
+# e.g. rosmsg show sensor_msgs/Image
+from sensor_msgs.msg import Image # This imports sensor_msgs/Image
+from geometry_msgs.msg import Twist # This imports geometry_msgs/Twist
+
+# Tips: This is special utility for converting between ROS Image message and OpenCV Image format.
+from cv_bridge import CvBridge
+
+import cv2 # this imports opencv python interface
+
+# Since indigo, opencv is not released from ROS infrastructure.
+cascade_path = "/usr/share/opencv/haarcascades/haarcascade_frontalface_alt2.xml"
+
+class FaceDetectorMonoNode(object):
+ """
+This class has feature to subscribe "image" and detect people face,
+then publishes those positions as geometry_msgs/Twist message.
+"""
+
+ def __init__(self):
+ # make instance of object for image processing
+ try:
+ self.bridge = CvBridge()
+ self.cascade = cv2.CascadeClassifier(cascade_path)
+ except Exception as e:
+ rospy.logerr("Error: %s" % e)
+
+ # 4. subscribe "image" topic whose message type is sensor_msgs/Image
+ self.image_subscriber = rospy.Subscriber("image", Image, self.image_callback)
+
+ # declare publishers
+ self.face_pose_publisher = rospy.Publisher("twist", Twist)
+ self.debug_image_publisher = rospy.Publisher("debug_image", Image)
+
+
+
+ # 5. define callback function for image topic
+ def image_callback(self, msg):
+ img_size = (msg.width, msg.height)
+
+ # 6. convert ROS sensor_msgs/Image to OpenCV format
+ img_mat = self.bridge.imgmsg_to_cv2(msg)
+
+ # 7. convert image to grey image
+ img_grey = cv2.cvtColor(img_mat, cv2.cv.CV_BGR2GRAY)
+
+ # 8. detect edge(Canny)
+ #you can regulate edge image by changing thresh1,2 ( 0-255 )
+ thresh1 = 50
+ thresh2 = 100
+ edge = cv2.Canny(img_grey,thresh1,thresh2)
+
+ # 9. publish debug image
+ pub_debug_img_msg = self.bridge.cv2_to_imgmsg(edge, encoding="mono8")
+ self.debug_image_publisher.publish(pub_debug_img_msg)
+
+
+ # # 7. detect face in an image
+ # face_rects = self.cascade.detectMultiScale(img_grey,
+ # scaleFactor=1.1,
+ # minNeighbors=1,
+ # minSize=(1,1))
+
+ # rospy.loginfo("%s" % msg)
+
+ # if len(face_rects) > 0:
+ # rect = face_rects[0] # use first rect
+ # face_rect_origin = (rect[0], rect[1]) # (x,y)
+ # face_rect_size = (rect[2] - rect[0], rect[3] - rect[1]) # (width, height)
+ # face_rect_center = (face_rect_origin[0] + face_rect_size[0] * 0.5,
+ # face_rect_origin[1] + face_rect_size[1] * 0.5)
+
+ # # 8. logging face position
+ # rospy.loginfo("face detected at (x, y) = (%d, %d)" % face_rect_center)
+
+ # # 9. compute center of face relative to center of camera image
+ # # Note that face_relative_center has value (-img_size/2 ~ +img_size/2)
+ # img_center = (img_size[0] * 0.5, img_size[1] * 0.5)
+ # face_relative_center = (face_rect_center[0] - img_center[0],
+ # face_rect_center[1] - img_center[1])
+
+ # # 10. make Twist message and set values
+ # pub_msg = Twist()
+ # pub_msg.linear.x = face_relative_center[1] / img_center[1]
+ # pub_msg.angular.z = face_relative_center[0] / img_center[0]
+
+ # # 12. publish debug image
+ # color = (0, 0, 255)
+ # cv2.circle(img_mat, face_rect_origin,
+ # 100,
+ # color, thickness=2)
+ # pub_debug_img_msg = self.bridge.cv2_to_imgmsg(img_mat, encoding="bgr8")
+ # self.debug_image_publisher.publish(pub_debug_img_msg)
+
+ # # 11. publish message
+ # self.face_pose_publisher.publish(pub_msg)
+ # else:
+ # rospy.loginfo("no face detected.")
+
+if __name__ == '__main__':
+ # 3. At first, we must set node name, and register to the master.
+ # In this case, node name is face_detector_mono
+ rospy.init_node("face_detector_mono")
+ face_detector = FaceDetectorMonoNode()
+
+ # wait for message comming
+ rospy.spin()
diff --git a/20150624/gazebo-48156511.png b/20150624/gazebo-48156511.png
new file mode 100644
index 0000000..09d0ead
Binary files /dev/null and b/20150624/gazebo-48156511.png differ
diff --git a/20150624/rviz-48156511.png b/20150624/rviz-48156511.png
new file mode 100644
index 0000000..b5c1f25
Binary files /dev/null and b/20150624/rviz-48156511.png differ