diff options
Diffstat (limited to 'SD-VBS/common/toolbox/toolbox_basic/io/readpgm.m')
-rwxr-xr-x | SD-VBS/common/toolbox/toolbox_basic/io/readpgm.m | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/SD-VBS/common/toolbox/toolbox_basic/io/readpgm.m b/SD-VBS/common/toolbox/toolbox_basic/io/readpgm.m new file mode 100755 index 0000000..7aaf998 --- /dev/null +++ b/SD-VBS/common/toolbox/toolbox_basic/io/readpgm.m | |||
@@ -0,0 +1,30 @@ | |||
1 | function img = pgmread(filename) | ||
2 | % function img = pgmread(filename) | ||
3 | % this is my version of pgmread for the pgm file created by XV. | ||
4 | % | ||
5 | % this program also corrects for the shifts in the image from pm file. | ||
6 | |||
7 | |||
8 | fid = fopen(filename,'r'); | ||
9 | if (fid < 0), | ||
10 | error(sprintf('can not find file: %s',filename)); | ||
11 | end | ||
12 | |||
13 | fscanf(fid, 'P5\n'); | ||
14 | cmt = '#'; | ||
15 | while findstr(cmt, '#'), | ||
16 | cmt = fgets(fid); | ||
17 | if length(findstr(cmt, '#')) ~= 1, | ||
18 | YX = sscanf(cmt, '%d %d'); | ||
19 | y = YX(1); x = YX(2); | ||
20 | end | ||
21 | end | ||
22 | |||
23 | fgets(fid); | ||
24 | |||
25 | %img = fscanf(fid,'%d',size); | ||
26 | %img = img'; | ||
27 | |||
28 | img = fread(fid,[y,x],'uint8'); | ||
29 | img = img'; | ||
30 | fclose(fid); | ||