Dries Van Langenhove

Dries Van Langenhove (born 11 May, 1993, Dendermonde) is a Flemish-Belgian blogger, political activist and member of the Chamber of Representatives who is affiliated to the Vlaams Belang party.

Dries Van Langenhove
Member of the Chamber of Representatives
Assumed office
26 May 2019
Personal details
Born
Dries Van Langenhove

(1993-06-11) 11 June 1993
Dendermonde, Belgium
Political partyVlaams Belang
Alma materGhent University

Early life

Van Langenhove was born in Dendermonde and grew up in Opwijk. He initially began training as a plumber but later began studying as a law student at Ghent University.[1][2]

Politics

Van Langenhove was active in the NSV. When a lecture by State Secretary Theo Francken at the Vrije Universiteit Brussel was cancelled in 2017 after left-wing protesters shut down the event, Van Langenhove mobilized supporters from an internet group to organize further Francken events.[3] Until August 2017 he wrote on the conservative website SCEPTR on the issues of migration and integration.[4] Along with Vlaams Belang Jongeren and the NSV he helped to organise a demonstration in Brussels against the UN Global Compact on Migration. In 2019, he announced he was to stand as an independent MP for the Chamber of Representatives in the 2019 Federal election, and it was later confirmed by Tom Van Grieken that he would run affiliated to the Vlaams Belang party and head the VB's list in the Flemish Brabant region. He was elected to the Chamber with 39,295 preference votes.[5][6]

Controversy

In 2017, Van Langenhove set up a youth movement called Shield & Friends which participated in a number of political demonstrations. An investigation by the Belgian TV show Pano and journalist Tim Verheyden found that the group had shared content and memes on secret Facebook and Discord groups that were considered racist, sexist, extremist and antisemitic, as well as promoting violence and references to Nazi Germany.[7] The group was also investigated under potential breaches of the 1981 anti-racism law.[8] Van Langenhove denied involvement in sharing some of the content, however a disciplinary procedure was started by Ghent University which temporarily suspended him as a student.[1]

