當前位置: 首頁>>代碼示例>>Python>>正文


Python msgpack_numpy.decode方法代碼示例

本文整理匯總了Python中msgpack_numpy.decode方法的典型用法代碼示例。如果您正苦於以下問題:Python msgpack_numpy.decode方法的具體用法?Python msgpack_numpy.decode怎麽用?Python msgpack_numpy.decode使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在msgpack_numpy的用法示例。


在下文中一共展示了msgpack_numpy.decode方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _blocking_request

# 需要導入模塊: import msgpack_numpy [as 別名]
# 或者: from msgpack_numpy import decode [as 別名]
def _blocking_request(self, _request):
        """
            request:
                -command_type
                -payload
                -response_channel
            response: (on response_channel)
                - RESULT
            * Send the payload on command_channel (self.namespace+"::command")
                ** redis-left-push (LPUSH)
            * Keep listening on response_channel (BLPOP)
        """
        assert type(_request) ==type({})
        _request['response_channel'] = self._generate_response_channel()

        _redis = self.get_redis_connection()
        """
            The client always pushes in the left
            and the service always pushes in the right
        """
        if self.verbose: print("Request : ", _response)
        # Push request in command_channels
        payload = msgpack.packb(_request, default=m.encode, use_bin_type=True)
        _redis.lpush(self.command_channel, payload)
        ## TODO: Check if we can use `repr` for json.dumps string serialization
        # Wait with a blocking pop for the response
        _response = _redis.blpop(_request['response_channel'])[1]
        if self.verbose: print("Response : ", _response)
        _response = msgpack.unpackb(_response, object_hook=m.decode, encoding="utf8")
        if _response['type'] == messages.OSIM_RL.ERROR:
            raise Exception(str(_response))
        else:
            return _response 
開發者ID:stanfordnmbl,項目名稱:osim-rl,代碼行數:35,代碼來源:client.py

示例2: receive_loop

# 需要導入模塊: import msgpack_numpy [as 別名]
# 或者: from msgpack_numpy import decode [as 別名]
def receive_loop(self):
        """
        This is the receive loop for zmq messages.

        This method may be overwritten to meet the needs
        of the application before handling received messages.

        :return:
        """
        for element in itertools.cycle(self.backplane_table):
            if element['subscriber']:
                try:
                    data = element['subscriber'].recv_multipart(zmq.NOBLOCK)
                    if self.numpy:
                        payload = msgpack.unpackb(data[1], object_hook=m.decode)
                        self.incoming_message_processing(data[0].decode(), payload)
                    else:
                        self.incoming_message_processing(data[0].decode(), umsgpack.unpackb(data[1]))
                except zmq.error.Again:
                    try:
                        time.sleep(self.loop_time)
                    except KeyboardInterrupt:
                        self.clean_up()
                        sys.exit(0)
                except AttributeError:
                    raise 
開發者ID:MrYsLab,項目名稱:python_banyan,代碼行數:28,代碼來源:banyan_base_multi.py

示例3: numpy_unpack

# 需要導入模塊: import msgpack_numpy [as 別名]
# 或者: from msgpack_numpy import decode [as 別名]
def numpy_unpack(self, data):
        return msgpack.unpackb(data[1], object_hook=m.decode) 
開發者ID:MrYsLab,項目名稱:python_banyan,代碼行數:4,代碼來源:banyan_base_aio.py

示例4: receive_loop

# 需要導入模塊: import msgpack_numpy [as 別名]
# 或者: from msgpack_numpy import decode [as 別名]
def receive_loop(self):
        """
        This is the receive loop for Banyan messages.

        This method may be overwritten to meet the needs
        of the application before handling received messages.

        """
        while True:
            data = await self.subscriber.recv_multipart()
            if self.numpy:
                payload2 = {}
                payload = await self.numpy_unpack(data[1])
                # convert keys to strings
                # this compensates for the breaking change in msgpack-numpy 0.4.1 to 0.4.2
                for key, value in payload.items():
                    if not type(key) == str:
                        key = key.decode('utf-8')
                        payload2[key] = value

                if payload2:
                    payload = payload2
                await self.incoming_message_processing(data[0].decode(), payload)
            else:
                payload = await self.unpack(data[1])
                await self.incoming_message_processing(data[0].decode(), payload) 
開發者ID:MrYsLab,項目名稱:python_banyan,代碼行數:28,代碼來源:banyan_base_aio.py

示例5: receive_loop

# 需要導入模塊: import msgpack_numpy [as 別名]
# 或者: from msgpack_numpy import decode [as 別名]
def receive_loop(self):
        """
        This is the receive loop for Banyan messages.

        This method may be overwritten to meet the needs
        of the application before handling received messages.

        """
        while True:
            try:
                data = self.subscriber.recv_multipart(zmq.NOBLOCK)
                if self.numpy:
                    payload2 = {}
                    payload = msgpack.unpackb(data[1], object_hook=m.decode)
                    # convert keys to strings
                    # this compensates for the breaking change in msgpack-numpy 0.4.1 to 0.4.2
                    for key, value in payload.items():
                        if not type(key) == str:
                            key = key.decode('utf-8')
                            payload2[key] = value

                    if payload2:
                        payload = payload2
                    self.incoming_message_processing(data[0].decode(), payload)
                else:
                    self.incoming_message_processing(data[0].decode(),
                                                     msgpack.unpackb(data[1], raw=False))
            # if no messages are available, zmq throws this exception
            except zmq.error.Again:
                try:
                    if self.receive_loop_idle_addition:
                        self.receive_loop_idle_addition()
                    time.sleep(self.loop_time)
                except KeyboardInterrupt:
                    self.clean_up()
                    raise KeyboardInterrupt 
開發者ID:MrYsLab,項目名稱:python_banyan,代碼行數:38,代碼來源:banyan_base.py

示例6: np_deserialize

# 需要導入模塊: import msgpack_numpy [as 別名]
# 或者: from msgpack_numpy import decode [as 別名]
def np_deserialize(s):
  import msgpack
  import msgpack_numpy as m
  return msgpack.unpackb(s, object_hook=m.decode)
#  return np.load(StringIO.StringIO(s)) 
開發者ID:andrewowens,項目名稱:multisensory,代碼行數:7,代碼來源:util.py

示例7: unserialize

# 需要導入模塊: import msgpack_numpy [as 別名]
# 或者: from msgpack_numpy import decode [as 別名]
def unserialize(self, serialized_vector):
        """ Unserialize a vector using msgpack.

        :param bytes serialized_vector:
        :return np.array:
        """
        return msgpack.unpackb(
            serialized_vector,
            object_hook = msgpack_numpy.decode,
            raw = self._raw
        ) 
開發者ID:ThoughtRiver,項目名稱:lmdb-embeddings,代碼行數:13,代碼來源:serializers.py


注:本文中的msgpack_numpy.decode方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。