Monday 16 October 2017

Dictionaries, Keys and Hash Codes

It's (or should be) common knowledge that objects used as keys in Dictionaries/Maps (Objects that are based in hash tables...) must be immutable [1], [2]. In few words, the Hash code of an object being used as key will be used to obtain the index in the internal structure in the hash table to locate the object. If you mutate an object, its hash code should also change, so it will no longer work for finding the right bucket in the Hash table. You can read a .net centric explanation here

In .Net when using an object as Dictionary key, the GetHashCode method will be used, and in case of collision it'll move to the the Equals method (and you should have overriden both methods in your class as the default Object.GetHashCode is considered not fit for dictionaries). Something similar is done in Java and Python.

ES6 introduced the Map class, and one of its advantages over using plain Objects as dictionaries is that we can use any object as keys (and not just strings). Object.prototype does not have a "getHashCode" method, so well, it seems a bit strange. Checking the MDN documentation on Maps it says that key equality works according to the semantics of the === operator. This means that if you use as key an objec (other than a string or a number), the key comparison will be based on the memory address of the object, so if you mutate the object, it will continue to be valid for accessing the dictionary. I mean:

let myMap = new Map();

let key1 = {name: "aaa"};

myMap.set(key1, "this is a value");

console.log("first item: " + myMap.get(key1));
//output: this is a value

key1.name = "bbbb";

//the modified object that we use as key is still valid!!! 
//"===" semantics/reference equality is being used

console.log("first item: " + myMap.get(key1)); 
//output: this is a value

This seems like a rather bizzarre behaviour for a Map/Dictionary. You can see here how people implement a "more standard" one.

Notice that MDN says according to the semantics of ===. Obviously one expects access to a Map item to be O(1), so for sure the runtime is not going to traverse the whole Map comparing the keys with "===". To simulate "===" sematics and have instant access, I guess one possibility is to get the hash code of the memory address of the object used as key.

Related to this, given that JavaScript objects behave similarly to a Dictionary of string keys (you can add or remove items and the lookup is supposed to be almost immediate), one could assume that they would be implemented as a Hash Table. Hash Tables are very fast, but they are slower that property access in a other class based languages (C#, Java, C++...) where the access to a specific property will always use a same offset from the beginning of the object (so you save the time of running the "getHashCode" function). Well, I can read here that for example V8 uses dynamically created hidden classes, making property access as fast as in C++.

I noticed this sentence: A Map may be perform better in scenarios involving frequent addition and removal of key pairs. in the MDN comparison. It rather fits with the V8 policiy. Each time you add a new property to an Object I guess V8 needs to create a new hidden class, and that comes at a (small) cost that most of the times is pretty much compensated by the very fast property access that the new class provides. However, if you add/remove very frequently, maybe the time saved in property access does not compensate the time spent in the hidden class creation.

Sunday 15 October 2017

Hendrik Beikirch Back in Toulouse

L'année dernière j'ai déjà écrit sur le magnifique et monumental fresque murale fait par Hendrik Beikirch à Toulouse (quartier Empalot). Comme je l'ai expliqué dans ce post, le bâtiment ignoble sur lequel le fresque a été fait, va être démoli. C'est pour ça que, et compte tenu que les habitants du quartier aiment bien cet fresque, la ville de Toulouse l'a invité à faire une autre fresque le mois dernier. Je suis allé voir le résultat ce weekend, et encore une fois, c'est magnifique!

Essayer d'écrire en Français m'épuise encore, je vais passer à l'anglais...

So another 12 stories building block 200 meters far from the one of the previous year was chosen to be gifted by this amazing piece:

In this picture you can see both murals:

Hendrik Beikirch had already visited Toulouse before these works in Empalot. In 2015 he took part in that year's edition of the Mister Freeze Urban Contemporary Art and Graffiti exhibition. He painted this not so massive but equally beautiful mural in the Mountaudran are. It's still in good health nowadays.

By the way, the Mister Freeze Urban Art festival has kept improving year after year. In 2015 it was good, in 2016 it was very good, and this year is's been just amazing. I should find some time to dedicate a post to this last edition.

Friday 6 October 2017

Low-Rise Cities

I've ever loved skyscrappers. My first times in The City and Canary Dwarf in London I was amazed, and in my first visit to La Defense in Paris I was on the verge of extasis. When I visited Frankfurt, it was mainly cause it's nicknamed "Mainzhattan" :-). Gothick cathedrals have always captivated me, and I tend to see Skyscrappers as a continuation of them.
As of today, I continue to enjoy the view of a skyscrapper dominating a cityskype, but I've turned more selective. It's not that they need to be architectonic masterpieces, but there are some aesthetical minimums that if not reached turn the skyscrapper (or any high-rise building) into a real pain. It's not just a matter of materials, in some occasions I find more interesting some restored high-rise residential buildings of the 70's that some recent glass and steel buildings. For example some of the skyscrappers in Tallinn are pretty "untasty".

