Skip to content

Commit

Permalink
Fixed Results folder for Mini Golf
Browse files Browse the repository at this point in the history
  • Loading branch information
smiller01985 committed Apr 28, 2022
1 parent c11415a commit 8751c2b
Show file tree
Hide file tree
Showing 23 changed files with 365 additions and 2,124 deletions.
Binary file added CFL_Core/Libraries/Images/Contact_Images.pptx
Binary file not shown.
10 changes: 10 additions & 0 deletions CFL_Core/Scripts_Data/Doc/CFL_publish_all_scripts.m
@@ -0,0 +1,10 @@
% Copyright 2014-2019 The MathWorks, Inc.

ds_list = dir('*Contact*.m');
for ds_i = 1:length(ds_list)
publish(ds_list(ds_i).name);
HTMLfilename = strrep(ds_list(ds_i).name,'.m','.html');
movefile(['./html/' HTMLfilename],['./' HTMLfilename]);
end
rmdir('html');
clear ds_list ds_i HTMLfilename
@@ -0,0 +1,34 @@
%% Simscape Multibody Contact Forces Library
%
% <html>
% <span style="font-family:Arial">
% <span style="font-size:10pt">
% <tr><b><u>Library Overview</u></b><br>
% <tr>1. <a href="matlab:web('Contact_Forces_Library_Use.html');">Using the Library</a><br>
% <tr>2. <a href="matlab:cd(fileparts(which('Contact_Forces_Lib.slx')));Contact_Forces_Lib;">Library</a><br>
% <tr>3. Forces: <a href="matlab:web('Force_Laws.html');">Laws</a><br>
% <tr>....1. Basic 2D:<br>
% <tr>.......a. Circle-to-Circle Force: <a href="matlab:web('Circle_to_Circle_Contact.html');">Description</a><br>
% <tr>.......b. Circle-to-Finite Line Force: <a href="matlab:web('Circle_to_Finite_Line_Contact.html');">Description</a><br>
% <tr>.......c. Circle-to-Ring Force: <a href="matlab:web('Circle_to_Ring_Contact.html');">Description</a><br>
% <tr>....2. Composite 2D:<br>
% <tr>.......a. Box-to-Box Force: <a href="matlab:web('Box_to_Box_Contact.html');">Description</a><br>
% <tr>.......b. Box-to-Belt Force: <a href="matlab:web('Box_to_Belt_Contact.html');">Description</a><br>
% <tr>....3. Basic 3D:<br>
% <tr>.......a. Sphere-to-Sphere Force: <a href="matlab:web('Sphere_to_Sphere_Contact.html');">Description</a><br>
% <tr>.......b. Sphere-in-Sphere Force: <a href="matlab:web('Sphere_in_Sphere_Contact.html');">Description</a><br>
% <tr>.......c. Sphere-to-Plane Force: <a href="matlab:web('Sphere_to_Plane_Contact.html');">Description</a><br>
% <tr>.......d. Sphere-to-Tube Force: <a href="matlab:web('Sphere_to_Tube_Contact.html');">Description</a><br>
% <tr>.......e. Sphere-to-Cone Force: <a href="matlab:web('Sphere_to_Cone_Contact.html');">Description</a><br>
% <tr>4. Friction Force: <a href="matlab:web('Friction_Laws.html');">Laws</a><br>
% <br>
% <tr><b><u>Test Models</u></b><br>
% <tr>1. Disks in Box (2D): <a href="matlab:cd(fileparts(which('Test2D_Disks_in_Box.slx')));Test2D_Disks_in_Box;">Model</a><br>
% <tr>2. Balls in Box (3D): <a href="matlab:cd(fileparts(which('Test3D_Balls_in_Box.slx')));Test3D_Balls_in_Box;">Model</a><br>
% <br>
% </style>
% </style>
% </html>
%
% Copyright 2014-2019 The MathWorks(TM), Inc.

Binary file not shown.
@@ -0,0 +1,6 @@
<?xml version='1.0' encoding='UTF-8'?>
<Info>
<Category UUID="FileClassCategory">
<Label UUID="e758491f-dede-4c34-ae7d-553888133829" />
</Category>
</Info>
@@ -0,0 +1,6 @@
<?xml version='1.0' encoding='UTF-8'?>
<Info>
<Category UUID="FileClassCategory">
<Label UUID="e758491f-dede-4c34-ae7d-553888133829" />
</Category>
</Info>
@@ -0,0 +1,6 @@
<?xml version='1.0' encoding='UTF-8'?>
<Info>
<Category UUID="FileClassCategory">
<Label UUID="e758491f-dede-4c34-ae7d-553888133829" />
</Category>
</Info>
@@ -0,0 +1,6 @@
<?xml version='1.0' encoding='UTF-8'?>
<Info>
<Category UUID="FileClassCategory">
<Label UUID="e758491f-dede-4c34-ae7d-553888133829" />
</Category>
</Info>
Binary file modified Examples/2D/Mini_Golf/Mini_Golf_Results.xls
Binary file not shown.
5 changes: 5 additions & 0 deletions Examples/2D/Mini_Golf/Results/README_run_course.txt
@@ -0,0 +1,5 @@
Run MATLAB script Mini_Golf_Run_Course.m
That code will run each hole and save the path of the ball
on each hole to this folder as a MATLAB figure.

