Just another Reddit refugee

  • 1 Post
  • 157 Comments
Joined 2 years ago
cake
Cake day: June 11th, 2023

help-circle



  • but I’ve accepted defeat in trying to understand it

    I may have shared the link but even I don’t know how it how it works.

    It’s like admiring the Eiffel Tower; you can understand that it’s a marvel of engineering without understanding the underlying engineering concepts. Such experiences are rare but they truly humble you.

    Regarding the square root, understand the following concepts

    1. Bit shifting simply shift the bits to a certain side (Left or right) => 0010 << 1 0100
    2. Mathematically, it multiplies or divides the input number with a factor of 2, depending upon the type of shift
    3. If you shift the number n with a nice shift amount x (I have greatly greatly over-simplified this), then you can calculate the inverse sq. root since inverse square root is 2^(-1/2)
    4. Calculating the inverse square root manually will take lots of clock cycles, which was not feasible for a FPS game with the limited h/w
    5. Bit shifting is a lot faster since we are not computing, but instead shifting

    The resultant shifting gives us an answer which is close enough to the answer, and that is good enough for FPS games for calculation of reflections.

    Source for bitshifting

    PS: Someone who is more experienced in this domain can correct me if I’m wrong.












  • Most of the time, the package is available on the standard package manager which makes the process extremely simple. Hardest part is knowing the package name. If you know apt search, you don’t even have to search on the browser to find the package name. But certain packages are only available as tar.gz or as source. But those are usually not encountered by newbies.

    If someone is using Nix, they generally don’t have trouble finding packages. Also, Nix has more packages compared to AUR.