1 | #! /usr/bin/octave -qf |
---|
2 | |
---|
3 | # ----------------------------------------------- |
---|
4 | # tesalbedo_build.m |
---|
5 | # Script to be used with Matlab or GNU-Octave |
---|
6 | # ----------------------------------------------- |
---|
7 | # Purpose: |
---|
8 | # MOLA MEGDR binary file >> WRF geogrid tiles |
---|
9 | # Author: |
---|
10 | # A. Spiga - 03/2007 |
---|
11 | # ----------------------------------------------- |
---|
12 | |
---|
13 | # Locate MOLA binary file |
---|
14 | filename = 'global_albedo_8ppd.img'; |
---|
15 | resolution = 8; |
---|
16 | |
---|
17 | # Read topographical data (PC_REAL, 32-bits/4-bytes float) |
---|
18 | f = fopen(filename,'r','ieee-le'); |
---|
19 | el = fread(f,[360*resolution Inf],'float32')'; |
---|
20 | |
---|
21 | # Flip North/South |
---|
22 | el = flipud(el); |
---|
23 | # Scale factor (ie accuracy): 10000 |
---|
24 | el = 10000.*el; |
---|
25 | # Conversion float >> integer |
---|
26 | el = round(el); |
---|
27 | |
---|
28 | # Create 2 WRF data tiles for geogrid |
---|
29 | tile=180*resolution; |
---|
30 | # Eastern part |
---|
31 | part = el(1:1:tile,1:1:tile)'; |
---|
32 | fid = fopen('00001-01440.00001-01440','wb','b'); |
---|
33 | fwrite(fid,part,'integer*2'); |
---|
34 | |
---|
35 | # Western part |
---|
36 | part2 = el(1:1:tile,tile+1:1:2*tile)'; |
---|
37 | fid = fopen('01441-02880.00001-01440','wb','b'); |
---|
38 | fwrite(fid,part2,'integer*2'); |
---|
39 | |
---|
40 | # Check the resulting arrays |
---|
41 | yeah = part(1:10:tile,1:10:tile); |
---|
42 | yeah2 = part2(1:10:tile,1:10:tile); |
---|
43 | contour(yeah) |
---|
44 | contour(yeah2) |
---|
45 | |
---|