Processing a nightscape in Siril

![](upload://vbuCOXE6fY9EcDMIt1G14ekk7J9.jpeg)

Processing a nightscape in Siril

A basic tutorial

Siril is a program for processing astronomical photographs.

In this tutorial, I’ll show you how to process a nightscape in Siril 0.9.10.

It doesn’t intend to be comprehensive tutorial but rather to present a basic general workflow that is a good starting point for those who want to learn Siril.

For this purpose, I’m sharing the raw files I used for the image I presented here, except that for this tutorial I limited the number of frames for the sake of bandwidth and processing speed.

![The Creations by Sebastien Guyader](upload://vbuCOXE6fY9EcDMIt1G14ekk7J9.jpeg)
The Creations, by Sebastien Guyader

You can find and download the raw files here (~1GB).

Setup

The raw files are placed in specific sub-folders according to their use:

  • bias/offset frames → ./Bias (20 files)
  • dark frames → ./Darks (15 files)
  • flats field frames → ./Flats (15 files)
  • main subject/light frames → ./Lights (10 files)

Bias, dark, and flat field frames are also called “calibration” frames, their purpose being to improve the quality of the image by correcting the signal-to-noise ratio (in the case of bias and dark frames) and vignetting (with the flat frames). There are several places where you can learn more about the different types of frames for astrophotography.

At the root of the folder, I placed two text files with the .ssf extension, these are scripts used by Siril for batch processing the files. Quite useful. If you want to run a script from Siril, place the .ssf files in ~/.siril/scripts. Upon restarting Siril, a new Scripts menu appears in the top menu bar, allowing you to launch the installed scripts.

I suggest you download the whole folder (~1GB), and move the scripts as indicated above. This way, if you set the working directory in Siril to the root of the folder, launching the script named processing_from_raw.ssf will automagically process the raws and create the output image in both .fit and .tif (16-bit) formats. Please note that in order to successfuly run the scripts, there must be a folder structure like the one used in this tutorial.

Step-by-step processing

I will present the steps I used to process an image of the Milky Way. I don’t know if it’s the best way, but it’s probably close to what the developers of Siril advise to do for the general case of starting from raw files (actually, I started from one of their scripts and just slightly adapted it).

We will start with processing the calibration files, and then processing the lights.

Preparing the bias frames

  1. Set the working directory to the Bias sub-folder by clicking on Change dir….
![](upload://lahZ13QEUKJlcI9eMIqyWaEI4yH.jpeg)
  1. We will use the 20 bias frames to generate a master-bias frame. To load the bias frames, click on the + button as shown (make sure that you select RAW DSLR Camera Files in the combo box) and select the bias frames located in the Bias subfolder.
![](upload://nesg7rKHNVW8tLGAoldrjVSJ0Ed.jpeg)
  1. In the “Sequence name” field, enter bias (or whatever you see fit) to set the prefix of the sequence and subsequent files, and click Convert to convert the files to the FITS format, which is the main format used by Siril. Note that you don’t need to demosaic the files yet, make sure the Debayer box is unchecked.

When done converting the bias frames, a window will pop up showing a preview of one of the bias frames. Note that since it’s not demosaiced, it will only show as a B&W channel image.

At this point, the bias frames are loaded and ready to be processed to make a master-bias frame.

  1. In the Stacking tab, choose Average stacking with rejection as stacking method, and No normalisation under the normalisation combo box. You can leave the Sigma parameters at their default (unless you know or want to experiment for better values).

It should look like this:

![](upload://Toz6Npyew5zQr0dmdY1ShNZllt.jpeg)
  1. Click on the Start stacking button. The resulting master-bias frame will be saved as bias_stacked.fit in the Bias subfolder.

Preparing the flat field frames

Since the flats also contain the sensor readout noise (contained in the bias frames), we should remove it by subtracting the master-bias.

  1. In the File conversion tab, remove the files already loaded by clicking on the button located just below the - (minus) button, and by clicking on the + (plus) button select and load the flat frames located in the Flats subfolder.

  2. Set the working directory to the Flats sub-folder by clicking on “Change dir…” and set the Sequence name as “flats”.

  3. Like for the bias frames, ensure Debayer is unchecked, then click on Convert.

  4. In the Pre-processing tab, check only the Use offset box, click on Browse to select the Bias/bias_stacked.fit file, and click on Start pre-processing.

![](upload://iA0deHkmCJfDfLpn1VCUaGx4AjN.jpeg)
  1. To generate the master-flat, go to the Stacking tab, and this time set Normalisation to Multiplicative and the Stacking Method as Average with rejection.

  2. Click on Start stacking to produce the pp_flat_stacked.fit master-flat frame in the Flats subfolder.

![](upload://uwJDsLf1nvtVEhJv3CdmXqZXAkf.jpeg)

Preparing the dark frames

As with the bias and flats, you need to load the dark frames.

  1. In the File conversion tab, remove the files already loaded, select and load the dark frames located in the Darks subfolder.

  2. Set the working directory to the Darks sub-folder by clicking on Change dir…, and set Sequence name as darks.

  3. Debayer should be unchecked.

  4. Click on Convert.

  5. The darks need to be stacked the same way as the bias frames. In the Stacking tab, choose Average with rejection and No normalisation.

  6. Click Start Stacking.

![](upload://bU3KJx8cPsOFZDmNqwzVWsPsKSj.jpeg)

The master-dark frame is saved as Darks/dark_stacked.fit.

Note: if you take images often in the same conditions (same air temperature, same exposure settings), you can save the dark_stacked and pp_flat_stacked files, and re-use them to process future light frames faster. I read on some forums that some astrophotographers keep their calibration files and use those for around 1 year, before taking new calibration frames.

Preparing the light frames

Now it’s time to start processing the light frames, by first subtracting the darks (which also contain the bias signal) and the flats (from which bias has already been subtracted).

  1. Select the light frames in the File conversion tab.

  2. Set the Sequence name to lights, and point the working directory to the Lights (Change dir...).

  3. Convert the files, still without debayering.

  4. Then go to the Pre-Processing tab, check Use dark, select the Darks/dark_stacked.fit file, check Use flat, and select the Flats/pp_flat_stacked.fit file.

  5. Make sure that the other boxes are checked as in the following screenshot.

![](upload://vjqaICZi30p7ejSFtbSqxxgNjq.jpeg)

Note that “Cosmetic Correction” can also be done from the “Image Processing” tab.

  1. Click Start pre-processing.

This will produce new FITS files with the prefix pp_light_ and the corresponding .seq file. These files are loaded.

Demosaicing the files

It’s time to demosaic our processed files. There’s something strange in the GUI, in that after pre-processing, when you uncheck “Use dark” and “Use flat” boxes, the “Debayer FITS images before saving” and the “Start pre-processing” button become grayed out.

  1. In the File conversion tab, remove the selected files and load the 10 pp_light_000xx.fit files.
  2. Check the Debayer box and write db_pp_light as the sequence name.
  3. Click Convert.
![](upload://zuY8cuu9IT7vfjaf3oENrt5cpZQ.jpeg)

The pre-processed lights will be saved as FITS files, and the corresponding db_pp_light.seq file loaded. Two preview windows will open this time, one with the 3 RGB channels separated, and one with the RGB composite image.

  1. In the Register tab, select Global Star Alignment (deep-sky) from the registratrion method drop-down list and click Go register.

If you have more 8GB of RAM, you can try checking the Simplified Drizzle x2 box (it will up-sample the images by a factor 2, increasing the RAM usage by a factor 4). Siril will detect the stars and register each of the 10 images. The preview windows will be updated. By the way, you can play with the zoom and select AutoStretch to get a better preview of the selected image.

![](upload://kUJrAJ59nydJk5dMOUjfQo9W777.jpeg)
  1. In the Stacking tab, make sure that Average with rejection is selected as the stacking method, and that Additive with scaling is set for Normalisation.

  2. Click on Start stacking.

The resulting aligned and stacked image will be saved as Lights\r_db_pp_light_stacked.fit.

  1. At this step, you can also save the resulting image as JPEG, TIFF, PNG, etc. for further processing in your favorite image editor. On the menu, just click on File > Save As, and pick the image format you wish (or right-click on the RGB windows and pick the format that best suits you).

Post-processing the image

Siril can do some more or less specialized post-processing to your image. I found it interesting to use.

  • While the stacked image is still loaded in Siril, you can apply a log transform (it is in linear mode in Siril). I haven’t found how to do it in the GUI, but you can simply type “log” in the “Console” field at the bottom of the Output logs tab, in the main window.
  • Still in the console field, you can use the command “crop” followed by the coordinates of the bounding box in pixels, to crop the image (some auto-detection tools in Siril require the image to be cropped to remove the borders introduced by aligning the images, in order to work properly). For example, my image can be cropped by typing crop 30 30 5950 3970.
  • You can apply green noise removal in the “Image Processing” tab > “Remove Green Noise…”.
  • Lucy-Richardson deconvolution can be applied in “Image Processing” menu option > “Deconvolution…”. 10 iterations and a Sigma value of 0.6 are a good starting point.

The resulting image can be saved as JPEG, TIFF, PNG, etc. for further processing in your favorite image editor or as a finished image if you’re satisfied.

Processing for the foreground

The problem with this whole process, is that because the images have been aligned with the stars as reference, the foreground will be blurred because earth moved between successive frames. What I do is to reprocess the light frames from just after the calibration step (i.e. after the dark and flat frames subtraction) but only skipping the stars registration step. By doing so, the foreground will undergo the same pre- and post-processing, and the resulting image will have a sharp foreground and trailing sky.

I provided a script (processing_from_raw_foreground.ssf) which will do that for you, if you already used the first script or if you use the same file naming convention as in the script.

Finally, in your favorite image editor, you can combine the “sky” and “foreground” images using a mask, to get both the sky and the foreground sharp.

Here’s what I obtained following these steps (but using the scripts), after just combining the 2 images in Gimp:

![](upload://rqdX3kJDSWuFekONNkYXHXee4lq.jpeg)

And after quick curve and saturation tweaking in Gimp:

![](upload://cPJS4e2GkjrvVAqCYT8OPBFuaMR.jpeg)

This is a companion discussion topic for the original entry at https://pixls.us/articles/processing-a-nightscape-in-siril/
12 Likes

openSUSE packages can be find here Install package graphics / siril

2 Likes

Thank you so much @sguyader for the original write up, the photos, and taking the time to share! And @gadolf for proof reading and verifying all of this is verifiable. Great work!

1 Like

I agree - a super big thanks to @sguyader and @gadolf for getting this published (and I’m super sorry it took so long to push - it’s entirely my fault).

Thank you guys for motivating me to write the tutorial, and turning it into this article.

1 Like

As reported here, it looks like sometimes the default star registration is set to “One star registration”, instead of “Global star alignment”. I don’t know if the change comes from a different build (it was reported from a MacOS build) or more likely from a previous use of the program (if you select another registration algorithm, on the next restart of Siril the selected algorithm is last one you have set).

So, the article we should precise the algorithm to be used. Instead of "

we should write something like “4. In the Register tab, select Global Star Alignment (deep-sky) from the registratrion method drop-down list and click Go register.”

Hello.

Looks like a nice tutorial !!

Cyril Richard
(a developer of Siril)

3 Likes

Great job,

Excellent tutorial :slight_smile:

2 Likes

@sguyader The link to the different type of frames is dead. I found A Brief Guide to Calibration Frames: Bias, Dark, Flats and Dark Flats - Practical Astrophotography Magazine

I don’t know if this this good, but please point to a valid source :slight_smile:

Thanks

1 Like

@system Can you update the article as @asn suggested? The source he linked to seems to provide valid information.

if you update the main site via git, it will be updated here as well

1 Like

I’m having some issues following this tutorial due to unsupported raw format of the files in the archive used for the tutorial.
I’ve been toying around with Siril already, using the AppImage, for version 0.9.10 and 0.9.12.
I’ve used both already a couple of times for curiosity, mostly to stack skies with stars.

However, now I tried to follow the tutorial, but I consistently stop already at the conversion step.
I’ve tried with all the 4 sets of raw files.

Version 0.9.12 (the latest) throws errors about libraw:

log: Setting CWD (Current Working Directory) to '/home/bill/workspace/Siril_Tutorial/Lights'
log: Conversion: processing...
/home/bill/workspace/Siril_Tutorial/Lights/03_DSCF6799.RAF: Unexpected end of file
Error in libraw Input/output error
/home/bill/workspace/Siril_Tutorial/Lights/03_DSCF6800.RAF: Unexpected end of file
Error in libraw Input/output error
/home/bill/workspace/Siril_Tutorial/Lights/03_DSCF6801.RAF: Unexpected end of file
Error in libraw Input/output error
/home/bill/workspace/Siril_Tutorial/Lights/03_DSCF6802.RAF: Unexpected end of file
Error in libraw Input/output error
/home/bill/workspace/Siril_Tutorial/Lights/03_DSCF6803.RAF: Unexpected end of file
Error in libraw Input/output error
/home/bill/workspace/Siril_Tutorial/Lights/03_DSCF6804.RAF: Unexpected end of file
Error in libraw Input/output error
/home/bill/workspace/Siril_Tutorial/Lights/03_DSCF6805.RAF: Unexpected end of file
Error in libraw Input/output error
/home/bill/workspace/Siril_Tutorial/Lights/03_DSCF6806.RAF: Unexpected end of file
Error in libraw Input/output error
/home/bill/workspace/Siril_Tutorial/Lights/03_DSCF6807.RAF: Unexpected end of file
Error in libraw Input/output error
/home/bill/workspace/Siril_Tutorial/Lights/03_DSCF6808.RAF: Unexpected end of file
Error in libraw Input/output error
log: No sequence found, verify working directory or change FITS extension in settings (current is .fit)
No valid sequence found in CWD.
log: Execution time: 118.00 ms.

Version 0.9.10 similarly:

log: Setting CWD (Current Working Directory) to '/home/bill/workspace/Siril_Tutorial/Lights'
log: Conversion: processing...
Error in libraw Unsupported file format or not RAW file
Error in libraw Unsupported file format or not RAW file
Error in libraw Unsupported file format or not RAW file
Error in libraw Unsupported file format or not RAW file
Error in libraw Unsupported file format or not RAW file
Error in libraw Unsupported file format or not RAW file
Error in libraw Unsupported file format or not RAW file
Error in libraw Unsupported file format or not RAW file
Error in libraw Unsupported file format or not RAW file
Error in libraw Unsupported file format or not RAW file
No sequence found, verify working directory or change FITS extension in settings (current is .fit)
No valid sequence found in CWD.
log: Execution time: 31.37 ms.

Ok, I guess that my libraw is too old…
Then, I tried to read the same raw files (.RAF) with the latest AppImage of RawTherapee and they can correctly be read and developed.

But then I thought… Shouldn’t the AppImage of Siril as well already include the needed libraries? Is this error due to the libraw of my OS (I have Ubuntu 18.04, so probably not a very new version…)?
What should I do in that case? (as you may have guessed, the reason I use AppImages is mostly because I need to keep that “old” Ubuntu for work-related things)

For further confirmation, I’ve tried converting some raw from the Fuji X100V (fairly new, I’d guess), and I get the same errors.

Thanks for helping with this.

By design, AppImage uses very old libraries, if you want it working on most platforms. So this is why it does not work.

Maybe I should teach you how to use the OBS for packages :stuck_out_tongue:

1 Like

There is a flatpak of siril, which can uses its own defined libs as well.

1 Like

Isn’t it possible to bundle any lib as needed? At least, that’s what’s done for some AppImage I’ve been using, I think., in the sense that they use newer lib versions than what I have installed. E.g. I use digikam AppImage and it uses LibRaw ver 0.19.5, but on my system only 0.18.8 is installed (and actually it can read correctly the raw files that Siril AppImage cannot). Isn’t the same possible for Siril AppImage?

Oh yeah, I’m already using the OBS for darktable, but I couldn’t find the same for Siril…

Thanks, I may try that, but I had not exciting experiences of Flatpak in Ubuntu, unfortunately. I may try again.

So, currently, what would be the way to have the tutorial working on Ubuntu 18.04? Is it possible at all?

I’d wager a guess that the appimage is built against centos 7 for maximum compatibility, as you still need the host system’s c libs for an appimage.

I run KDE neon, which has an ubuntu 18.04 base. I installed Alexander Larson’s flatpak ppa and I’ve had zero issue with flatpak itself, installing applications and removing them has been fine. It even integrates with plasma’s discover app store thing.

No because i’m using PPA version of old stable to build the AppImage.

Ok, thanks, I’ll probably give a try. If you’re using it, can you confirm that the Siril in the flatpak comes with its newer libraw?

Anyhow, probably the fastest way I have now to do the tutorial is through the Manjaro laptop (newer libs, even though far worse horsepower…), or convert the RAWs from the tutorial do DNG, maybe with the RawTherapee AppImage… Is the latter a totally bad idea?

It uses LibRaw-0.19.5, which is the latest released version.

1 Like