Yes, it would be fairly easy to model this in the case of a wall that is only in the y-direction (up/down), but I want a more generic reflection. First, how do we know if there is a collision? There are several methods for collision detection (it's an important part of many video games) but I want to create my own.

Suppose I have a wall with a length of *L*, oriented in some direction, and a shield moving toward it. The first thing I am going to do is to find the position of the two end points for the wall (P1 and P2). Now I can calculate the distance from P1 and P2 to the position of the shield. If the shield is intersecting this wall, the sum of these distances should equal *L*. Here is a diagram:

If I calculate these distances as vectors, the sum of the magnitudes of r1 and r2 (from P1 and P2 to the shield) will only equal *L* if the center of the shield is between the two points. If the shield is outside the points or not yet to the wall, their sum will exceed *L*.

A couple of things to notice. First, I am just dealing with this wall in 2-D, but this method should work in 3-D. Second, I don't care about the size of the shield---I am merely dealing with it as a point object. I don't think this matters for playing with collisions with a wall (we could change this later if it bothers you).

Now for the reflection. This is trickier and my method only works in 2-D so the shield moves in the x-y plane. If I create a wall in VPython (Glowscript), there are some properties of this object which is technically a "box." There is the position of the center of the box, the size of the box and the "axis." The axis is a vector that is perpendicular to the box to describe its orientation.

Here is a diagram showing the shield colliding with the wall. The two important vectors are the velocity and the axis.

Here I have α as the angle between the incident velocity vector and the axis vector. You can find this angle by first finding the dot product between these two vectors and using the following relationship:

Finding the dot product for vectors is simple if you know the vector in component form (the x,y,z components). It's also simple to find the magnitude of these vectors. So, in the end you get the angle between these two vectors. Oh, it's even easier since both the dot product (dot) and the vector magnitude (mag) are built in functions in VPython. But what I really need is the angle θ which shows the amount I would have to rotate the original vector. Based on my drawing, this vector θ would be:

Now that I have the rotation angle, I need to rotate the vector. I can use the rotation matrix in 2-D. Here is the xkcd version of the rotation matrix. It's funnier than the actual matrix. So, that's pretty simple. Now let's put it all together.