net_func

#include <winsock2.h>  
#include <stdio.h>
 
#pragma once
 
struct HQServerInfo
{
	char   szServer[32];
	short iPort;
 
	int iCmdId;
};
 
BOOL WinSockInit();
 
unsigned int  __stdcall GetHQAvgCostvoid * pInfo  );
 
unsigned int  __stdcall TestFuncvoid * pInfo  );
 
unsigned int  __stdcall HQRefreshCheckvoid *pPara );
 
 
 

#include "stdafx.h"
 
#include <stdio.h>    
#include <string.h>    
#include <iostream>    
 
#include "StockIo.h"
#include "request.h"
#include "Channel.h"
#include "net_func.h"
#include "util.hpp"
#include "NBSocket.h"
 
#pragma comment(lib,"ws2_32.lib")    
 
using namespace std;
 
 
 
BOOL WinSockInit()  
{  
	WSADATA data = {0};  
	if ( WSAStartupMAKEWORD( 2, 2 ), &data ) ) 
	{
		return FALSE; 
	}
 
	if ( LOBYTE(data.wVersion) !=2 || HIBYTE(data.wVersion) != 2 )
	{  
		WSACleanup();  
		return FALSE;  
	}  
	return TRUE;  
}
 
 
 
 
 
unsigned int  __stdcall GetHQAvgCostvoid *pPara )  
{
	CmdQueue_t g_Queue;
	NBSocket  * pSocket = new NBSocket();
 
	Channel * pChannel = new Channel();
 
	pSocket->SetChannel( pChannel );
 
	HQServerInfo * pInfo = (HQServerInfo *)pPara;
 
	//cout << "begin to connect to " << pInfo->szServer << ":" << pInfo->iPort << endl;
	struct timeval tv;
	tv.tv_sec = 3;
	tv.tv_usec = 0;
 
	int iRet = pSocket->Connect( pInfo->szServer, pInfo->iPort, &tv );
 
	if ( iRet == 0 )
	{
		//cout << "connect succ " << endl;
	}
	else
	{
		cout << "connect failed " << endl;
		return -1;
	}
 
	pChannel->SetServerInfo( pInfo );
 
 
	// just to calculate the total stocks in each market
	//AddStockListRequest( false );
 
	int iCount = 0;
 
	while ( true )
	{
		CmdQueue_t &q = g_Queue;
 
		if ( q.empty() &&  iCount < 100   )
		{
			//CmdData_t r( new GetStockCountReq( (uchar)0x00 ) );
			vector<QuotePara> vec;
			QuotePara stPara;
			stPara.cMarket = 0x00;
			memcpy( stPara.sStockCode, "000001"sizeof( stPara.sStockCode ) );
			vec.push_back( stPara );
		
			CmdData_t r( new GetStockQuotesReq(  vec ) );
			q.push_back( r );
			
			//cout << "add one GetStockCountReq cmd" << endl;
			//cout << "add one GetStockQuotesReq cmd" << endl;
			++iCount;
		}
 
		while ( !q.empty() )
		{
			CmdData_t  d = q.front();			// retreive a command
			d->SetSeqId( pChannel->GetSeqId() );
			d->send( pSocket );
 
			ReqTimeInfo stInfo;
			d->SetRequestInfo( stInfo );
 
			pChannel->StartRequest( stInfo );
 
			q.pop_front();
		}
 
		iRet = pSocket->Recv();
		if ( iRet != 0 )
		{
			break;
		}
	 
	}
 
	delete pInfo;
	pInfo = NULL;
 
	delete pChannel;
	pChannel = NULL;
 
	delete pSocket;
	pSocket = NULL;
 
	return -2;
}
 
 
void addRequestint iCmdId, CmdQueue_t & q)
{
	if ( iCmdId == CMD_GET_STOCK_QUOTES )
	{	
		vector<QuotePara> vec;
		QuotePara stPara;
		stPara.cMarket = 0x00;
		memcpy( stPara.sStockCode, "000001"sizeof( stPara.sStockCode ) );
		vec.push_back( stPara );
		CmdData_t r( new GetStockQuotesReq( vec ) );
		q.push_back( r );
	}
	else if ( iCmdId == CMD_GET_MINUTE_DATA )
	{
		CmdData_t r( new GetMinuteTimeDataReq(  1, "600300") );
		q.push_back( r );
	}
	else if ( iCmdId == CMD_GET_HIS_MINUTE_DATA )
	{
		CmdData_t r( new GetHisMinuteTimeDataReq(  20171026, 1, "600300") );
		q.push_back( r );
	}
	else if ( iCmdId == CMD_GET_TRANSACTION_DATA )
	{
		CmdData_t r( new GetTransactionDataReq(    0, "000001", 0, 30 ) );
		q.push_back( r );
	}
	else if ( iCmdId == CMD_GET_HIS_TRANSACTION_DATA )
	{
		CmdData_t r( new GetHisTransactionDataReq(   20171026,  0, "000001", 0, 30 ) );
		q.push_back( r );
	}
	else if ( iCmdId == CMD_GET_INDEX_BARS )
	{
		CmdData_t r( new GetIndexBarsReq(   9, 1, "000001", 1, 2 ) );
		q.push_back( r );
	}
}
 
 
unsigned int  __stdcall TestFuncvoid *pPara )  
{
	CmdQueue_t g_Queue;
	NBSocket  * pSocket = new NBSocket();
 
	Channel * pChannel = new Channel();
 
	pSocket->SetChannel( pChannel );
 
	HQServerInfo * pInfo = (HQServerInfo *)pPara;
 
	//cout << "begin to connect to " << pInfo->szServer << ":" << pInfo->iPort << endl;
	struct timeval tv;
	tv.tv_sec = 3;
	tv.tv_usec = 0;
 
	//114.67.61.70
	//int iRet = pSocket->Connect( pInfo->szServer, pInfo->iPort, &tv );
	int iRet = pSocket->Connect(  "114.67.61.70",  7709, &tv );
	if ( iRet == 0 )
	{
		//cout << "connect succ " << endl;
	}
	else
	{
		cout << "connect failed " << endl;
		return -1;
	}
 
	pChannel->SetServerInfo( pInfo );
 
 
	// just to calculate the total stocks in each market
	//AddStockListRequest( false );
 
	int iCount = 0;
 
	while ( true )
	{
		CmdQueue_t &q = g_Queue;
 
		if ( q.empty() &&  iCount < 1   )
		{
		
			addRequest( pInfo->iCmdId,  g_Queue );
			
			++iCount;
		}
 
		while ( !q.empty() )
		{
			CmdData_t  d = q.front();			// retreive a command
			d->SetSeqId( pChannel->GetSeqId() );
			d->send( pSocket );
 
			ReqTimeInfo stInfo;
			d->SetRequestInfo( stInfo );
			pChannel->StartRequest( stInfo );
 
			q.pop_front();
		}
 
		iRet = pSocket->Recv();
		if ( iRet != 0 )
		{
			break;
		}
	 
	}
 
	delete pInfo;
	pInfo = NULL;
 
	delete pChannel;
	pChannel = NULL;
 
	delete pSocket;
	pSocket = NULL;
 
	return -2;
}
 
 
 
