Simutrans 25th Anniversary #6: An interview with James Petts, the Ex-Father

One of the greatest honours an open-source project can have is to generate enough interest so that other people consider making their own versions of it. Simutrans, being a successful open source project, is no exception, and the greatest of those versions is Simutrans Extended (formerly Simutrans Experimental). Today, we will take a closer look at this fantastic fork with the help of his creator, James Petts.
_____________________________________________

First of all, introduce yourself. Who are you? Where do you live? What did you study? Where are you working or have worked on the past?

I am James Petts, and I live in London. My education and professional life are in the law.

How does a man of law end up doing software development in his spare time?

As with many open source developers, I started work on what eventually became the Extended fork of Simutrans because I wanted to see features in the game that were not present. I remember playing Simutrans in around 2007, shortly after the British railway vehicles had first become available as an addon for Pak128. I enjoyed it, but found that there were certain things that were not quite right for what I wanted.

I remember making some feature requests on the forum, but the developers were not interested in implementing them, so I thought that I could implement them myself. This was in around 2008. They were initially written as patches for Simutrans, intended to be part of the main codebase, but they were not integrated, so I eventually just made my own fork. I think that I had a different idea as to what made a good game than the developers of of the original Simutrans; but also, I imagine that, as I was only just learning C++, the coding quality of my patches at the time was not what it should have been.

Once I had started adding features, I realised that there were more and more that were desirable, and I ended up spending more time developing the game than actually playing it; and the more complex features that were added, the more bugs that needed to be fixed and the more pakset work needed to implement the features.

Has Simutrans been your only experience with open source software development, or have you ever contributed to any other open source project?

Simutrans has indeed been my only experience with open source software. I have briefly contemplated contributing to other things, but I only have the one lifetime to live, and open source development is extremely time consuming.

And what do you devote your life to when not working and doing Simutrans development?

When not working or developing Simutrans, I enjoy photography, baking and railway modelling. The latter has entailed me having a sizeable shed built in my garden for several model railway layouts, and I am also a member of the Model Railway Club in London. As may be anticipated, there is some overlap between Simutrans and railway modelling.


James’ model railway.

How did you know Simutrans? What was your first contribution?

I cannot remember exactly how I came across it now. I think that I was searching for transport based games to play in around 2007, and found Simutrans and thought it interesting; I think that I had considered Open TTD, but this was at a time when only the executable was available, and one already had to have Transport Tycoon Deluxe to play it; had the original Transport Tycoon, but not the Deluxe version, hence could not play Open TTD at the time. Simutrans, however, was available in a full version, so I think that I downloaded that. As to my first contribution; I am afraid that this is now lost to the mists of time and fading memory. This would have been sometime in late 2008, and I think that I wanted to implement something like comfort or journey time based routing, both of which are now long-standing Extended features.

When did you announce that you were making a Simutrans fork?

Initially, I just intended to produce a patch for Simutrans with the various features. This would have been in late 2008. The features were all in one large patch (literally, a .patch file for SVN), which was not the best way of doing it, and I was introduced to Github at around this time by another contributor, I think, so I created a “Simutrans-Experimental” branch on Github I think in around 2009 and added all of my features to this. Initially, the idea was still for the features to be merged into the main Simutrans trunk, but it became apparent after a while that some of my development goals, especially the targetting a higher level of economic realism at the cost of higher complexity, were not consistent with the development goals of the principal Simutrans developers, who tended to favour simplicity and a more synthetic economy, and so gradually the patch became a fork, although some Simutrans-Experimental features were merged into the original version (“Simutrans-Standard”) eventually. However, the “Simutrans-Experimental” name stuck until 2017, when, after discussions with others, I thought that it was time to make it clear that what I was working on was in fact its own game and a distinct fork, rather than just a development/beta branch. Nonetheless, I did not really want to divide the Simutrans community, as both Extended and Standard have a lot in common, and fans and developers of both have more to gain by co-operation than competition. I am very pleased that all of the Simutrans community still shares one single international forum and, latterly, Discord server.


On January 21 2009, James announced that he was working on an experimental version.

What are the core features that differentiate Simutrans Extended from Simutrans Standard?

The core Extended features, I think, are (1) the time based routing; (2) the passenger generation model; (3) passenger and mail classes; (4) the more realistic vehicle physics; and (5) private car transport. These are the features that fundamentally alter how players build networks. The time based routing means that players need to build networks that are time efficient rather than merely having sufficient capacity. It matters when people get to their destinations rather than just whether they get there. If their journey is too long, they may not travel at all, thanks to the passenger generation model. It is not enough to have a single one way circular ‘bus route that covers the whole town – players must build a complex ‘bus network consisting of multiple point-to-point lines that get people where they want to go quickly. If people can get to where they are going more quickly by driving their own car or by walking, they will. If people can get to where they want to go more quickly using a rival transport company’s services, they will. People can interchange between distant stations/stops by walking between them, and can walk long distances to player stops – but would sooner travel from a nearer stop if the transport services take them where they want to go within a reasonable time. It is no longer the dominant strategy to use the most powerful locomotive on every train – balancing power and tractive effort means that different locomotives work better for heavy freight, short distance commuter trains and long distance express passenger trains. Different classes mean that wealthier passengers or mail senders can pay a premium for a faster or (in the case of passengers) more comfortable journey, allowing different modes of transport between the same points (e.g., aircraft, train and coach) to co-exist at different price points. Other significant features that have a real impact on player network design are infrastructure wear and renewal, public rights of way (which links with the private car routing
feature), automatic road connexions to industries and realistic railway signalling. Also worth mentioning, although having less of a direct impact on player network design, is the improved UI (largely as a result of efforts by Ranran in the last two years or so), with lots of very clear and engaging visual presentation of often complex data, and the multi-threading which allows even very large games to work (relatively) smoothly.

What is the biggest challenge you faced when working on Simutrans Extended?

This is not an easy question to answer, as there have been many challenges. From a technical perspective, probably the greatest
challenge was the multi-threading work in 2016-2017. Multi-threading is one of the most technically challenging aspects of computer programming: essentially, one has to manage multiple completely independent bits of the program (“threads”) all working at the same time and potentially reading and writing the same information, and try to stop it all from conflicting with itself and making things go terribly wrong. I had no experience of writing multi-threading code before this, so this was definitely a steep learning curve. It has made a real difference to the performance of the game on larger maps, however, so it is worth it.
Another very challenging thing has been debugging loss of synchronisation errors for the game in its online mode: essentially,
different instances of the game running on several different computers must all do absolutely precisely the same thing or else the everybody will immediately disconnect. Any tiny difference between what one computer does and what another does with respect to the simulation code will cause the whole online game to fail completely. Debugging this sort of problem is much harder than finding normal bugs, because one has to work out exactly where two completely separate computers running the same code can end up diverging. There have been occasions when it has taken six months to find and fix a single bug of this type. I am very grateful for all of the people who have helped with this process over the years. One of the biggest challenges coming up, I think, is doing the full costs balancing. We currently have an interim balance produced by Dr. Supergood a few years ago, which has made the costings make much more sense than they did before, but when we cone to do the final cost
balancing, that will be a lot of work. I have been researching in anticipation of this balancing project for over 11 years; I am just awaiting the balance critical features on which I am currently working before launching into that.

Talking about upcoming challenges, what are the next goals for Simutrans Extended?

The current work on Simutrans-Extended is focussed on the 15.x branch. The focus of this intended major version is implementing all the features necessary for balancing the costs. This is a complex task: the amount of fuel that vehicles use must change depending on how hard that they are being worked; vehicles must need to be maintained regularly and thus not be available for service all the time, but for this to work automatically and seamlessly to avoid the need for constant player supervision; vehicles must be able to be overhauled periodically, at substantial cost, and this also must be partly automated to avoid the need for micromanagement; maintenance costs need to depend on how long that it has been since the last overhaul; overhaul costs need to depend on how many overhauls that the vehicle has already had; staff costs need to depend on what sort of and how many vehicles are in a train or similar (e.g., a train with continuous brakes needs only one guard even if there should be multiple brake carriages); costs need to vary with time according to inflation, and different costs need to vary to different extents with time (the cost of staff, for example, needs to increase at a different rate to the cost of coal, and the cost of oil at a different rate again, and so forth); vehicles need to require refuelling stops; it needs to be possible to lay over vehicles temporarily so as to avoid the need to expend staff cost on them for a low frequency service; and it needs to be possible to break up and re-combine multi-vehicle consists (“convoys” in the Simutrans way of describing things) dynamically.

This is all a very large project; coding work on this commenced in 2018, but stalled shortly thereafter because of the need to resolve some of those very difficult loss of network synchronisation bugs described in the previous answer, and I have only recently been able to recommence this work, having been focussing more on my model railway during the pandemic. Fortunately, we now have an excellent UI developer in the form of Ranran, who is likely to make it much easier to add the UI for these features, and greatly increase the quality of the UI that we get from what it would have been had I done the work myself. This will probably be the largest single set of features added at once, so this is likely to take a long time not just to code but also to test – and then an equally large amount of time to update the pakset (Pak128.Britain-Ex) to balance according to these new features. However, this will hopefully very much be worth it: we currently have only an interim balance, and, to a large extent, the game is the balance.

