当前位置: 首页 > news >正文

C# WPF 自己写的一个模拟病毒传播的程序,有可视化

源代码: https://github.com/t39q/VirusSpread
在这里插入图片描述

主要代码

using System;
using System.Collections.Concurrent;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;namespace VirusSpread.BussnessLogic
{public class VirusSpread{public static ConcurrentBag<Model.PeopleModel.People> peoples;public static void Init(){peoples = new ConcurrentBag<Model.PeopleModel.People>();Random random = new Random(DateTime.Now.Millisecond * DateTime.Now.Second);for (int i = 0; i < 100; i++){Model.PeopleModel.People people = new Model.PeopleModel.People();people.ID = i;people.X = random.NextDouble() * 400;people.Y = random.NextDouble() * 400;people.Disease = false;peoples.Add(people);}for (int i = 100; i < 103; i++){Model.PeopleModel.People people = new Model.PeopleModel.People();people.ID = i;people.X = random.NextDouble() * 400;people.Y = random.NextDouble() * 400;people.Disease = true;peoples.Add(people);}}public static void Run(int spreadCount,int moveDistance){int count = 0;Random random = new Random(DateTime.Now.Millisecond * DateTime.Now.Second);while (true){if (count > spreadCount){break;}foreach (var item in peoples){int parity = random.Next(0,200);double tempX, tempY;if (parity % 2 == 0){tempX = item.X + random.NextDouble() * moveDistance;tempY = item.Y + random.NextDouble() * moveDistance;}else{tempX = item.X - random.NextDouble() * moveDistance;tempY = item.Y - random.NextDouble() * moveDistance;}if (tempX>0 && tempX < 400 && tempY>0 && tempY < 400){item.X = tempX;item.Y = tempY;}}Thread.Sleep(1000);count++;}}public static void Spread(int spreadCount,int infectious){int count = 0;while (true){if (count > spreadCount){break;}var healthy = peoples.Where(item => item.Disease == false).ToList();var infected = peoples.Where(item => item.Disease == true).ToList();var pairsJoin = (from healthyItem in healthyfrom infectedItem in infectedselect new { healthyItem, infectedItem }).ToList();foreach (var item in pairsJoin){CalcDistance(item.healthyItem, item.infectedItem, out double distance);if (distance < infectious){var infectedLabel = peoples.Where(find => find.ID == item.healthyItem.ID).FirstOrDefault();infectedLabel.Disease = true;}}Thread.Sleep(1000);count++;}}public static void Display(out string statistics){statistics = peoples.Where(item => item.Disease == true).Count().ToString();}public static void CalcDistance(Model.PeopleModel.People A, Model.PeopleModel.People B, out double distance){double X = Math.Abs(A.X - B.X);double Y = Math.Abs(A.Y - B.Y);distance = Math.Sqrt(X * X + Y * Y);}}
}
http://www.lryc.cn/news/163854.html

相关文章:

  • stable diffusion实践操作-大模型介绍-SDXL1大模型
  • 软考高级系统架构设计师系列案例考点专题四:嵌入式系统
  • Django Form实现表单使用及应用场景
  • golang面试题:json包变量不加tag会怎么样?
  • 国内项目管理中级证书CSPM-3正在报名!
  • vue表格不显示列号123456
  • 【大数据】Kafka 入门指南
  • Qt 5.15集成Crypto++ 8.8.0(MSVC 2019)笔记
  • 前端面试的话术集锦第 9 篇:高频考点(webpack性能优化)
  • 程序员,你真热爱编程吗?
  • 算法通关村-----海量数据的处理方法
  • Pytorch 多卡并行(1)—— 原理简介和 DDP 并行实践
  • 快速排序(重点)
  • python高级内置函数介绍及应用举例
  • 人体呼吸存在传感器成品,毫米波雷达探测感知技术,引领智能家居新潮流
  • 软件设计模式(三):责任链模式
  • 开发者的商业智慧:产品立项策划你知道多少?
  • Linux 6.6 初步支持AMD 新一代 Zen 5 处理器
  • 第五章 Linux常用应用软件
  • 连接云-边-端,构建火山引擎边缘云网技术体系
  • 系统架构设计师(第二版)学习笔记----系统架构设计师概述
  • 自动化测试:Selenium中的时间等待
  • vim 替换命令 “:s“
  • 【golang】调度系列之m
  • 可持久化线段树
  • 运行 Node.js 与浏览器 JavaScript
  • File类操作
  • C# 实现电子签名
  • 小米6/6X/米8/米9手机刷入鸿蒙HarmonyOS.4.0系统-刷机包下载-遥遥领先
  • 集合框架和泛型二