unsigned int  __stdcall HQRefreshCheckvoid *pPara )  
{
	CmdQueue_t g_Queue;
	NBSocket  * pSocket = new NBSocket();
 
	Channel * pChannel = new Channel();
 
	pSocket->SetChannel( pChannel );
 
	HQServerInfo * pInfo = (HQServerInfo *)pPara;
 
	//cout << "begin to connect to " << pInfo->szServer << ":" << pInfo->iPort << endl;
	struct timeval tv;
	tv.tv_sec = 3;
	tv.tv_usec = 0;
 
	//114.67.61.70
	//int iRet = pSocket->Connect( pInfo->szServer, pInfo->iPort, &tv );
	int iRet = pSocket->Connect(  "114.67.61.70",  7709, &tv );
	if ( iRet == 0 )
	{
		//cout << "connect succ " << endl;
	}
	else
	{
		cout << "connect failed " << endl;
		return -1;
	}
 
	pChannel->SetServerInfo( pInfo );
 
 
	// just to calculate the total stocks in each market
	//AddStockListRequest( false );
 
	int iCount = 0;
 
	while ( true )
	{
		CmdQueue_t &q = g_Queue;
 
		if ( q.empty()     )
		{
			addRequest( pInfo->iCmdId,  g_Queue );
		}
 
		while ( !q.empty() )
		{
			CmdData_t  d = q.front();			// retreive a command
			d->SetSeqId( pChannel->GetSeqId() );
			d->send( pSocket );
 
			ReqTimeInfo stInfo;
			d->SetRequestInfo( stInfo );
			pChannel->StartRequest( stInfo );
 
			q.pop_front();
		}
 
		iRet = pSocket->Recv();
		if ( iRet != 0 )
		{
			break;
		}
 
		Sleep( 1000 );
	 
	}
 
	delete pInfo;
	pInfo = NULL;
 
	delete pChannel;
	pChannel = NULL;
 
	delete pSocket;
	pSocket = NULL;
 
	return -2;
}
 

