| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | #include <QtCore/QCoreApplication>
 | 
					
						
							|  |  |  | #include<VSMD12XControl.h>
 | 
					
						
							|  |  |  | #include "QTextCodec"
 | 
					
						
							|  |  |  | #include "SensorMannager.h"
 | 
					
						
							|  |  |  | #include"SensorOptoSky.h"
 | 
					
						
							|  |  |  | #include"SensorQExPRO.h"
 | 
					
						
							|  |  |  | #include <iostream>
 | 
					
						
							|  |  |  | #include <fstream>
 | 
					
						
							| 
									
										
										
										
											2022-01-12 15:28:02 +08:00
										 |  |  | #include <QTextStream>
 | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  | #include <QSettings>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | QTextStream cout1(stdout, QIODevice::WriteOnly); | 
					
						
							|  |  |  | void logout(QString str){ | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |     cout1<<str<<" <br>"<<flush; | 
					
						
							|  |  |  |     cout1<<endl; | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  |    // std::fflush(stdout);
 | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | } | 
					
						
							|  |  |  | vector<int> FindFeng(vector<int > point1ist, vector<float> valuelist); | 
					
						
							|  |  |  | vector<int> DengJianJu(int position, int distanc, int times = 10); | 
					
						
							|  |  |  | vector <float> PingHua(vector <float> value, int step = 2); | 
					
						
							|  |  |  | int main(int argc, char* argv[]) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |     if (argc!=4) | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |         logout("Some Thing error Please check the input"); | 
					
						
							|  |  |  |         logout( "The Correct Should Be application sensor numberofposition"); | 
					
						
							|  |  |  |         logout( "apllication Sensor positionneed shutter_time"); | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  |         logout("Senor: OSIFAlpha  QEPRO"); | 
					
						
							|  |  |  |         logout("Senor: OSIFBeta  QE65"); | 
					
						
							|  |  |  |         logout("Senor: ISIF   ATP6500"); | 
					
						
							|  |  |  |         logout("Senor: IS1    ATP1010"); | 
					
						
							|  |  |  |         logout("Senor: IS2    ATP5020"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-01-14 14:15:25 +08:00
										 |  |  |    // cali;
 | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  |     int bandsnumber=1024; | 
					
						
							|  |  |  |     QString SensorTypestr(argv[1]); | 
					
						
							|  |  |  |     QString PositionNumberstr(argv[2]); | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |     int shuttertime=QString(argv[3]).toInt(); | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  |     int PositionNumber=PositionNumberstr.toInt(); | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 	QCoreApplication aaaaa(argc, argv); | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     QString m_qstrDeviceConfigFilePath; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef WIN32
 | 
					
						
							|  |  |  |     m_qstrDeviceConfigFilePath = ("D:\\03MyGit\\linux\\movingliner\\DeviceSettings.ini"); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     m_qstrDeviceConfigFilePath = ("/home/data/Setting/DeviceSettings.ini"); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     QSettings *m_qsDeviceConfig; | 
					
						
							|  |  |  |     m_qsDeviceConfig = new QSettings(m_qstrDeviceConfigFilePath, QSettings::IniFormat); | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |     int numberofsensor=m_qsDeviceConfig->value("DEVICE INFO/TotalSpectrometer").toInt(); | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     logout("Welcom to use the Auto Locate Application"); | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 	string hdrPath = "/home/data/test.csv"; | 
					
						
							|  |  |  | 	std::ofstream outfile(hdrPath.c_str()); | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |     string hdrPath1 = "/home/data/result.csv"; | 
					
						
							|  |  |  |     std::ofstream outfile1(hdrPath1.c_str()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     logout("Sensor is "+SensorTypestr); | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  |     SensorBase* aa= nullptr; | 
					
						
							|  |  |  |     if (SensorTypestr=="OSIFAlpha") | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       aa = new SensorQExPRO(QE65PRO_QE); | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  |     } else if (SensorTypestr=="OSIFBeta") | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         aa = new SensorQExPRO(QE65PRO_QE); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if(aa== nullptr) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         QString portname=""; | 
					
						
							|  |  |  |         for (int i = 0; i < numberofsensor; ++i) { | 
					
						
							|  |  |  |             QString key="FS"+QString::number(i+1)+"/Model"; | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |             qDebug()<<key; | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  |             if (m_qsDeviceConfig->value(key).toString()==SensorTypestr) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 QString portstr=m_qsDeviceConfig->value("FS"+QString::number(i+1)+"/Port").toString(); | 
					
						
							|  |  |  |                 QStringList strlist=portstr.split('/'); | 
					
						
							|  |  |  |                 portname=strlist.at(strlist.length()-1); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |        // qDebug()<<portname;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  |         if (portname=="") | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |             logout("<b style=\"color:red\">Can not find the sensor"+SensorTypestr+"<\/b>"); | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  |             return 1; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |         logout("Sensor Port is "+portname); | 
					
						
							| 
									
										
										
										
											2022-01-14 14:07:18 +08:00
										 |  |  |         aa=new SensorOptoSky(ATP6500,portname); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 	//SensorBase* aa = new SensorOptoSky(ATP6500,"ttyUSB0");
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	aa->initSensor(); | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |     STRSensorInfo info= aa->SensorInfo; | 
					
						
							|  |  |  |     int bandsshow=info.BandNum/2; | 
					
						
							|  |  |  |     logout("Sensor Bands to Show is "+QString::number(bandsshow)); | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 	STROnePlot oneplot; | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     CVSMD12XControl Motercontrol; | 
					
						
							|  |  |  |     //Motercontrol.ILMES_InitializeComm("COM16");
 | 
					
						
							|  |  |  |     if ( m_qsDeviceConfig->value("LINEAR SHUTTER/Port").toString()!="") | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         logout("Find the motor port:"+m_qsDeviceConfig->value("LINEAR SHUTTER/Port").toString()); | 
					
						
							|  |  |  |         Motercontrol.ILMES_InitializeComm( m_qsDeviceConfig->value("LINEAR SHUTTER/Port").toString()); | 
					
						
							|  |  |  |     } else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     logout("The max Postion is "+QString::number(550000/4*PositionNumber)); | 
					
						
							|  |  |  |     ControllerParams cpTest; | 
					
						
							|  |  |  |     bool res = Motercontrol.ILMES_InitializeParams(cpTest); | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |     aa->Settingshuttertime(shuttertime); | 
					
						
							|  |  |  |     aa->GetOnePlot(oneplot); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     logout("GO TO ZERO"); | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 	Motercontrol.StartBackZero(); | 
					
						
							|  |  |  | 	Motercontrol.SetRunSpeed(10000); | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |     logout("GO TO ZERO OK"); | 
					
						
							|  |  |  |     logout("Start Moving to "+QString::number(550000/4*PositionNumber)); | 
					
						
							|  |  |  | 	Motercontrol.MoveTo_NoSyn(550000/4*PositionNumber); | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 	aa->GetOnePlot(oneplot); | 
					
						
							|  |  |  | 	MSInfo temp; | 
					
						
							|  |  |  | 	Motercontrol.GetStatus(temp); | 
					
						
							|  |  |  | 	vector<int > point1ist; | 
					
						
							|  |  |  | 	vector<float> valuelist; | 
					
						
							|  |  |  | 	int i = 0; | 
					
						
							|  |  |  | 	Motercontrol.GetStatus(temp); | 
					
						
							|  |  |  | 	//outfile <<i<<"," << oneplot.Plot[1024] << "," << temp.iPosition << std::endl;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	point1ist.push_back(temp.iPosition); | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  | 	valuelist.push_back(oneplot.Plot[bandsshow]); | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 	while (temp.fVelocity!=0) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		aa->GetOnePlot(oneplot); | 
					
						
							|  |  |  | 		//qDebug() << oneplot.BandNum;
 | 
					
						
							|  |  |  | 		//std::cout << temp.iPosition << std::endl;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		Motercontrol.GetStatus(temp); | 
					
						
							|  |  |  | 		i++; | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  | 		outfile << i << "," << oneplot.Plot[bandsshow] << "," << temp.iPosition << std::endl; | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 		point1ist.push_back(temp.iPosition); | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  | 		valuelist.push_back(oneplot.Plot[bandsshow]); | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |     logout("FINISH Moving"); | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 	vector<float> valuepinghua1 = PingHua(valuelist, 3); | 
					
						
							|  |  |  | 	vector<int>loction1=FindFeng(point1ist, valuepinghua1); | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 	int lenth = loction1.size(); | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |     if (lenth!=PositionNumber) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         logout("<b style=\"color:red\">can not find all position please change the shutter time and try agin<\/b>"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     cout1<<"First find "<<lenth<<" point "<<"<br>"<<flush; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     logout("GO TO ZERO"); | 
					
						
							|  |  |  |     Motercontrol.StartBackZero(); | 
					
						
							|  |  |  |     logout("GO TO ZERO OK"); | 
					
						
							|  |  |  |     logout("Start Moving"); | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 	for (size_t i = 0; i < lenth; i++) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		vector<int> location1point = DengJianJu(loction1[i], 5000, 25); | 
					
						
							|  |  |  | 		vector<float> valuepoint; | 
					
						
							|  |  |  | 		int lennow = location1point.size(); | 
					
						
							| 
									
										
										
										
											2022-01-19 13:47:02 +08:00
										 |  |  |         cout1<<"Detail find "<<i<<" point begin"<<"<br>"<<flush; | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 		for (size_t ii = 0; ii < lennow; ii++) | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 			Motercontrol.MoveTo(location1point[ii]); | 
					
						
							|  |  |  | 			aa->GetOnePlot(oneplot); | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  | 			valuepoint.push_back(oneplot.Plot[bandsshow]); | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 			//outfile << ii << "," << oneplot.Plot[1024] << "," << location1point[ii] << std::endl;
 | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		vector<float> valuepinghua = PingHua(valuepoint,3); | 
					
						
							|  |  |  | 		vector<int>loction2 = FindFeng(location1point, valuepinghua); | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 		if (loction2.size() == 1) | 
					
						
							| 
									
										
										
										
											2022-01-19 13:47:02 +08:00
										 |  |  | 		{   cout1<<"find "<<i<<"point value is <b color=\'green\'>"<<loction2[0]<<"<\/b><br>"<<flush; | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  | 			outfile1 <<i+1<<"," << loction2[0]<< std::endl; | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		int cc = 10; | 
					
						
							|  |  |  | 		cc++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |     logout("FINISH Moving"); | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	std::cout<<"totle:" << i; | 
					
						
							|  |  |  | 	outfile.close(); | 
					
						
							| 
									
										
										
										
											2022-01-17 09:30:08 +08:00
										 |  |  |     outfile.close(); | 
					
						
							| 
									
										
										
										
											2022-01-12 14:30:11 +08:00
										 |  |  |     if (!res) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return 0; | 
					
						
							|  |  |  | 	return aaaaa.exec(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | vector<int> FindFeng(vector<int > point1ist, vector<float> valuelist) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	vector<int> ret; | 
					
						
							|  |  |  | 	int lenth = point1ist.size(); | 
					
						
							|  |  |  | 	if (lenth<10) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		ret.push_back(0); | 
					
						
							|  |  |  | 		return ret; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	for (size_t i = 5; i < lenth-5; i++) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (valuelist[i] > 5000&&valuelist[i]>valuelist[i-1]&& valuelist[i] > valuelist[i - 4]&& valuelist[i] >valuelist[i + 1]&& valuelist[i] > valuelist[i + 4] | 
					
						
							|  |  |  | 				&& valuelist[i-1] > 5000 && valuelist[i-4]&& valuelist[i +1] > 5000 && valuelist[i + 4]) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			if (ret.size()!=0) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				if (point1ist[i]-ret[ret.size()-1]<5000) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			ret.push_back(point1ist[i]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return ret; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | vector<int> DengJianJu(int position, int distanc, int times ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int begin = position - distanc; | 
					
						
							|  |  |  | 	vector<int> ret; | 
					
						
							|  |  |  | 	int eachstep = distanc / times; | 
					
						
							|  |  |  | 	for (size_t i = 0; i < 2*times; i++) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		ret.push_back(begin + i * eachstep); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return ret; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | vector <float> PingHua(vector <float> value,int step) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	vector <float> ret; | 
					
						
							|  |  |  | 	if (value.size()<2*step) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return value; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	int len = value.size(); | 
					
						
							|  |  |  | 	for (size_t i = 0; i < step; i++) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		ret.push_back(value[i]); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	for (size_t i = step; i <len-step; i++) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		float sumi = 0; | 
					
						
							|  |  |  | 		for (size_t ii = 0; ii < 2*step+1; ii++) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			sumi += value[i - step + ii]; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		ret.push_back(sumi / (2 * step + 1)); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	for (size_t i = len  - step; i < len; i++) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		ret.push_back(value[i]); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return ret; | 
					
						
							|  |  |  | } |