Sandbox/ReverseEngineering
Reverse Engineering
Reverse engineering software involves reversing a program's machine code to obtain the original source code or determine the file structures the program uses. This is done when source code is lost or is not available. For example, when a project is reactivated after being dormant for years to add new features to a product, the original design documentation may have been lost. Also, when companies are writing a program that must interface with a second company's software, the second company may not have any incentive to cooperate by describing how the data in the files they use are organized, forcing the first company to deduce it on their own. Sometimes, this process is used to improve the performance of a program, to fix a bug, or to find a virus. When the source code is obtained in this way for any of these reasons, it is legal and necessary. Reverse engineering software to copy it constitutes a copy¬right violation and is illegal.[1]
Hardware reverse engineering involves taking apart a device to see how it works. If a processor manufacturer wants to see how a competitor's processor works, the company can purchase the processor, disassemble it, and then make a new processor similar to it. In some countries, this process is illegal. Hardware reverse engineering is quite expensive and requires an expert in the field.[1]
Design Considerations
Carefully consider the lab objectives and what needs to be done to achieve them:
- What made or will make the results, inaccurate or imprecise?
- If the robot failed a test, why did it fail?
Center of Gravity
Center of Gravity is the place in a system or body (such as a robot) where the weight is evenly distributed and all sides are in balance. An example of the center of gravity is the middle of a seesaw when it is balanced.
You can think of a robot’s center of gravity as the “center position” of all the weight on the robot. Because the Center of Gravity uses both weight and position, heavier objects have a greater effect than lighter ones in determining where the center of gravity is. For example, if your robot can collect, hold, and/or manipulate objects, those objects change the center of gravity as they are being manipulated because they add weight.
Likewise, pieces that are farther out have a greater effect than pieces that are near the middle of the robot. So, if your robot has an arm that lifts and/or reaches, it's center of gravity changes with that movement.
Drivetrain Design
The most basic, multi-functional competition robot Drivetrain design consists of:
- A rectangular Chassis (the structure of a mobile robot that holds wheels, motors, and/or any other hardware used to make up a Drivetrain)
- Two Motors
- Four Wheels
- Gears transmitting Power from the Motors to all Wheels
Drivetrains can come in all shapes and sizes - some don’t provide power to all wheels, use different types of wheels, or are not even a rectangular shape! Whatever the details of your Drivetrain, you should always be aware of a property known as Turning Scrub.
Turning Scrub is the friction that resists turning. This friction is created from the wheels dragging sideways on the ground as a robot (or another mobile vehicle) turns. The greater the Turning Scrub in a Drivetrain, the harder it is for a robot to turn. Turning Scrub in a basic Drivetrain can be easily managed and minimized in two ways:
1. Make sure that the Wheelbase (distance between Drivetrain wheels) is wider (side-to-side) than it is long (front-to-back):
2. Use different wheel and/or tire types to reduce the friction of Turning Scrub:
Part 1: Reverse Engineering
Upon receiving the pre-built robot, selected by the TA, analyze the design and performance of the robot by both physical inspection and basic testing (i.e. run the robot at least once to see how it works). Run the robot once on the ramp and once on the flat surface in Section 1. There are 5 basic problems in the pre-built robots. The problems are listed below:
- The Center of Gravity of the robot is too high. This will be observed when the robot is tested over the ramp. The high center of gravity does not allow the robot to traverse the hill.
- The incorrect Drivetrain is installed. The lack of tires on the rear wheels of the robot cause it to slip when it tries to turn.
- The Light Sensor is positioned incorrectly. The Light sensor is more than 2 cm above the ground.
- The Gyro Sensor is installed in the incorrect orientation. It has been installed vertically which hinders its functioning.
- The Ultrasonic Sensor is also oriented incorrectly. The Ultrasonic sensor is installed in the z-axis orientation whereas the robot will need the sensor to record data in the x-axis.
The fixes for these problems are listed below:
- The Connectors connecting the EV3 Brick and the chassis can be shortened to lower the robot.
- Disconnect the Gyro Sensor
- Remove the angled connectors marked in the picture below
- Remove the right-angled connectors shown in the picture below
- Connect a 7-hole connector to the square frame as labeled in the picture below using the blue arrow:
- Connect the right-angled lego pieces as marked in the picture above using red arrows.
- The Tires can be attached to the rear wheels which will provide enough traction for a proper turn.
- The Light Sensor can be moved to a different mounting position to make it closer to the ground.
- The Gyro Sensor can be flipped to make it horizontal.
- Connect it as shown in the picture below
- The Ultrasonic Sensor can be oriented so that it’s horizontal instead of diagonal. This will be achieved when the Center of Gravity is brought down.