mirror of
https://github.com/NanjingForestryUniversity/supermachine--tomato-passion_fruit.git
synced 2025-11-09 14:54:07 +00:00
167 lines
6.6 KiB
Python
167 lines
6.6 KiB
Python
|
||
import numpy as np
|
||
import socket
|
||
import logging
|
||
import matplotlib.pyplot as plt
|
||
import cv2
|
||
|
||
def rec_socket(recv_sock: socket.socket, cmd_type: str, ack: bool) -> bool:
|
||
if ack:
|
||
cmd = 'A' + cmd_type
|
||
else:
|
||
cmd = 'D' + cmd_type
|
||
while True:
|
||
try:
|
||
temp = recv_sock.recv(1)
|
||
except ConnectionError as e:
|
||
logging.error(f'连接出错, 错误代码:\n{e}')
|
||
return False
|
||
except TimeoutError as e:
|
||
logging.error(f'超时了,错误代码: \n{e}')
|
||
return False
|
||
except Exception as e:
|
||
logging.error(f'遇见未知错误,错误代码: \n{e}')
|
||
return False
|
||
if temp == b'\xaa':
|
||
break
|
||
|
||
# 获取报文长度
|
||
temp = b''
|
||
while len(temp) < 4:
|
||
try:
|
||
temp += recv_sock.recv(1)
|
||
except Exception as e:
|
||
logging.error(f'接收报文长度失败, 错误代码: \n{e}')
|
||
return False
|
||
try:
|
||
data_len = int.from_bytes(temp, byteorder='big')
|
||
except Exception as e:
|
||
logging.error(f'转换失败,错误代码 \n{e}, \n报文内容\n{temp}')
|
||
return False
|
||
|
||
# 读取报文内容
|
||
temp = b''
|
||
while len(temp) < data_len:
|
||
try:
|
||
temp += recv_sock.recv(data_len)
|
||
except Exception as e:
|
||
logging.error(f'接收报文内容失败, 错误代码: \n{e},\n报文内容\n{temp}')
|
||
return False
|
||
data = temp
|
||
if cmd.strip().upper() != data[:4].decode('ascii').strip().upper():
|
||
logging.error(f'客户端接收指令错误,\n指令内容\n{data}')
|
||
return False
|
||
else:
|
||
if cmd == 'DIM':
|
||
print(data)
|
||
|
||
# 进行数据校验
|
||
temp = b''
|
||
while len(temp) < 3:
|
||
try:
|
||
temp += recv_sock.recv(1)
|
||
except Exception as e:
|
||
logging.error(f'接收报文校验失败, 错误代码: \n{e}')
|
||
return False
|
||
if temp == b'\xff\xff\xbb':
|
||
return True
|
||
else:
|
||
logging.error(f"接收了一个完美的只错了校验位的报文,\n data: {data}")
|
||
return False
|
||
|
||
|
||
# def main():
|
||
# socket_receive = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
||
# socket_receive.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
||
# socket_receive.bind(('127.0.0.1', 21123))
|
||
# socket_receive.listen(5)
|
||
# socket_send = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
||
# socket_send.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
||
# socket_send.bind(('127.0.0.1', 21122))
|
||
# socket_send.listen(5)
|
||
# print('等待连接')
|
||
# socket_send_1, receive_addr_1 = socket_send.accept()
|
||
# print("连接成功:", receive_addr_1)
|
||
# # socket_send_2 = socket_send_1
|
||
# socket_send_2, receive_addr_2 = socket_receive.accept()
|
||
# print("连接成功:", receive_addr_2)
|
||
# while True:
|
||
# cmd = input('请输入指令:').strip().upper()
|
||
# if cmd == 'IM':
|
||
# with open('data/newrawfile_ref.raw', 'rb') as f:
|
||
# data = np.frombuffer(f.read(), dtype=np.float32).reshape(750, 288, 384)
|
||
# data = data[:, [91, 92, 93, 94, 95, 96, 97, 98, 99, 100], :]
|
||
# n_rows, n_bands, n_cols = data.shape[0], data.shape[1], data.shape[2]
|
||
# print(f'n_rows:{n_rows}, n_bands:{n_bands}, n_cols:{n_cols}')
|
||
# n_rows, n_cols, n_bands = [x.to_bytes(2, byteorder='big') for x in [n_rows, n_cols, n_bands]]
|
||
# data = data.tobytes()
|
||
# length = len(data) + 10
|
||
# print(f'length: {length}')
|
||
# length = length.to_bytes(4, byteorder='big')
|
||
# msg = b'\xaa' + length + (' ' + cmd).upper().encode('ascii') + n_rows + n_cols + n_bands + data + b'\xff\xff\xbb'
|
||
# socket_send_1.send(msg)
|
||
# print('发送成功')
|
||
# result = socket_send_2.recv(5)
|
||
# length = int.from_bytes(result[1:5], byteorder='big')
|
||
# result = b''
|
||
# while len(result) < length:
|
||
# result += socket_send_2.recv(length)
|
||
# print(result)
|
||
# data = result[4:length].decode()
|
||
# print(data)
|
||
|
||
def main():
|
||
socket_receive = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
||
socket_receive.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
||
socket_receive.bind(('127.0.0.1', 21123))
|
||
socket_receive.listen(5)
|
||
socket_send = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
||
socket_send.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
||
socket_send.bind(('127.0.0.1', 21122))
|
||
socket_send.listen(5)
|
||
print('等待连接')
|
||
socket_send_1, receive_addr_1 = socket_send.accept()
|
||
print("连接成功:", receive_addr_1)
|
||
# socket_send_2 = socket_send_1
|
||
socket_send_2, receive_addr_2 = socket_receive.accept()
|
||
print("连接成功:", receive_addr_2)
|
||
while True:
|
||
cmd = input().strip().upper()
|
||
if cmd == 'IM':
|
||
|
||
image_paths = [
|
||
r"D:\project\deep-learning-for-image-processing-master\data_set\test_image\1.jpg",
|
||
r"D:\project\deep-learning-for-image-processing-master\data_set\test_image\2.jpg",
|
||
r"D:\project\deep-learning-for-image-processing-master\data_set\test_image\3.jpg",
|
||
r"D:\project\deep-learning-for-image-processing-master\data_set\test_image\4.jpg",
|
||
r"D:\project\deep-learning-for-image-processing-master\data_set\test_image\5.jpg",
|
||
]
|
||
|
||
# 连续发送五张图片
|
||
for image_path in image_paths:
|
||
# 读取图片文件
|
||
img = cv2.imread(image_path)
|
||
|
||
# img = cv2.imread(r"/Users/zhouchao/Library/CloudStorage/OneDrive-macrosolid/PycharmProjects/wood_color/data/data20220919/dark/rgb60.png")
|
||
# img = cv2.imread(r"D:\project\Astragalin\data\02newrawfile_ref.png")
|
||
img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
|
||
img = np.asarray(img, dtype=np.uint8)
|
||
width = img.shape[0]
|
||
height = img.shape[1]
|
||
print(width, height)
|
||
img_bytes = img.tobytes()
|
||
length = len(img_bytes) + 8
|
||
print(length)
|
||
length = length.to_bytes(4, byteorder='big')
|
||
width = width.to_bytes(2, byteorder='big')
|
||
height = height.to_bytes(2, byteorder='big')
|
||
send_message = b'\xaa' + length + (' ' + cmd).upper().encode('ascii') + width + height + img_bytes + b'\xff\xff\xbb'
|
||
socket_send_1.send(send_message)
|
||
print('发送成功')
|
||
result = socket_send_2.recv(10)
|
||
print(result)
|
||
|
||
|
||
|
||
if __name__ == '__main__':
|
||
main() |