質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.63%

sudo実行で、なぜかビデオwindowsを生成できない、できるようにしたい

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 144

ono3

score 0

from __future__ import division
import time

import os,sys
#sys.path.append(os.getcwd())


#from Adafruit_Python_PCA9685.Adafruit_PCA9685 import Adafruit_PCA9685
#from Adafruit_Python_PCA9685 import Adafruit_PCA9685
import Adafruit_PCA9685

pwm = Adafruit_PCA9685.PCA9685()
pwm.set_pwm_freq(50)

import cv2 
print(cv2) 

import sys
import cv2.cv as cv
#import cv2 

#import cv2 as cv

from optparse import OptionParser


def move(degree_1,degree_2):
    degree_1 = int(degree_1 * 5.27)
    degree_2 = int(degree_2 * 5.27)
    pwm.set_pwm(0, 0, degree_1)
    pwm.set_pwm(1, 0, degree_2)

# Parameters for haar detection
# From the API:
# The default parameters (scale_factor=2, min_neighbors=3, flags=0) are tuned 
# for accurate yet slow object detection. For a faster operation on real video 
# images the settings are: 
# scale_factor=1.2, min_neighbors=2, flags=CV_HAAR_DO_CANNY_PRUNING, 
# min_size=<minimum possible face size

min_size = (20, 20)
image_scale = 2
haar_scale = 1.2
min_neighbors = 2
haar_flags = 0

def detect_and_draw(img, cascade):
    # allocate temporary images
    gray = cv.CreateImage((img.width,img.height), 8, 1)
    small_img = cv.CreateImage((cv.Round(img.width / image_scale),
                   cv.Round (img.height / image_scale)), 8, 1)

    # convert color input image to grayscale
    cv.CvtColor(img, gray, cv.CV_BGR2GRAY)

    # scale input image for faster processing
    cv.Resize(gray, small_img, cv.CV_INTER_LINEAR)

    cv.EqualizeHist(small_img, small_img)

    if(cascade):
        t = cv.GetTickCount()
        faces = cv.HaarDetectObjects(small_img, cascade, cv.CreateMemStorage(0),
                                     haar_scale, min_neighbors, haar_flags, min_size)
        t = cv.GetTickCount() - t
        print "detection time = %gms" % (t/(cv.GetTickFrequency()*1000.))
        if faces:
            for ((x, y, w, h), n) in faces:
                # the input to cv.HaarDetectObjects was resized, so scale the 
                # bounding box of each face and convert it to two CvPoints
                pt1 = (int(x * image_scale), int(y * image_scale))
                pt2 = (int((x + w) * image_scale), int((y + h) * image_scale))
                cv.Rectangle(img, pt1, pt2, cv.RGB(255, 0, 0), 3, 8, 0)

    cv.ShowImage("result", img)

if __name__ == '__main__':

    print('move')
    move(60,60)
    time.sleep(1)
    move(65,60)
    time.sleep(1)
    move(65,65)
    time.sleep(1)
    move(60,65)
    time.sleep(1) 
    move(60,55)
    time.sleep(1)   
    print('stop')
    print('koko')


    parser = OptionParser(usage = "usage: %prog [options] [filename|camera_index]")
    parser.add_option("-c", "--cascade", action="store", dest="cascade", type="str", help="Haar cascade file, default %default", default = "../data/haarcascades/haarcascade_frontalface_alt.xml")
    (options, args) = parser.parse_args()

    cascade = cv.Load(options.cascade)

    if len(args) != 1:
        parser.print_help()
        sys.exit(1)

    print('koko1')

    input_name = args[0]
    if input_name.isdigit():
        capture = cv.CreateCameraCapture(int(input_name))
        print('koko222')
    else:
        capture = None
        print('koko2')

    print('abspath:     ', os.path.abspath(__file__))
    print('abs dirname: ', os.path.dirname(os.path.abspath(__file__)))
    print('koko3')

    cv.NamedWindow("result",0)
    #cv.NamedWindow("aresult")

    print('koko4')


    width = 320 #leave None for auto-detection
    height = 240 #leave None for auto-detection

    if width is None:
        width = int(cv.GetCaptureProperty(capture, cv.CV_CAP_PROP_FRAME_WIDTH))
    else:
        cv.SetCaptureProperty(capture,cv.CV_CAP_PROP_FRAME_WIDTH,width)    

    if height is None:
    height = int(cv.GetCaptureProperty(capture, cv.CV_CAP_PROP_FRAME_HEIGHT))
    else:
    cv.SetCaptureProperty(capture,cv.CV_CAP_PROP_FRAME_HEIGHT,height) 

    if capture:
        frame_copy = None
        while True:

            frame = cv.QueryFrame(capture)
            if not frame:
                cv.WaitKey(0)
                break
            if not frame_copy:
                frame_copy = cv.CreateImage((frame.width,frame.height),
                                            cv.IPL_DEPTH_8U, frame.nChannels)

