forked from pcb2gcode/pcb2gcode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathautoleveller.hpp
170 lines (142 loc) · 6.14 KB
/
autoleveller.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
/*
* This file is part of pcb2gcode.
*
* Copyright (C) 2014, 2015 Nicola Corna <[email protected]>
*
* pcb2gcode is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* pcb2gcode is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with pcb2gcode. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef AUTOLEVELLER_H
#define AUTOLEVELLER_H
//Fixed probe fail depth (in inches, string)
#define FIXED_FAIL_DEPTH_IN "-0.1"
//Fixed probe fail depth (in mm, string)
#define FIXED_FAIL_DEPTH_MM "-3"
#include <string>
#include <fstream>
#include <vector>
#include <memory>
#include <boost/program_options.hpp>
#include "geometry.hpp"
#include "unique_codes.hpp"
#include "common.hpp"
#include "tile.hpp"
#include "options.hpp"
class autoleveller
{
public:
// The constructor just initialize the common parameters variables (parameters are in inches)
autoleveller( const boost::program_options::variables_map &options, uniqueCodes *ocodes,
uniqueCodes *globalVars, double xoffset, double yoffset,
const struct Tiling::TileInfo tileInfo );
// prepareWorkarea computes the area of the milling project and computes the required number of probe
// points; if it exceeds the maximum number of probe point it return false, otherwise it returns true
// All the arguments must be in inches
void prepareWorkarea(const std::vector<std::pair<coordinate_type_fp, multi_linestring_type_fp>>& toolpaths);
// header prints in of the header required for the probing (subroutines and probe calls for LinuxCNC,
// only the probe calls for the other softwares)
void header( std::ofstream &of );
// autoleveller doesn't just interpolate a point, it also checks that the distance between the
// previous point and the new point is not too high. If the distance is too high, it creates the
// required number of points between the previous and the current point and it interpolates them too.
// This function adds a new chain point. Always call setLastChainPoint before starting a new chain
// (call it also for the 1st chain)
std::string addChainPoint(point_type_fp point, double zwork);
// g01Corrected interpolates only one point (without adding it to the chain), and it prints a G01 to that
// position
std::string g01Corrected(point_type_fp point, double zwork);
// Set lastPoint as the last chain point. You can use this function when you want to start a new chain
inline void setLastChainPoint ( point_type_fp lastPoint )
{
this->lastPoint = lastPoint;
}
// This function returns the maximum number of probe points
inline unsigned int maxProbePoints()
{
return software == Software::LINUXCNC ? 4501 : 500;
}
// This function returns the required number of probe points
inline unsigned int requiredProbePoints()
{
return numXPoints * numYPoints;
}
// Since Mach3/4 require the subroutine body to be written at the end of the file, footer writes them
// if software != LinuxCNC
inline void footer( std::ofstream &of )
{
if( software != Software::LINUXCNC )
footerNoIf( of );
}
// Some parameters are just placed as string in the output, saving them as strings saves a lot of
// string to double conversion. These parameters are probably not useful for the user, but we can
// safely define them as public as they are const
const double input_unitconv;
const double output_unitconv;
const double cfactor;
const std::string probeCodeCustom;
const std::string zProbeResultVarCustom;
const std::string setZZeroCustom;
const double XProbeDistRequired;
const double YProbeDistRequired;
const std::string zprobe;
const std::string zsafe;
const std::string zfail;
const std::string feedrate;
const std::string probeOn;
const std::string probeOff;
const Software::Software software;
const double xoffset;
const double yoffset;
//Number of the g01 interpolated macro
const unsigned int g01InterpolatedNum;
//Number of the X/Y probe subroutines
const unsigned int yProbeNum;
const unsigned int xProbeNum;
// Global variables
const std::string returnVar;
const std::string globalVar0;
const std::string globalVar1;
const std::string globalVar2;
const std::string globalVar3;
const std::string globalVar4;
const std::string globalVar5;
const struct Tiling::TileInfo tileInfo;
const unsigned int initialXOffsetVar;
const unsigned int initialYOffsetVar;
static const std::string callSubRepeat[];
static const std::string probeCode[];
static const std::string zProbeResultVar[];
static const std::string setZZero[];
protected:
double startPointX;
double startPointY;
unsigned int numXPoints;
unsigned int numYPoints;
double XProbeDist;
double YProbeDist;
double averageProbeDist;
uniqueCodes *ocodes;
std::string callSub2[3];
point_type_fp lastPoint;
// footerNoIf prints the footer, regardless of the software
void footerNoIf( std::ofstream &of );
// getVarName returns the string containing the variable name associated with the probe point with
// the indexes i and j
std::string getVarName(unsigned int i, unsigned int j);
// interpolatePoint finds the correct 4 probed points and computes a bilinear interpolation of point.
// The result of the interpolation is saved in the parameter number RESULT_VAR
std::string interpolatePoint ( point_type_fp point );
};
linestring_type_fp partition_segment(const point_type_fp& source, const point_type_fp& dest,
const point_type_fp& grid_zero, const point_type_fp& grid_width);
#endif // AUTOLEVELLER_H