Although there are substantial additional features in Extended, and the game plays very differently to Standard in terms of network design, the game still plays in much the same way as Standard (and much the same way as Transport Tycoon before it, and myriads of other transport based games, such as the more modern Transport Fever): there always comes a time, assuming that the player should design a successful network, when the player has more money than he or she can spend, and only truly catastrophically bad decisions can bankrupt the player; beyond that point, players are limited by time rather than by money. This is obviously not how any real commercial company ever works (with the possible exception of Apple or Google, but that is another matter), so we need gameplay in which money is always an issue to a significant extent even for players with larger and generally successful networks. By simulating entropy and inflation, as well as some other dynamics, it should be possible for the game to get much closer to a reality based economic balance using reality based figures, although we cannot be sure of how this will work until we actually try it, and there may be need for further adjustment. To my knowledge, no other game has ever tried to simulate transport economics to this depth before.


RanRan’s work has helped to improve greatly the UI for Simutrans Extended

Regarding other transport based games, Simutrans is usually compared with OpenTTD (because both are open source). But while OpenTTD is a huge success, Simutrans has gone pretty much under the radar in comparison – and even more Simutrans Extended. Why do you think players prefer OpenTTD over Simutrans?

It is difficult to know for sure the reason for others’ preferences as that needs more information than I have available to me; I can only guess and the guesses could easily be wrong. Perhaps it has something to do with OpenTTD having what I and many would regard as a more robust open source licence (the GPL, I believe, compared to the Artistic Licence of Simutrans). Perhaps it has something to do with the fact that OpenTTD is more closely connected with a classic well-known commercial game, Transport Tycoon. Perhaps it is because, in its early years, Simutrans seemed to be focussed on the German-speaking market, wheras OpenTTD was focussed more on the English speaking market (note that Simutrans has a higher level of interest in Germany and Japan). It might simply be that OpenTTD acquired a critical mass early on and that that lead into positive feedback.

Compared to Simutrans-Extended in particular, it might be that Simutrans-Extended is more niche and in-depth, whereas OpenTTD is more accessible to casual players. It would certainly be good to broaden the audience for Simutrans and Simutrans-Extended; those who do play it do seem to get a great deal of enjoyment from doing so, but I do not know how many people that there are who are interested in a game that has the singular focus on economic realism that Simutrans-Extended by design has.

Simutrans (Standard) reached its peak in April 2012, when the game was downloaded more than 100.000 times on SourceForge. Since then its popularity has declined slowly but surely. Has this decline affected Simutrans Extended too?

I am not entirely sure as I do not keep download statistics. Certainly, forum activity seems to have peaked in 2012; the early 2010s were a time of rapid development in Simutrans-Extended (or “Simutrans-Experimental” as it was then), but it was less stable at the time. 2012 was the year that the Bridgewater-Brunel server first started, with the large semi-persistent online games that have become the hallmark of Simutrans-Extended play. At the time, the codebase was less stable, and the games were prone to interruptions through bugs that needed fixing, including some of the most difficult bugs to fix, loss of synchronisation bugs, which sometimes took 4-6 months to fix a single bug, during which time the server was unavailable. In more recent times, the game has been much more stable and the hours that people play online have greatly increased. Only to-day, I notice that somebody has started a new Simutrans-Extended server. I am not sure of the total numbers playing Simutrans-Extended now compared to 10 years ago, but, for those who do play, I am quite sure that the experience is significantly better, and suspect that, as a result, people play for longer now than they did then.

Indeed, the playerbase of Simutrans Extended, although smaller than Standard, seems to be also more active. Which do you think are the reasons behind Simutrans Extended players sustained interest?

It is always difficult to answer these questions as I can never really be sure about what motivates other people. One thing that I have seen mentioned on the forums and in the Discord servers by Extended players, many of whom spend many hours nurturing large and highly complex networks in the Bridgewater-Brunel server (and others servers that have been run from time to time) is that there are no other transport games that quite have the depth of Simutrans-Extended. Another factor may well be the servers themselves; I am not aware of any other transport game that has a large, semi-persistent online server and that by itself – the ability to build a successful network in a persistent and stable world lasting over one real life year in which others are striving to do the same thing – may well make the game satisfying in a way that other games are not. I know that Standard also has online servers, but, from what I gather, they tend to use smaller maps and have time passing more quickly, so may not generate the level of personal satisfaction that comes with carefully nurturing a large network gradually evolving over a long time. Also, Extended’s features, especially relating to passenger transport (things such as walking between stops and time based routing), makes it easier both to co-operate and compete in a realistic way with other players, which I suspect makes the world feel more immersive for players.

More generally, one of the reasons that Extended diverged from Standard in the first place was that Extended was intended to have features that added depth and realism at the expense of additional complexity, whereas Standard focussed on accessibility to newer players and simplicity at the expense of depth and realism; that by itself would probably tend to generate fewer, more dedicated players for Extended as compared with Standard.


The Bridgewater-Brunel server is the most popular server of Simutrans Extended.

Is there anything you think current Simutrans Extended is in great need of improving?

Yes – there are lots of plans for improvement. I have written in a previous answer about many of the things that I am working on for version 15.x, such as vehicle maintenance and inflation that are needed to improve the balance. However, after that, the next major thing that needs improving is town growth. Currently, town growth works largely in the same way as Standard with some minor modifications over the years: the whole town grows evenly (and, due to a quirk in the way in which town boundaries are currently set in Extended, in a square) depending on the rates of fulfilment of mail, freight and passengers in the town as a whole. In reality, towns were shaped – literally – by their transport: they were small, compact units before public transport, with high densities in the centres but no suburbs. Commuter railways allowed high and middle wealth residents to live in suburbs centred around stations (termed “Metroland” by the Metropolitan Railway in London – this company also bought land near the stations to sell or rent for a profit once the lines had opened, a practice also common in Japan, I believe), while lower wealth residents still lived near the centre. Then, trams and later motor ‘buses allowed lower wealth residents to live farther away from their workplace. Finally, the mass adoption of the private car resulted in evenly sprawling suburbs for people of all levels of wealth around city centres that had very little in the way of residential buildings.

So, after 15.x, the next major project will be a total overhaul of the town growth system so as to make growth based on local, rather than whole town, transport, for towns to compete with one another for residents (the population increase over time being not dependant on the quality of transport in towns, but rather the best towns attracting the
most residents), towns to be able to shrink as well as grow, buildings to be able to become abandoned, overcrowded or be re-purposed as times change, players to be able to buy buildings in towns and rent them out or later sell them, the occupancy rates and market rent depending on the desirability which will be heavily influenced by transport, towns that grow so as to touch other towns will become metropolitan areas with the consumed former towns becoming boroughs, the overall rate of population growth should be in line with historical figures and towns should finally cease to be square.

Simutrans Extended has changed a lot through the years. When you look at it today, what makes you think?

Simutrans-Extended has indeed changed over the years, and hopefully will continue to do so. In the early years, its original name of “Simutrans-Experimental” was apt, as there were many features that had not been fully implemented in the pakset or fully tested. I think that it is only with the regular use of the Bridgewater-Brunel server from perhaps about 2012/2013 onwards that Simutrans-Extended began to mature. It was always intended to be a realistic and detailed economic simulation, but earlier versions had a lot of anomalies that were only shown up with testing over time and which often required quite sophisticated new features to remedy. That process is continuing as a large number of the currently planned features arise out of testing showing up anomalies, but Simutrans-Extended is certainly more mature and stable now than it was 10 years ago.

If you were to start Simutrans Extended today, would you make anything different?

There is a lot that one can learn from hindsight. If I were to start afresh, I should have rewritten the railway signalling code rather than adapted the existing code for multiple types of signalling, as it has proved to be difficult to debug and maintain. I should not have used an arbitrary number for comfort, but instead had a field for the maximum comfortable journey time (and comfort is likely to change to this in the future). There are many things that started out being done one way that have long since changed to being done another way, and in many cases I cannot recall what the original way of doing things was, where, if I were starting afresh, I should just go straight to doing things the current way. When I started working on Simutrans-Experimental, as then it was, I was just learning C++ specifically in order to work on Simutrans. I have learnt much about coding since then and about modern C++, and if I were starting afresh now, I should like to think that the code that I wrote would be more modular and robust.


Video by James Petts demonstrating how signals work for Simutrans Extended

How is your relationship with Simutrans (Standard) developers?

I think that when what became Simutrans-Extended first started back in 2008, there was perhaps a degree of tension with the Standard developers: I may have given the impression by coding new features that I was expressing dissatisfaction with their work or with their game design choices. My own coding skills were not the best at the time, having learnt C++ specifically to add features to Simutrans and having no professional background in coding, so one of the reasons that some of the features that I wrote in the early days were not added was that the coding quality was not to the standard of Standard. Also, I think that, in my eagerness to promote the new features, I may inadvertently have given the impression that I was trying to take credit for things which were largely based on others’ hard work. Also, I think that forking a codebase can be seen as a somewhat hostile thing to do in some ways.