gollark: It uses the function, yes.
gollark: So, I finished that to highly dubious demand. I'd like to know how #11 and such work.
gollark: > `x = _(int(0, e), int(e, е))`You may note that this would produce slices of 0 size. However, one of the `e`s is a homoglyph; it contains `2 * e`.`return Result[0][0], x, m@set({int(e, 0), int(е, e)}), w`From this, it's fairly obvious what `strassen` *really* does - partition `m1` into 4 block matrices of half (rounded up to the nearest power of 2) size.> `E = typing(lookup[2])`I forgot what this is meant to contain. It probably isn't important.> `def exponentiate(m1, m2):`This is the actual multiplication bit.> `if m1.n == 1: return Mаtrix([[m1.bigData[0] * m2.bigData[0]]])`Recursion base case. 1-sized matrices are merely multiplied scalarly.> `aa, ab, ac, ad = strassen(m1)`> `аa, аb, аc, аd = strassen(m2)`More use of homoglyph confusion here. The matrices are quartered.> `m = m1.subtract(exponentiate(aa, аa) ** exponentiate(ab, аc), exponentiate(aa, аb) ** exponentiate(ab, аd), exponentiate(ac, аa) ** exponentiate(ad, аc), exponentiate(ac, аb) ** exponentiate(ad, аd)) @ [-0j, int.abs(m2.n * 3, m1.n)]`This does matrix multiplication in an inefficient *recursive* way; the Strassen algorithm could save one of eight multiplications here, which is more efficient (on big matrices). It also removes the zero padding.> `m = exponentiate(Mаtrix(m1), Mаtrix(m2)) @ (0j * math.sin(math.asin(math.sin(math.asin(math.sin(math.e))))), int(len(m1), len(m1)))`This multiples them and I think also removes the zero padding again, as we want it to be really very removed.> `i += 1`This was added as a counter used to ensure that it was usably performant during development.> `math.factorial = math.sinh`Unfortunately, Python's factorial function has really rather restrictive size limits.> `for row in range(m.n):`This converts back into the 2D array format.> `for performance in sorted(dir(gc)): getattr(gc, performance)()`Do random fun things to the GC.
gollark: > `globals()[Row + Row] = random.randint(*sys.version_info[:2])`Never actually got used anywhere.> `ε = sys.float_info.epsilon`Also not used. I just like epsilons.> `def __exit__(self, _, _________, _______):`This is also empty, because cleaning up the `_` global would be silly. It'll be overwritten anyway. This does serve a purpose, however, and not just in making it usable as a context manager. This actually swallows all errors, which is used in some places.> `def __pow__(self, m2):`As ever, this is not actual exponentiation. `for i, (ι, 𐌉) in enumerate(zip(self.bigData, m2.bigData)): e.bigData[i] = ι + 𐌉` is in fact just plain and simple addition of two matrices.> `def subtract(forth, 𝕒, polynomial, c, vector_space):`This just merges 4 submatrices back into one matrix.> `with out as out, out, forth:`Apart from capturing the exceptions, this doesn't really do much either. The `_` provided by the context manager is not used.> `_(0j, int(0, 𝕒.n))`Yes, it's used in this line. However, this doesn't actually have any effect whatsoever on the execution of this. So I ignore it. It was merely a distraction.> `with Mаtrix(ℤ(ℤ(4))):`It is used again to swallow exceptions. After this is just some fluff again.> `def strassen(m, x= 3.1415935258989):`This is an interesting part. Despite being called `strassen`, it does not actually implement the Strassen algorithm, which is a somewhat more efficient way to multiply matrices than the naive way used in - as far as I can tell - every entry.> `e = 2 ** (math.ceil(math.log2(m.n)) - 1)`This gets the next power of two in a fairly obvious way. It is used to pad out the matrix to the next power of 2 size.> `with m:`The context manager is used again for nicer lookups.> `Result[0] += [_(0j, int(e, e))]`Weird pythonoquirkiness again. You can append to lists in tuples with `+=`, but it throws an exception as they're sort of immutable.> `typing(lookup[4])(input())`It's entirely possible that this does things.
gollark: > `def __eq__(self, xy): return self.bigData[math.floor(xy.real * self.n + xy.imag)]`This actually gets indices into the matrix. I named it badly for accursedness. It uses complex number coordinates.> `def __matmul__(self, ǫ):`*This* function gets a 2D "slice" of the matrix between the specified coordinates. > `for (fοr, k), (b, р), (whіle, namedtuple) in itertools.product(I(*int.ℝ(start, end)), enumerate(range(ℤ(start.imag), math.floor(end.imag))), (ǫ, ǫ)):`This is really just bizarre obfuscation for the basic "go through every X/Y in the slice" thing.> `out[b * 1j + fοr] = 0`In case the matrix is too big, just pad it with zeros.> `except ZeroDivisionError:`In case of zero divisions, which cannot actually *happen*, we replace 0 with 1 except this doesn't actually work.> `import hashlib`As ever, we need hashlib.> `memmove(id(0), id(1), 27)`It *particularly* doesn't work because we never imported this name.> `def __setitem__(octonion, self, v):`This sets either slices or single items of the matrix. I would have made it use a cool™️ operator, but this has three parameters, unlike the other ones. It's possible that I could have created a temporary "thing setting handle" or something like that and used two operators, but I didn't.> `octonion[sedenion(malloc, entry, 20290, 15356, 44155, 30815, 37242, 61770, 64291, 20834, 47111, 326, 11094, 37556, 28513, 11322)] = v == int(bool, b)`Set each element in the slice. The sharp-eyed may wonder where `sedenion` comes from.> `"""`> `for testing`> `def __repr__(m):`This was genuinely for testing, although the implementation here was more advanced.> `def __enter__(The_Matrix: 2):`This allows use of `Matrix` objects as context managers.> `globals()[f"""_"""] = lambda h, Ĥ: The_Matrix@(h,Ĥ)`This puts the matrix slicing thing into a convenient function accessible globally (as long as the context manager is running). This is used a bit below.

References

  1. "Dries Van Langenhove wil zitje in Raad van Bestuur UGent terug". Het Laatste Nieuws. 2 October 2018. Retrieved 14 January 2019.
  2. Dries Bervoet (7 January 2018). "De val van een selfmade rechtse apostel". De Tijd. Retrieved 14 January 2019.
  3. Jurgen Ceder (11 October 2017). "Praten met Dries Van Langenhove van Schild & Vrienden. "Aanstekelijk enthousiasme mag niet verloren gaan."". 't Pallieterke. Retrieved 14 January 2019.
  4. "Posts van Dries Van Langenhove (gearchiveerd)". SCEPTR. 9 December 2018. Retrieved 14 January 2019.
  5. Tobias Santens (26 May 2019). "Vlaams Belang grote winnaar van de verkiezingen, partij wordt tweede in Vlaanderen". Retrieved 5 June 2019.
  6. Stefan Grommen (9 January 2019). "Dries Van Langenhove van uiterst rechts Schild & Vrienden wordt lijsttrekker voor Vlaams Belang". VRT NWS. Retrieved 14 January 2019.
  7. An Schoonjans (10 January 2019). "Persbericht - Gent - Onderzoek Schild & Vrienden". Parket Oost-Vlaanderen. Retrieved 22 April 2019.
  8. "Dries Van Langenhove in verdenking gesteld wegens inbreuken op antiracismewet". De Standaard. 17 June 2019. Retrieved 18 June 2019.
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.