This week I finished up wiring the robot and wrote code to run and send angle feedback position moves. It took alot of trouble shooting to get all three angle sensors accurately measuring 0-180 of the three main actuators but luckily it wasn’t to hard to get the vacuum to turn on and off. I spent alot of time this week wiring, troubleshooting, and programming the robot arm. Luckily all the work paid off and we had a successful package pick up and move. I was able to get the robot to run to 7 diffrent positions in a row using a command sender app and a Arduino control sketch. I got the robot to pick up a moving package on its 15th try.
Team’s Status Report 3/15
This week, we completed our qr tracking algorithm for realtime tracking down the conveyor belt. This program also includes code for determining the box’s speed and depth (y-coordinate). We loosely tested it using our Brio3000 webcam on actual boxes moving on the treadmill, and it seems to work accurately. We also wired the robot arm and got it to pick up packages. We tested the voltage feedback for each component and dialed the angles in the Arduino code to have each actuator have an accurate 0 – 180 measurement. We were able to get t1 and t2 to run specific angle moves with feedback.
Our current main concern is the time it will take the robot arm to grab the package from the treadmill. We plan to extensively test the vision program, PC-Arduino connection, and tweak the motors / Arduino responsiveness to get accurate timings measured.
Our next steps are to finish wiring the robot arm’s motors and getting it to run multiple sequential moves (accurately and quickly). We also plan on completing the Python/Arduino interfacing code so that we can immediately run our vision software as soon as the arm is ready.
Marcus’s Status Report 3/15
This week I soldered most of the arm wiring, and connected it up to an Arduino controller. I tested the voltage feedback for each component. The 360 angle sensors were more like 180 so I had to account for dead space in the actuator movement. It took many iterations of Arduino to get the angles dialed to have each actuator have an accurate 0 – 180 measurement. I then wired the motors for t1 an t2. I had to get the direction of rotation and limit switches right through flipping wires. I was able to get t1 and t2 to run specific angle moves with feedback. I then wired the vacuum and got the robot to do a box pick up move.
Teams Status Report for 3/8/25
This week we worked on the design report and planning out the connection of our algorithms. We discussed using pixel differences in the qr to judge the height of the box on the treadmill. We are working to test the camera and the rest of our electrical components. When we get the robot arm to work were are going to feed it live position control calculate from camera data.
Here is about halfway finished soldering and wiring of the robot arm motor control box.
Marcus’s status report for 3/8
These weeks I worked on the report and wiring the robot. I was able to wire about half of the robot and do tests on one of motors and angle sensors. I was able to create a preliminary Arduino angle feedback control system for 1 motor. One setback is that the “360” angle sensors were actually 250, and I think the overall cause was ESP32 only supporting 3.3v and not 5. This problem might require a switch to Arduino. Otherwise everything going smooth, next week I am going to finish wiring the robot arm and do full movement tests.
Marcus’s Status Report for 2/22
This week I moved a treadmill to a stable location and ran speed tests. Additionally I took it apart to see the motor and pulley setup. Planning on ordering electronic components in the next week. I need to ask for where to get bulk 18-22 awg wire. I also made a 3d kinematics visualizer and move solver
Team Status Report for 2/22/25
This week we worked on finalizing out design, and camera setup. We have received the treadmill and camera, and are going to run tests accordingly. We ran the treadmill to see what speed settings it had and .5 mph is the lowest we can go without modifying the treadmill. This speed is fast relative to the robot arm so we are going to do some calculations on required move kinematics.
Marcus’s Status Report for 2/15/25
This week I finished designing and printing the robot arm. My biggest challenges next week will be wiring the motors sensors and controllers. I will then need to connect the ESP32 to a computer and see if I can get position feedback, and do PWM motor control. Ive made a wiring diagram but will need to order many components. The suction gripper has proved effective on lifting packages > 4 lbs.
I set up coordinate frame transform and made an algorithm for setting the positions of robot moves .
Team Status Report for 2/15/25
This week we worked on planning out our kinematic flow. We also looked into camera options and purchased a camera for computer vision. We are working on developing kinematic planning algorithms for the robot. We decided on how we are going to set up the camera in relation to the conveyor belt: 1m above. We decided to change the scope of our project to include boxes of different heights, which will greatly increase our project’s overall usefulness. We decided to use OpenCV modules to determine the size of the QR code on each box, from which we should be able to extrapolate the height of the box.
A was written by Marcus, B was written by __, C was written by Matt:
A: In response to safety, we want a strict perimeter around the robot that puts people our of arm range. Additionally a full stop control should be established. In response to public welfare, back strain and warehouse related injuries are the main aches that our product aims to sooth. In regards to public health, fast packages will help people get their meds and happiness faster.
B:
C: Our project directly addresses the growing need for efficient and cost-effective package sorting in warehouses and distribution centers. As commercialization and e-commerce shipments continue to boom, the number of packages that need to be sorted will eventually reach unsustainable levels. This is especially true due to human inefficiencies, rising labor costs, and the physical toll of the work itself. Our robotic arm would significantly reduce labor dependency, which would allow businesses to minimize sorting errors, optimize workflow, and improve overall operational efficiency. This would affect the entire supply chain and improve the overall production, distribution, and consumption of goods.
By using our robotic arm to reduce labor costs and standardize sorting speed/accuracy, warehouses would be able to increase their package volumes, leading to greater profitability. Additionally, our robotic arm would streamline logistics and reduce bottlenecks, which would ultimately enable faster order fulfillment. Ideally, consumers would benefit from quicker delivery times, which would also increase their consumption. Another interesting effect of automating package sorting is that it allows companies to reallocate funds for human labor towards higher-value roles, which would potentially improve overall productivity and economic growth.
Team Status Report for 2/8/25
The most significant risk that we face is getting the precision of the robotic arm to be accurate enough to locate the boxes. We will need the forward and inverse kinematic equations to be spot on along with the sensor data to be able to locate the box correctly. If this isn’t precise enough, the vacuum suction will not be able to pick up the box and our MVP will not need to be achieved. We are going to manage this risk by focusing on significant simulation for the kinematic equation solver and also getting a vacuum suction with strong enough force to be able to pick up objects even if the location of the arm isn’t extremely precise. Our contingency plan might be able to have the robotic arm punch the boxes off the conveyor belt instead of using suction, which won’t need as much precision.