## hepia

Haute école du paysage, d'ingénierie et d'architecture MRU - LPSCP Prof. Fabien Vannel Hes-so

Haute Ecole Spécialisée
de Suisse occidentale

Fachhochschule Westschweiz

University of Applied Sciences
Western Switzerland

# **Fractales** semestre printemps 2018

## **Projet**

## 1 Objectifs

Cet énoncé a pour but d'aider à la conception d'un composant capable d'effectuer les calculs nécessaires à l'affichage de la courbe de Mandelbrot.



#### 1.1 Description

Nous allons commencer par réaliser un composant capable de calculer le résultat de l'équation de Mandelbrot pour un point donné. Les calculs doivent se faire en virgule fixe.

La courbe de Mandelbrot est construite en appliquant itérativement la fonction  $Z_{n+1} = Z_n^2 + C$ , où C est le point à évaluer, et  $Z_0 = 0$ . Le calcul se fait à l'aide de nombres complexes, et si une des itérations génère un point en dehors du cercle centré en (0,0) de rayon 2, alors le point est en dehors de la courbe. Si tel est le cas, le nombre d'itérations pour atteindre la frontière doit être retourné.

Un nombre maximum d'itérations est défini, et si ce nombre est atteint sans que Z n'ait dépassé le cercle de rayon 2, le nombre d'itérations retourné sera 0. Dans tous les autres cas, le Z

résultant de la dernière itération sera retourné, afin de pouvoir afficher correctement la courbe.

Il existe de nombreuses variantes à cette courbe de Mandelbrot. Internet sera une bonne source pour trouver des formules mathématiques. Par exemple  $Z_{n+1} = Z_n^3 + C$ , ou  $Z_{n+1} = Z_n^4 + C$ 

#### 1.2 Réalisation du bloc CALCUL

L'entité suggérée du composant pourra être la suivante :

Les paramètres génériques permettent de définir la taille des opérandes, la place de la virgule, ainsi que le nombre maximum d'opérations.

Le nombre à évaluer est fourni sous la forme d'une partie réelle  $(c\_real)$ , et une partie imaginaire  $(c\_imaginary)$ . Le résultat, donc le dernier Z l'est également de la même manière, avec  $(z\_real, z\_imaginary)$ . Enfin le nombre d'itérations est également retourné.

Votre calculateur doit indiquer s'il est prêt à effectuer un calcul, en activant ready. Si tel est le cas, l'entrée start lance un calcul. Lorsque celui-ci est terminé, vous devez activer finished pendant un coup d'horloge, en fournissant les sorties  $z_*$  et iterations.

Votre implémentation est libre quant à son fonctionnement. Vous pouvez très bien effectuer un calcul complet avant d'en accepter un autre, ou réaliser une structure un peu plus pipelinée (qui devrait nettement complexifier le système).

Il vous est vivement suggéré de réaliser un banc de test pour vérifier le bon comportement de votre système.



## 2 Déroulement du projet

Le projet représente l'équivalent de 7 séances de laboratoire. Il est effectué individuellement.

Chaque personne devra, dans la réalisation de son projet, mettre un effort supplémentaire sur un point particulier à choisir dans la liste suivante :

- 1. Gestion d'une fractale de taille plus grande en utilisant la mémoire externe DDR;
- 2. Précision augmentée de la fractale en travaillant avec des nombres à virgule fixe de plus grande taille et analyse des performances en fonction de différentes tailles.
- 3. Précision augmentée de la fractale en travaillant avec des nombres à virgule flottante et analyse des performances;
- 4. Exécution en parallèle des calculs par la réplication de plusieurs blocs de calculs identiques;
- 5. Intégration d'un pipeline dans le bloc calcul permettant de traiter plusieurs points avec le même bloc et augmentation de la vitesse de calcul à une fréquence supérieure.
- 6. Optimisation du système pour un fonctionnement à une vitesse d'horloge maximale.
- 7. Transmission des données par fibre optique entre deux cartes (sous réserve matérielle);

Le projet devra être géré au travers de l'environnement de gestion de projet GIT. Un dépôt privé sous Bitbucket ou équivalent vous sera demandé. Le professeur et l'assistant devront disposer des droits de consultation.

## 3 Evaluation du projet

Le projet sera évalué de la façon suivante :

- Présentation orale. 5 minutes suivi de 5 minutes pour les questions /réponses. Un support de type Powerpoint sera le bienvenue. Durant cette présentation il vous est demandé de présenter l'architecture globale de votre système, d'indiquer les type d'implémentation choisies (IP core, VHDL, ...) et discuter les problèmes rencontrés ainsi que solutions proposées.
- Rapport écrit à rendre. Ce rapport doit reprendre les différents points cités dans la présentation et bien détailler l'architecture du système. Il doit également donner des informations sur l'utilisation des ressources du FPGA (en pourcentage d'utilisation des différents blocs) et les analyser. Même chose pour les fréquences d'horloges utilisées et possible. Un effort sera donné sur l'implémentation du calcul de la fractale, entre autre en discutant les résultats d'intégration dans les DSP à l'aide de l'outil FPGA editor. Un mémoire d'une dizaine de page devrait pouvoir être suffisant. Les schémas étant plus que souhaités.
- Démonstration
- Participation régulière au projet. L'analyse des *commits* sous Bitbucket pourra être utilisés à ces fins.

Documents informatiques à rendre : Présentation, rapport au format PDF, archive du projet Xilinx.