Friday, November 13, 2015

Battle Map Explorer

Unfortunately the Kickstarter project I created did not get funded. Here is what the funding graph looked like: Today I released an open source project based on the idea used in the Kickstarter project: https://github.com/byronknoll/battle-map-explorer

Wednesday, November 11, 2015

cmix v8

I have released a new version of cmix. I have also migrated the code from a private Bitbucket repository to a public GitHub repository: https://github.com/byronknoll/cmix.

Saturday, April 25, 2015

Baka Analytics



I have a pet hamster named Baka. Baka spends most of his free time running on a hamster wheel. I put together a device to track the hamster wheel's rotation. It uses a Raspberry Pi 2, a magnetic sensor, and Google Analytics. Here is a webpage with live coverage of Baka's running: https://sites.google.com/site/bakaanalytics/. He tends to run about 6 kilometers per day (13,000 rotations) and sticks to a strict schedule of running between 10pm and 6am.

Sunday, March 01, 2015

Picavet

I have been attempting to do aerial photography with a GoPro. My first attempt was using a quadcopter (Parrot AR.Drone):



Unfortunately the GoPro was too heavy for the quadcopter and it kept crashing. I tried two types of mounts for the camera: one on top (pictured above) and one suspended underneath the quadcopter using string. Mounting on top was more stable, but the quadcopter still occasionally crashed so it was too risky to attempt flying high altitudes.

One of my coworkers told me about a way to mount a camera to a kite using a device called a Picavet. I constructed my own Picavet using two wooden rulers and some carabiners:



It works great!

Wednesday, February 04, 2015

cmix v7

I just released cmix v7. I spent a long time fixing a bug which caused cmix v6 to crash in Windows. For v7 I focused on improving image compression.

Thursday, December 04, 2014

Geometric Median

During a meeting with some coworkers we started debating if it was possible to find a better meeting location. Given the starting location of all the meeting participants, could we find a point which minimizes the total travel distance?

It turns out that it is not trivial to solve. The average of the participant locations is not necessarily the optimal point. The actual optimal point is called the geometric median.

I made a HTML5 page which visualizes the geometric median, along with the convex cost function: http://www.byronknoll.com/median.html

Thursday, August 21, 2014

Cardboard

I finally own a VR device: Google Cardboard. It works surprisingly well! I am using it with a Nexus 5, which has a nice display. Cardboard doesn't work quite as well as the first developer edition of the Oculus Rift (see my review here), but it is pretty close. The demo apps for Cardboard are currently quite limited, so there isn't really much to do on it after the first 10 minutes. I am still waiting for my kickstarter edition of the Avegant Glyph: they have delayed the delivery date until next year :(

Saturday, July 26, 2014

Wargames

I recently started a fun activity called wargaming. Wargames are a set of computer science related challenges/puzzles. So far I have completed three of the wargames on overthewire.org: Bandit, Krypton, and Leviathan. I track my progress on wechall.net. wechall.net tracks scores across dozens of wargaming sites and has user rankings/leaderboards. The wargames I have seen touch many different areas of computer science: cryptography, network security, linux tools, C++ debugging, etc. Very educational.

Wednesday, July 16, 2014

Dwarf Fortress


I recently beat GTA V, so I was looking for a new game to play. GTA V is the most expensive video game ever made and has amazing production value. I eventually decided on Slaves to Armok: God of Blood Chapter II: Dwarf Fortress as the next game I would try. It is on the opposite-end of the game spectrum compared to GTA V: it is free, made by a single developer, and has a text-based interface. I am a fan of NetHack and it looked like DF might have some similarities.

I have been playing DF for three days and so far it is incredible. The first day was tough since there is such a steep learning curve. My first fortress was a mess because I didn't understand how stairs/slopes worked - all my dwarves got trapped underground in a pit. I ended up watching a youtube tutorial to figure out the basics. After the tutorial I started up a second fortress and for the last two days I have managed to survive in this.

I had one near disaster when my fortress ran out of food. My dwarves were so hungry that they started ignoring my orders so I couldn't get them to work on actually finding new food sources. Some of my dwarves started dying and one went crazy and started attacking everyone. I thought I was doomed until suddenly a group of immigrants arrived. I immediately put the healthy immigrants to work on making/collecting food. Success!

Today I worked on creating a reliable water source for my fortress. I looked up how wells work on the DF wiki and starting building one. It ended up taking me two hours to finish the well. My fortress is underground and the most convenient water source was from a river on the surface. Channeling water around is dangerous because it could end up flooding my fortress or drowning the workers mining the tunnels. I built a tunnel from the river to a reservoir below my fortress. The well is connected to the reservoir. To control the flow of water I created two floodgates and connected them to levers in my fortress. I could then use the levers to control the flow of water from a safe distance, once the dwarves had finished digging and evacuating the reservoir. In the screenshot above you can see one level of my fortress and a party my dwarves organized in celebration of the new well.

Sunday, July 06, 2014

visibility_polygon.js Version 1.5


I have released a new version of my visibility polygon library. One of the constraints in the old version was that none of the input line segments could intersect. In this new version, I added a function which breaks apart any intersecting line segments into non-intersecting components.

Demo: http://www.byronknoll.com/visibility.html

Thursday, June 26, 2014

cmix v3

I have released cmix version 3. This version is over twice as fast, uses less memory, and gets better compression ratio.

Sunday, June 15, 2014

Backpropagation

Today I derived backpropagation for a logistic activation function and a cross entropy loss function. This has been done before, but I couldn't find the full set of formulas for it online. I am using the variable notation from here: http://neuralnetworksanddeeplearning.com/chap2.html

Wednesday, April 16, 2014

Saturday, March 01, 2014

Vector Earth



I added a new HTML5 experiment to my website: Vector Earth. Inspired by the xkcd now comic, I downloaded some vector map data and tried experimenting with making some of my own map projections. The first projection I implemented was the Azimuthal equidistant projection, similar to what was used for the xkcd comic. If you are interested in map projections, Jason Davies has implemented some very cool demos.

While I was implementing the map projection, I encountered a bug where there was an unnatural vertical line cutting through Siberia. I went to Google Maps to see what Siberia was supposed to look like, and was amused to find that Google Maps seemed to have the same bug!



In both the vector and satellite data, there are strange discontinuities along this line. It turns out that this line is the threshold where 180 degrees longitude meets -180 degrees.

Wednesday, February 26, 2014

xkcd now clock


I liked the clock in today's xkcd. However, it only has a 15 minute granularity. Well, this is something I can fix in HTML5 canvas! I checked to see if anyone else has done this and I think I am the first.

Saturday, February 22, 2014

Texture

Can you guess what this is?



It is a zoomed in picture of the lid to a container of yogurt I ate yesterday. It reminded me of the patterns produced by the Belousov-Zhabotinsky reaction. I have no idea why the lid has such a strange pattern on it.

cmix update

cmix has now surpassed paq8l on both the calgary corpus and enwik8. cmix is probably now one of the most powerful general purpose compression programs. cmix is about the same speed as paq8l, but uses much more memory (which gives it an advantage on large files such as enwik8).

cmix currently uses an ensemble of 112 independent predictors (paq8l uses 552). cmix uses a more extensive neural network to mix the models than paq8l. cmix uses a four layer network with 528,496 neurons (paq8l uses a three layer network with 3,633 neurons).

For both calgary corpus and enwik8, there is still a significant gap until cmix reaches state of the art. PAQAR and decomp8 are both specialized versions of paq8, which use dictionary preprocessing specific to the dataset (i.e. they are not very good at general purpose compression). I think my first official benchmark submission will probably be on the large text compression benchmark. cmix would currently be ranked as 4th out of 183 submissions. However, I still have a number of ideas which should make cmix significantly better, so I'll hold off on submitting until I reach first place!

Saturday, February 15, 2014