-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.cpp
More file actions
65 lines (52 loc) · 2.05 KB
/
main.cpp
File metadata and controls
65 lines (52 loc) · 2.05 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
// Copyright 2019 Adam Campbell, Seth Hall, Andrew Ensor
// High Performance Computing Research Laboratory,
// Auckland University of Technology (AUT)
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include <cstdlib>
#include <cstdio>
#include "direct_fourier_transform.h"
int main(int argc, char **argv)
{
printf("==============================================================\n");
printf(">>> AUT HPC Research Laboratory - Direct Fourier Transform <<<\n");
printf("==============================================================\n\n");
// Initialise the DFT configuration
Config config;
init_config(&config);
// Obtain Sources from file, or synthesize
Source *sources = NULL;
load_sources(&config, &sources);
// Something went wrong during loading of sources
if(sources == NULL)
return EXIT_FAILURE;
// Obtain Visibilities from file, or synthesize
Visibility *visibilities = NULL;
load_visibilities(&config, &visibilities);
// Something went wrong during loading of visibilities
if(visibilities == NULL)
{
if(sources) free(sources);
return EXIT_FAILURE;
}
printf(">>> UPDATE: Performing extraction of visibilities from sources...\n\n");
extract_visibilities(&config, sources, visibilities, config.num_visibilities);
printf(">>> UPDATE: Visibility extraction complete...\n\n");
// Save visibilities to file
save_visibilities(&config, visibilities);
// Clean up
if(visibilities) free(visibilities);
if(sources) free(sources);
printf(">>> UPDATE: Direct Fourier Transform operations complete, exiting...\n\n");
return EXIT_SUCCESS;
}