mirror of
git://projects.qi-hardware.com/cae-tools.git
synced 2025-01-03 22:30:14 +02:00
cameo: added optimization of movements between tool paths
- ops.h, ops.c (optimize_paths): reorder toolpaths to reduce the distance between them - lang.l, lang.y: added command "optimize" - README: documented "optimize"
This commit is contained in:
parent
ffaded7f48
commit
57b4e276e5
@ -179,3 +179,12 @@ and write the toolpaths to the file "drill.gp". Next, we retrieve the
|
||||
remaining paths, generate toolpaths for a 0.8 mm endmill, and write
|
||||
them to the file "mill.gp". Finally, we check that all paths have been
|
||||
processed.
|
||||
|
||||
|
||||
Tool path optimization:
|
||||
|
||||
optimize
|
||||
|
||||
Try to reduce the movements made between paths by reordering the paths.
|
||||
Note that this disturbs the order generated by "offset" and should thus
|
||||
not be used on paths that to be executed in a specific sequence.
|
||||
|
@ -46,6 +46,7 @@ NUM -?[0-9]+\.?[0-9]*
|
||||
<INITIAL>empty return TOK_EMPTY;
|
||||
<INITIAL>mill return TOK_MILL;
|
||||
<INITIAL>offset return TOK_OFFSET;
|
||||
<INITIAL>optimize return TOK_OPTIMIZE;
|
||||
<INITIAL>remainder return TOK_REMAINDER;
|
||||
<INITIAL>reset return TOK_RESET;
|
||||
<INITIAL>translate return TOK_TRANSLATE;
|
||||
|
@ -150,7 +150,7 @@ static struct path **classify(struct path **anchor, struct path *path)
|
||||
|
||||
|
||||
%token TOK_ALIGN TOK_ARRAY TOK_CLEAR TOK_DRILL TOK_EMPTY
|
||||
%token TOK_MILL TOK_OFFSET TOK_REMAINDER TOK_RESET
|
||||
%token TOK_MILL TOK_OFFSET TOK_OPTIMIZE TOK_REMAINDER TOK_RESET
|
||||
%token TOK_TRANSLATE TOK_Z
|
||||
%token TOK_APPEND TOK_GERBER TOK_GNUPLOT TOK_EXCELLON TOK_WRITE
|
||||
%token TOK_DOG TOK_INSIDE
|
||||
@ -208,6 +208,10 @@ command:
|
||||
tool_comp_paths(paths,
|
||||
!!($2 & OO_DOG), !!($2 & OO_INSIDE));
|
||||
}
|
||||
| TOK_OPTIMIZE
|
||||
{
|
||||
paths = optimize_paths(paths);
|
||||
}
|
||||
| TOK_TRANSLATE dimen dimen
|
||||
{
|
||||
translate(paths, $2, $3, 0);
|
||||
|
46
cameo/ops.c
46
cameo/ops.c
@ -12,6 +12,7 @@
|
||||
|
||||
|
||||
#include <stddef.h>
|
||||
#include <math.h>
|
||||
|
||||
#include "path.h"
|
||||
#include "shape.h"
|
||||
@ -88,3 +89,48 @@ struct path *try_mill(struct path *path, double diam, double step)
|
||||
path->first->z, path->r_tool, diam/2, step);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* This isn't a perfect solution for the traveling salesman problem, but it's
|
||||
* easy to implement and usually produces results that don't look overly
|
||||
* offensive.
|
||||
*/
|
||||
|
||||
struct path *optimize_paths(struct path *paths)
|
||||
{
|
||||
struct path **walk, **best = NULL;
|
||||
struct path *res = NULL, **anchor = &res;
|
||||
struct path *curr;
|
||||
struct point *p;
|
||||
double best_d = 0, d;
|
||||
|
||||
for (walk = &paths; *walk; walk = &(*walk)->next) {
|
||||
p = (*walk)->first;
|
||||
if (!p)
|
||||
continue;
|
||||
d = hypot(p->x, p->y);
|
||||
if (!best || d < best_d) {
|
||||
best = walk;
|
||||
best_d = d;
|
||||
}
|
||||
}
|
||||
while (best) {
|
||||
curr = *best;
|
||||
*anchor = *best;
|
||||
anchor = &curr->next;
|
||||
*best = curr->next;
|
||||
best = NULL;
|
||||
for (walk = &paths; *walk; walk = &(*walk)->next) {
|
||||
p = (*walk)->first;
|
||||
if (!p)
|
||||
continue;
|
||||
d = hypot(p->x-curr->last->x, p->y-curr->last->y);
|
||||
if (!best || d < best_d) {
|
||||
best = walk;
|
||||
best_d = d;
|
||||
}
|
||||
}
|
||||
}
|
||||
return res;
|
||||
}
|
||||
|
@ -20,5 +20,6 @@
|
||||
void tool_comp_paths(struct path *paths, int dog_bone, int all_inside);
|
||||
struct path *try_drill(struct path *path, double d_min, double d_max);
|
||||
struct path *try_mill(struct path *path, double diam, double step);
|
||||
struct path *optimize_paths(struct path *paths);
|
||||
|
||||
#endif /* !OPS_H */
|
||||
|
Loading…
Reference in New Issue
Block a user