2

SuperCollider が初めてなので、チュートリアルを使用して、Pycharm アプリケーションを Supercollider (Python バージョン: 3.7/SuperCollider 3.9.3) と通信させようとしています。クライアント側では、pythonosc と OSC を試しました:

pythosc コード:

import argparse
import random
from pythonosc import osc_message_builder
from pythonosc import udp_client
import socket

if __name__ == "__main__":

    parser = argparse.ArgumentParser()
    parser.add_argument("--ip", default='127.0.0.1',
                        help="The ip of the OSC server")
    parser.add_argument("--port", type=int, default=57110,
                        help="The port the OSC server is listening on")
    args = parser.parse_args()

    client = udp_client.SimpleUDPClient(args.ip, args.port)

    client.send_message("/print", 500)

OSC コード:

import OSC
import time, random

if __name__ == "__main__":
    client = OSC.OSCClient()
    client.connect(("127.0.0.1", 57110))
    msg = OSC.OSCMessage()
    msg.setAddress("/print")
    msg.append(500)
    client.send(msg)

SuperCollider のコード:

s.boot;

(
SynthDef( \sin, { | amp = 0.01, freq = 333, trig = 1 |
    var env, sig;
    env = EnvGen.kr( Env.asr( 0.001, 0.9, 0.001 ), trig, doneAction: 0 );
    sig = LFTri.ar( [ freq, freq * 0.999 ], 0.0, amp ) * env;
    Out.ar( [ 0 ], sig * 0.6 );
}).add;

h = Synth( \sin, [ \amp, 0.4 ] );

x = OSCFunc( { | msg, time, addr, port |
    var pyFreq;

    pyFreq = msg[1].asFloat;
    ( "freq is " + pyFreq ).postln;
    h.set( \freq, pyFreq );
}, '/print' );
)

pythonosc と OSC コードの両方を使用すると、「FAILURE IN SERVER: /print Command not found」というメッセージが表示されます. 明らかに、Python アプリは SC との通信を確立していますが、「/print」を解釈できません。SC サーバーはポート 57110 で起動しますが、NetAddr.langPort は 57120 として返されることに注意してください。なぜそれらが異なるのかわかりません。私は一晩中オンラインで考えられる解決策を検討しましたが、うまくいきませんでした。他の数人の StackOverflow ユーザーが同様の問題を公開しており、ポートの問題である可能性があることを示唆しています。現在のケースでは、その条件下では、SC はまったく何もしないので、それがどのようになるかわかりません。(Python コードでポートを 57120 に変更すると、SC サーバーからの応答がなくなります)。基本的に、それが私を駆り立てているので、このボギーの以前の経験から発せられる提案は大歓迎です. 非常にゆっくり、ナッツ !!

4

1 に答える 1