Failed to build real.exe when compiling WRF-CMAQ two-way model

Hi all,

I want to build WRFv4.1.1-CMAQv5.3.2 two-way model. When I follow the guidance Step 11 in the tutorial, I find that only wrf.exe has been built in /WRF-4.1.1/main/, but real.exe, tc.exe and ndown.exe don’t exist.

I have built CMAQ BLD_CCTM_v532_pgi_twoway folder and copy it as cmaq in /model/WRF-4.1.1/. I use ioapi 3.2 installed earlier, and it works well in one-way model. If I do something wrong, please give me some advice to fix it.

Big thanks for your kind help. Here are my configure.wrf and compile.log files.

configure.wrf.txt (20.5 KB)
compile.log.txt (52.4 KB)

Liu

Hi Liu,

Could you please check the section $(SOLVER)_real in the file main/Makefile and see the compilation for real.exe and other *exe are being commented out.

Cheers,
David

Hi David,

Thanks for your reply. I checked the Makefile you pointed out and found that the relevant part was commented out.

A few days ago I found that WRFv4.5.2-CMAQv5.4 twoway model description interface mentioned that WRFv4.1.1-CMAQv5.3.2 had bugs, so I referred to this guide and tried to compile, but this time I encountered different error.

Log file shows that some modules were compiled without .o files that were not included in previous compilations .F file is converted to .f90 file.

For example, /CCTM/scripts/BLD_WRFv4.5.2_CCTM_v54_pgi/phys/module_cam_support.F doesn’t build .f90 and .o files, then causes an error message.
1724838382221

Meanwhile, the twoway files at /CMAQ_REPO/CCTM/src/twoway/ don’t appear to have been compiled either.

I don’t know why compilation selectively skips some modules required for subsequent compilation. If you have any suggestion on them, please let me know.

Here are my latest log files.
configure.wrf.txt (20.6 KB)
bldit_cctm.log.txt (1.5 MB)
wrf-cmaq_buildlog.txt (1.1 MB)

Best wishes,
Liu

Hi Liu,

If you check wrf-cmaq_buildlog.txt, you will see a line with “-j 2” at the very beginning of the file. It means the compilation was done with two cores. In your case, the compilation failure was likely due to compilation was out of syn in those two cores and broke file dependency. You just need to retype “compile em_real >& mylog” again and you might need to do a few more times. If you want to avoid this, you can compile the code with one core (much slower) by typing “compile -j 1 em_real >& mylog”.

Cheers,
David

Hi David,

Thank you very much for your helpful advice. After adding “-j 1” in compile code, my previous error were resolved. Now I can find wrf.exe, real.exe and tc.exe in /main/ folder, but there are still some errors compiling ndown.exe. It seems that /dyn_em/solve_em.f90 can’t get the module of twoway.

Here is my compile log file. Maybe there are some details I missed during compiling.
mylog.txt (64.0 KB)

Best wishes,
Liu

Hi Liu,

When I constructed the WRF-CMAQ coupled model, those *.exe other than wrf.exe were not on my mind. This short coming has been rectified in WRF v4.4. If you need to use the WRF version you have, please download a new copy of WRF of the same version and compile the model without constructing the coupled model to generate those other exe files.

Cheers,
David

Hi David,

I tried compiling the twoway model using WRFv4.1.1 and CMAQv5.4 and found that 4 *.exe were successfully generated.

I used separate WRFv3.9.1.1 and WRFv4.5.2 before trying the twoway model and didn’t experience the compilation errors I encountered this time. This could be due to my configuration mistakes or an unknown bug.

In addition, there are several questions about runscript. If I want to simulate multiple nested domains, do I just need to change the Building WRF Namelist in runscript, like changing the namelist.input in the WRF model, separated by commas for multiple days? And I notice there is a option about running WRF only or WRF-CMAQ. I don’t understand the meaning of w/o in option 2 = run WRF-CMAQ coupled model w/o producing GRID and MET files.

1725017256693

Thank you very much for your help, your method has been helpful to all the problems I have encountered. :smiley:

Best wishes,
Liu

Hi Liu,

I am glad your problem has been solved and thanks for your interest in using the coupled model.

Cheers,
David

Hi David,

I found that in the bldit_cctm.csh file, CMAQv5.4 requires WRFv4.4+ to build the WRF-CMAQ twoway model. When using WRFv4.1.1, I found that the files located in /CCTM/scripts/BLD/cmaq/ did not compile automatically, and still only. F or.f90 files, so I then tried WRFv4.4 with CMAQv5.4.

When I run bldit_cctm.csh, I found that ndown.exe still cannot be generated. The log file shown /dyn_em/solve_em.f90 does not recognize and CALL the subroutine located in /cmaq/twoway*, and the associated log file looked something like this in our previous discussion.

Finally, I discovered the cause of this problem. It may not be the root cause, but I found the problem is related to it.

During the usual compilation, I had a problem calling the hd5f library, so I modified the LIB_EXTERNAL in configure.wrf to add -ldl at the end of hdf5 (which was related to the local server setup). After this, I still run bldit_cctm.csh and then the error arose.

This time, after I modified configure.wrf, I did a

./clean -a

in the BLD folder, and the.o and.mod files in the BLD folder were deleted. Then I ran bldit with the modified configure.wrf and found that all four .exe files were generated, with no error with solve_em.f90.

By the way, I’d like to ask two questions on WRF-CMAQ runscript.

  1. If I want to simulate multiple nested domains, do I just need to change the Building WRF Namelist in runscript, like changing the namelist.input in the WRF model, separated by commas for multiple days?
  2. And I notice there is a option about running WRF only or WRF-CMAQ. I don’t understand the meaning of w/o in option 2 = run WRF-CMAQ coupled model w/o producing GRID and MET files .

Best wishes,
Liu

Hi Liu,

I am glad to hear now you can create those 4 exe files. Here are the answers for your questions:

  1. For nested domains, you can’t run WRF-CMAQ the way as running WRF only by providing nesting information in the WRF namelist separated by comms. You need to generate corresponding WRF input for each domains as well as IC/BC. Then run the nested domains one by one in a sequential order.

  2. When you run the offline CMAQ model, here is the flow: run WRF, run MCIP, then run CMAQ. For the WRF-CMAQ coupled model, the MCIP step is gone (literally being absorbed in the coupled model calculation). When you run the coupled model with option 1 or 3, MCIP like files are created for checking purposes. The values of in those MCIP like files are not exactly the same as corresponding MCIP files. They are off by one WRF time step.

Cheers,
David