Copyright 2012-2022 The MathWorks(TM), Inc.
4 changes: 2 additions & 2 deletions Examples/2D/Mini_Golf/Scripts_Data/Mini_Golf_Run_Course.m
@@ -1,5 +1,5 @@
% RUN COURSE AND SAVE RESULTS IN EXCEL FILE
% Copyright 2012-2019 The MathWorks(TM), Inc.
% Copyright 2012-2022 The MathWorks(TM), Inc.

% RETURN TO HOME DIRECTORY SO THAT FIGURES ARE SAVED IN CORRECT FOLDER
cd(Mini_Golf_Model_HomeDir);
Expand Down Expand Up @@ -35,7 +35,7 @@
MGT.SimTime(hole_i) = Elapsed_Sim_Time;

% SAVE FIGURE WINDOWS TO A FILE
saveas(gcf,['./Results/Ball_Path_' HoleList(hole_i).Name],'fig');
saveas(gcf,[pwd filesep 'Results' filesep 'Ball_Path_' HoleList(hole_i).Name],'fig');
close(gcf);
end

Expand Down
Binary file modified Examples/3D/Simple/Friction/Frict3D_01_Box_on_Table.slx
Binary file not shown.
Binary file modified Examples/3D/Simple/Friction/Frict3D_02_Ball_on_Table.slx
Binary file not shown.
11 changes: 11 additions & 0 deletions LICENSE.md
@@ -0,0 +1,11 @@
Copyright (c) 2020, The MathWorks, Inc.
All rights reserved.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
3. In all cases, the software is, and all modifications and derivatives of the software shall be, licensed to you solely for use in conjunction with MathWorks products and service offerings.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.




255 changes: 255 additions & 0 deletions README.md
@@ -0,0 +1,255 @@
# **Simscape Multibody Contact Forces Library**
Copyright 2014-2022 The MathWorks, Inc.

