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 サーバーからの応答がなくなります)。基本的に、それが私を駆り立てているので、このボギーの以前の経験から発せられる提案は大歓迎です. 非常にゆっくり、ナッツ !!