如何调试超级编译器和Python应用程序之间的OSC协议
作为Supercallider的新手,我正在使用一个教程尝试让Pycharm应用程序与Supercallider对话(Python版本:3.7/Supercallider 3.9.3)。在客户端,我尝试了pythonosc和OSC: pythosc代码:如何调试超级编译器和Python应用程序之间的OSC协议,python,osc,supercollider,Python,Osc,Supercollider,作为Supercallider的新手,我正在使用一个教程尝试让Pycharm应用程序与Supercallider对话(Python版本:3.7/Supercallider 3.9.3)。在客户端,我尝试了pythonosc和OSC: pythosc代码: import argparse import random from pythonosc import osc_message_builder from pythonosc import udp_client import socket if
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)
超级对撞机中的代码:
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代码时,我得到:“服务器中失败:/print命令未找到”。显然,python应用程序正在与SC建立通信,但无法解释“/print”。我注意到SC服务器在端口57110上启动,但NetAddr.langPort返回为57120。我不知道他们为什么不同。我花了整整一个晚上在网上回顾可能的解决方案,但运气不好。其他几个StackOverflow用户发布了类似的问题,其中一个用户认为这可能是端口问题。在目前的情况下,我不明白这是怎么回事,因为在这种情况下,SC根本不会做任何事情。(在python代码中将端口更改为57120会导致SC服务器没有响应)。从人们以前对这种妖怪的经验中得出的任何建议都是最受欢迎的,因为基本上,它驱使着我。慢慢来,笨蛋 简短回答:使用NetAddr.langPort返回的端口
超级对撞机服务器(scsynth)和语言处理(sclang)是不同的东西。如果您使用的是超级编译器IDE,您可能会感到困惑,因为这两个进程的输出都发布在那里的post窗口中,而且作为初学者也很难理解其中的区别
您非常接近答案--您注意到服务器的端口与语言的端口不同。为了使这两个进程通过基于UDP的OSC相互通信,它们需要使用单独的端口。服务器使用OSC地址来实现命令协议,您可以找到相关文档。如您所见,有一些命令用于创建新的synth节点(/s_new
),分配缓冲区(/b_alloc
),以及在控制总线上设置值(/s_set
),但没有用于/print
的命令。这就是为什么您会看到特定的错误消息:“未找到服务器中的故障:/print命令”。(顺便说一句,该消息来自服务器,而不是语言。)
另一方面,对象对进入语言过程的OSC消息作出响应。因此,您所需要做的就是将OSC消息从Python发送到正确的端口57120
可能有助于理解超级准直器服务器(scsynth)和客户端(Python、sclang或任何其他发送OSC消息的程序)之间的区别。感谢您的回复,这非常有帮助。我现在有工作了!没问题!你能接受我的答案吗?这样看来它就是解决办法了?谢谢:)