Coupler Curve System PDF
Coupler Curve System PDF
Coupler Curve System PDF
Introduction:Mechanisms are mechanical devices that are used extensively in a myriad of applications
which include home-tools, toys, automobiles, and machines. They are essential to the
development and operation of almost any machine. Every mechanical engineering program
includes a course designed to introduce students to various types of mechanisms. The wide
range of topics to be covered and the limited time available pose a challenge to provide
students with necessary modern tools to analyze and synthesize mechanisms. As such a simple
code using a familiar programming environment would enhance the course offerings and allow
for more coverage of mechanism design.
Linkage designer can put to use one of several powerful commercially available
kinematic packages. Most notable of these packages are LINKAGES 2000 1 and SyMec2.
These packages are designed to yield solutions for precision position synthesis problems of 4R
mechanisms for motion, path, and function generation tasks. Computer aided mechanism
packages like ADAMS3, Pro/E4, AutoCAD5, and IDEAS6 have also been used for mechanism
design tasks.
1|Page
SoftLink is being developed for educational use. The software will evolve to eventually
include kinematic and dynamic analysis and control of linkage mechanisms, gear drives,
cam-follower mechanisms, and other mechanisms. Currently it integrates kinematics
synthesis of 4R mechanisms for precision position and optimum synthesis techniques.
SoftLink provides synthesis for three- and four-precision position motion, function, and path
synthesis using dyad equations in complex number forms. The four-position synthesis
employs Burmester theory. Optimum synthesis is required when more than four precision points
are desired. The code implements Simulated Annealing (SA) and Weighted Least- square
techniques for optimization synthesis. Once a mechanism is synthesized for a specified task,
the code allows one to analyze the synthesized linkage to assess its kinematics performance.
This is an important step because mathematical solutions do not guarantee that the synthesized
mechanism can traverse the positions in the desired order or it does not suffer from branching
defects. The simulation option in SoftLink allows the designer to check fine details in the
kinematics before moving to the kinetics design and analysis.
Matlab/Simulink is the platform of choice for several reasons:
(1) It is a code familiar to students and faculty as it is already available and used in many
courses in a curriculum to solve a wide range of engineering problems including control,
communications, DSP, optimization, etc.;
(2) It has a vast library of functions dedicated to numerical computation;
(3) It has an extensive graphics library;
(4) It has Graphics User Interface capability;
(5) It has the proper hooks for communication with external devices;
(6) An extensive set of tool boxes covering a wide spectrum of engineering problems such as
optimization and control;
(7) The code can be compiled to create an executable file that could run independent of
Matlab.
The ultimate goal of SoftLink is to develop an educational mechanical design code which can
be used to perform kinematic and dynamic analysis and synthesis of linkages, gear drives,
cam-follower systems, Geneva mechanism, screw-drives, and other mechanisms without the
need to pay for expensive software. The impetus here is to facilitate teaching/learning of
mechanical systems design using the already available Matalb/Simulink simulation, graphics,
control, and optimization capabilities.
In this paper the basic structure of SoftLink is introduced and its menus and uses are
explained. Two examples are provided to show the capabilities and possible limitations of the
code. The first example is a four precision point synthesis problem solved using Burmester
theory and SA. The second example utilizes SA to synthesize a mechanism for 8-position
path generation task with user defined constraints.
Optimum Synthesis using Simulated Annealing:The theory behind precision and optimum synthesis techniques is well documented in the
literature and will not be addressed here. However, a brief description on features that have
been devised and found to enhance the performance of SA is presented.
1. The objective function built in the code is developed to integrate Grashof criteria and to
force the crank to rotate in one direction. This objective function may be easily modified
by the user as needed.
2. The user can define the limits of any variable (angles, link dimensions, etc.) or choose
to hold any set of variable to specific values or to be within a range of values while
requesting the code to optimize for the other variables. A vector called Modify is added
to
allow
the
user
2|Page
to select the parameters to optimize for while the rest are provided as initial guesses. An entry
of 0 to the Modify vector indicates that the corresponding variable is fixed as the value
provided in the input window and will not be varied in the optimization process. A nonzero
value supplied to the Modify vector represents the upper limit of the corresponding variable
whose lower limit is the value provided in the input window. While this feature adds
computation time, it facilitates the use of the same objective function for many possibilities.
3. The code is designed to change the number of iterations as the number of variables change.
4. Geometric cooling schedule Ti + 1 = cTi is used. The default value for c is 0.9, but it may be
changed by the user.
5. The probabilistic range of variables change as the temperature cools down from the very hot
initial values. This is accomplished by allowing the range for parameters to be selected in
regions that include low probabilities but mainly high probabilities; otherwise too much
iteration may be performed without minimal acceptance rate. The range selection is made
according to the following function
0.25
r current
Thot
SoftLink Structure:SoftLink is designed to facilitate modifications and additions that will be implemented in
future versions. This explains the clear separation between three different components of the
code: the user interface, the solver modules, and the simulator. The user interface is the set of
menus, buttons, popup windows, shortcut keys and other input/output functions that interact
with the user. The solver modules are either precision point solvers or optimization solvers. The
simulation option is made a separate entity to leave room for future enhancements to optimize
graphics refresh rates, choice of link shapes, choices of colors and surrounding plot, and other
features.
From operational standpoint, the software is divided into three levels. The first is
Input/Output (IO), the second is the Data Transfer and Manipulation (DTM), and the third is
the Solver level (Sol). Each level is briefly discussed below. Figure 1 shows a block diagram of
the structure and operation of SoftLink dedicated to 4R linkage design. Figure 2 shows a 4R
mechanism with the main parameters used in the code.
Input/Output (I/O):The IO is very critical and very important for proper operation of SoftLink. The role of the IO
level is twofold: (1) to wait for a command, and once a command is issued, the IO acquires
relevant data, checks the validity of such data, and then provides that data to the DTM level, and
(2) to properly and clearly display the output results.
It is relatively simple to wait and load data from the user, but a more involved part is
checking the validity of the input. This is done by first checking the solver option. For each
solver option a set of constraints and conditions are intelligently posed on the input. This
allows the input modules to modify obvious errors or even accept different inputs for the same
set of options. In case of ambiguity or erroneous inputs, the input modules prompt the user and
returns to the input window for reentry of data.
3|Page
D
B
Input variables:
[, , , , , , , A, , ]
OUTPUT
1
1
2 2
DTM
A, B, C, D
Solver -1
[ , , , .. ]
Solver -2
Solver -3
4|Page
Solver -n
D
B
Coupler curve
j
j
A
A0
B0
Data Transfer and Manipulation (DTM):Even though this stage is mundane in some cases, it could be crucial and necessary in other
cases for smooth operation of the software. Sometimes the input provided by the user is
directly passed to the solver. But in many cases the solver requires data to be re-partitioned
into matrices or vectors differently. Some solvers require different number of inputs. The
DTM fills the missing inputs. The DTM mission could be briefly summarized in two tasks:
(1) Reformatting input data and
(2) Adding missing data or options those are not transparent to the user.
DTM is not a separate module in the code, but rather bits and pieces of code that are
distributed inside functions and subroutines. A good way to distinguish DTM codes is to
consider the solver as a function that could be used independent of SoftLink, which is true for
all solvers, and then considering the input from the user which is different from the input of
the function.
Solvers (Sol):Solvers are functions where pertinent algorithms are coded. They are direct realizations of
solutions available for design of mechanisms. Solvers are either MATLAB functions or
SIMULINK modules. Whenever a new feature is to be added to SoftLink, the first step is to
design its solver. The solver is then tested and used as a function without the user interface
shell. If the results are verified a DTM code is customized for the solver and a new input
form associated with it is constructed. If the solver is tested again and the results did not
match desired results, the problem is more easily determined and limited to the pertinent IO
and DTM parts. One common user mistake is inconsistency of angle formats (deg or radians).
This coding scheme makes the solvers robust and independent, which helps in building a
5|Page
Operating SoftLink:To start the software simply type SoftLink at the MATLAB prompt. Figure 3 shows the
default design that is loaded initially. Currently there are three user interface menus in
SoftLink: File, Solver and Quit. There are also shortcut keys - S to simulate mechanism, D to
input a new design, and H for Help. More will be added in future versions.
The File menu allows the user to save the mechanism task parameters and the link dimensions
for later use. This is done by using the Save command which saves a file in a .mech format.
Open loads a saved file and Save as makes a new file with a different name. Figure 4 shows the
File menu.
The Solver menu allows the user to choose the method used to synthesize the problem. The
Solver menu is shown in Figure 5. The 3-precision-point synthesis requests the user to
provide the coupler point displacements, j, the crank angular displacements, j, and the
follower angular displacements, j, and finally the angular rotations of the coupler link, j as
the mechanism moves from the first position to the j-th position. For three-position synthesis,
these increments are formed as 12 Matlab vectors. The same variables are required for 4precision-point and Least Squares Optimum syntheses except that the number of increments is
3 for 4-precision-point and more than 3 for optimum synthesis. See Figure 6 for and
example of the input window. The synthesis task results in the first position of the
mechanism.
6|Page
7|Page
Application Examples:In this section, SoftLink will be demonstrated by way of two examples. One applies fourprecision position synthesis using Burmester theory and SA and the other is an 8-position
synthesis using SA. The task for the first example is to synthesize a motion generator 4R
mechanism to traverse a straight line trajectory through four prescribed positions using
Burmester theory and SA. The task parameters are given in Table 1.
Table 1 Design positions and solution for example 1
Position
Solution
j
j
A = 0.9507 + 2.9438i
1
B = 0.2387 - 2.0863i
2
1+0i
17
C = -3.3277 + 3.0285i
3
2+0i
33
D = -1.8595 - 1.3819i
4
3+0i
52
Figure 8 shows the two sets of Burmester pair curves generated for the 4 position synthesis
problem. The user can choose the set of solution points from either pair. The color of
associated Burmester points changes to help the user choose the corresponding points. Once
chosen, the code will assemble the mechanism and the user can simulate it to assess its
performance and check for possible branching and order defects. The user may go back and
select different Burmester points until a satisfactory linkage is found. In this example, the
8|Page
Burmester point pairs chosen corresponds to 2 = -8 for the left dyad and to 2 = -9 for the
right dyad. The final solution for this example is shown in Figure 9.
D
A
Precision points
9|Page
j
j
j
1
2
3
4
5
6
7
8
1+0i
2+0i
3+0i
4+0i
5+0i
6+0i
3+3i
-8.9988
-19.1190
-27.8974
-35.5514
-42.0683
-48.3691
21.8695
34.9146
47.2920
61.3130
78.6143
96.7430
-10.6481
-27.8532
-35.7177
-38.8225
-37.0967
-34.1182
10 | P a g e
11 | P a g e