Après un long moment dabsence voilà un petit avant goût pour la suite. Il s’agit d’une playlist des différents patterns de réseau routier obtenu avec le système précédemment présenté. Très prochainement vous aurez droit à la suite (Export en Fbx et intégration dans un moteur de jeu, et génération de façade), les façades étant déjà partiellement fonctionnel je vais attendre d’avoir quelque chose de plus avancé avant de le montrer…
Author Archives: Soufiane KHIAT
Preview route
Après une longue phase de prototypage dont je ne vais rien montrer pour l’instant (Terrain, Route, Facade…), voici quelques nouvelle du projet :
Architecture
Un grand problème fait rage depuis la nuit des temps dans le monde de la programmation. Dans de nombreux cas nous en avons rien à faire des performances… Mais lorsque c’est le cas nous devons faire un choix entre la modularité et les performances ! C’est bien triste mais je voudrais que le générateur de ville soit modulaire. Donc comment faire puisque de nombreux algorithme sont assez lourd. Dois-je préférer la modularité au détriment de la performance ? Je pense avoir trouver un bon compromis, j’attends vos avis…
Le générateur est composer de plusieurs couche :
- Le Parser prend en entré un fichier XML et en sortie produit des Parameters
- Le Generator prend en entré des Parameters et en sortie produit des CityObjectsDescriptor ( RoadsDesc, IlotsDesc, BuildingVolumesDesc, FacadesDesc, IndoorsDesc, …)
- Le City prend en entré des CityObjectsDescriptor et en sortie produit des données topologiques ( RoadGraph, BuildingVolume, …)
- Le Meshing prend en entré des informations topologiques pour en produit des données géométriques interprétable par un moteur graphique (*.fbx, *.collada…)
Le Scripting :
De nombreuses options du générateur peuvent être modifier par scripting. Comme la manière dont les routes sont générées, la manière dont les ilots sont subdivisés…
De nombreuse solution existe par exemple le Lua, Python (des librairies existe déjà, lua++, boost.python…). D’autre programmeur on trouvé une autre solution pour résoudre le problème de la modularité. Certain on crée un compilateur C-Like vers du ByteCode qu’il interprète au Runtime… La solution du C-Like to ByteCode est dans certain cas comparable aux méthodes avec du lua et python (puisque certain compilateur lua et pyhton génère du ByteCode, il existe même compilateur qui génère du Code Machine à partir du python…). La solution du C-Like vers du ByteCode demande beaucoup de code alors que je voudrais me concentrer sur le générateur de ville.
Voici ma solution :
Dans un fichier XML je décris des fonctions de la manière suivante :
<Function name= »GaussLike » value= »Exp(-_1*_1) » />
De ce fichier, dans le bloc des Parameters je génère les informations nécessaire à la création du code C++. Puis dans le Generator je génère du Code C++ qui est compiler en *.DLL (ou *.so selon les plateformes). A partir d’ici il me suffit de stoker un pointeur de fonction 🙂 Une simple indirection, puis j’ai du code directement lu dans le CPU sans interpréteur quelconque. Si l’on change le script un simple déchargement et chargement de DLL puis une remise à jour les pointeurs de fonction 🙂 et voilà notre scripting mis à jour
Exemple :
Le bout de xml suivant :
<Function name= »DistanceRatio » value= »Clamp( _1/_2, 0.f, 1.f ) » />
Génère le code C++ suivant :
DLL_EXPORT
float DistanceRatio( float const _1, float const _2 )
{
return Clamp( _1/_2, 0.f, 1.f );
}
Voilà rien de bien complexe 🙂
Les routes
Comme quasi-toute les références sur la génération de route je me base sur des L-System. Un système avec une tortue qui avance. La tortue à de nombreux paramètre comme la longueur, la largeur, sa probabilité de crée des routes enfants, le nombre max d’enfant…
Une tortue est assez idiote. Elle est issu d’une route et peut créer une route devant elle et des routes enfants à sa gauche et sa droite, schéma :
Lorsque l’on veut crée une nouvelle route on demande à la tortue associée dans quel direction, quel distance fera cette route, est ce qu’on lui crée des enfants et combien…
Voici quelque exemple (ces exemples sont issu du même programme seul les fonctions définie dans le xml et les paramètres change) :
Voici la première préview. Prochain objectif, améliorer le générateur de route en donnant plus de paramètre au tortue pour faire des routes tournant autour d’un point, pour pouvoir avoir le pattern « Paris »…
Bientôt je présenterais une vidéo montrant le générateur en « temps réel »…
First
Bonjour,
Bienvenue dans notre devblog où nous présenterons l’avancée de notre générateur de ville. Le but est de créer un générateur de ville 3d modulaire avec un générateur de terrain afin d’avoir un rendu temps réel. Nous ne chercherons pas à développer un moteur de rendu; nous développerons notre outil comme un middleware indépendamment de la plateforme de rendue et du moteur 3D. Voici les différentes étapes du développement que nous nous sommes fixés :
- Placement des centres de villes (zone où la densité de population maximal en son centre)
- Générer la hiérarchie des réseaux routiers
- Détection des îlots
- Subdivision des îlots
- Sémantique des terrains à bâtir
- Génération du terrain
- Génération du volume des bâtiments
- Extraction des façades
- Génération des façades
- Génération des intérieurs
- Génération du Scène Graph
Pour l’instant c’est déjà pas mal… 🙂 En ce qui concerne les inspirations il y a bien évidement les travaux de Pascal Müller, Peter Wonka, Julien Perret, la vidéo de Marco Corbetta ainsi que les nombreuses publications que nous offre la SIGGRAPH, nous on fortement inspiré. Ce projet est assez ambitieux mais, nous le considérons dans le domaine du faisable du fait des softs du marché comme Procedural, Ürban Pad et X. Ainsi que de nombreux projets comme subversion se lançant sur la même voie que nous.
A bientôt pour de nouvelle nouvelle…