The other big change in my perception of skyscrappers is their location. In the past I absolutely loved huge concentrations of skyscrappers, now I tend to prefer isolated ones (1, 2 or 3) scattered over different points of one city. They act as reference points for the urban landscape and I pretty apreciate the contrast with the low or mid-rise surrounding buildings. Related to this also, I don't see the need (or the good taste) of going much higher than 200 meters. I pretty much like Brussels for example, with several towers between 80 and 150 meters spreading all over the cityscape, and with a "non oppressive" small concentration of them in the Gare du Nord area. I also quite like how it goes in Berlin.

Regarding high-rise buildings (I consider like that buildings between 40 and 80 meters), it's a bit the same. I like them a lot, but not massive concentrations of them. Coming from a city (Xixon) where there are no skyscrappers, but half of the city is made up of buildings above 40 meters, disorderly glued ones to others... I can understand that some people are not particulary fond of them (and if you've ever been to Vigo or A Corunha it's even easier to understand).

When I arrived to Toulouse I pretty missed (and continue to miss, waiting eagerly for the planned Tour d'Occitanie and the intended Tour Fenetre de Pista) having at least 1 skyscrapper, and this lack felt odd to me, I was not familiar with cities of this size and healthy economy that didn't have a single skyscrapper (at this moment no building rises above 70 meters). On the other side, I felt quite pleasant its low-rise nature. You find quite a few buildings between 10 and 15 stories, but there are not massive areas full of them, so putting aside that most of them are from the 60's/70's, are ugly and desperately need a total facade refurbishing, they work a bit as the reference points that I mentioned earlier. The low-rise nature of the city center and certain neighbourhoods is really nice, but I absolutely can not understand that they have been constructing tons of buildings of 3 or 4 stories in the last decade (hopefully as of late there seems to be a tendency to construct a bit higher). Low density means a crazy level of urban sprawl that means that you'll never manage to have an efficient public transport system. Just to give you an idea, the future third Metro line that will go from one end to another of the Metropolitan area (the one of 750.000 inhabitants, not the urban area of 1.250.000) will be 25 kms long!!! I think it should be forbidden to construct new buildings of less than 5-6 stories, and 7-9 ones should be the norm. Indeed, overtime I've started to appreciate the mid/high rise mess of my hometown (also because many of them have undergone an amazing facade renovation).

In general terms French people dislike mid/high-rise buildings, and deeply hate skyscrappers. I think it's a sort of trauma caused by how bad things have gone in the social housing states (cités) of the 70's. For me for sure architecture has nothing to do with this disaster. There are some housing states (at least in Toulouse) that are mainly low-rise (Les Izards) and that have ended up turned into no-go areas. It's not a matter of architecture, it's a matter of Islam, fake victimization and pure senseless hate for the old colonial power. There's also a sort of Tour Montparnasse syndrome. Most Parisians hate it; to the point that time ago one candidate to the mayor's office intended to demolish it! (fuck, J'adore cette tour!!!, it makes an amazing contrast with the perfect and so Parisian neighbourhoods around it). Another reason why it's pretty uncommon to see skyscrappers in the French landscape outside Paris it's that there are some very strict security rules. Buildings above 60 meters need to have a permanent unit of fireworkers, so this makes maintenance crazily expensive, and even for cities that seem to be more friendly to high rise buildings (like Marseille and Lyon) it's difficoult to get more than one skyscrapper per decade.

Ma si belle Tour de Montparnasse

I love cities, and I got quite interested in whether there are other relatively big cities that at this day lack any skyscrapper. From my trips, I could think of a few candidates, but I didn't know if maybe there would be some office building or some huge residential block in the outskirts. So I've been investigating in wikipedia and Emporis, and I've come up with a listing (for sure there can be errors, maybe outdated data or some skyscrapper in the metropolitan area that did not show up in the listings I've checked). Notice that I'm not including here churches, historical buildings or TV/Airport towers.

  • Washington DC. This pretty shocked me. The strong height restrictions that have always been in place cause that no building rises above 60 meters.
  • Dresden. It seems no building goes beyond 60 meters
  • Edimbourgh. Tallest building is 64 meters and is just an ugly tower block in a housing state. No proposed skyscrappers as far as I know.
  • Glasgow. Quite a few 70-60 meters towers in housing states. There's some proposal for going higher, but nothing confirmed so far.
  • Dublin. Seems the Irish are "very French" regarding buildings height. Right now the highest building is below 70 meters, but there are approved plans for some buildings between 90 and 70 meters (that have caused quite controversy).
  • Belfast. A couple of buildings around 80 meters.
  • Stuttgart. This one rather surprised me. In one of the most wealthy European cities just a couple of buildings reach 75 meters (hey, like my hometown!!!)
  • Athens. They have a 100 meters building done in the 70's leveraging one moment when they managed to skip the very strict law that prevents buildings from going above 40 meters!!!
  • Bremen. It has a recent office tower reaching 80 meters
  • Strasbourg. Its top is below 80 meters, no plans for rising higher.
  • Malaga. Right now nothing goes beyond 60 meters. There's a controversial proposal for a 130 meters hotel
  • Zaragoza. They have a couple of buildings around 80 meters.
  • Budapest. This beautiful, decadent city has an unintersting tower reaching 85 meters, for the rest is rather low-rise and skyscrappers remain a very controversial topic.
  • Helsinki. A not particularly interesting residencial building tops the city (that as a whole is not particularly beautiful) at 86 meters.
  • Copenhagen. A hospital in the suburbs reachs 120 meters. Then it has several towers between 100 and 80 meters (some of them very beautiful) scattered over the whole city. I pretty like its urban landscape.
  • Geneve. Pretty surprising for such an international city, even more when Zurich and Basel have been moving high in the last years. They just have an old, uninteresting, 90 meters residential building in a "cite".
  • Thesaloniki. Seems like nothing goes beyond 50 meters!
  • Nice. Quite similar to Toulouse. Contrary to Lyon, Nantes or Bordeaux, the 70's, when French laws were not so strict, did not gift them with a remarkable office tower or an ugly residential tower in a "Cité", that would rise beyond 70 meters. There does not seem to be plans for breaking this dynamic

I've also found quite a few other cities that just got their only (or very few) skyscrapper in the last years

  • Seville. They've built a pretty nice glass and steel tower in the last years. Other than that, no building seems above 60 meters.
  • Rome. They seem to have woken up lately, maybe trying to catch up with Milan and Naples.
  • Turin. It's been in the last years when the have had the luck to see the completion of 2 pretty beautiful towers (200 and 160 meters). Notice that before that the city's roof was a 100 meters building of 1933!!!.
  • Goteborg. One recent tower reaches 100 meters. Then a few towers of 80-70.
  • Bilbao. Well, this is a quite particular case. In the city proper there is a single building well above 100 meters (the beautiful Iberdrola Tower, 166 meters). Then there's a new, not particularly cute, residential tower next to the bus station, and then the city is full of mid/high rise buildings absolutely everywhere, so indeed it's a very vertical city. Notice that in Baracaldo (just next to Bilbao) you find the 100 meters BEC tower and some rather noticeable and interesting residential towers.
  • Marseille. The magnificent 150 meters CGA-CGM tower was completed in 2010, and the slightly shorter Jean Nouvel tower should be completed next year. These 2 towers aside, Marseille is very vertical for being a French city. The breathtaking views from La bonne Mere show tons of mid/high-rise buildings, reminding me of Bilbao

Sunday 1 October 2017

Islamists and Delinquency

There's an evident link between radical Islam and delinquency. A big part of the Islamists that go to rape and enslave women in Syria have a background as dealers, common thieves and so on. The same goes for those committing attacks in Europe, indeed, in many cases these ones have not left behind their past as petty criminal, and have been dealing and committing robberies until the day before their attacks. One root reason why these bastards fall easily into Islamism is that they are most of the time very poorly educated people (better to smoke joints in the park than going to high school...) and in most cases they are not particularly smart individuals... This bunch of ignorant bastards are easy prey for any of those Saudi paid and educated imams managing the radical mosque of the neighbourhood, for the Video game style yihadist propaganda on the net or for a previously radicalised prison mate.

It's not only that petty criminals are easier to indoctrinate, it's also that the more criminality exists in one neighbourhood, the more isolated from the rest of the city it will become. The closer and more communitarist the area becomes, the easier it will for the disaffected population to be lured into the Islamist trap. So for the Islamist indoctrinators, every time the police is prevented from entering a "quartier sensible", or the firemen are attacked while trying to do their work, or an ambulance is set on fire (like last month in "Le Mirail" in Toulouse), or a teacher is silenced, insulted and even physically attacked, it's a step in the right direction. That's the main reason why these "thinking heads" of the islamization of Europe, while advocating a "society" where people will get an arm chopped for having committed a robery, approve and support delinquency in the neighbourhoods that they are trying to dominate.

The other day, reading an impressive and terrifying investigation in Charlie Hebdo about the Islamization of the High Schools in the Northern neighbourhoods of Marseille (it's even worse that I would expect), I came across with another motivation for Islamists to tolerate and get involved in delinquency. One High School director explains how in 2004 (yes, the islamization process to destroy our societies has been working from well before many people think) a group of dealers used to insult some young teachers, calling them bitches and infidels for wearing a skirt... After the intervention of the police there was some "negotiation" between the school and these pieces of crap to calm down the situation. The director was quite intrigued by how it was possible that these "very strict" Muslims would be involved in a vicious activity (drugs are forbidden in Islam, they are "haram") like dealing drugs, and discussing with them he learnt:

"They've sweared to me that they only sold drugs to "whites", the French youngsters, and that this was their way to practice jihad. To fuck their brain, their defenses, to break their shit society. That day, I understood that these guys, even if they were lying, were at war with you, with us, with me".

So they conduct jihad by poisonig "the infidels" with drugs. Quite in line with the last directives by Daech and other Islamist beasts, asking for poisoning water supplies, supermarket foods... they also ask for burning forests!!!

Just before publishing this post I learn with sadness about this new Islamist attack, this time in Marseille, in one of world's most beautiful train stations, a place that I particularly love. Hopefully the terrorist has been shot dead by the Security Forces.

More than ever, Let's hunt down (dead or dead) the Islamists