1和0.9的循环关系

由1/3引发的悖论

0.9的循环等于1

1/3 = 0.33333...(无限循环)
1/3 * 3 = 1
0.3333... * 3 = 0.99999...(无限循环)

那么: 1 = 0.99999...(无限循环)

如上的证明,1/3 乘以 3 等于 1, 而 0.3的循环乘以3得到的结果就是0.9的循环,那么 1 与 0.9的循环相等.

0.9的循环不等于1

0.9的循环可以表示为 0.9 + 0.09 + 0.009 + … + 0.00…009,由此:

定义一个数列 a1 = 0.9,q = 0.1 的数列

则有 a1 = 0.9, a2 = 0.09,a3 = 0.009

于是有 Sn = 0.999999…(无限循环)= a1 + a2 +… + an

由此,Sn = a1 (1 - qn) / (1 - q) = 0.9 ( 1 - 0.1n ) / (1 - 0.1) = 1 - 0.1n

那么可以定义函数: f(x) = 1 - 0.1x

可以作图:

在这里插入图片描述

由上图可知 f(x) 将无限趋近于 1,即 0.9的循环不等于1

0.9的循环与1 产生的悖论

综上所述,0.9的循环和1即相等,又不相等。感觉我的知识体系出现了问题,他们矛盾了。


如果有错,欢迎指出。

邮箱:ningmonguo@foxmail.com

算法思路解说: 1. 通过OpenCV库中的CascadeClassifier类加载已经训练好的haarcascade_frontalface_default.xml,进行人脸检测。 2. 将检测到的人脸区域进行裁剪,输入到CNN模型中进行分类,判断是否佩戴口罩。 3. 训练CNN模型时,先将mask和without_mask两个数据集按照一定比例划分为训练集和测试集,然后使用ImageDataGenerator类进行数据增强,包括旋转、翻转、缩放等操作,增加模型的鲁棒性。 4. 模型架构采用卷积层、池化层、全连接层等结构,最后使用softmax函数进行分类。 5. 对于测试集结果进行评估,计算准确率、召回率等指标,选择模型表现最好的参数进行模型保存。 6. 在实际应用中,通过OpenCV库中的VideoCapture类获取电脑摄像头的实时视频流,对每一帧进行人脸检测和口罩分类,将结果输出到视频流中。 代码实现: 1. 导入相关库 ```python import cv2 import numpy as np from keras.models import load_model ``` 2. 加载已经训练好的人脸检测模型和口罩分类模型 ```python face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml') model = load_model('mask_detection.h5') ``` 3. 定义函数进行口罩分类 ```python def mask_detection(image): # 缩放图像大小为100x100 image = cv2.resize(image, (100, 100)) # 对图像进行预处理,归一化像素值 image = np.array(image) / 255.0 # 添加一个维度,变为4D张量 image = np.expand_dims(image, axis=0) # 预测分类结果,返回概率 prediction = model.predict(image)[0] # 根据概率值确定分类结果 if prediction[0] > prediction[1]: return 'mask' else: return 'without_mask' ``` 4. 打开摄像头,进行检测和分类,并输出结果到视频流中 ```python # 打开摄像头 cap = cv2.VideoCapture(0) while True: # 读取一帧图像 ret, frame = cap.read() # 将图像转为灰度图像 gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) # 检测人脸 faces = face_cascade.detectMultiScale(gray, scaleFactor=1.1, minNeighbors=5, minSize=(30, 30)) # 遍历每一个人脸区域 for (x, y, w, h) in faces: # 裁剪人脸区域 face = frame[y:y+h, x:x+w] # 进行口罩分类 mask_type = mask_detection(face) # 绘制人脸区域和分类结果 cv2.rectangle(frame, (x, y), (x+w, y+h), (0, 255, 0), 2) cv2.putText(frame, mask_type, (x, y-10), cv2.FONT_HERSHEY_SIMPLEX, 0.9, (0, 255, 0), 2) # 显示处理后的图像 cv2.imshow('Mask Detection', frame) # 按下q键退出程序 if cv2.waitKey(1) & 0xFF == ord('q'): break # 释放摄像头资源 cap.release() # 关闭窗口 cv2.destroyAllWindows() ``` 5. 训练口罩分类模型,代码如下: ```python import os import cv2 import numpy as np from keras.models import Sequential from keras.layers import Conv2D, MaxPooling2D, Flatten, Dense from keras.preprocessing.image import ImageDataGenerator # 定义数据集路径 train_dir = 'dataset/train/' test_dir = 'dataset/test/' # 定义图像大小和批次大小 image_size = 100 batch_size = 16 # 定义训练集和验证集的图像生成器 train_datagen = ImageDataGenerator( rescale=1./255, rotation_range=20, width_shift_range=0.2, height_shift_range=0.2, shear_range=0.2, zoom_range=0.2, horizontal_flip=True ) test_datagen = ImageDataGenerator(rescale=1./255) # 生成训练集和验证集 train_generator = train_datagen.flow_from_directory( train_dir, target_size=(image_size, image_size), batch_size=batch_size, class_mode='categorical' ) test_generator = test_datagen.flow_from_directory( test_dir, target_size=(image_size, image_size), batch_size=batch_size, class_mode='categorical' ) # 定义模型 model = Sequential() model.add(Conv2D(32, (3, 3), activation='relu', input_shape=(image_size, image_size, 3))) model.add(MaxPooling2D((2, 2))) model.add(Conv2D(64, (3, 3), activation='relu')) model.add(MaxPooling2D((2, 2))) model.add(Conv2D(128, (3, 3), activation='relu')) model.add(MaxPooling2D((2, 2))) model.add(Conv2D(128, (3, 3), activation='relu')) model.add(MaxPooling2D((2, 2))) model.add(Flatten()) model.add(Dense(512, activation='relu')) model.add(Dense(2, activation='softmax')) # 编译模型 model.compile(optimizer='rmsprop', loss='categorical_crossentropy', metrics=['accuracy']) # 训练模型 history = model.fit_generator( train_generator, epochs=50, validation_data=test_generator ) # 保存模型 model.save('mask_detection.h5') ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值