Mips Assembler-如何获得.ascii的长度

时间:2017-01-17 23:01:10

标签: assembly mips assemblies mips32 mips64

我是这个社区的新手。我们在大学编程mips,我需要在我的作业中解决我的问题。 我们必须打开一个.pgm文件并读取所谓的标题(在这种情况下使用p5格式和可变长度x宽)。当您打开已阅读的文件时,您将获得4行第1行。 P5;第2位。长x宽;第三个ascii代码的颜色深度和第四个长期。 我的工作是现在转换ascii,我想我必须知道这个ascii的大小。 以前,我有一个用于转换ascii的mips代码,但问题是,这段代码只转换了我的ascii术语的一部分,就像这样(评论是德语 - 对不起):

.data
str:    .ascii "GV_]VTI=97:@JPH<1-/6;L\pz ­¶³¶»ÃËËÄ»°y{xzk`L@@?>9326<DD:1.--++*-./-//000002222344///35;@LVau ¥´¬§»Çĸ³³»ª °¿Åù±¯¦||x{{yttw{sv}¡°¸±¡¡£¢£p_Z[_hfYUW^accacdehhhhdghjjlnnonnnljifjgfdggfdiiiillllglrvtkiltzx~«ÀÖ¿°©´¾ÃÇÈ×ßãÖÇ»º­¡±¼ËÙENSOIHD>;>CHTPB4/+.6<JWizª¯®°¸ÃËËÄ»¶xvj\NECDB<735:?:40//---,+,--./00000222235400259=DNXdw£­®³½Á½³¯¯²¢¥§°»ÃÆõ©«}z{|xtmmqus¡±À¹¦m`ZZ^ce\WZ^abcacdehhhhdghjjlnnonnnlljijhggihhfiiiillmljnuxvnlqw~|¤¶ÐáÕÉÅÇÈÇÉÌÝàÒľ³µª¡¡¤±¼ËÙBGIHB@??DILNRI=1,*-6=ISao §¨­·ÃËËÄ»º¯wpg\SIEDC>83359520110//.--,-//0000022224751139=CGOXfx£®¼¶®¨¤£¥°»À»¾¼³©¥vnjjmsz¬ÅÅƳxxttxuja[Y[_c`^]^abcacdfhhhhdghjjlnnnnnnonkjlkihjjhghhhhkkjknsy}vpqw~¸ÏãéáÝ×ÓÌÁÂÈÙ඲ª¬¥¦¢§ ¡¨±¼ÌÙ@DFKC?=@CFFA<82.+)-6>IO[e| £«´ÅËËļÁ¹­vndbVKACA<632247322321011/.-.//000022225772/4<AFIQYhx¢°½­{¡±½½±²¶´®|lmos¸ÍÌ®tpmjgnnjc[XX[`a`_^abcacdfhjhhdghjjlnoonnnpomknmkjljihggggjjjjsv{wrs}¸ÑãíêÝß×ÏǸ´½ÐÛµ²§¡¨¡ª ¢«²¤¡«±ºÌÙ:ADEA>:5;94268501051"
# it converts just to: GV_]VTI=97:@JPH<1 
        .text
main:


addi $s0, $zero, 0  # $s0 :=0; hier wird das Ergebnis aufsummiert
la $s1,str          # $s1 := &str; hier wird der Zeiger auf das nächste Zeichen gehalten
addi $s2, $zero, 10 # $s2 := 10; hier steht konstand die 10 zur Multiplikaton
addi $s3, $zero, 48 # s3 := 48; hier 48, um die ASCII "0" in den Wert 0 umzuwandeln

loop:
lb $s4,($s1)        # Lade nächstes Zeichen des
sub $s4, $s4, $s3   #Bilde ASCII-Ziffer auf Integer-Wert [0..9] ab
bltz $s4,terminate  # Wenn Zeichen <0,
mult $s0, $s2
mflo $s0            # §s0 := §s0 *10
add $s0, $s0, $s4   # s0= s0 + Ziffernwert
addi $s1, $s1, 1    # s1= s1+1; also auf die nächstes Zeichn im String
j loop

terminate:
li $v0,1            # Resultat ausgeben
or $a0, $zero, $s0  # in ss0 stand das Ergebnis
syscall
li $v0,10
syscall

希望你能给我一个提示。

1 个答案:

答案 0 :(得分:0)

起初我误解了你的问题,但我仍然认为我的答案也是真正答案的一部分,所以首先:

一个问题应该是“如何找到标题的结尾和图像数据的开头”

PGM header的最后一个字符是“最大灰度值后的第一个空白字符”。因此,您必须按值解析整个标头值,直到您解析gray-max,然后下一个字节应为空格(32(空格),9(TAB),13 (CR),10(LF),11(VT),12(FF)),然后像素数据开始。

恕我直言,这是非常愚蠢的格式,因为我打赌DOS中的某人确实产生了一些带有“13,10”CR + LF的灰色最大图像,但是......不是你的问题(或者在加载到内存后检查你的文件,什么读了吗。

现在回到你真正的问题......

首先,这些数据不是ASCII。它们是二进制像素数据。您的“GV”已经是值71和86的两个像素。当您将其显示为ASCII字符串时,当然71显示为“G”,但这与任何方式无关。关于PGM的所有“ASCII”只是标题,在您检测到标题的结尾后,二进制数据会涌入。

这些二进制数据的大小为width*height*bytes_per_pixelBytes_per_pixel的{​​{1}}为1,gray_max < 256的{​​{1}}为2,范围为256..65535。

当使用每个像素2个字节时,最重要的字节是第一个(因此值gray_max编码为字节:4097,值71编码为:16, 1)。< / p>

如果你有一个0-255灰度图像,标题中的“max gray”设置为255,那么你只需将剩余的0, 71个字节的文件作为二进制数据读取(在最后一个标题字符之后),那就是它,这些是你的像素数据,从上到下逐行。

如果max_gray是其他东西,比如40或15000,那么它是否值得怀疑,你是否应该以某种方式将像素数据转换为0-255 8位范围(在第一种情况下“升级”它们,在第二次“缩小”,可能通过一些伽马变换,如果这将是专业的PGM读者)。但我希望你的学校任务只有大约0-255张图像,而不实施伽马校正。