⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 disksim_stat.c

📁 目前最精确的磁盘模拟器的第3版
💻 C
📖 第 1 页 / 共 2 页
字号:
/* * DiskSim Storage Subsystem Simulation Environment (Version 3.0) * Revision Authors: John Bucy, Greg Ganger * Contributors: John Griffin, Jiri Schindler, Steve Schlosser * * Copyright (c) of Carnegie Mellon University, 2001, 2002, 2003. * * This software is being provided by the copyright holders under the * following license. By obtaining, using and/or copying this software, * you agree that you have read, understood, and will comply with the * following terms and conditions: * * Permission to reproduce, use, and prepare derivative works of this * software is granted provided the copyright and "No Warranty" statements * are included with all reproductions and derivative works and associated * documentation. This software may also be redistributed without charge * provided that the copyright and "No Warranty" statements are included * in all redistributions. * * NO WARRANTY. THIS SOFTWARE IS FURNISHED ON AN "AS IS" BASIS. * CARNEGIE MELLON UNIVERSITY MAKES NO WARRANTIES OF ANY KIND, EITHER * EXPRESSED OR IMPLIED AS TO THE MATTER INCLUDING, BUT NOT LIMITED * TO: WARRANTY OF FITNESS FOR PURPOSE OR MERCHANTABILITY, EXCLUSIVITY * OF RESULTS OR RESULTS OBTAINED FROM USE OF THIS SOFTWARE. CARNEGIE * MELLON UNIVERSITY DOES NOT MAKE ANY WARRANTY OF ANY KIND WITH RESPECT * TO FREEDOM FROM PATENT, TRADEMARK, OR COPYRIGHT INFRINGEMENT. * COPYRIGHT HOLDERS WILL BEAR NO LIABILITY FOR ANY USE OF THIS SOFTWARE * OR DOCUMENTATION. * *//* * DiskSim Storage Subsystem Simulation Environment (Version 2.0) * Revision Authors: Greg Ganger * Contributors: Ross Cohen, John Griffin, Steve Schlosser * * Copyright (c) of Carnegie Mellon University, 1999. * * Permission to reproduce, use, and prepare derivative works of * this software for internal use is granted provided the copyright * and "No Warranty" statements are included with all reproductions * and derivative works. This software may also be redistributed * without charge provided that the copyright and "No Warranty" * statements are included in all redistributions. * * NO WARRANTY. THIS SOFTWARE IS FURNISHED ON AN "AS IS" BASIS. * CARNEGIE MELLON UNIVERSITY MAKES NO WARRANTIES OF ANY KIND, EITHER * EXPRESSED OR IMPLIED AS TO THE MATTER INCLUDING, BUT NOT LIMITED * TO: WARRANTY OF FITNESS FOR PURPOSE OR MERCHANTABILITY, EXCLUSIVITY * OF RESULTS OR RESULTS OBTAINED FROM USE OF THIS SOFTWARE. CARNEGIE * MELLON UNIVERSITY DOES NOT MAKE ANY WARRANTY OF ANY KIND WITH RESPECT * TO FREEDOM FROM PATENT, TRADEMARK, OR COPYRIGHT INFRINGEMENT. *//* * DiskSim Storage Subsystem Simulation Environment * Authors: Greg Ganger, Bruce Worthington, Yale Patt * * Copyright (C) 1993, 1995, 1997 The Regents of the University of Michigan  * * This software is being provided by the copyright holders under the * following license. By obtaining, using and/or copying this software, * you agree that you have read, understood, and will comply with the * following terms and conditions: * * Permission to use, copy, modify, distribute, and sell this software * and its documentation for any purpose and without fee or royalty is * hereby granted, provided that the full text of this NOTICE appears on * ALL copies of the software and documentation or portions thereof, * including modifications, that you make. * * THIS SOFTWARE IS PROVIDED "AS IS," AND COPYRIGHT HOLDERS MAKE NO * REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED. BY WAY OF EXAMPLE, * BUT NOT LIMITATION, COPYRIGHT HOLDERS MAKE NO REPRESENTATIONS OR * WARRANTIES OF MERCHANTABILITY OR FITNESS FOR ANY PARTICULAR PURPOSE OR * THAT THE USE OF THE SOFTWARE OR DOCUMENTATION WILL NOT INFRINGE ANY * THIRD PARTY PATENTS, COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS. COPYRIGHT * HOLDERS WILL BEAR NO LIABILITY FOR ANY USE OF THIS SOFTWARE OR * DOCUMENTATION. * *  This software is provided AS IS, WITHOUT REPRESENTATION FROM THE * UNIVERSITY OF MICHIGAN AS TO ITS FITNESS FOR ANY PURPOSE, AND * WITHOUT WARRANTY BY THE UNIVERSITY OF MICHIGAN OF ANY KIND, EITHER * EXPRESSED OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE REGENTS * OF THE UNIVERSITY OF MICHIGAN SHALL NOT BE LIABLE FOR ANY DAMAGES, * INCLUDING SPECIAL , INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, * WITH RESPECT TO ANY CLAIM ARISING OUT OF OR IN CONNECTION WITH THE * USE OF OR IN CONNECTION WITH THE USE OF THE SOFTWARE, EVEN IF IT HAS * BEEN OR IS HEREAFTER ADVISED OF THE POSSIBILITY OF SUCH DAMAGES * * The names and trademarks of copyright holders or authors may NOT be * used in advertising or publicity pertaining to the software without * specific, written prior permission. Title to copyright in this software * and any associated documentation will at all times remain with copyright * holders. */#include "disksim_global.h"#include "disksim_stat.h"int stat_get_count (statgen *statptr){   return(statptr->count);}int stat_get_count_set (statgen **statset, int statcnt){   int i;   int count = 0;   for (i=0; i<statcnt; i++) {      statgen *statptr = statset[i];      count += statptr->count;   }   return(count);}double stat_get_runval (statgen *statptr){   return(statptr->runval);}void stat_update (statgen *statptr, double value){   int  i = 0;   int  start = statptr->distbrks[0];   int  step = statptr->distbrks[1];   int  grow = statptr->distbrks[2];   int  equals = statptr->equals;   int  buckets = statptr->distbrks[(DISTSIZE-1)];   int  intval = (int) (value * (double) statptr->scale);   statptr->count++;   if (statptr->maxval < value) {      statptr->maxval = value;   }   statptr->runval += value;   statptr->runsquares += (value*value);   if (buckets > DISTSIZE) {      if (intval < start) {      } else if (!grow) {         if ((equals) && (intval <= (start - step + (step * equals))) && (((intval - start) % step) == 0)) {            i = intval / step;         } else {            i = (intval + step - start) / step;            if (i >= buckets) {               i = buckets - 1;            }         }      } else {         int top = buckets - 1;         while (i < equals) {            if (intval == statptr->largediststarts[i]) {               break;            }            i++;         }         if ((i >= equals) && (i < buckets)) {            top--;            if (intval < statptr->largediststarts[top]) {               int bottom = i;               while (top != bottom) {                  i = bottom + ((top - bottom) / 2);                  if (intval < statptr->largediststarts[(i+1)]) {                     top = i;                  } else {                     bottom = i+1;                  }               }            }            i = top + 1;         }      }      statptr->largedistvals[i]++;   } else {      i = 0;      while (i<(DISTSIZE-1)) {         if ((i < equals) && (value == (double) statptr->distbrks[i])) {            break;         } else if ((i >= equals) && (intval < statptr->distbrks[i])) {            break;         }         i++;      }      statptr->smalldistvals[i]++;   }}static void stat_print_large_dist (statgen **statset, int statcnt, int count, char *identstr){   int  i, j;   statgen *statptr = statset[0];   int  step = statptr->distbrks[1];   int  grow = statptr->distbrks[2];   int  buckets = statptr->distbrks[(DISTSIZE-1)];   int  bucketno = statptr->distbrks[0];   double scale = (double) statptr->scale;   int scaled = (scale == 1.0) ? FALSE : TRUE;   double dist = 0.0;   int  bucketcnt;   double density;   if (count == 0) {      return;   }   fprintf (outputfile, "%s%s distribution\n", identstr, statptr->statdesc);   for (i=0; i<buckets; i++) {      if (statcnt > 1) {         bucketcnt = 0;         for (j=0; j<statcnt; j++) {            statptr = statset[j];            bucketcnt += statptr->largedistvals[i];         }      } else {         bucketcnt = statptr->largedistvals[i];      }      density = (double) bucketcnt / (double) count;      dist += density;      if (scaled) {         fprintf (outputfile, "%6.3f  \t%7d  \t%f  \t%f\n", ((double) bucketno / scale), bucketcnt, density, dist);      } else {         fprintf (outputfile, "%4d  \t%7d  \t%f  \t%f\n", bucketno, bucketcnt, density, dist);      }      bucketno += step + (int)((double) (abs(bucketno) * grow) / (double) 100);   }}void stat_print (statgen *statptr, char *identstr){  stat_print_file(statptr, identstr, outputfile);}void stat_print_file (statgen *statptr, char *identstr, FILE *outfile){   int i;   int count = 0;   int buckets = statptr->distbrks[(DISTSIZE-1)];   double scale = (double) statptr->scale;   int intval = statptr->distbrks[(DISTSIZE-2)];   char *statdesc = statptr->statdesc;   char distchar = '=';

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -