Lab 1 Linearity, Nonlinearity, and the Compound Pendulum

Spring 2025 • E91 • Swarthmore College • Due Mon, Feb 24

In this lab, you will use a compound pendulum to investigate linear and nonlinear dynamics.

Logistics

This lab is self-scheduled; you will carry out the tasks here on your own time. The due date for the lab report is Monday, February 24, but you are recommended to complete the experimental portion of these tasks by February 17. The apparatus is located in Singer Hall 120 (a.k.a. ‘the High Bay’). This space is shared with multiple other engineering labs, so please be mindful of the space and respectful of other people’s work.

Sign up for times in the High Bay here using the drop-down menu as illustrated below. Please keep in mind that there will be other people using the space, especially 1-4 PM, so you are encouraged to find times outside of the usual lab hours. You should all have OneCard access to the High Bay.

signup

Your group has been assigned in Moodle; if you asked to be in a particular group, you have been placed with those students.

Experiments

Equipment and hardware

This lab makes use of a compound pendulum mounted onto a potentiometer. The pendulum is secured with the help of a set-screw to the shaft of the poteniometer. Note: Make sure the set screw is tight; you don’t want the pendulum to go flying off the shaft.

The potentiometer is the Vishay Spectrol 157-11103, which provides a voltage reading that is expected to scale, hopefully linearly, with the angle of rotation of the shaft. The potentiometer is wired with alligator clips: red for power, black for ground, and white for the voltage reading.

Data collection is carried out using the Analog Discovery 3, a multi-purpose data acquisition and signal-generating device. In this lab, the Analog Discovery powers the potentiometer by providing 5V across pins 1 and 3, and reads the voltage from pin 2.

!pendulum2 analogdiscovery

Measurements

Measure the length, width, and thickness of the pendulum. You should also measure the distance of the mounting hole from its closest short edge. In addition, use a mass balance (located in the center of the High Bay) to determine its mass. Note: You will have to loosen the set screw (using the provided allen key) to make these measurements. Make sure you tighten the set screw securely when you return the pendulum on to the shaft; you don’t want the pendulum to go flying off the shaft.

Software

This lab will make use of the open-source software WaveForms from Digilent, the manufacturer of the analog I/O device that you’ll use to collect data. Download WaveForms, install it on your computer, and bring it with you to the lab.

WaveForms can load a ‘workspace’, which is a collection of settings that you can pre-load when you run WaveForms. Download the workspace needed for this lab here. It will look something like this:

workspace

We will be using Waveforms together with the Analog Discovery 3 as an Oscilloscope, which should be a familiar tool for you. If you need to restart from scratch without using the workspace file provided to you, you can re-create the settings by choosing ‘Scope’ as the tool on the startup screen.

A reference manual for WaveForms is available here.

Wiring and Connections

The wiring should already be set up for you; all you need to do is plug in the USB-c cable from the Analog Discovery. In case you need to re-wire the potentiometer to the Analog Discovery:

In case you need to re-connect the alligator clips:

Testing the virtual oscilloscope

After connecting your Analog Discovery to your computer and opening WaveForms, the software should recognize the Discovery 3 with a panel on the bottom right as shown here.

connected

Start scanning the voltage reading by clicking ‘scan’ near the top left, which will start a real-time scan of the voltage reading from the potentiometer. Make sure that ‘mode’ is set to ‘Screen’ as shown here. scan

You should see a trace of the voltage develop across the screen. ‘C2’ reads the voltage directly, whereas ‘M1’ is a moving average that acts as a low-pass filter, smoothing out the noise in the voltage. gif1

The scale and offset of the horizontal and vertical axes can be controlled using the panels on the right, as shown below. In my experience, a good value for time is 3 s/div and for the voltage is 10 mV/div, but you should feel free to change these settings to suit your needs. These settings do not affect the data collected; they only determine how the data are visualized.

rightpanel

Calibration

Before any dynamic data can be collected, you must calibrate the potentiometer. It is important that you perform the calibration as close as possible to when you collect dynamic data to minimize the possibility that environmental uncertainties introduce errors into the calibration. Such errors can be fixed during post-processing, but it is best to minimze them when collecting data.

Drift

It has been noticed that the rest reading of the potentiometer can sometimes drift. Therefore, after switching on the scope, you should wait for the rest reading to settle at a constant value. A good way to decide whether the potentiometer has ‘settled’ is to check if the reading is off by more than 1 mV in about a minute. Your mileage may vary; just keep in mind that this drift is bad for our experiment.

Calibrating at zero degrees

We will measure the angle from the vertical, and so the rest reading — when you are not doing anything to the pendulum — is zero degrees. After you are satisfied that the drift has settled down, make a 5-second recording at 1 kHz to record the rest reading. This is almost certainly overkill, but computers make it easy for us to save five thousand nearly-equal numbers just so we can average them later.

Select ‘Mode: Record’ as shown here, and set the sampling rate to 1 kHz with 5 s of total time.

gif2

From now on, the ‘record’ button will use these settings unless you change them.

Use the ‘Export’ button in the top-left corner to save the result as a CSV file named, e.g., Deg0.csv.

Calibrating at other angles

Use the protractor to make 5-second long recordings of the voltage when the pendulum is held to other angles. One lab partner should hold the pendulum up to the right angle while the other records the reading.

It is up to you to choose how many angles you would like to do this for; the gold standard is to do this at 10 degree intervals between $\theta = 0^{\circ}$ and $\theta = 170^{\circ}$; avoid trying to do this for $\theta = 180^{\circ}$. It is sufficient to do so for positive values of $\theta$, and to assume that the relationship between voltage and angular position is symmetric about $\theta = 0^{\circ}$.

It is recommended that you save each measurement with a name such as Deg20.csv, etc.

Dynamic Experiments

You will conduct a series of experiments in which the pendulum is held up to a certain angle and released from rest. Since you have already calibrated the voltage-angle relationship, you need not measure the angle at which you release the pendulum. For each experiment,

gif3

Collect dynamic data for the following six cases:

Case Description Approximate Angle
Case 1 Low acute angle Below $30^{\circ}$
Case 2 Medium acute angle Between $60^{\circ}$ and $90^{\circ}$
Case 3 High acute angle A little below $90^{\circ}$
Case 4 Obtuse angle Between $90^{\circ}$ and $120^{\circ}$
Case 5 High obtuse angle Around $150^{\circ}$
Case 6 Nearly vertical Just less than $180^{\circ}$

Save each case as a *.csv file.

Checklist for experiments

Theory

The equation of motion for a frictionless compound pendulum can be expressed as

\[\frac{d}{dt} \left( \boldsymbol{h} \right) = \boldsymbol{M}_O,\]

where $\mathbf{h}$ is the angular momentum of the pendulum about its pivot and $\boldsymbol{M}$ is the moment, $\boldsymbol{r} \times \boldsymbol{F}$ relative to the pivot. After some vector calculus, it is possible to show that the equation becomes

\[\ddot{\theta} + \frac{m g l}{I_O} \sin \theta = 0,\]

where

pendulum

Recall that the moment of inertia about the centroid of a rectangle with width $w$ and height $h$ in the out-of-plane direction is

\[I_{G,z} = \frac{m}{12} \left( w^2 + h^2\right),\]

where `$G$’ stands for ‘center of gravity / centroid’. Using the parallel axis theorem, it is possible to write the moment of inertia about a different point — here, the pivot — as

\[I_O = I_G + m l^2.\]

Making appropriate simplifications, use this information to calculate a numerical value for the coefficient in the equation of motion above.

The small-angle approximation

Under the small-angle approximation, $\sin \theta \approx \theta$. With this simplification in mind, write down the equation of motion for this pendulum when friction is neglected. Leave your answer in terms of $m$, $g$, $l$, and $I_O$ for now. Solve this differential equation for the initial condition $\theta(0) = \theta_0$ and $\dot{\theta}(0) = 0$, where $\theta_0$ is the angle with which the pendulum is initially released.

What is the numerical value of the pendulum frequency predicted by this equation? Later, you will compare this numerical value against the observed frequency from the first few cycles of oscillation in each case of your dynamic experiments.

In your answer, make sure you think about the difference between ‘angular frequency’ and ‘frequency’.

Incorporating damping effects

The governing differential equation above is missing the effect of damping. Write down a more complete (still linear) equation of motion in which there is a damping term with units of $T^{-1}$. Then, solve this equation of motion for $\theta(t)$ with the same initial condition as before. Leave your answer in symbolic form; you may find it useful to substitute $\omega^2$ for $m g l/I_O$ when doing so. Your final result will have an exponential term multiplying a cosine term.

Incorporating nonlinear effects

Write down what the governing differential equation would be if the equation included both nonlinear effects and damping effects.

Data Analysis

Experimentally observed frequency

Your dynamic experiments, being affected by friction like all real engineered systems, will have a decaying behaviour in which oscillatory motion eventually dies out until there is no more motion. However, there is often a nearly-constant period with which the pendulum oscillates while it does.

Your first data analysis task is to determine the experimentally observed frequency (in `swings per second’, with units of Hz) for each of cases 1 through 6. You may choose any method to do this, as long as you are consistent across the different experiments. Use your best engineering judgement, and be prepared to explain in your lab report your method and your rationale for choosing this method.

Note that:

Comparison with theory

Compare your measurements of the pendulum’s frequency with the theoretical value that you found from using the equation of motion for a frictionless pendulum undergoing small oscillations. Present this data visually using any method of your choice.

Calibration

Using the static data that you collected, make a plot of voltage on the horizontal axis and angle $\theta$ (in degrees) on the vertical axis. Draw a line (or, if necessary, a curve) of best fit, and determine its coefficients. Your final result should look something like the following, although your specific numbers may be different.

calibration

Use these coefficients to translate data from all six cases into angles instead of voltages. You do not need to turn in this data.

Without any further data processing, plot the resulting information on six axes neatly arranged in a 2x3 or 3x2 grid. In these plots, the y-axis should be in units of degrees, and the x-axis in units of seconds. Note: Do not remove any data from the beginning of your measurement. You may choose to truncate your data toward the end if the pendulum isn’t doing anything interesting.

Data fitting and the damping parameter

It will be clear that the experiments involve such a large degree of damping that using the undamped equations of motion of the pendulum is not very useful beyong a rudimentary estimate of the frequency of its motion. In the next step, you will use the linearized equations of motion with damping to fit the experimental data. To do this, you must have the correct solution to the ‘incorporating damping effects’ part of the Theory section. This solution is in the form of a function $\theta(t)$ that has several parameters; although some of these parameters can be determined theoretically, in this section we will determine all parameters by a best-fit procedure that is described below.

Fitting the pendulum’s nonlinear (?) dynamics to the linear model with damping.

When performing a fit to the data, it is necessary to incorporate some additional parameters that are entirely ‘experimental’, in the sense that they help us reconcile the observed data with the mathematical model that arises from the laws of physics. One such simple model could be of the form

\[\theta(t) = A e^{Bt} \cos (Ct -D),\]

where $B$ and $C$ have some physical meaning, as you found earlier in the theory section; $A$ serves to scale the linear solutions based on the initial condition (recall that, in the linear world, 2x a solution is also a solution), and $D$ serves to move the data around on the horizontal axis so that it starts at the ‘top’ of the cosine curve.

Your task is to:

Below, you will find Python and MATLAB scripts that performs a fit to this equation for a sample dataset that was collected from this apparatus.

import pandas as pd
from statistics import mean,median,stdev
import matplotlib.pyplot as plt
import numpy as np
from scipy.optimize import curve_fit

# Define a function to which data will be fit.
def theta_solution(t,a,b,c,d):
    return a*np.exp(b*t)*np.cos(c*t-d)

# Define a function that can read a data file.
def getData(file):
    tab1 = pd.read_csv(file,
                    index_col=None,
                    header=None,
                    names=['Time','Voltage','AveVoltage'],
                    skiprows=12,
                    )
    return tab1

# Read one of the data files.
experiment_1 = getData("Dynamic1.csv")

# Remove data before and after
start = 450
finis = 12500

# Center data at zero vertically and horizontally
v_offset = experiment_1["AveVoltage"][finis]
t_offset = experiment_1["Time"][start]

# Create data vectors
t_data = np.array(experiment_1["Time"][start:finis]) - t_offset
v_data = np.array(experiment_1["AveVoltage"][start:finis]) - v_offset

# Fit curve and extract coefficients.
curvefit = curve_fit(theta_solution,t_data,v_data)
a = curvefit[0][0]
b = curvefit[0][1]
c = curvefit[0][2]
d = curvefit[0][3]

# Use coefficients to build the {x,y} data that arises from the model
theta_model_vals = theta_solution(t_data,a,b,c,d)

# Plotting
labelstring = f"A={a:.2f},B={b:.2f},cC={c:.2f},D={d:.2f}"
titlestring = "$\theta(t) = A e^{Bt} \cos(Ct -D)$"

plt.plot(t_data,v_data,marker='.',markersize=1,label='data')
plt.xlabel("Time (s)")
plt.ylabel("Voltage")
plt.plot(t_data,theta_model_vals,label=labelstring)
plt.title(titlestring,usetex=True)
plt.legend()
plt.savefig("curvefit.png")
plt.show()

curvefit

You may also choose to use MATLAB. I recommend that you save the following two functions as separate files:

% Define the function to which data will be fit
function y = theta_solution(t, a, b, c, d)
    y = a .* exp(b .* t) .* cos(c .* t - d);
end
% Define a function that can read a data file
function tab1 = getData(file)
    opts = detectImportOptions(file, 'NumHeaderLines', 12);
    opts.VariableNames = {'Time', 'Voltage', 'AveVoltage'};
    tab1 = readtable(file, opts);
end

and then run the following script:

% Read one of the data files using the 'get table' function of MATLAB.
experiment_1 = getData("Dynamic1.csv");

% Remove data before and after
startIdx = 450;
finisIdx = 12500;

% Center data at zero vertically and horizontally
v_offset = experiment_1.AveVoltage(finisIdx);
t_offset = experiment_1.Time(startIdx);

% Create data vectors
t_data = experiment_1.Time(startIdx:finisIdx) - t_offset;
v_data = experiment_1.AveVoltage(startIdx:finisIdx) - v_offset;

% Fit curve and extract coefficients
fitFunc = @(params, t) theta_solution(t, params(1), params(2), params(3), params(4));
initial_guess = [0.01, -0.22, 7.64,6.59]; 
% I cheated here and used a nearly-perfect guess!
% You can explore other curve-fitting techniques, or just guess ... or use
% Python ¯\_(ツ)_/¯
options = optimset('Display', 'off');
params = lsqcurvefit(fitFunc, initial_guess, t_data, v_data, [], [], options);

% Extract coefficients
a = params(1);
b = params(2);
c = params(3);
d = params(4);

% Use coefficients to build the {x, y} data that arises from the model
theta_model_vals = theta_solution(t_data, a, b, c, d);

% Plotting
figure;
plot(t_data, v_data, '.', 'MarkerSize', 1, 'DisplayName', 'data');
hold on;
plot(t_data, theta_model_vals, 'DisplayName', sprintf('A=%.2f, B=%.2f, C=%.2f, D=%.2f', a, b, c, d));
hold off;
xlabel('Time (s)');
ylabel('Voltage');
title('\theta(t) = A e^{Bt} \cos(Ct - D)', 'Interpreter', 'latex');
legend;
saveas(gcf, 'curvefit_matlab.png');

Some debugging will probably be required.

Narrative

Write a lab report based on the pieces of information you have collected and/or generated during these experiments. Make it as self-contained as possible, so that the reader can fully understand the experiments you conducted, the data analysis that you conducted, and the theory that ties them together. Comment on the ability of the linear model of pendulum dynamics to predict the behavior of a real pendulum.

Turn in a single PDF with figures embedded in the narrative. Attach any code you write in an appendix.