Wednesday, December 18, 2013

Computer Graphics

Computer graphics are a blatant example of how much computer technology has improved. The difference between a LCD monitor and a CRT TV is huge. If you show a Ps1 game and a Ps4 game it is astronomical how different the games are. Caring this between the watch design of a watch created  being 20 years ago and the a watch being created today, the overall feel is pretty close. There is certainly differences but for the most part, a watch's basic functionality and design hasn't changed that compared to the basic functionality and design of a graphics card or integrated graphics card.

Here is a quick comparison between the IBM 8514a (yes, IBM made graphics cards!!!)
And the Nvidia Titan.
The sheer difference between size and power is clearly shown, there wasn't even fans on the one of the first graphics cards. The architecture and chip design has made major improvements as well as the general audience buying computers has improved. Allowing for the technology to improve at an amazing pace.

Sunday, December 1, 2013

Computer Security and Cryptogrophy


Computer security is an ever increasing field. With the recent boom of corporate hacking, nation state hacking, and organized criminal hacking and interception cryptography is a big deal.

So where do we start? How do we protect our data? What are viable means are there and how do we go about do we go about researching these topics?

There are a few key things to consider in building security.
1. What are you protecting?
2. Who are you protecting the information from?
3. How much do you care about protecting the information?
4. How much do you plan on investing in terms of time/money/personnel/ and future expenses?
5. Can you do anything once you've detected that information is no longer secure?

If you are trying to protect your information against people who are spying on you with binoculars and already are tapping your line between you and your internet service provider, I'd recommend trying to change locations then setting up some form of PGP(Pretty Good Privacy) encryption and remote login of that computer.

If you are worried about someone taking your hardrive, you probably want to encrypt your hard drive and have the encryption key written down somewhere far away or far on another device that no one knows about.

As far as standard communication, and files, I'd recommend using a PGP encrypted chat client and encrypting your hard drive as well as not downloading or installing any non libre software. As the likelihood that proprietary software is tracking you in some fashion is extremely high.

Sunday, November 24, 2013

Artificial Intelligence


Artificial intelligence is an interesting concept. It isn't very practical without some form of network and variant. What that variant is, is an interesting question and interesting guess.  The animated series Ghost in the Shell: Stand Alone Complex uses an interesting approach. However, the definition of artificial intelligence is rather difficult.

Try looking for a definition and you will most likely find something similar to this:
"the theory and development of computer systems able to perform tasks that normally require human intelligence, such as visual perception, speech recognition, decision-making, and translation between languages."

This is a pretty decent definition. However, it will need to be modified if we ever end up being able to create self-aware programs.  The likelihood of that happening anytime is rather slim though. A good example of AI are programs found in video games. Video game technology has made tremendous contributors to the advancement of AI. One of the large reasons for this is because of the large amounts of money poured into games to make them be more realistic and challenging.

Programming the AI of a fighter or a shooter can be difficult, their needs to be a good balance of how the AI reacts and preforms actions against the character. Finding the balance of difficulty and fairness is something very difficult and takes a lot of test time and algorithm crunching.

Additionally, game provide the capability for large amount of feedback data from users. This allows for big data calculations as well as great statistics in how code should be modeled for the general user.

Friday, November 15, 2013

Sharing is Caring, privacy, content filtering, and applications.

Welcome to the information age, where the governing principles of the world are undefined and misguided. Them being misguided without being defined is rather odd without thinking about the underlying factors. Big business has played a large part int his as well as storage capacities being incredibly cheap. The internet is a wonderful and dangerous place. Anytime you send/share information with another user, that information has the possibility of being read, tracked, traced, copied, and modified. This is a much larger threat then before. The primary reason being that storage space is incredibly cheap and getting cheaper, and that documents are generally rather small.

With everything said, there are times when you want to share. There are plenty of useful tools for this, but remember that when you use a tool that you do not own, you are at the full discretion of the provider. A few lovely tools are: Dropbox, Google drive, Idrive, and Skydrive.
Out of all of these. My favorites are Google drive and Dropbox. Dropbox is rather nice because it cloud storage is the only thing that they do. Additionally, it is very easy and is not email specific. Additionally they have a cool feature that provides you with additional space based on the number of people you invite, to a maximum I believe of 15GB's. Google drive is also pretty neat.  It has a lot of nice sync features, additionally it has a very nice sharing features making it easy to share with who you want. 
However, it is a bit of a pain to setup on GNU/Linux and doesn't work all that well even after you setup. Sharing is both a gift and a curse. It is easy to share, and because it is easy to share things that you didn't want shared can easily find themselves on the web. After something has been on the web and has been viewed by many different people it is almost impossibly to stop people from sharing the information. 




Thursday, October 31, 2013

Data Structures and Algorithms, what they do.