However, I did not wish to cause any tensions, and I think that the other developers are reasonable people too. I did work to ensure that I gave proper credit to the existing developers for the excellent work that they had done, without which Simutrans-Extended would never have been possible, and to acknowledge that there is nothing inherently wrong with the play style and game design choices in Simutrans-Standard: it is just that different people’s preferences differ, and my preference (and, as it turns out, the preference of a number of other people who play Simutrans-Extended avidly) is for a higher degree of realism and complexity than the preference of those who tend to prefer Simutrans-Standard, which has its own loyal following.

After the brief initial tensions and for most of Simutrans-Extended (and its predecessor’s) 14 year lifespan, the relationship with the Standard developers has generally been good: they have often been very helpful in responding to my questions about how the code works, or even proposing solutions to problems specific to the Simutrans-Extended code (and in some cases have even written fixes for Simutrans-Extended, which is very much appreciated). In turn, Simutrans-Standard has over the years adopted a few features that started life in Simutrans-Extended and that are compatible with the somewhat different design philosophy of Standard, so there is a definite symbiosis. Perhaps most importantly, although there are two forks of the game and many players play only one or the other, there remains one single community: both the International Simutrans Forum and the more recent Simutrans Discord channels are common to both Standard and Extended and the same people interact freely and happily with each other in those channels. This has, I think, been very mutually beneficial for both variants of the game, and we are very lucky in the Simutrans community that we seem to be far less prone to the sort of aggressive and abusive behaviours that for reasons that remain obscure seem so common in online communities dedicated to many other forms of computer games.

Although you did neither start nor were involved in pak128.britain, you choose this pakset to be sort of the default pakset for Simutrans Extended, where new features are implemented first. Why did you choose pak128.britain?

Being from the UK, I had a particular interest in British vehicles and buildings; but, also, and probably more importantly, Pak128.Britain was a new pakset at just around the time that I was forking Simutrans-Extended, and it was being made open source, so there was the opportunity to adapt the sources for the Extended fork, as well as have the pakset be developed in part with Extended in mind (the original Standard maintainers actually added buffet cars and multiple liveries before these features were included in Extended). The only other open source pakset at the time was Pak.64, and I found the graphics too low resolution for my liking; Pak.128 had not been open sourced at this time.

How is the process of creating graphics for pak128.Britain-ex?

The system for creating graphics for Pak128.Britain-Ex was inherited from the original Pak128.Britain. It uses Blender to create simple 3d objects, which are then rendered automatically (with a pre-set lighting orb, intended to represent lighting on a typical British cloudy day) into the requisite 4 or 8 images as the case may be. This was all set up in circa 2006, I believe, by Kieron Green, the original progenitor of Pak128.Britain. It does actually make creating realistic looking graphics (within the confines of a 128×128 pixel set) much easier than they would be if one were pixel painting, not least because a single 3d model will automatically produce all the directional renders. This process has allowed us to create a very large number of graphics over the years to have a very large number of subtly different vehicles, which is one of the hallmarks of the pakset.

What is your favourite pakset? (Excluding pak128.Britain(-Ex))

A challenging question! I think probably the Japanese Pak.256. This is another pakset that has an Extended version: it has excellent high resolution graphics and is evidently curated with much meticulous attention to detail. Simutrans is more popular in Japan than anywhere else in the world so far as publicly available sources show (there is even an annual in-person Simutrans conference in Japan, or at least was before the pandemic), so I am always very interested in the Japanese Simutrans scene.


The Japanese Pak256-Ex is the highest definition pakset ever done

Thank you so much for the interview! Is there anything more you would like to say to Simutrans players?

Simutrans-Extended has been a long journey; there have been very many achievements along the way, but also some frustrations. My own development of Simutrans-Extended is not as intense as once it was as I have other hobbies to compete for my time, as well as a busy professional life, but I still enjoy working on Simutrans when I have the time, and we have some other very dedicated coders such as Ranran who have been doing some excellent work in the last few years. I very much hope that people will continue to enjoy playing Simutrans-Extended for years to come.

_____________________________________________

Schedule of the Simutrans 25th Anniversary Posts
I hope you have enjoyed this first interview to a non-Standard Simutrans developer. We will keep exploring the boundaries of Simutrans with the final interview next month. But before of that, the next event in two weeks will feature the most exciting creation made to commemorate the Simutrans anniversary so far. Stay tuned!

Tags:

Simutrans 25th Anniversary #5: For everything else, there is Simutrans

Enjoy this remake of a Simutrans advert video made 14 years ago by (the now inactive Devotee) vilvoh.

The Simutrans Community does not only welcome coders and artists. People who spread its love for Simutrans are also important, specially when they put as much effort and love in that as vilvoh did. Let this video serve as a reminder of all of you who enjoy making and sharing Simutrans content (be it now or in the past): Thank you! Without you too, Simutrans would not be what it is today.

Would you like to see (or make) more Simutrans-related media content? Well, you are in luck, because we have more surprises coming!

Next time, however, we will come back with another interview. Join us in two weeks as we will explore the boundaries of Simutrans with an exclusive interview with James Petts, lead developer of Simutrans Extended.

Schedule of the Simutrans 25th Anniversary Posts

Tags:

Simutrans 25th Anniversary #4: An interview with Markus Pristovsek, the Adoptive Father.

After Hajo left Simutrans, a man took care of continuing development – and has continued to do so for over 17 years (more than double the time Hajo was involved with Simutrans!). Without him, we would not be here today celebrating 25th years of development. It is now the turn of developer Markus Pristovsek (known as prissi) to answer some questions!

You will find that many questions are similar to those from Hajo’s interview, so you have the oportunity to compare the points of view of the two most influential Simutrans developers.

Let’s begin the interview!
_______________________________________________________________

First of all, introduce yourself. Who are you? Where do you live? What did you study? Where are you working or have worked on the past?

I am Markus Pristovsek, which is a pretty unique name. So if you found this on the internet, chances are high it is connected to me.

