Blog Articles 116–120

Moral Questions on Predictive Policing

The Guardian ran an article this weekend discussing predictive policing and its future. Read it, it’s worthwhile.

I greatly appreciated a number of the moral concerns Morozov raises, and he does an excellent job of connecting the issue to much of its surrounding social context. He also is quite balanced in his approach, urging caution while being cognizant of the real, on-the-ground benefits of the technology.

Unfortunately, he falls into the same trap as Eli Pariser (The Filter Bubble) in ascribing algorithmic deficiencies to questionable allegiances of their creators:

But how do we know that the algorithms used for prediction do not reflect the biases of their authors? For example, crime tends to happen in poor and racially diverse areas. Might algorithms – with their presumed objectivity – sanction even greater racial profiling?

Democratizing Education — open access or MOOCs?

Think about it. Universities pay their faculty to write and publish, then must pay commercial entities to sell those publications back to them. Universities also pay their faculty to teach, then charge students for access to that pedagogy (in most cases, charging only a fraction of the cost). The rhetorics of those two models tend to be reversed when discussing digital transformations. Why is it that the most business-minded people in academe, the boards of trustees and CFOs, seem to be enamored of giving away the resource that they actually charge for now, while being mostly indifferent to giving away the resource they are now paying for (twice)?

— Jason Mittell, in his excellent Chronicle piece on why open access, not MOOCs, is a more fundamental and important force for democratizing higher education

Simplifying US Visas

H1B’s. U-visas. J1’s, F1’s, guest worker permits, green cards, tourist visas.

There are too many types of visas. And they’re too temporary, too revokable, too dependent on the whims of a ‘sponsor’.

How about simplifying to just three groups of people:

  • Citizens. Born or naturalized.
  • Residents. Persons residing long-term or permanently in the country. They are entitled to all the rights and privileges of citizenry except voting, holding elected office, and possibly armed service. They can work, go to school, or whatever. Since continued residency is not required to maintain resident status, international commuters can classify as residents. Residents are eligible for citizenship after a reasonable waiting period (say 5 years, spending 54 of the last 60 months in the country), a civics test, and maybe an English proficiency test.
  • Visitors. Persons in the country temporarily. They only reason this category exists is to let people into the country for business or pleasure without setting up a taxpayer number for them. The ‘temporary’ is not enforced. Visitors probably don’t qualify for many social services, except for health care (if/when we get public health care). If a visitor wants to stay long-term, they can go to their local immigration office, fill out a bit of paperwork, and get their taxpayer number.

I See Scared People

“If you see something, say something!”

I see it at the airport, at the bus terminal, at the train station. It is painted on the bus (yes, I’ve seen a full-wrap bus ad for it). The DHS tweets it.

Only you can prevent terror attacks!

My fundamental problem with this campaign is that it encourages us to be suspicious of our neighbors. Even if the authors intend them to simply encourage alertness, these messages prime us to view the world through the lens of suspicion.

Big-O meets the world

Daniel Lemire wrote a good article on how big-O notation is a great teaching tool but not the end of the story.

One example from a previous project I worked on: bubble sort. Bubble sort is conceptually simple but analytically troublesome. It is O(n^2); its analysis, while not difficult, is not as straightforward other sorts; and worst for practice, its worst-case scenarios are are common (unlike quicksort).

It does, however, have excellent constants (due to its simplicity), great cache locality (in part due to being in-place), and near-linear runtime on almost-sorted data.

I was working on a 3D graphics project and, to render alpha-blending, I needed to draw my faces in sorted order by depth. I started using the STL’s generic sorting algorithm (a hybrid merge/insertion sort), but my redraw was slow. However, as the user rotated and moved the object, the faces wouldn’t get very far out of sort from frame to frame.