Data structures and Algorithms are an interesting subject. Data structures and the understanding of implementing and when to implement particular data structures are what allow for complex programs and applications to be created. Choosing a data structure for an algorithm/program effects everything from memory allocation, run time, search time, insertion time, and code re-usability. Typically the ideas behind build reusable blocks of code isn't hard, however when choosing data structures it can often make it rather difficult. Have your program work based off of user defined types can drastically change your code and often make it longer and harder to program.

Data structures are exactly what it sounds like. They are structures for holding data. Most data structures are represented with either a cell(http://3.bp.blogspot.com/-o0HXsxh1O-s/TzUzB7a0wlI/AAAAAAAAAZ0/OC03E2t_mBM/s1600/selection_sort_00.gif, example) or with circles often refereed to as nodes. (http://blog.cogswell.edu/wp-content/uploads/2011/04/binarysearch.gif). These structures drastically effect the performance. For example, choosing the wrong data structure in an search algorithm can often change the search time of n from nlogn to n^2. However, space can often just as important if not more important than speed.

A few common data structures are Linked Lists(The most common being Single linked List, double, and circular), Tree's(Binary Tree's, B-Tree's, Red-Black Tree's, 2-3 Tree's), Array's, Hash Tables, and Stacks.

Algorithms are logic that provides some change of state using data structures. Algorithms are generally designed being system and language independent and then are implemented to fit specification. The final result can often look very different then the initial rough draft.


Suggested Reading:
http://en.wikipedia.org/wiki/Linked_list
http://en.wikipedia.org/wiki/List_of_data_structures

Friday, October 25, 2013

Hacking, what and why?

Hacking is an interesting subject and when used, should have some sort of context associated with it. Most non technical people believe that hacking is some form of malicious activity. However, that is not is not accurate.  In the words of Richard "hacking means exploring the limits of what is possible, in a spirit of playful cleverness. Activities that display playful cleverness have "hack value". This is a decent and interesting definition. A great example of this are hackathons. Hackathons are where numerous people are invited and attend a coding event to produce new projects.

With that said, there are many different forms of hacking. Particularly where it involves security. However, it is best to remember that hacking and security are two separate functions that have some common ground. With that said, there are a few different common security hacking classifications. 
These include Black hat, White hat, Grey Hat,  Hacktivist and many more. (http://en.wikipedia.org/wiki/Hacker_(computer_security)). The most common public interpretation of hackers are black hat's. Black hats are hackers that disrupt computer security for personal gain at the expense of another. The hacking community has a group that counter acts Black hats. These hackers are referred to white hat's. Hence WhiteHat security's name(https://www.whitehatsec.com/).

The motivations of each hacker and why they do what they do is complex. It can be as simple as for personal financial gains, to respect and cleverness , to being an activist trying to prove a point(Hacktivist). (http://en.wikipedia.org/wiki/Hacktivism). Hacking can be a fun and interesting activity, however it has consequence. Whether it is simply playful hacking, for example going to a hackathon and building a neat app and using resources that fall inline with the hack, to hacking a military base. All hacks require the hacker to tonight about potential consequences. Hacking a military base has some very obvious merits and consequences, but the consequences and merits of hacking at a hackathon are not always obvious. For example, if you end up building a hack that you wish to make money off using a library at the hack, who owns the hack and what roll does money play?

Sources / Additional Reading:

Friday, October 11, 2013

Open Source: Pro's Con's and the in between



Open source is the sharing of source files. What this means is that if you compile the source or interpret the source you should be able to predict what is going to happen. With that said,  it is not always true.
Also there are many problems that arise between proprietary systems and open source systems. Knowing the strengths and weaknesses of both are key to being a good developer or at least understanding what you are talking about. 

These topics range from security, data retention, what you see is what you get (WYSIWYG). One of the great things that open source provides is that it allows for many different people to look at your code. This helps finding new bugs, optimizing algorithms, developing awareness about your project, and allowing people to understand what your project does. 

Some of the pro's of a proprietary system is that it easier to make money or a business model off of it. Additionally you do not have to worry about competition taking code, modifying it, and selling it. You can sell binaries without as a contractor such that if there is a problem with the code they have to either reverse engineer the code or rehire you.

Looking at the grey, there are controversial topics, assumptions, and many other things to consider about what goes on between the two. With open source projects, most of the time people are encouraged to expand upon the project. Usually a group or person oversee's new code that is submitted and incorporated it into the project. However, code does not always do what it appears to do. Additionally it takes a lot of work to look over code, decide of it works and is useful. A great example of this is the IOCCC(http://www.ioccc.org/). With proprietary systems, users and sometimes developers do not know where or what is happening to the data they are submitting. Additionally, you can not change proprietary software. The closest thing you can do is to use API's and try to add onto the project.

Opensource generally lags behind proprietary solutions. This is typically because there is a lot more money in proprietary software. Also opensource projects are often very diverse while proprietary solutions are more narrow.


Some very liberal thoughts on opensource, and why it matters: