====== Generating nice images in Matlab ======
Here are some brief details and tips for developing a good workflow for generating publication-quality images. 
===== 1. A workflow for saving images =====
As you become a more experienced researcher, you will learn the value of developing a workflow where images can be easily re-generated. This means that you can easily replot the images when you are finalising the presentation. 
  - **Rule:** Save all data or all scripts. Get in the habit of saving data as ''%%.mat%%'' files. 
  - **Tip: use scripts to generate your figures.** Create scripts that will load in ''%%.mat%%'' files and plot the data. This means if you ever need to regenerate pictures, you can do it very easily. If you are performing a numerical experiment, make sure to comment the filename or comment the file directly, indicating important clues about when the figure was generated, and the conditions.
  - **Tip: save your figures as .fig.** Similar to above, you may want to save ''%%.fig%%'' files of the pictures. Again, it allows fine-tuning. (In fact, you can extract raw data from ''%%.fig%%'' files via  scripts if you look into it). To save such a file, simply click File > Save-As on the figure window.
===== 2. Exporting figures =====
Traditionally (meaning literally in the last 20 years), Matlab has had very poor ability to generate publication-quality images. Problems include: poor bounding boxes, weird rasterisation effects, weird layering issues, etc. 
**Always, always, always** whenever possible, export your images in PDF. This is currently the best format for including into LaTex. When done in the vectorised format of a PDF, the image is then scalable. 
There are exceptions to the above rule in the context of images that are extremely data-hungry (thousands of points) or involve 3D surfaces, contour plots, etc. In those cases, the export to PDF can cause file sizes that are too large, or can cause weird layering effects (due to the complexity of rendering a surface, say). In those cases, you want to export to a rasterised format like PNG. 
Use [[https://uk.mathworks.com/matlabcentral/fileexchange/23629-export_fig|export_fig]] package (Matlab file exchange) to export to pdf format. 
Once you have downloaded the ''%%export_fig%%'' package, unzip it and move the folder into a unified functions folder on your computer. Refer to the [[it_matlab_startup|startup.m]] guide. By doing so, you can issue a command like
export_fig 'test.pdf' 
in order to produce a PDF of the currently focused figure.
===== 3. Annotations =====
In order to add annotations to figures, you have a few options:
  - Add the annotation natively within Matlab using commands like text(...); this is a good idea in combination with scripts. 
  - Add the annotation afterwards by using a vector editor like [[https://en.wikipedia.org/wiki/Inkscape]]. This is not a bad idea and can be quite powerful. However note that it can be difficult due to LaTeX fonts not importing nicely into Inkscape. 
  - Use a native LaTeX package like tikz or [[https://www.ctan.org/pkg/pdfpages|pdfpages]]
===== 4. Advanced image generation using TikZ =====
More 'advanced' figure generation can involve things like [[https://en.wikipedia.org/wiki/PGF/TikZ|TikZ]], which generates figures natively within LaTeX. The advantage of this approach is consistency in annotation.  
There are now very powerful scripts that allow Matlab figures to be automatically converted to TiKZ, such as [[https://uk.mathworks.com/matlabcentral/fileexchange/22022-matlab2tikz-matlab2tikz|matlab2tikz]]. Once your figure has been generated, you can run: 
matlab2tikz
Save the file, either as a .tex or as a .tikz. If you save it as a .tex, you can compile the file to generate the images.
If you are an undergrad student or under pressure to write a report, I don't recommend trying to learn this!
===== 5. Colormaps =====
The default colormaps are not so good. Use [[https://uk.mathworks.com/matlabcentral/fileexchange/45208-colorbrewer-attractive-and-distinctive-colormaps|ColorBrewer]] to generate a beautiful colormap. Add the package folder to your [[it_matlab_startup|Matlab startup]] functions folder. Then in my `startup.m` file, I add the following: 
set(0,'DefaultFigureColormap', brewermap([],'*RdYlBu'));
You can view all the colormaps with 
brewermap('demo') 
Open via `open brewermap` to view the documentation and examples.