I am a Dedicated Professor [at”> Nagoya University in Japan. (Dedicated Professor means that I do not have to teach. But I teach anyway a little, because I like it.) Since I have recently got my tenure that will likely stay so. Yeah, my first stable job at 52 years …

Science is a little like the old medieval crafts: You have to travel a lot until you find place you can settle. In my case it involved studying physics at the TU Berlin in Germany, and from 1995 or so I worked on crystal growth of semiconductors like GaAs and GaN (see the Nobel prize of 2014 to my director). After my PhD I stood in Japan (2000-2003), Berlin again to 2009, University of Cambridge 2012-2016, and from 2017 Nagoya.

I wrote job applications for almost 50 positions but was invited only four times, which is pretty normal in my field. From 2010 or so I put something like Simutrans coding coordinator into my CV under other activities, mostly to have more to show. However, at my second to last interview in 2016, one of the committee members was from the IT department. He was very eager to to know more about it (actually he had looked up on Simutrans a lot!) and 1/4 or the interview derailed to Simutrans and “herding” open source projects. He seemed quite impressed on it and I could have probably got a position for teaching IT and Open Source if the interview would not have been about Teaching Photonics at an Applied University.

Did you learn programming as part of your physics background or did you learn it by yourself?

I wrote my first program in 1983 when stuck in an Austrian pension during a very rainy hiking holiday. My parents set out anyway, and I wrote a Pascal “database” for keeping track of my sailing competition results on six A4 sheets of scribble paper, based on the book “Pascal Programming for the CDC6000” from the mid 1970ies from my home library.

Shortly after I also implemented a line drawing algorithm on a friend C64 in USDC Pascal were one could see the line emerging pixel by pixel… That routine I reused in Simutrans.

My first Computer came in 1986. By chance it was an Atari ST, which we got with 30% rebate because my father somewhat knew Jack Tramiel (the founder) since he worked as Chief Concierge in the best hotel (then Hilton).

I first programmed it in Basic, then Pascal (as soon as the school yard network provided a compiler). But soon I ended up programming in C, since there was an IDE. My main contribution from that time is an Editor (PrED, sold about 100 times), and a viewer for TeX’s DVI-files, which was mentioned in the 1990 LaTeX companion. This combined highly optimised C and assembler (I even wrote a 30% faster replacement 32 bit division routine compared to the already optimised C-lib.) MC 68k assembler was great. (68k was also the base for the PamOS, where I learned about UTF-8 http://palmdict.sourceforge.net/ )

Formal training was 1 Semester in University, IT for Physics, at the ripe age of 22. It was a HP workstation with 8 X-terminals. Almost unworkable slow, so the true nerd met at 22h in the evening, spawned 20 emacs until the network card overheated and the system rebooted with cleared memory. Had to repeated every three hours or so. The only thing I learned was hacking Unix on that one … In the next room were PCs with absolutely filled with Viruses, which were for “IT for Philosophers”! But they had Internet connection, so I could download ST software from the US at mind blowing 8 Bytes per second during the night (well whole the University had a 9600 baud connection).

The next big thing I am proud, is a software I am still using today: https://github.com/prissi/snomputz It was written in 1997 to 1999 to run on a 386 without compressor and 2 MB main memory under windows.

Thus, in 2004, when I started contributing to Simutrans, I was quite computer literate, but had zero ideas on OOP. Also the Stroustrup book is great if you cannot sleep. Honestly, one of the most boring text I failed to read.

So a lot of my early code is rather C in disguise than proper C++. But I never really learned it. Tron (who hosted the third SVN) taught me a lot of proper C++, which I often stubbornly ignored first for some time.

Apart from physics and programming, do you have any other interests?

That changed with time. However, I like to be outdoors. So at some point in live, I made myself the rule to not switch on the computer when there is sun outside, and I pretty much lived by this rule. (Not too hard with miserable German winters or now sunset before 19h even in summer in Japan … )

Walking or Hiking is great. I cycle a lot, even more since Covid. (I have a tandem and send my 10 year old off to the 6 km away school and then cycle almost back 9 km to my University, whenever the weather permits.) I like sailing, but in Japan the summer is too hot and the Nagoya bay is mostly harbour with refineries and steelworks and the airport on an artifical island …

I like to read, but lacking time, it is mostly webcomics (I recommend the belfry archive, https://new.belfrycomics.net/ around since 1996 without advertising – the last old school internet site I know).

I used to write Science Fiction (in German), but that is even more time consuming. Also my work involves a lot of writing, so usually in the evening I am quite empty anyway.

I enjoy playing with my three children, but due to getting older (them) and the whole Covid online transition, they rather like to play with “friends” online. (Before we had 30 min/day cap all together, now this feels more like the daily minimum for one of them).

I like dancing, Folk dances (Irish, Isreal, south-east European, …) but like for hiking, I lack willing companions (and especially in Japan also occasions). I also like all kind of music. In the evening during dinner, one choses one tune on youtube, plays it screen down, and then passes the phone to the next. So there is a very broad range of music we all listen. Mostly around Christmas I dust off my guitar and various recorders as well.

Do your children play Simutrans? If so, do you play with them?

No, I showed them once. But I have had not played for over a year now, so I can be hardly setting an example …

Did you ever publish any of your Science Fiction writings?

Yes, less than 10 stories appeared in monthly a fanzine in the 90ies (on paper), called Solar-X, where I also wrote several book critics. Some more (in their rather raw state) can be still found on my old homepage: http://www.physik.tu-berlin.de/~prissi/m-werke.html

But nothing in English.

How did you know Simutrans? What was your first contribution?

I came to Simutrans in 2001 via a game collection CD of the German magazine c’t (which I am still subscribing today). I was in Japan at that time, but the magazine send also there with surprisingly little delay (5 days later or so). At that time most magazines had software CDs, c’t was about four times a year.

Contribution started in autumn 2004. First was the compilation of a pak64.japan from the objects in the Japanese wiki and some other sources.

Codewise, just a little later in November I asked Hajo for the vehicle acceleration code. Simutrans was Freeware, but not open source; quite common then. So Hajo as creator hold the codebase, and had sent out parts to possible contributors.

I wanted to try a more physical model. (Before vehicle always accelerated to max speed, even if totally underpowered.) I have a PdD in Physics, but in the end I made it intentionally non-physical, since a physical code (like the one extended is using) was too performance heavy and even worse, did not look good in game scale, and failed with many vehicles of the existing paks. Hajo was pleased, and so I got a zip of the whole code. Next was UTF8 support, where I had a very solid knowledge from the Japanese Dictionary for PalmOS. Then I got SVN access and in January 2005 Hajo left Simutrans with me and Dariok and Hsiegeln, who hosted the second SVN, which just vanished one day.

How did you become the lead developer of Simutrans after that?

Very simple, from March 2005 to end of 2006 I was the only regularly active developer left. In that year I did a lot of work (powerlines, winter transition, roadsigns, quick zooming, pak64.german, … ) Only mip was longer active than me, and has contributed to the gui infrequently all that time. All other developer joined later, so they implied that I am the lead developer. I never really claimed the title in any proper way.

Have you ever felt uneasy with your unclaimed leadership of the project?

No, not really uneasy. Maybe tired, and I would happily hand it over to someone with more time and more drive, and maybe a vision what to do next. I think I am too old for this now.

I am not sure if people need a leader. Whenever possible I would like to do things with a Simutrans team, but in the end few things are done and it is down to oneself. I think you know this quite well …

I often wonder if I am too strict, or too German rude for a good leadership role anyway.

Simutrans has been in your hands for most of his lifetime (17 years, double the time than in the hands of his creator, Hajo). Do you think it will survive without you? How do you envision this transition?

Simutrans turns 25. There are very few programs under active development that ever reach that age. Most of those are editors, compilers and other tools. Most programs did a complete makeover during such time (look at Word for Dos, Word for Windows, and the current ribbon Word: These are separate programs.)

In that regard, Simutrans simply will not go away. As to my contribution: I host the SVN, and the server listing, and the German forum. But now there is a github standard repo under the simutrans team control, and the server list node.js code is on github. So anyone could continue.

Apart from the Android porting (which was less a coding effort than learning and applying new stuff), I did not do much in the last two years. Maybe Standard is now mature enough to not require any leader. The server uptimes are as long as the OS itself, and automated test find many serious errors immediately.

And then there are the forks, like OTRP and extended (although its stability is rather experimental to me). These are sucking on Simutrans; maybe Simutrans (standard) will fizzle out due to everybody contributing on forks. And the recent code reorganisation (especially the slitting of large files), while in theory making contribution and maintenance easier, had in practice the effect I feared: it became almost impossible to port anything back for me or anybody else without investing much more time. I am very grateful for Ranran going both ways occasionally.

Its getting long, but let’s go into the Simutrans forks a little more:

There are two typical user bases: The extended one who play British on one server and the Japanese ones, who like model railroading, play sole or net simutrans.

They dictate the development in these branches/communities: Extended is mostly dictated by some ideas of mostly british realism mostly concerning railroads. The Japanese community (which is by far the largest, just look at the Discord) is mostly focussing on building clockwork like little realities. There was a Japanese freeware Freetrain (http://www.kohsuke.org/freetrain/) which just run trains along lines, no economics, which pretty much give a good idea of the style of many players in Japan.

In standard we have some US players (mostly in pak128) which are mostly focussed on road vehicles, and the Brasilian community, the German community, so it is a colorful fragmented community with a clear summer-winter contribution cycle. Standard tries to cater to all, but of course that is bound to fail when competing with specialized forks. So maybe Standard just dies in active development, and will rather be the base for various shorter and longer surviving forks.

Indeed, the Japanese community is pretty big and active, even making annual conferences. Since you have been living in Japan for many years, have you ever attended any of those events?

Just before corona I was at a Simutrans con in Tokyo, and last autumn I met with five nice guys in Nagoya, where we went to the local Shinkansen museum. It was my first “con” (in the fandom kind), and it was quite impressive, with the amount of work put into counting cars throughput for different crossing designs for instance. I think there are videos on the net or in the forum.

What is the biggest challenge you faced when working on Simutrans?

Lack of time.

The tools have been greatly improved (in 2004, simutrans only compiled with cygwin GCC, and had no working debugger). Contribution is also there, motivation is still there. But in End of 2006 my first child was born, and since then contribution went down. Now it is only two hours in the evening at most.

When you first took care of Simutrans, it was still closed source. Did you push to make it open source? How went the process of making previous contributors to agree? Why the Artistic License was chosen over more popular open source licenses?

After the birth of my first child my time got less and less, and I became worried. Thus, in May 2007 I finally got Hajo’s permit, and then contacted all the other contributors of whom I knew their addresses, Markus Weber, Hendrik Siegeln, Volker Meyer, Owen Rudge, Kieron Green, Stefan Wuttich, and Tomas Kubes. Other vanished. Also without SVN or the other old CVS, we could not really assign code ownership, and code gets reworked many times. So who is the copyright holder after a code review with corrections? For graphics, we did not publish work from anybody who we could not reach.

Several people wanted a non-commercial license, but there was nothing there. The artistic license had a clause that could be interpreted as non-commercial (even though a non-commercial license is actually incompatible with GPL). It states “Freely Available means that no fee is charged for the item itself, though there may be fees involved in handling the item.”

Modern CC licenses of course fill that hole.

Still, I got a blanko permit from the original developers. In principle we could change to GPL, if we get permission from Knightly, Dwachs, and the other main contributors since 2007.

What is the thing you like the most about working in Simutrans? And the thing you like the least?

I certaily do not like “working”, even thoguh occassionly this is neccessary. What I like least:

– tools with awful documentation, or the need to watch youtube tutorials (I thought programmers could read and write)

– maintenance of all kind

What I like:

– most of the rest, I would say, otherwise I would have quit a long time ago

Is there anything you think current Simutrans is in great need of improving?

There are a lot of other stuff, like a directional wayobj for single direction roads and not the OTPR “hack” of special roads, which also give no real indication without an overlay. Porting the overtaking code back from OTRP, now that it does not desync any more and seems stable. (Unfortunately this has became very difficult after all the splitting and reorganisation, so it needs to be done manually routine for routine. Might be good time for in depth for code review anyway.) This would cater to the general simutrans play, to be not biased towards rails (like extended). Here standard is lacking, and a directional wayobj would be also nice for airplanes.

More server hosting would certainly help to increase user base.

But nothing “great need” category.

Do you have any roadmap for Simutrans next version(s)?

I answered that one many times. No roadmap. There is an outdated todo.txt. I would not mind retiring as coordinator and just occasionally submit patches (as I do now anyway).

I think Simutrans can still improve on some areas, especially usability and network gaming (like more passenger and goods routing along competing connections, a nice side-effect of the static code of Knightly, but with less impact on performance and faster route recalculations than currently in extended).

However, the active international user base is shrinking, so maybe the foremost task of any Simutrans chef must be recruiting new players (as you do very nicely with Steam!) which will increase new contributors.

Indeed, the playerbase has been shrinking slowly but surely for quite a while, since April 2012, when the game was downloaded more than 100.000 times on SourceForge. What do you think this is due to?

Multiple factors, I guess, like going to yearly releases with plenty nightlies, start of experimental dividing attention, and changes of the industry, games from centralized platform, more gaming from mobile platforms. Also falling out of time, graphic-wise.

I find also the download per country quite interesting:
https://sourceforge.net/projects/simutrans/files/stats/map?dates=2007-05-16%20to%202022-07-01

So after Germany and Japan, there is Brazil and United States, and also Indonesia on 8th. Some unusual countries for a transport simulator.

Simutrans has changed a lot through the years. When you look at it today, what makes you think?

A tough one. Actually, I think the principal game play is still very similar to the earliest releases.

So I would rather say, I am surprised that Simutrans survived that long.

If you were to start Simutrans today, what would you make different?

This is extremely hypothetical given my lack of time since the last ten years. However, one thing would be probably to do this 3D or pseudo 3D. There have been other approaches like checz game which is very close to simutrans in terms of track laying and still allowing for full 3D. But as far as I know it lacked in other transport modes and industry connections beyond rail.

And not sure how to have large maps and 3D together. The networkmode model would be the same, since I see no realistic way of syncing 10000 convoy departures and millions of routing events per minute. And at least standard is extremely stable, servers run for months, and clients disconnect mostly on request of their users and not because of loosing sync.

What’s your opinion about Simutrans Extended? Have you ever played it? How is your relationship with Simutrans Extended developers?

I think extended took a lot of pressure to review and incorporate patches, especially ones that were done not so well and also ones which disturbed the balance between easy entry and heavy playing. Some ideas are great and I would like to have them in standard.

But extended has become one sink, happily taking advice and patches from standard but almost never giving back (apart from ranran). With a shrinking number of contributors, of course I see extended critical for the long term future.

However, I think the code quality of extended is in need of improvement.

I tried twice to start it. But it did not in a meaningful way, at least I could not connect to BB then respective the pak128.Britain extended did not start because the demo game did not work for that version of simutrans.

Compiling was also not working well. I then looked at some of the warnings in MSVC (beyond the trivial ones) and there were a lot of places that indeed needs fixing. The multithreaded code must work by luck because there are some accesses on variables just declared volatile instead mutex protected and so on.

Also the gameplay with signals is so geared towards Britain and so user unfriendly, that it has really entered a very special niche.

The discussion about Simutrans VS OpenTTD is a recurrent one between our players, since both are open source transportation simulation games. However, the reality is that Simutrans is far from close to the success of OpenTTD. What do you think this is due to?

While OpenTTD came late, there was the TTpatch before. So there is rather an uninterrupted chain of user from TT(D) to OpenTTD, and people remember oh TTD is still around. Also OpenTTD rewards quick success. Vanilla pak has four engines/trucks/busses and a very quick success. Getting bankrupt is close to impossible. The downside is that after 2 h or so one is drowned in micromanagement of broken down vehicles and close to the year 2020.

Simutrans after 2h is still in stage one of connecting everything in a way without getting bankrupt and/or causing insane queues of waiting goods/passengers.

So while vanilla OpenTTD is the fast food, Simutrans is rather the 12 course menu. In the real world, McDonald serves more customer than a Michelin starred restaurant per day. This goes along that OpenTTD is often played by rather young gamers (at least this is the impression I got from the forums) while Simutrans caters to the more well aged community who had outgrown the kick of quick satisfaction.

And in the time of mobile games with 5 minute success, and streaming stuff in 20 minute slices, Simutrans is clearly no mainstream, since 20 minutes in Simutrans is almost nothing.

So it boils down to different audiences, and different fame deriving from *THE* transport simulator.

Did you have any relationship with OpenTTD developers? Was there any interchange of ideas or code?

I had little direct contact with the OpenTTD developer. Actually Owen Ridge, who hosts to he TRD forum, has contributed midi code to Simutrans. I did two patches, a winter seasons one (which is doomed since there are less winter than summer trees), a night time patch, and a rudimentary destination systems, all in 2005/6. I did not contribute since then.

Occasionally I look at the OpenTTD forum, but development has also stalled a bit it seems.

Although you are now mainly a developer, you actually started contributing with graphics to pak64.japan. Do you still like to paint graphics?

Never painted much, just a tiny bit of copy and paste and editing. I would like to paint, but I am bad at it.

What tools do you use when creating objects?

When making button or other GUI stuff, I use an ancient Paint Shop Pro 4.12 from the late 90ies. Still the best tool to push pixels for me on these few occasions. And then shades and tile cutter and so on.

Do you have anything you worked on you are specially proud of?

After so many years, no. Maybe not giving up on Simutrans.

Which is you favourite pakset? (paksets maintained by you are not valid!)

Even though it is no longer maintained, pak96.comic was graphically very nice. Pak128.japan is second, but the graphics are too bright for my liking. pak129.comic is very complete, but somehow the industries never engaged me much. pak48.excentique does not have enough choices, but i like the abstract setting (same with pak contrast). pak.HD (handdrawn) looks ugly with the new climate system, but is also a nice addition. pak.HO I have ever really tried out at all. pak.nippon fails due to the use of pak64 vehicles, so technically I am involved with it …

Thank you for this interview. Is there anything more you would like to tell to Simutrans players?

I thank you all for playing Simutrans. And please consider to contribute, whether spreading the word, reporting bugs, running a public server at home, paint a simple object, or help with coding. Simutrans can only live another 25 years if there is contribution from players.

____________________________________________

Schedule of the Simutrans 25th Anniversary Posts

Next time we’ll bring you something different: A remake! A remake of what do you ask? Ah, you will need to wait to find out!

Tags:

Simutrans 25th Anniversary #3: The Simutrans Museum

In the last post of this series we talked with Hajo about the first years of Simutrans. However, many of the players reading this today have never played a Simutrans version from Hajo’s era. If you ever wanted to take a taste of one of the earlier Simutrans releases, today is your lucky day!

The first demo version


A screenshot of Simutrans demo version 0.50, with text in German.

The first of the versions we have made available is not the actual first release, but it is pretty close. This beta version was released on 02/05/1999, while the history.txt starts just two months before (06/03/1999). As the “demo” name suggest, this version has practically no content, and crashes frequently, since it was just a version to show up the Simutrans engine working and a little more. Because of this and the need to use a DOSBOX, we recommend you to skip this version and try the next one if you want to truly play an early Simutrans.

The first playable version


A screenshot of Simutrans beta version 0.78.7 with the minimap and some toolbars and windows opened.

Thanks to the donation of user Khaki we got our hands on one of the firsts playable versions of Simutrans, beta version 0.78.7 (released on 14/06/01, two years after the previous demo). As you can see in the image, this version has already some basic working tools (rail, road, ship and terrain tools). The minimap is also present, with a familiar view.

You can play this version natively on Windows or with WINE under Linux, although you might find some game-breaking bugs (particularly one with pop-up windows).

The Museum and other versions

In the SourceForge Museum you can find the versions mentioned in this post and other versions from Hajo’s era (beta versions 0.80, 0.84.01, 0.84.04.1 and 0.84.10) which were recovered thanks to Markus Pristovsek. Do you have any other previous version of Simutrans not listed there? Please share it with us!

And of course, you can still download (and compile) any version of Simutrans since it became open-source on SourceForge.

Schedule of the Simutrans 25th Anniversary Posts

Talking about Markus Pristovsek, join us two weeks from now as we will interview the lead developer for the 25th Simutrans anniversary!

Tags:

Simutrans 25th Anniversary #2: An interview with Hansjörg Malthaner, the Founding Father.

Simutrans was started 25 years ago, not by a game development company, not even by a team, but by a single man who dreamed to build the best ever transportation simulator: Hansjörg Malthaner, known by the Simutrans Community as “Hajo”.

But who is this “Hajo”? How did he develop Simutrans in its early days? What has he been doing since he left the project, and what does he think about Simutrans today? We have reached Hansjörg Malthaner himself for an exclusive anniversary interview to reply to these and more questions.

Let’s begin the interview!
________________________________________________________________

First of all, introduce yourself. Who are you? Where do you live? What did you study? Where are you working or have worked on the past?

I live in Stuttgart, Germany. A place that often is called boring and provincial, but actually the living quality here is quite good. To German standards it counts as a larger town with a population of more than half a million people.

Most of my professional career I’ve worked as programmer, mainly using Java. Later the focus changed to quality assurance and automatization of build processes, testing and deployment. Meanwhile research has also become an aspect, to find and compile information which enables other people to do their work efficiently. In summary, still all typical software development just with emphasis on different aspects of the development process.

With such a curriculum, it is of no surprise that programming is also a big hobby of yours. But do you have any more hobbies?

There never was a scarcity of hobbies, just scarcity of time. Electronics was something that I was very interested in during my teenage years, and which recently was refreshed by experiments with microcontrollers, like the Arduino. Gardening was something that I picked from my parents. Not sure if hobby is the right term, it’s more just part of my life all the time. As child I used to paint, and art has become a growing focus, while programming became less of a hobby and just a profession. Traditional art, pencil and watercolour, but also 3D art with help of the computer. Also experiments in sculpting and with arrangements of dried plant parts and rocks, but I even have written a few story fragments, that got some positive recognition.

Cooking has also taken a bigger role in my life lately, and I consider that a very nice hobby, particularly in conjunction with gardening and the options to grow some vegetables of my own. At times I build furniture or refurbish old furniture. There is really a lot of different things that I’m interested in. Music, both in composing or performing is likely seeing the least attention, but that didn’t stop me from building a pipes instrument which is played similar to a xylophone.

Overall I think the shift away from programming released a lot of energy that went into very interesting and often also very satisfactory activities.

Talking about your art hobby, in the previous interview (more than 10 years ago) you stated that you were bad at 3D modelling. But now, looking at your art gallery, you have definitely improved a lot. Did you work on any 3D-related project that boosted your ability?

I think I am still bad at 3D modelling, but over the years I found ways to work around this and still produce interesting scenes. There are things like people or animals though, which I can do only with a huge investment of time.

There was no particular project, but at some point I changed from drawing game related graphics to 3d modelling. The rendered graphics both were more consistent and of higher quality than what I could draw. That set my focus on using the 3d tool, and made it worthwhile to really try to get good at it.

I’m still learning new things all the time though. Both about the 3d software and also how to set up scenes. There was no quick boost, it was more of a slow progress over many years. As you mentioned, 10 years passed and I even had used the 3d software before.

The next level will be short movies, so I’ll have to learn how to move the camera, when to zoom how to cut and blend from one view to the next.


One of the artistic creations of Hansjörg Malthaner

Did you work on any serious project before starting Simutrans?

I’ll say no. I had made a ray-casting engine, the original Doom game was popular the early 90s, and a simple space flight simulation, as I was an Elite fan. Also a drawing tool. Well, let’s say the drawing tool was a serious project and actually used by some friends. But it soon was surpassed by other tools which were available for free. Also I had made a tool to model a sort of skeleton for 3D puppets and pose them easily. That one had potential but also limitations. Now tools like Blender serves the same purpose and does it much better. So I was working on projects, but none of them was published, at best shared with friends. Just the drawing tool I’ve offered as download for years, but I don’t think it ever was used by many people.

A remnant of the space flight project persists, it went through many incarnations, had become Solarex, then Solarex GL, then Stellar Prospector, using OpenGL for display but deep inside there are still some design ideas that came from the old 3D space thingy. It actually might become a game some day.

https://freegamedev.net/d/22-stellar-prospector-formerly-solarex-gl

Allow me a note here – Simutrans did not start as a serious project. It started as a “let’s see if I can do something like this” project and was only published when a person whom I had told about it in a sort of forum, asked to show a demo. The first versions were very bad, crashed often and barely had any functionality but show vehicles moving over roads on a tiled landscape. It took a lot of time to get past this infant stages.

The drawing tool sounds interesting. Did you ever use it to paint Simutrans graphics?
Yes, all the early graphics of pak64 were made with it. At that time 8 bit graphics with colour maps were still pretty standard, and the tool was aimed at working with colour mapped images. Later I changed to GIMP which is now the graphics tool that I use the most.

Actually, I forgot a later incarnation of the drawing tool, which focused on creating tile sets for games with tiled graphics. That one was used for some of the graphics in pak48.Excentrique, but more to conveniently handle and edit them. Most of the graphics were made with PovRay, a ray-tracing tool.


A screenshot of the painting tool “Drops” main menu.

So at mid 1997 you started Simutrans. A transportation simulator. Of all the projects you could have started, you started a pretty complex one. Did you ever think that the project was too much of a task for you?

Yes, I was often pushed to the limits of my skills. Particularly creating suitable graphics was a big problem. One time I got a comment, “Simutrans is too ugly to play.”

I sure wanted to do better, but at the time my graphics skills were just not good enough, and only slowly improving as well. Programming was also tough, but a task that seemed to be more a matter of time to develop good solutions.

So from about 2000 I had been looking for help, and while it was very hard in the early days to find people willing to help, the more the project grew, the more it showed potential, the more offers came. I think, you can still see all the names in the credits scroller of the intro screen. Some had gotten monuments in the game. That time there was only one pak set, so pak64 was “the game” as much as the binary.

Only few wanted a monument though. So some had their names or nicknames preserved as vehicle manufacturers, architects and company names in the game. Some wanted no mention like that and only are named in the credits.

It was my way to honour those who helped in the years when help was really hard to get.

How did you promote Simutrans and find your first contributors in the early days?

This is a surprisingly tough question. After this long time memories can be deceiving. I remember the first announcement was made in a Usenet group, but version was very incomplete, so definitely not suitable for promotion.

I remember that for a while there were a very small number of people who had shown interest and which whom a had frequent email contact to talk about the project.

Before the first forum, we used e-group, a mix of mailing list and file repository. That was the major place for Simutrans for some years. Actually I tried to keep all talk in one place, I did not want to scout a lot of places daily and look if there are questions or comments which I should respond to.

Later it spread out, and we moved from the e-group to a forum which I hosted for a while. At that point I am fairly sure that I posted links in several game development places to the forum to attract more people.

This way I got into a surprisingly friendly contact with someone who was working on a commercial transport game.

But the pressure to promote was smaller, internet was somewhat exclusive. In private I did not have internet access before 1998 and that was a pay-per minute dial up connection, so any minute online was costly and somewhat precious.

Usenet also was a good place to get in touch with other game developers, but over the years, that also moved to forums.

It was not before 2015 that I published a game video on YouTube, way past my active time with Simutrans. I never was on Facebook, so my social media experience is limited.

How was the reaction to the first releases of Simutrans?

I really can’t remember many details. It was just a demo, to show vehicles driving on roads. A proof of concept for the landscape display and vehicle driving. No game by far, and most of all, the early versions had no railroads.

A few people believed that it can become a proper game, helped with testing and feedback. If there were negative comments I seem to have forgotten, except that the art had to be improved a lot. That stuck, cause I could program, but not paint, and I had to deal with it somehow.


One of the first Simutrans demos released.

You have been quite a while apart from Simutrans. Do you miss working on Simutrans?

I certainly did not miss the working. I felt burned out and disappointed when I left, at least that is what I remember. Also more than once I voiced the opinion that software projects are a bad hobby for me, and even that I started a few over the years, it usually boiled down to the very same finding. These projects do not make me happy. I now have a stance, to only work on them when I really want to, which means that there are often year long breaks.

I missed the talk though. Usually around these projects there were challenges, ideas, solutions. They often were challenging in many ways, technical, artistic and in interaction of the player and the game. I liked to talk to other game developers about such.

What is the biggest challenge you faced when working on Simutrans?

At first I was tempted to say route calculations for vehicles and goods. But while this indeed was the biggest challenge in the early days, long term, the creation of good graphics and sound effects turned out to be an even bigger problem.

While graphics have improved over time thanks to pakset authors (pak128.german, pak192.comic, and pak256 specially), the sounds are indeed still a challenge no one wants to take. Is there anything more you think current Simutrans is in great need of improving?

I think a better user interface is needed. One that is easy to learn, understand and use. One which makes common tasks easy to accomplish. Also I think, a better looking user interface would be nice on top of an easier to use one.


Simutrans Depot window with the classic theme. The UI has improved since then, but not by much.

What was the thing you liked the most about working in Simutrans?

Actually, the thing I liked most was the feeling to be important. Older games, like civilization, had a big name on the title screen. Now I was on my way to join the ranks of these, whom I admired for their game making.

Simutrans has changed a lot through the years. When you look at it today, what makes you think?

It might sound strange, but often I wonder how much of it still is the same. All the core of the game is still quite like in the old days. I think the underground mode is the biggest new part, much of the rest was optimization and tuning what was already there. And yes, the networking code. I had a different approach in mind, and the team chose what I considered the hard way to do it. So that truly is new and it was no easy feat.

Simutrans has stand the test of time, so far. But it reached its peak in April 2012, when the game was downloaded more than 100.000 times on SourceForge. Since then its popularity has declined slowly but surely. What do you think this is due to?

I can think of three reasons. The first one is kinda obvious. Even free to play or indie games nowadays have very good graphics. Simutrans struggled to get on par with games from the 90s, and clearly looks very poor these days, compared to what players are used from other games.

The second is a more general change in gaming. Simutrans is very complex. Overall there has been a trend to simplify games. I think for most new players these days, learning how to play Simutrans is ridiculously hard.

This leads to the third point. Simutrans offers nothing inside the game to help new players. At least nothing that is easily accessible. After starting Simutrans, a player is prompted with some menus, lots of options to choose, and if they make their way through it, they are left with a kinda sad looking map and a bar of icons.

I think most new players give up at this point, if they even make it past the map creation dialog. They want to play a transport game but have to choose a pak set – a term that new players don’t even know – and then create a map. “Where is the transport game?”, many will think. And the newly generated map doesn’t look that much like a transport game either.

I think Simutrans is just too obscure for new players and not looking good enough. These days games must look very good and help the player right from the start to give them a feeling of success.

But these are just my thoughts, and others my find other explanations.

If you were to start Simutrans today, would you make it different? Would you make it simpler to accommodate the game to current trends?

This is a difficult question. I was not very experienced, neither as programmer nor as game designer and if I put myself in that position today, I think I’d again miss to understand the importance of a good interface and what is called user experience today. It had not been part of my studies, it’s something I’ve learned later.

When you left Simutrans, the code was still closed-source. However, a few years later, you agreed to open-source it. Why did you took this decision then and not before? And why was the Artistic License choose over more popular open-source licenses?

The message from Prissi came in a very bad time. I was very depressed and not able or not willing to care. I was just like “leave me alone and do what you want with Simutrans”. I was not involved in the choice of license, I think. I am sure I was asked but did not discuss, just said the choice looks good to me, that is what I remember. I did not think much about the consequences. I just tried to live. If you are depressed like that, you care very little about license details and I did not expect to get in touch with the project again, so it meant very little to me those days.


An old post by Hajo, stating that he would open-source Simutrans should he left the project, which he finally ended up doing

There has always been the discussion of OpenTTD vs Simutrans, because they are both open source transportation games with similar looks and inspirations. While Simutrans is a success, it is far from OpenTTD in term of success. Why do you think players prefer OpenTTD over Simutrans?

The Transport Tycoon games had a huge fan base already when I started to work on Simutrans. And they are good games. There is little reason for their fans to look for alternatives.

Another aspect came to my mind when I dug out TTD once and compared it to Simutrans. It had limits, but it felt more fun to play. More dynamic? More “game”? Hard to really name it. My impression was, Simutrans is a huge and heavy simulation, TTD though was more fun to play.

It is hard for any project to be alive for 25 years without an organization backing it. And yet, here it is Simutrans. What do you think are the reasons Simutrans has gone so far and lasted so long?

I think it’s mostly Prissi’s determination and persistence, also Dwachs. Maybe there are more which I missed here, due to my long absence from the community. But in any case, it’s the persistence and endurance of the people around it.

What’s your opinion about Simutrans Extended? Have you ever played it?

I never played Simutrans Extended but I think it’s good to have some competition. Usually this sparks new ideas and gives a push to try new approaches and solutions.

Finally, the question everyone wants to know., What is your favourite pakset?
pak96.comic was much to my liking. I don’t know if it is still in development, but I liked the easy and fun approach taken there.


“Big Bus station” from pak96.comic, 1st place SMSC October 2010

Let’s talk about your other recent project, “Stellar Prospector”, a sim trading game set in the space. What are your inspirations and what do you want to accomplish with it?

Inspirations are old, games like Elite and Elite 2 – Frontier, but to some extent also Masters of Orion and Ascendancy.

The project’s core is very old, dates back to 2000 or even before. It started as a stellar system generator, suns, planets, moons, atmospheres, resources and physics that were at least not openly nonsensical, even if very likely nowhere accurate either.

After that stage it became a trading game, actually without a flight simulation, well eventually a very limited 2D one. Just enough to get from place to place, cause that is what a trading game needs.

Then I’ve tried to add a 3D flight simulation, but never could fix some bugs in the display of the planets. I think, compared to other projects of mine, it got some pretty cool looks, though.

There were days when I really wanted to make a proper game out if it. I designed 5 major species to inhabit the galaxy, some politics and an attempt to simulate social events like sports events and concerts. The game even had a newspaper to read what happens in systems near and far.

But in one of the former questions you asked what is the reason for the success of Simutrans and I answered, the persistence and endurance of the core team members.

I don’t have that any-more, or maybe never had. So at the moment I don’t want to accomplish anything with it and I think the last update happened a year ago.

Furthermore there are now projects like Elite Dangerous and Star Citizens, crowd funded, very ambitioned, with very good graphics and likely way better stellar system generation code than mine.

So I don’t think it makes sense to have big plans here. I’ll work on it if want to try something, or to entertain myself in boring times.


A screenshot of Stellar Prospector

Thank you very much for this interview. Anything more you would like to say to Simutrans players?

Actually the ones I would like to address are those who joined and helped in the early years. They joined while the project hardly showed potential, had very limited graphics and it was closed source. Thank you for your trust in the project and thank you for the contributions.

________________________________________________________________

Did you find this interview interesting? Do you want to know more about how these early Simutrans versions by Hajo were? Well, you are in luck! Join us in two weeks as we will explore Simutrans’ past in the most practical way possible: re-releasing the earliest versions of Simutrans we were able to find!

Schedule of the Simutrans 25th Anniversary Posts

Tags:

Simutrans 25th Anniversary #1: A look back at our shared history. The Simutrans Timeline.


Hajo’s first Simutrans sketch. At the top-right, a date can be read: 30-06-1997. Today, 25 years ago.

Simutrans started 25 years ago. Not yet as bits and bytes, but in the mind of a man: Hansjörg Malthaner (known by the Simutrans community as “Hajo”). Today, Simutrans is still alive, not only as bits and bytes in the thousands of computers (and now smartphones) that run Simutrans, but also in the hearts of many talented programmers, excellent artists, amazing modders and dedicated players.

To everyone of you: Thank you! Simutrans has gone very far, and it will go even further, thanks to everyone who believes in the Simutrans project.

Let’s take some time to congratulate ourselves and celebrate this milestone!

But first things first…

A little bit of history

Hajo started Simutrans alone in mid-1997. It was not until early 1999 that the first public beta was released. Simutrans started gaining some interest, and the first contributors, as the precursor of our current forum was created in the early 2000’s to accommodate a growing community.

Hajo kept developing Simutrans until he retired from development because of personal reasons in 2005. Since then, Markus Pristovsek “prissi” takes care of Simutrans, but not alone. In 2007, Simutrans became open source. This move ensured the long term survival of Simutrans and attracted many contributors.

Simutrans stayed on good track after that and would eventually come to other platforms such as Linux distributions, Steam, or more recently, Android.

Meanwhile, as Simutrans matured, other projects were born from it with the intention to innovate even further like jamespetts’ Simutrans Extended or himeshi’s OTRP.

But enough of reading about history. Reading about history is boring. So why don’t you instead see it?

The Simutrans Interactive Timeline

For the first event of this anniversary, here is an exciting idea: Let’s build a Simutrans Timeline of events. Surely a project as old as Simutrans has a lot of history to tell! So let’s tell it, graphically.

The very good news is that we already have built the foundations of this timeline, and it is interactive!

See it right now at simutrans.github.io. You can look more closely an also filter by event type. Here is a closer look at the last two years.

I have added the events that came to my mind, but there are many things missing, and I don’t know everything about Simutrans. Help us get a complete view of Simutrans history by adding missing events to the repository at GitHub. Missing releases, the date a contributor joined, or important events such as the forum migration. Every help is welcome!

The Simutrans 25th Anniversary

That’s not all we have prepared for this anniversary, but that’s all for today. In the upcoming weeks, you will see more posts to celebrate the anniversary. Join us in two weeks from now for an exclusive interview with the Man Who Started It All: Hansjörg Malthaner (Hajo).

If you want to know about the rest of the events: I am not telling you yet!

  • 2022-06-30 – A look back at our shared history. The Simutrans Timeline.
  • 2022-07-15 – An interview with Hansjörg Malthaner, the Founding Father.
  • 2022-07-30 – ???
  • 2022-08-15 – ???
  • 2022-08-30 – ???
  • 2022-09-15 – ???
  • 2022-09-30 – ???
  • 2022-10-15 – ???
  • From 2022-10-30 to 2022-12-31 – ???

Happy Simutransing!

Tags:

Simutrans on Social Media


Screenshot shared by ahakuoku on the Simutrans Discord

Building amazing transport networks is a lot of fun, and after building the railway of your dreams you surely would want to share it with others! For this purpose, and also delivering to you Simutrans news and other content, Simutrans is present on many Social Media platforms.

Official presence

You can follow or join the following communities, managed by Simutrans contributors:

Simutrans Extra #2: Simutrans for Android, Introducing the Extended Pier System and the New Directory Structure.

Welcome to another Simutrans Extra! For the ones that join us for the first time, Simutrans Extra is a series of articles bringing you the latest news of the Simutrans world, in a bulletin format. You can read previous editions in the Simutrans Steam News section.

We have been very quiet this year so far, but there are nonetheless exciting things to share! We’ll also be celebrating the 25 years of Simutrans during the second part of this year, so stay tuned: special publications coming soon!

But now, let’s review what has been happening these months in the Simutrans world, starting with the biggest plate: the Android port.

Simutrans for Android

Since the past year and thanks to the initial efforts made by krosk, we have a working Android build of Simutrans. This was one of the major goals for Simutrans, and it is finally here!

Publishing the game to the Play Store was a long effort (which prissi took personally), due to Google’s review process. And it is mainly the reason why this Simutrans Extra number took so long to publish – I was waiting for that process to end.

Although the build an publishing is already done, that does not mean that there’s nothing left to do: Simutrans has not been designed to be played on mobile, and a lot of work needs to be done to adapt the current interface to mobile characteristics.

You can download and play Simutrans from the Google Play Store:
=> https://play.google.com/store/apps/details?id=com.simutrans
Or directly from the GitHub releases page:
=> https://github.com/simutrans/simutrans/releases/tag/Nightly

For the Google Play Store, you can play the current nightly by joining the beta program. If you encounter any problems or have any suggestions feel free to post them on the Simutrans International Forum.

New directory structure

Traditionally, Simutrans has had two main directories:

  • Base directory – Simutrans installation and paksets go here.
  • User directory – Savegames, configuration and other user-specific stuff go here.

However, with the new pakset installer it was clear that this separation was not enough; we have added a third directory:

  • Paksets install directory – Simutrans paksets installed by the installer will go there.

Why? Well, when Simutrans is installed in the system, the user usually does not have sufficient permissions to allow paksets installation. Also, operating systems (like MacOS) have been pushing for self-contained programs, which was not compatible with pakset installation in the previous directory structure, and involved some hacks to even make it work in the first place.

From now on, paksets will be installed in a separate directory (inside %appdata% on Windows and the user directoyr on Unix-like systems. Note: Name still to be decided). Worry not, because this will not affect traditional Simutrans installations (including Steam) – Simutrans will still be able to read your paksets from the base directory!

Pak128 maintained again

This year started with a bad new: pak128 (default pakset on Steam) was marked as unmaintained, after 5 years without updates. After the announcement was done, however, Simutrans user garro (Gianmarco Garrisi) expressed interest in maintaining it again, and prissi also made some necessary maintenance.

However, this effort is losing momentum. So if you want to collaborate, check “pak128 revive: How to contribute” post in the International Simutrans Forum:
=> https://forum.simutrans.com/index.php/topic,21329.0.html

Elevated Way Support System for Simutrans Extended

We have not yet talked about Simutrans Extended in Simutrans Extra, and I owe you a proper presentation. But for current Simutrans Extended players, this is a new worth mentioning.

A new system for elevated way supports (formerly know as “Pier System”) has been incorporated recently into Simutrans Extended (Simutrans’ main fork). The Elevated Way Support System, developed for months by PJMack, is (in the word of its author):

“A new system for elevated ways that allows not only half-height elevated ways, but elevated ways on uneven terrain. Such method involves an new object type pier and new ground type pier-deck where the ground is placed on top of a pier. The system also allows the pakset designer to place restrictions on the ribi of ways both on the pier-deck and under it, as well as place restrictions on what types of piers can be built on others what other types and what types of piers can be placed on the same tile as another.”

You may find helpful this video-tutorial made by MG about this system

How can YOU contribute to Simutrans

Simutrans is an open source project. That means that anyone – including you – can improve it! Did you ever want to contribute to Simutrans but you have no skill for coding? Worry not, you can contribute to Simutrans in a variety of ways:

Translating

Simutrans is constantly updating and adding texts so we are always in need for translators:

Painting

Simutrans is always looking for artists! If you want to paint graphics for Simutrans, check:

Coding

Reporting bugs and submitting suggestions

Simutrans 123.0.1 Released

Simutrans 123.0.1 has been released. This is a small bugfix release to address some of the bugs of the 123 release, but there are also some interesting quality-of-life changes (such as the the option to scale the screen manually).

This release brings the Steam version back in sync with the non-Steam version, so regular players should be able to play network games again with Steam players.

Download Simutrans 123.0.1

Highlights of this version

  • All resizeable windows get minimize button in title-bar
  • Infinite mouse scrolling can be activated manually in the display settings
  • Option to adjust screen scaling manually (either via display settings or ‘-screen_scale’ command line option)
  • Illegal schedule entries are highlighted and a button to clear them up will appear.

Paksets updated

  • Pak64.german 123.0.0.2
  • Pak128.german 2.1
  • Pak128 2.8.2 (this is the default pakset on Steam)
  • pak48.excentrique 0.19 rc3

Full changelog

Here’s the full list of changes since the last version.

Added

  • Option to adjust screen scaling manually (either via display settings or ‘-screen_scale’ command line option)
  • not connected to any player network as additional option
  • selected convoi in minimap now magenta. Also network display properly updated when activating or closing windows
  • Illegal schedule entries are highlited and a button to clear them up will appear.
  • Infinite mouse scrolling can be activated manually in the display settings; but it will fail with certain touch devices
  • mark obsolete vehicls in vehicle-details tab
  • minimize buttons to convoi, halt and line window
  • button to remove double entries in schedules

Changed

  • Infinite mouse scrolling can be activated manually in the display settings; but it will fail with certain touch devices~
  • FluidSynth looks also for SF3 soundfonts
  • All resizable windows get minimize button in titlebar
  • one more row in schedule dialog for a little nicer display
  • lang files are loaded if their name is *XX.tab or XX*.tab. The first is preferred to avoid confusion by name like ja-taken.tab

Fixed

  • show overlay number on vehicle of convoy in depot
  • station display crashes on old paksets when certain windows unicode fonts are selected
  • time and minimum loading were not correctlin shown for schedule entries
  • empty schedules should be allowed…
  • pakset installer closes simutrans again after exiting the second time, but only if no paksets are found
  • sscanf_schedule ensures valid schedule
  • correctly adjust current_stop when moving entries in schedule up/down
  • Mouse pointer is restored after exiting the pakset installer from in-game options
  • allow tunnel building starting from tunnel tiles
  • Exiting pakset installer for a second time no longer closes Simutrans
  • loading of savegames with broken AI data (table keys have to be enclosed by [“..””> not only “..”)
  • when loading AI scripts respect -noaddons setting
  • delete double entries in schedules while editing, fix memory leak
  • Memory leak when translation contains malformed strings
  • tooltip in main menu
  • beach calculation was broken
  • crash in line window (when sorting in reverse order)
  • size of follow convoi when minimap is zoomed
  • Wrong formatting specifier in network_send_data
  • Translations from paksets fail to load
  • schedule highlightnigh in transport net on convois and minimap fixed and restored
  • ISO code can be first or last
  • pakset isntaller in windows after fullscreen enabled caused hang, because of invisble isntaller
  • Runaway simulation speed in some cases if modal_dialogue is open
  • show_month==1 now consistently for 24h per month
  • buy vehicle only with release (fixes also finger usage)
  • no jumping up and down in gui if schedule in empty or waypoint
  • arrow now call the inteded routines
  • arrow also works with two entries in schedule

Announcing the Simutrans Steam Screenshot Contest 2 winners

Votes have been submitted and winners are very clear. Congratulations to the winners!

First winner

The first position goes to… Aéroport De Jean Luc Picard, by DThunder518. Congratulations for your revenge, you finally win a contest!

Second winner

In second place, we have another image by DThunder. Schmetterlingsstadt gets the silver medal. What’s this, is DThunder518 going to claim all the podium?

Third winner

The well-earned third place is for… Leartin! Tropical Screen managed to reach the podium and deny DThunder518 yet another victory. Congratulations!

Winners 4-10

In order of votes.

4 – Transit Center, by DThunder518

5 – HSL ICE Passing Berngau Station, by danivenk

6 – Lübbecke, by Flemmbrav

7 – Dos Puentos, by DThunder518 (I think you mean “Dos Puentes”?)

8 – To The Moon!, by Flemmbrav.

9 – Bösel Hauptbahnhof In The DMZ, by danivenk.

10 – Fuchshofen Grenzbahnhof Where 2 Nations Meet In The DMZ, by danivenk.

Conclusion

I’m personally very happy with the results (specially since my favourite screenshot won) and with the participations. The screenshots look pretty good and more than enough were submitted to populate the Pak192.Comic store page, where you can already see them, replacing the old screenshots.


Library Header using the second winner.

I’m also delighted to see that this contest has drawn some necessary attention to pak192.comic, and I’m sure some of you have discovered this magnificent pakset thanks to this. Many of you have expressed feedback on the forums or other channels, and this was very valuable to pak192.comic developers. Perfect, all of this was a secondary objective of this contest. So if you have any additional comments, go leaving them before you forget! And if you liked pak192.comic, let a thumbs up in the Pak192.Comic store page.

Congratulations to the winners, and good luck next time to the ones who didn’t make it there! Join us next time at the end of this year in a special edition of this contest to celebrate the 25th Anniversary of Simutrans. Until them, happy Simutransing!