rop_size_h, crop_size_w = crop_size_h // self.scale * self.scale, crop_size_w // self.scale * self.scale这段代码中文含义
时间: 2024-04-01 09:35:53 浏览: 83
这段代码用来计算裁剪后的图像尺寸,其中crop_size_h和crop_size_w是原始图像的高度和宽度,self.scale是缩放比例。代码首先使用整除运算符“//”将crop_size_h和crop_size_w缩小到最接近self.scale的整数倍,然后再将它们乘以self.scale,得到裁剪后的图像尺寸。这个过程确保了裁剪后的图像尺寸是self.scale的整数倍,方便后续的处理。
相关问题
#include "stdio.h" #include "string.h" #define ACC -2 #define sy_if 0 #define sy_then 1 #define sy_else 2 #define sy_while 3 #define sy_begin 4 ...../宏定义/ char ch='\0'; int count=0; static char spelling[10]={""}; static char line[81]={""}; char *pline; static char ntab1[10][10]; struct rwords { char sp[10]; int sy; }; struct rwords reswords[10]={{"if",sy_if}, {"do",sy_do},{"esle",sy_else},{"while",sy_while},{"then",sy_then}, {"begin",sy_begin},{"end",sy_end},{"and",op_and},{"or",op_or} ,{"not",op_not}}; struct aa { int sy1; int pos; }buf[100]; int ssp=0; int tt1=0; int lnum=0; FILE *cfile; int nlength=0; struct aa *pbuf=buf; /****************************/ readline()/读入行 { ………… } *pline='\0'; pline=line;} /****************************/ readch()/读入字符 …… } ch=*pline; pline++; } /********************************/ find(char spel[])/查找 {...... } identifier()/标识符识别 { ........ } /*************************/ number()/常数识别 {.......} scan()/扫描程序 {while(ch!='~') {switch(ch) {case ' ': break; case 'a': case 'b': ...... case 'z': identifier();break; case '0': case '1': ....... case '9': number();break; case '<':readch();if(ch=='=') {buf[count].pos=0;} else{if(ch=='>')buf[count].pos=4; else{buf[count].pos=1;pline--;}} buf[count].sy1=rop; count++;break; case '>':readch();if(ch=='='){buf[count].pos=2;} else{buf[count].pos=3;pline--;} buf[count].sy1=rop; count++;break; case '(': buf[count].sy1=lparent;count++;break; case ')':buf[count].sy1=rparent;count++;break; case '#':buf[count].sy1=jinhao;count++;break; case '+':buf[count].sy1=plus;count++;break; case '*':buf[count].sy1=times;count++;break; case ':':readch();if(ch=='=')buf[count].sy1=becomes; count++;break; case '=':buf[count].sy1=rop;buf[count].pos=5;count++;break; case ';':buf[count].sy1=semicolon;count++;break; } readch(); }buf[count].sy1=-1; }/***********************/ disp1()/输出 {.... } disp2() {....../输出 } main() { if((cfile=fopen("PAS.C","r"))==NULL) {printf("file not open\n");exit(0);} readch(); scan(); disp1(); disp2();
这段代码是一个简单的词法分析器,可以用于识别 Pascal 语言的单词和符号,并输出它们的种类和位置。其中,readline() 和 readch() 用于读入一行和一个字符,identifier() 和 number() 用于识别标识符和常数,find() 用于查找保留字,scan() 用于扫描整个程序并进行词法分析,disp1() 和 disp2() 用于输出结果。这段代码中使用了一些宏定义和结构体来简化代码。
补全代码#include "stdio.h" #include "string.h" #define ACC -2 #define sy_if 0 #define sy_then 1 #define sy_else 2 #define sy_while 3 #define sy_begin 4 ...../宏定义/ char ch='\0'; int count=0; static char spelling[10]={""}; static char line[81]={""}; char pline; static char ntab1[10][10]; struct rwords { char sp[10]; int sy; }; struct rwords reswords[10]={{"if",sy_if}, {"do",sy_do},{"esle",sy_else},{"while",sy_while},{"then",sy_then}, {"begin",sy_begin},{"end",sy_end},{"and",op_and},{"or",op_or} ,{"not",op_not}}; struct aa { int sy1; int pos; }buf[100]; int ssp=0; int tt1=0; int lnum=0; FILE cfile; int nlength=0; struct aa pbuf=buf; // readline()/读入行 { ………… } pline='\0'; pline=line;} // readch()/读入字符 …… } ch=pline; pline++; } /********************************/ find(char spel[])/查找 {...... } identifier()/标识符识别 { ........ } /*********************/ number()/常数识别 {.......} scan()/扫描程序 {while(ch!='~') {switch(ch) {case ' ': break; case 'a': case 'b': ...... case 'z': identifier();break; case '0': case '1': ....... case '9': number();break; case '<':readch();if(ch=='=') {buf[count].pos=0;} else{if(ch=='>')buf[count].pos=4; else{buf[count].pos=1;pline--;}} buf[count].sy1=rop; count++;break; case '>':readch();if(ch=='='){buf[count].pos=2;} else{buf[count].pos=3;pline--;} buf[count].sy1=rop; count++;break; case '(': buf[count].sy1=lparent;count++;break; case ')':buf[count].sy1=rparent;count++;break; case '#':buf[count].sy1=jinhao;count++;break; case '+':buf[count].sy1=plus;count++;break; case '':buf[count].sy1=times;count++;break; case ':':readch();if(ch=='=')buf[count].sy1=becomes; count++;break; case '=':buf[count].sy1=rop;buf[count].pos=5;count++;break; case ';':buf[count].sy1=semicolon;count++;break; } readch(); }buf[count].sy1=-1; }/***********************/ disp1()/输出 {.... } disp2() {....../输出 } main() { if((cfile=fopen("PAS.C","r"))==NULL) {printf("file not open\n");exit(0);} readch(); scan(); disp1(); disp2();
这段代码是一个简单的词法分析器,用于识别 Pascal 语言中的关键字、标识符、常数和运算符,并将其分类输出。具体实现如下:
1. 定义了一些宏和结构体,包括关键字的宏定义、符号种类的宏定义、关键字结构体、符号结构体等。
2. 定义了一些全局变量,包括字符变量 ch、计数变量 count、拼写变量 spelling、行变量 line、行指针变量 pline、预留词表变量 ntab1、关键字结构体数组 reswords、符号缓冲区变量 buf、符号种类指针变量 pbuf 等。
3. 实现了两个函数,readline() 和 readch(),前者用于读取文件中的一行文本,后者用于读取文本中的一个字符。
4. 实现了 find() 函数,用于在预留词表中查找给定字符串,返回其对应的符号种类。
5. 实现了 identifier() 函数,用于识别标识符并加入符号缓冲区中。
6. 实现了 number() 函数,用于识别常数并加入符号缓冲区中。
7. 实现了 scan() 函数,用于扫描文本中的每一个字符,并根据其类型进行分类处理,并将结果加入符号缓冲区中。
8. 实现了 disp1() 函数和 disp2() 函数,前者用于输出关键字、标识符和常数,后者用于输出运算符和界符。
9. 在 main() 函数中,先打开文件并读取第一个字符,然后调用 scan() 函数进行词法分析,并最终调用 disp1() 和 disp2() 函数将结果输出。
需要注意的是,这段代码只是一个简单的词法分析器,并不能完全解析 Pascal 语言的语法。如果需要实现一个完整的编译器,还需要进一步实现语法分析、语义分析等模块。
阅读全文
相关推荐
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/eb415/eb41547855414ef61ebf691da53d850ed318decb" alt="-"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt=".zip"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""