Making use of programming skills
Continue reading
Posted on January 02, 2019 in Tutorials • Tagged with music, tutorials, learning • 4 min read
Posted on January 24, 2015 in Learning • Tagged with Programming, Learning, University • 2 min read
I am right in front of a ton of exams and I need to learn about
algorithms and data structures. When I read about pseudocode of Graph
traversal algorithms, I thought:
Why not actually implement them in a real programming language? So I
did so and now you can study my code now here. I guess this problem was
solved a thousand times before, but I learnt something and I hope my
approach has some uniqueness to it.
Additionlay, you can also generate a topological order after you traversed the whole Graph, which is a nice little extra.
If you want the most recent version of the code, you can visit its own Github repo here.
Well, here's the code. Just download and run it like this: python graph_traversal.py
# -*- coding: utf-8 -*-
__author__ = 'Nikolai Tschacher'
__version__ = '0.1'
__contact__ = 'admin@incolumitas.com'
import time
from collections import deque
"""
This is just a little representation of two basic graph traversal methods.
- Depth-First-Search
- Breadth-First-Search
It's by no means meant to be fast or performant. Rather it is for educational
purposes and to understand it better for myself.
"""
class Node(object):
"""Represents a node …
Posted on October 16, 2013 in Learning • Tagged with Captcha, Programming, Design, Glyphs, Learning, Font • 9 min read
Last major update on 23.10.2013
As promised previously in my last article, I will guide you through the creation process of a rudimentary font. I will use the glyphs of my font to draw captchas and incorportate the implementation in my brand new captcha plugin for wordpress. There are already quite a few captcha plugins out there, some of them are better than mine (RECAPTCHAfor instance translates books and thus solves two problems at the same time), others are worse, because the math equations can simply be parsed (As far as I can judge without inspecting the code further).
In this article however, I will center the focus entirely on the font and abstract from it's future usage in the captcha.
A logical start of font creation is to answer the question what type of font we are going to create. But lets first introduce some concepts that are of importance when it comes to font design.
In short: A font is a collection of glyphs. Each glyph has a shape and there are various ways of describing that shape. You can imagine a glyph as a instanteation of a character. Whereas …
Posted on October 06, 2013 in Learning • Tagged with Font, Captcha, Programming, Mathematics, Learning, Bézier • 13 min read
Last major Update: 21.10.2013
Github repo that contains the presented code in this post.
In this article I will present you a very simple and in no sense optimized algorithm written in Python 3 that plots quadratic and cubic Bézier curves. I'll implement several variants of Bézier rasterization algorithms. Let's call the first version the direct approach, since it computes the corresponding x and y coordinates directly by evaluation of the equation that describes such Bézier curvatures.
The other possibility is De Casteljau's algorithm, a recursive implementation. The general principle is illustrated here. But the summarize the idea very briefly: In order to compute the points of the Bézier curve, you subdivide the lines of the outer hull that are given from the n+1 control points [Where n denotes the dimension of the Bézier curve) at a ratio t (t goes from 0 to 1 in a loop). If you connect the interpolation points, you'll obtain n-1 connected lines. Then you apply the exactly same principle to these newly obtained lines as before (recursive step), until you finally get one line remaining. Consider again the point at the ratio t on this single line left and …
Posted on July 24, 2013 in Learning • Tagged with Themeprojectsnewredesigncsshtml, Meta, Learning, Uncategorized • 2 min read
Hello everybody!
I finally found some motivation and time to give my blog a design upgrade - Basically an endavour that was overdue since this blog has seen the light of the day ;)
On the technical side, this theme is a complete redevelopment. It's not finished yet, on the contrary, it's the very first version and there remain a lot of issues that need to be resolved. For instance: The majority of the CSS code is still rather dirty and of experimental nature. Additionally, I want to include an image slideshow based on unslider.js. Your template function in the your theme would then look something like the following:
if ( ! function_exists( 'clearcontent_header_slider' )):
/*
* This function includes a minimal jquery slideshow into the header of the site. It uses unslider.js in
* order to achieve this objective. Link to github site: https://github.com/idiot/unslider
*/
function clearcontent_header_slider() {
?>
<div class="header-slideshow">
<ul>
<li style="background-image: url('<?php echo get_template_directory_uri() . '/pics/slideshow/1.png' ?>');"></li>
<li style="background-image: url('<?php echo get_template_directory_uri() . '/pics/slideshow/2.png' ?>');"></li>
<li style="background-image: url('<?php echo get_template_directory_uri() . '/pics/slideshow/3.png' ?>');"></li>
</ul …
Posted on June 02, 2013 in Learning • Tagged with Programming, Learning • 4 min read
Hey dear readership :)
I recently was in a need of a handy and nice way (not just pragmatic) to chose between different entities in the command line, each of them constituting an option. Surely, you can craft a simple menu with standard I/O functions, but I wanted to explore something different and more beautiful.
Therefore I found curses, a simple wrapper around ncurses, the famous BSD/UNIX library for portable advanced terminal handling.
So, I dived into this library, I'd recommend this tutorial for everyone who wants to deal with this old school stuff...
You can check out the recent script on my github site. Here is a copy, for everyone to lazy to look it up:
import curses
# Author: Nikolai Tschacher
# Date: 02.06.2013
class BoxSelector:
""" Originally designed for accman.py.
Display options build from a list of strings in a (unix) terminal.
The user can browser though the textboxes and select one with enter.
"""
def __init__(self, L):
""" Create a BoxSelector object.
L is a list of strings. Each string is used to build
a textbox.
"""
self.L = L
# Element parameters. Change them here.
self.TEXTBOX_WIDTH = 50
self.TEXTBOX_HEIGHT = 6
self.PAD …