Merge pull request #1148 from revarbat/revarbat_dev

Revarbat dev
This commit is contained in:
Revar Desmera 2023-04-28 17:41:57 -07:00 committed by GitHub
commit 58aa30ed8c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 59 additions and 11 deletions

View File

@ -44,9 +44,9 @@ xdistribute(50) {
xdistribute(24) { xdistribute(24) {
screw("M12,70", head="hex", anchor="origin", orient=BACK) screw("M12,70", head="hex", anchor="origin", orient=BACK)
attach(BOT,CENTER) attach(BOT,CENTER)
nut("M12", thickness=10, diameter=20); nut("M12", thickness=10);
screw("M12,70", head="hex", anchor="origin", orient=BACK) screw("M12,70", head="hex", anchor="origin", orient=BACK)
attach(BOT,CENTER) attach(BOT,CENTER)
nut("M12", thickness=10, diameter=20); nut("M12", thickness=10);
} }
} }

View File

@ -16,6 +16,9 @@
// Function: is_vector() // Function: is_vector()
// Synopsis: Returns true if the given value is a vector.
// Topics: Vectors, Math
// See Also: is_matrix(), is_path(), is_region()
// Usage: // Usage:
// bool = is_vector(v, [length], [zero=], [all_nonzero=], [eps=]); // bool = is_vector(v, [length], [zero=], [all_nonzero=], [eps=]);
// Description: // Description:
@ -53,9 +56,11 @@ function is_vector(v, length, zero, all_nonzero=false, eps=EPSILON) =
// Section: Scalar operations on vectors // Section: Scalar operations on vectors
// Function: add_scalar() // Function: add_scalar()
// Synopsis: Adds a scalar value to every item in a vector.
// Topics: Vectors, Math
// See Also: add_scalar(), v_mul(), v_div()
// Usage: // Usage:
// v_new = add_scalar(v, s); // v_new = add_scalar(v, s);
// Topics: List Handling
// Description: // Description:
// Given a vector and a scalar, returns the vector with the scalar added to each item in it. // Given a vector and a scalar, returns the vector with the scalar added to each item in it.
// Arguments: // Arguments:
@ -70,6 +75,9 @@ function add_scalar(v,s) =
// Function: v_mul() // Function: v_mul()
// Synopsis: Returns the element-wise multiplication of two equal-length vectors.
// Topics: Vectors, Math
// See Also: add_scalar(), v_mul(), v_div()
// Usage: // Usage:
// v3 = v_mul(v1, v2); // v3 = v_mul(v1, v2);
// Description: // Description:
@ -87,6 +95,9 @@ function v_mul(v1, v2) =
// Function: v_div() // Function: v_div()
// Synopsis: Returns the element-wise division of two equal-length vectors.
// Topics: Vectors, Math
// See Also: add_scalar(), v_mul(), v_div()
// Usage: // Usage:
// v3 = v_div(v1, v2); // v3 = v_div(v1, v2);
// Description: // Description:
@ -103,6 +114,9 @@ function v_div(v1, v2) =
// Function: v_abs() // Function: v_abs()
// Synopsis: Returns the absolute values of the given vector.
// Topics: Vectors, Math
// See Also: v_abs(), v_floor(), v_ceil()
// Usage: // Usage:
// v2 = v_abs(v); // v2 = v_abs(v);
// Description: Returns a vector of the absolute value of each element of vector `v`. // Description: Returns a vector of the absolute value of each element of vector `v`.
@ -116,6 +130,9 @@ function v_abs(v) =
// Function: v_floor() // Function: v_floor()
// Synopsis: Returns the values of the given vector, rounded down.
// Topics: Vectors, Math
// See Also: v_abs(), v_floor(), v_ceil()
// Usage: // Usage:
// v2 = v_floor(v); // v2 = v_floor(v);
// Description: // Description:
@ -126,6 +143,9 @@ function v_floor(v) =
// Function: v_ceil() // Function: v_ceil()
// Synopsis: Returns the values of the given vector, rounded up.
// Topics: Vectors, Math
// See Also: v_abs(), v_floor(), v_ceil()
// Usage: // Usage:
// v2 = v_ceil(v); // v2 = v_ceil(v);
// Description: // Description:
@ -136,6 +156,9 @@ function v_ceil(v) =
// Function: v_lookup() // Function: v_lookup()
// Synopsis: Like `lookup()`, but it can interpolate between vector results.
// Topics: Vectors, Math
// See Also: v_abs(), v_floor(), v_ceil()
// Usage: // Usage:
// v2 = v_lookup(x, v); // v2 = v_lookup(x, v);
// Description: // Description:
@ -166,6 +189,9 @@ function v_lookup(x, v) =
// Function: unit() // Function: unit()
// Synopsis: Returns the unit length of a given vector.
// Topics: Vectors, Math
// See Also: v_abs(), v_floor(), v_ceil()
// Usage: // Usage:
// v = unit(v, [error]); // v = unit(v, [error]);
// Description: // Description:
@ -188,6 +214,9 @@ function unit(v, error=[[["ASSERT"]]]) =
// Function: v_theta() // Function: v_theta()
// Synopsis: Returns the angle counter-clockwise from X+ on the XY plane.
// Topics: Vectors, Math
// See Also: unit()
// Usage: // Usage:
// theta = v_theta([X,Y]); // theta = v_theta([X,Y]);
// Description: // Description:
@ -199,6 +228,9 @@ function v_theta(v) =
// Function: vector_angle() // Function: vector_angle()
// Synopsis: Returns the minor angle between two vectors.
// Topics: Vectors, Math
// See Also: unit(), v_theta()
// Usage: // Usage:
// ang = vector_angle(v1,v2); // ang = vector_angle(v1,v2);
// ang = vector_angle([v1,v2]); // ang = vector_angle([v1,v2]);
@ -241,6 +273,9 @@ function vector_angle(v1,v2,v3) =
// Function: vector_axis() // Function: vector_axis()
// Synopsis: Returns the perpendicular axis between two vectors.
// Topics: Vectors, Math
// See Also: unit(), v_theta(), vector_angle()
// Usage: // Usage:
// axis = vector_axis(v1,v2); // axis = vector_axis(v1,v2);
// axis = vector_axis([v1,v2]); // axis = vector_axis([v1,v2]);
@ -285,6 +320,9 @@ function vector_axis(v1,v2=undef,v3=undef) =
// Function: vector_bisect() // Function: vector_bisect()
// Synopsis: Returns the vector that bisects two vectors.
// Topics: Vectors, Math
// See Also: unit(), v_theta(), vector_angle(), vector_axis()
// Usage: // Usage:
// newv = vector_bisect(v1,v2); // newv = vector_bisect(v1,v2);
// Description: // Description:
@ -310,9 +348,11 @@ function vector_bisect(v1,v2) =
// Function: pointlist_bounds() // Function: pointlist_bounds()
// Synopsis: Returns the min and max bounding coordinates for the given list of points.
// Topics: Geometry, Bounding Boxes, Bounds
// See Also: closest_point()
// Usage: // Usage:
// pt_pair = pointlist_bounds(pts); // pt_pair = pointlist_bounds(pts);
// Topics: Geometry, Bounding Boxes, Bounds
// Description: // Description:
// Finds the bounds containing all the points in `pts` which can be a list of points in any dimension. // Finds the bounds containing all the points in `pts` which can be a list of points in any dimension.
// Returns a list of two items: a list of the minimums and a list of the maximums. For example, with // Returns a list of two items: a list of the minimums and a list of the maximums. For example, with
@ -333,9 +373,11 @@ function pointlist_bounds(pts) =
// Function: closest_point() // Function: closest_point()
// Synopsis: Finds the closest point in a list of points.
// Topics: Geometry, Points, Distance
// See Also: pointlist_bounds(), furthest_point(), closest_point()
// Usage: // Usage:
// index = closest_point(pt, points); // index = closest_point(pt, points);
// Topics: Geometry, Points, Distance
// Description: // Description:
// Given a list of `points`, finds the index of the closest point to `pt`. // Given a list of `points`, finds the index of the closest point to `pt`.
// Arguments: // Arguments:
@ -348,9 +390,11 @@ function closest_point(pt, points) =
// Function: furthest_point() // Function: furthest_point()
// Synopsis: Finds the furthest point in a list of points.
// Topics: Geometry, Points, Distance
// See Also: pointlist_bounds(), furthest_point(), closest_point()
// Usage: // Usage:
// index = furthest_point(pt, points); // index = furthest_point(pt, points);
// Topics: Geometry, Points, Distance
// Description: // Description:
// Given a list of `points`, finds the index of the furthest point from `pt`. // Given a list of `points`, finds the index of the furthest point from `pt`.
// Arguments: // Arguments:
@ -363,10 +407,11 @@ function furthest_point(pt, points) =
// Function: vector_search() // Function: vector_search()
// Synopsis: Finds points in a list that are close to a given point.
// Topics: Search, Points, Closest
// See Also: vector_search_tree(), vector_nearest()
// Usage: // Usage:
// indices = vector_search(query, r, target); // indices = vector_search(query, r, target);
// See Also: vector_search_tree(), vector_nearest()
// Topics: Search, Points, Closest
// Description: // Description:
// Given a list of query points `query` and a `target` to search, // Given a list of query points `query` and a `target` to search,
// finds the points in `target` that match each query point. A match holds when the // finds the points in `target` that match each query point. A match holds when the
@ -465,10 +510,11 @@ function _bt_search(query, r, points, tree) =
// Function: vector_search_tree() // Function: vector_search_tree()
// Synopsis: Makes a distance search tree for a list of points.
// Topics: Search, Points, Closest
// See Also: vector_nearest(), vector_search()
// Usage: // Usage:
// tree = vector_search_tree(points,leafsize); // tree = vector_search_tree(points,leafsize);
// See Also: vector_nearest(), vector_search()
// Topics: Search, Points, Closest
// Description: // Description:
// Construct a search tree for the given list of points to be used as input // Construct a search tree for the given list of points to be used as input
// to the function `vector_search()`. The use of a tree speeds up the // to the function `vector_search()`. The use of a tree speeds up the
@ -526,9 +572,11 @@ function _bt_tree(points, ind, leafsize=25) =
// Function: vector_nearest() // Function: vector_nearest()
// Synopsis: Finds the `k` nearest points in a list to a given point.
// Topics: Search, Points, Closest
// See Also: vector_search(), vector_search_tree()
// Usage: // Usage:
// indices = vector_nearest(query, k, target); // indices = vector_nearest(query, k, target);
// See Also: vector_search(), vector_search_tree()
// Description: // Description:
// Search `target` for the `k` points closest to point `query`. // Search `target` for the `k` points closest to point `query`.
// The input `target` is either a list of points to search or a search tree // The input `target` is either a list of points to search or a search tree