(randlanet) root@autodl-container-5fe44bab80-cdf86d9c:~/autodl-tmp/RandLA-Net-master# python main_SemanticKITTI.py --mode train --gpu 0 Initiating input pipelines Traceback (most recent call last): File "main_SemanticKITTI.py", line 206, in <module> dataset.init_input_pipeline() File "main_SemanticKITTI.py", line 176, in init_input_pipeline self.batch_train_data = self.batch_train_data.map(map_func=map_func) File "/root/miniconda3/envs/randlanet/lib/python3.6/site-packages/tensorflow/python/data/ops/dataset_ops.py", line 1861, in map return MapDataset(self, map_func, preserve_cardinality=True) File "/root/miniconda3/envs/randlanet/lib/python3.6/site-packages/tensorflow/python/data/ops/dataset_ops.py", line 4985, in __init__ use_legacy_function=use_legacy_function) File "/root/miniconda3/envs/randlanet/lib/python3.6/site-packages/tensorflow/python/data/ops/dataset_ops.py", line 4218, in __init__ self._function = fn_factory() File "/root/miniconda3/envs/randlanet/lib/python3.6/site-packages/tensorflow/python/eager/function.py", line 3151, in get_concrete_function *args, **kwargs) File "/root/miniconda3/envs/randlanet/lib/python3.6/site-packages/tensorflow/python/eager/function.py", line 3116, in _get_concrete_function_garbage_collected graph_function, _ = self._maybe_define_function(args, kwargs) File "/root/miniconda3/envs/randlanet/lib/python3.6/site-packages/tensorflow/python/eager/function.py", line 3463, in _maybe_define_function graph_function = self._create_graph_function(args, kwargs) File "/root/miniconda3/envs/randlanet/lib/python3.6/site-packages/tensorflow/python/eager/function.py", line 3308, in _create_graph_function capture_by_value=self._capture_by_value), File "/root/miniconda3/envs/randlanet/lib/python3.6/site-packages/tensorflow/python/framework/func_graph.py", line 1007, in func_graph_from_py_func func_outputs = python_func(*func_args, **func_kwargs) File "/root/miniconda3/envs/randlanet/lib/python3.6/site-packages/tensorflow/python/data/ops/dataset_ops.py", line 4195, in wrapped_fn ret = wrapper_helper(*args) File "/root/miniconda3/envs/randlanet/lib/python3.6/site-packages/tensorflow/python/data/ops/dataset_ops.py", line 4125, in wrapper_helper ret = autograph.tf_convert(self._func, ag_ctx)(*nested_args) File "/root/miniconda3/envs/randlanet/lib/python3.6/site-packages/tensorflow/python/autograph/impl/api.py", line 695, in wrapper raise e.ag_error_metadata.to_exception(e) AttributeError: in user code: main_SemanticKITTI.py:142 tf_map * neighbour_idx = tf.py_func(DP.knn_search, [batch_pc, batch_pc, cfg.k_n], tf.int32) AttributeError: module 'tensorflow' has no attribute 'py_func'
最新发布
07-30
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值