#                frame_copy = cv.CreateImage((frame.width,frame.height),
#                                            cv.IPL_DEPTH_8U, frame.nChannels)

            if frame.origin == cv.IPL_ORIGIN_TL:
                cv.Copy(frame, frame_copy)
            else:
                cv.Flip(frame, frame_copy, 0)

            detect_and_draw(frame_copy, cascade)

            kuri=1            
            print('move')
            move(60+kuri,60+kuri)
            time.sleep(1)
            kuri=-5
            move(60+kuri,60+kuri)
            time.sleep(1)

            if cv.WaitKey(10) >= 0:
                break
    else:
        image = cv.LoadImage(input_name, 1)
        detect_and_draw(image, cascade)
        cv.WaitKey(0)

    cv.DestroyWindow("result")

 前提・実現したいこと

Raspbery-Piで、顔画像を追いかけるように、カメラを動かそうとしています。sudo実行では、カメラをサーボモータで動かせるが、ビデオが作成されません。sudo無しで実行すると、サーボ駆動ができなくなります。

発生している問題・エラーメッセージ

sudo実行で、
SUDO python m-facedtect.py --cascae=face.xml 0 だと、下記のエラーです。

Client is not authorized to connect to Server
(result:3174): Gtk-WARNING **: cannot open display: :0.0

調べると、import cv2cv as cv としていて、コードが、
cv.NamedWindow("result",0)
のところです。

sudoなしの実行で、python m-facedtect.py --cascae=face.xml 0 だと、下記のエラーです。

Traceback (most recent call last):
File "m-facedetect.py", line 12, in <module>
pwm = Adafruit_PCA9685.PCA9685()
File "/usr/local/lib/python2.7/dist-packages/Adafruit_PCA9685-1.0.1-py2.7.egg/Adafruit_PCA9685/PCA9685.py", line 75, in init
self._device = i2c.get_i2c_device(address, kwargs) File "/usr/local/lib/python2.7/dist-packages/Adafruit_GPIO-1.0.3-py2.7.egg/Adafruit_GPIO/I2C.py", line 65, in get_i2c_device return Device(address, busnum, i2c_interface, kwargs)
File "/usr/local/lib/python2.7/dist-packages/Adafruit_GPIO-1.0.3-py2.7.egg/Adafruit_GPIO/I2C.py", line 98, in init
self._bus = Adafruit_PureIO.smbus.SMBus(busnum)
File "/usr/local/lib/python2.7/dist-packages/Adafruit_PureIO-0.2.1-py2.7.egg/Adafruit_PureIO/smbus.py", line 97, in init
self.open(bus)
File "/usr/local/lib/python2.7/dist-packages/Adafruit_PureIO-0.2.1-py2.7.egg/Adafruit_PureIO/smbus.py", line 122, in open
self._device = open('/dev/i2c-{0}'.format(bus), 'r+b', buffering=0)
IOError: [Errno 13] Permission denied: '/dev/i2c-1'

該当のソースコード 

試したこと

sudo に、cv2.cv の利用権限を、与えなおそうとした。
sudo -R root /usr/lib/pymodules/python2.7/cv2.so
しかし、/usr/lib/pymodules/python2.7/cv2.so がないというメッセージがでた。
この場所は、
import cv2
print(cv2)で、返ってくる、場所で、実際にあります。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • y_waiwai

    2020/02/07 22:06

    これではコードが読めません
    質問を編集して、<code>ボタンを押し、出てきた’’’の枠にコードを貼り付けてください。
    また、エラーメッセージはいらぬ翻訳省略しないで、そのままコピペで提示しましょう

    キャンセル

  • ono3

    2020/02/08 10:01

    ありがとうございました。
    TightVNC でリモートアクセスしていたのが、画面ができない原因でした。
    直接、アクセスしたら、sudo実行で、サーボも画像生成もできました。
    ネットアークを介すると、Opencvでは、画像windowsが生成できないようです。とりあえず、問題は解決しました。

    キャンセル

回答 1

check解決した方法

0

TightVNC でリモートアクセスしていたのが、画面ができない原因でした。
直接、アクセスしたら、sudo実行で、サーボも画像生成もできました。
ネットアークを介すると、Opencvでは、画像windowsが生成できないようです。とりあえず、問題は解決しました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.63%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る