[![View Simscape Multibody Contact Forces Library on File Exchange](https://www.mathworks.com/matlabcentral/images/matlab-file-exchange.svg)](https://www.mathworks.com/matlabcentral/fileexchange/47417-simscape-multibody-contact-forces-library)

This library contains contact force models for use with Simscape Multibody.
They can be used for intermittent contact (parts bouncing off each other)
and persistent contact (parts resting on each other).

**Please note that the Spatial Contact Force block has been added in R2019b.**
**You should see if this block meets your needs before using this library.**

**See File Exchange submission [Spatial Contact Force Examples Simscape Multibody](https://www.mathworks.com/matlabcentral/fileexchange/109680-spatial-contact-force-examples-simscape-multibody)**

You are welcome to use these models in your own projects. If you need to
include the library in your own example, I recommend you use just the
project Contact_Forces_Core.prj in subfolder Core. You can either use it
directly, or include it as a Referenced Project just as is done
in this project.


General approach for using this library:
1. Identify the parts in your system that will hit each other during simulation
2. Figure out which edges or surfaces will touch.
The contact models provided allow you to model contact between combinations
of connected circular arcs with straight lines (2D)
and spheres with flat planes or cylinders (3D).
3. Add reference frames for the lines and arcs that will touch.
4. Add the correct contact force model between the two frames.

See the examples to understand how they are used.

Recommendations:
1. Start with stiffness of 1e4 and damping of 1e2 and adjust from there.
2. Use solver ode23t, Relative Tolerance = 1e-4, Absolute Tolerance = 1e-5
and set the maximum step size to 1e-2.
3. If you get unexpected behavior (parts flying through one another,
system gaining energy) your tolerances are not small enough.
Reduce tolerances by a factor of 10 and max step size by a factor of 10
until you get expected behavior. Reducing stiffness and increasing damping
can also help.

### **Release History**
**v5.0 Sep 2019** (R2019b through R2020a)
1. Move to MATLAB Projects

**v4.1 Mar 2019** (R2015a through R2019a)
1. Updated v4.1 for R2019a
2. Minor changes to accommodate physical signal units

**v4.1 Nov 2018** (R2015a through R2018b)
1. New example Caster_4_Whl.slx
Models a four-wheel cart with casters on front wheels
2. New example sm_build_spheres_in_sphere
MATLAB code to automatically assemble a model that has
a user-defined number of spheres inside a sphere with
contact forces between all inner spheres and between
inner spheres and outer sphere.

**v4.1 Sep 2018** (R2015a through R2018b)
1. Updated v4.1 for R2018b
2. All v4p1 have updated Extr_Data_Cam_Roller_Curve.m

**v4.1 Mar 2018** (R2015a through R2018a)
1. Adjusted Sphere to Belt Force (in 3D, Composite Forces)
Changed orientation of reference frame for the two
Sphere to Tube Enabled Forces. Z-axis flipped 180 deg
so that vx and wz inputs have the same sign.
2. Adjusted sm_tread_drive example.slx
Uses adjusted Sphere to Belt Force, test sequence altered
to show turning and show both treads striking bump in
forward and reverse.
3. New example sm_robot_6legs_4bar.slx
Models 6-legged robot. Legs on each side are a pair of
connected four-bar linkages. Shows how to model robot
walking on uneven surface.
4. Added CFL_contact_setModel.m
Function to select force law in all contact forces in model.
5. Additions to support Parts_Lib.slx
Extrusion file Extr_Data_TriangleRounded_Holes.m and
various images for masking parts.

**v4.0 Mar 2018** (R2015a through R2018a)
1. Added Sphere to Tube Enabled Force
Sphere to Tube force that can be enabled/disabled
and can be used to model the ends of a driven conveyor belt.
2. Added Sphere to Belt Force (in 3D, Composite Forces)
Used to models spheres on a moving conveyor belt. Can
also be used to model vehicles that ride on treads
like a bulldozer. See sm_tread_drive
3. New examples sm_tread_drive, Frict3D_Balls_on_Driven_Tube
These examples use Sphere to Tube Enabled Force and
Sphere to Belt Force.
4. Added sm_ball_bearing_testrig example
Models a ball bearing with variants that use
Common Gear Constraint (ideal) and contact forces
(permits vibration).
5. Added extrusion script Extr_Data_Block_NotchCircle.m
Used to calculate cross-sectional profile for inner and
outer race in Ball Bearing Testrig example

**v3.9 Jan 2018** (R2017b)
1. Added Cam Roller Constraint.
Uses Point-on-Curve Constraint to model circular
roller on a cam with arbitrary profile.
2. Added Extr_Data_Cam_Roller_Curve.m to calculate
path of Point-on-Curve Constraint.
3. Added Cam_Follower_Constraint example.

**v3.8 Sept 2017** (R2017b)
1. Updated for R2017b

**v3.7 July 2017** (R2015b through R2017a)
1. Added Sphere to Cone Force. Contact force is active on
inside and outside of cone. Also added extrusion script
Extr_Data_Frustrum_Conical.m and example
Coll3D_08_Ball_in_Spinning_Cone.slx
2. Sphere to Tube Force - fixed relative velocity calculation in
Contact_Forces_Lib/3D/Sphere to Tube Force/Forces/Ff/vTan
Previous releases delivered incorrect results if the cylinder
could spin. Added new example Coll3D_07_Balls_and_Sliding_Tube.slx
3. Extr_Data_Box.m: functional change, parameters are full width
and height instead of half width and half height. Affected
parameters within a few examples, such as Spinning Boxes
4. Extr_Data_Cam.m: Changed to Extr_Data_Cam_Circles.m, which has
two additional parameters (radii of holes). Affected example
Cam Follower and the UI for parameterizing the cam.
5. Many 2D contact forces have been modified so that they
no longer refer to the World frame. This permits them to be
used in any plane, not just the x-y plane.
6. Circle to Ring Force: calculations adjusted to use consistent
distance to contact point for circle and ring. May result in
minor changes to simulation results.
7. Mask commands adjusted - eliminated imread(), use option
"Opaque with ports" (R16a and above), and other settings.

**v3.6 Mar 2017** (R2016b through R2017a)
1. New example: Ball on Wheel with Controller (2D Friction Examples)
Models a ball balanced on a wheel.
2. Removed MATLAB variables from blocks in Contact_Forces_Lib.slx
Some library elements contained MATLAB variables in the dialog box
parameters on the Dimensions and Visual tab. These were replaced
with hardcoded default values to avoid warnings about undefined variables.
3. Additional parameters were added to the Sphere block in Parts_Lib.slx
to enable the marks to be shown or hidden per axis.
4. New script CFL_SaveLibsOnly.m that copies only the critical files
of this repository to a new folder so you can include them in
your own project.

**v3.5 Jan 2017** (R2016b)
1. Added Face-to-Plane in 3D/Composite Forces. This is useful for
two flat square surfaces that may contact each other at arbitrary
angles. It assumes no edges will intersect (one square is
significantly larger than the other
2. Added Face-to-Belt-Faces forces in 3D/Composite Forces. This is
useful for modeling 3D boxes on conveyor belts where only one
face of the box will encounter the belt. It accepts the
speed of the belt as an input signal (vx and/or vy)
3. Added Sphere-to-Plane Enabled Force. This is used within the
composite force Face-to-Belt-Faces composite force
4. Added example Gripper with Conveyor Belts (3D Applications).
Uses the new forces to model a box that is transferred by a
gripper between two conveyor belts. One belt brings the box
to the gripper, the other moves it away.
5. Additional parameters were added to the Cylinder block
in Parts_Lib.slx to enable arbitrary colors for the cylinders.

**v3.4 Sep 2016** (R2016b)
1. Fixed outputs for Circle-to-Ring, Sphere-to-Tube, Sphere-to-Plane
Force output signals for these signals now go to zero when
circle/sphere leaves active range for force, where active range is
an arc of the ring/tube or length of the plane. Previously, the
measured value for the force would be held if the force was active
as the circle/sphere left the active range for the force.
2. Copy for Merge block added in Sphere-to-Plane block
This block is necessary in some configurations.


**v3.3 Apr 2016** (R2016a)
1. Added optional visualization for contact surfaces
The surfaces associated with the contact forces can now be visualized.
This helps you confirm you have oriented the surfaces properly and
defined them to be an appropriate length or active range of angles.
2. All contact forces now have an additional tab labeled "Visual". On
this tab you can enable a visualization of the surface, which is done
using a Solid with density set to 0. For the 2D contact forces you
will need to define the length of the surface along the z-axis of
the contact force and it is used for visualization purposes only.
You can show/hide all contact surfaces in the model using the
new function CFL_visual_setOnOff.m in the Scripts_Data directory.

Additionally in this release, a number of plotting scripts have been
added to the examples, and in many cases the variables used by
the example were moved to the Model Workspace.

**v3.2 Mar 2016** (R2015b through R2016a)
1. Disabled zero crossings in some Abs blocks
Affects Circle-to-Finite Line, Sphere to Finite Plane
The zero-crossings in Abs blocks used to check the displacement
of the circle/sphere reference frame from the line/plane
reference frame along the line/surface (y / xy) direction is
not necessary. When the line/plane can move along the (y / xy)
direction, it can lead to excessive zero crossings, slowing down
the simulation.

**v3.1 Mar 2016** (R2016a)
1. Renamed Simscape Multibody Contact Forces Library
2. Geneva drive model imported from CAD is now parameterized


**v3.0 Sept 2015** (R2015b)
1. Updated to R2015b

**v3.0 July 2015** (R2015a)

**(3D Models)**

1. Sphere-to-Sphere, Sphere-in-Sphere, Sphere-to-Plane,
Sphere-to-Tube added, all with optional friction model
2. Added 3D collision and friction examples
3. Added Two Wheel Robot example (3D Applications)

**(2D Models)**

4. Modified 2D enabled forces
** Change from v2.0 -- may require you to update your models **
Modified Circle to Circle Force Enabled,
Circle to Finite Line Force Enabled to use a bus as the
input signal instead of signal input. Bus permits user to
optionally define enabled/disabled, and to set velocity
perpendicular to normal force (vy). Primary use is for ideal
models of conveyor belts.
5. Added 2D/Composite forces (Box to Box force, Box to Belt force)
6. Added Belts_01_Two_Belts.slx (simple conveyor belt example)

**(Documentation, Dialog boxes)**

7. Updates to all dialog boxes (added images, fixed prompts and description)
8. Documentation revised


**v2.0 September 2014** (R2014a)
1. Added optional friction model (Stick-Slip Continuous)
to Circle to Circle, Circle to Finite Line, Circle to Ring
2. Added all Friction_* examples
3. Added Spinning Boxes example
Shows box-to-box contact force
4. Fixed callback commands, all contact force blocks
Set variant in Initialization commands instead of mask callbacks
5. Fixed Circle to Finite Line, Circle to Finite Line Enabled
Force on line was applied in wrong reference frame

**v1.0 August 2014** (R2014a)
1. Circle-Circle (Enabled), Circle-Line (Enabled), Circle-Ring
2. Examples: 7 Simple , Cam Follower, Geneva Drive. Mini Golf compatible

0 comments on commit 8751c2b

Please sign in to comment.