鱼C论坛

 找回密码
 立即注册
楼主: ShuviDoura

[已解决]关于bp神经网络

[复制链接]
发表于 2024-11-6 10:44:55 | 显示全部楼层
ShuviDoura 发表于 2024-11-06 10:44
以上我都做到了,为何仍然存在报错
Traceback (most  ...


PyCharm 不检测到 Conda 环境中的 NumPy 包,通常是由于配置导致的。以下步骤可以帮助解决这个问题:

1. **确保已在 Conda 环境中运行 PyCharm**:
   - 打开 Anaconda Prompt。
   - 激活你的环境: `conda activate sky01`。
   - 启动 PyCharm(确保打开的是配置了正确解释器的项目):`pycharm`。
   
2. **再次确保解释器配置正确**:
   - 如前所述,打开 PyCharm 的 "Settings" -> "Project: " -> "Python Interpreter",确保显示的路径指向 Conda 环境下的 Python 解释器。

3. **检查 PyCharm 权限**:
   - 有时由于系统权限导致,确保 PyCharm 可以访问你的 Conda 环境目录。

4. **使用 PyCharm 内置终端**:
   - 打开 PyCharm 下方的 Terminal,输入 `conda list` 查看是否能检测出 NumPy。
   - 如果终端正常,依然有问题,可能是 PyCharm 未正确同步,请重启软件。

5. **检查包安装位置**:
   - 确保你的 `numpy` 安装在 Conda 环境的 `site-packages` 目录中。
   - 在 Anaconda Prompt 中,运行 `conda list`,确保正确的包被列出。

6. **更新 PyCharm 和 Conda**:
   - 确保 PyCharm 和 Conda 是最新版本,排除因版本旧引发的不兼容问题。

如果以上步骤都无法解决,尝试在项目外创建一个全新的环境,再将项目设置指向该环境。如果问题仍然存在,请检查是否有其他包或脚本影响环境变量。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2024-11-6 11:19:15 | 显示全部楼层
FishC 发表于 2024-11-6 10:44
PyCharm 不检测到 Conda 环境中的 NumPy 包,通常是由于配置导致的。以下步骤可以帮助解决这个问题:
...

我新创另一个conda环境下载torch,显示这样算安装成功了吗
(kissshot) C:\Windows\System32>conda install pytorch torchvision torchaudio pytorch-cuda=12.1 -c pytorch -c nvidia
Collecting package metadata (current_repodata.json): done
Solving environment: failed with initial frozen solve. Retrying with flexible solve.
Collecting package metadata (repodata.json): done
Solving environment: failed with initial frozen solve. Retrying with flexible solve.

PackagesNotFoundError: The following packages are not available from current channels:

  - torchaudio
  - torchvision
  - pytorch-cuda=12.1
  - pytorch

Current channels:

  - https://conda.anaconda.org/pytorch/win-32
  - https://conda.anaconda.org/pytorch/noarch
  - https://conda.anaconda.org/nvidia/win-32
  - https://conda.anaconda.org/nvidia/noarch
  - https://repo.anaconda.com/pkgs/main/win-32
  - https://repo.anaconda.com/pkgs/main/noarch
  - https://repo.anaconda.com/pkgs/r/win-32
  - https://repo.anaconda.com/pkgs/r/noarch
  - https://repo.anaconda.com/pkgs/msys2/win-32
  - https://repo.anaconda.com/pkgs/msys2/noarch

To search for alternate channels that may provide the conda package you're
looking for, navigate to

    https://anaconda.org

and use the search bar at the top of the page.
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-11-6 11:19:26 | 显示全部楼层
ShuviDoura 发表于 2024-11-06 11:19
我新创另一个conda环境下载torch,显示这样算安装成功 ...


r
根据错误信息提示,当前设置的Conda通道中找不到你请求的PyTorch、TorchVision、TorchAudio和CUDA包。这可能是因为所用的通道不支持这些软件包,或可能是你正在使用32位操作系统,而这些包通常需要64位的Win。
r
### 解决方案r
r
1. **添加合适的通道**:
   - 确保通道配置正确并支持64位的Win。可以通过以下命令添加:
   
conda config --add channels defaults
     conda config --add channels conda-forge
     conda config --add channels pytorch
     conda config --add channels nvidia

2. **查找可用包**:r
   - 在 [Anaconda网站](https://anaconda.org/pytorch/pytorch) 上查找所需软件包及其通道。您可以指定适当的版本号,并确保选择支持的平台。
r
3. **指定PyTorch教程**:r
   - 使用PyTorch官网的安装向导来获取特定于您的平台、Python版本和CUDA版本的安装命令(如有必要)。
     访问 [PyTorch](https://pytorch.org/get-started/locally/) 获取指南。r
r
4. **尝试特定环境**:
   - 假设已将通道正确配置为64位,请使用以下替代命令之一以尝试:
   
conda install pytorch torchvision torchaudio cudatoolkit=11.8 -c pytorch -c nvidia
     或者只使用cpu版本:
   
conda install pytorch torchvision torchaudio cpuonly -c pytorch

通过这些步骤,您应该可以正确安装PyTorch及其附属组件。确保安装环境配置正确,且平台符合包的要求(通常为64位win)。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2024-11-6 14:41:47 | 显示全部楼层
FishC 发表于 2024-11-6 11:19
r
根据错误信息提示,当前设置的Conda通道中找不到你请求的PyTorch、TorchVision、TorchAudio和CUDA包 ...

不同块度下多尺度重建结构元素尺寸选取
这是什么意思
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-11-6 14:42:02 | 显示全部楼层
ShuviDoura 发表于 2024-11-06 14:41
不同块度下多尺度重建结构元素尺寸选取
这是什么意思


这句话可能涉及图像处理或信号处理领域,特别是在多尺度分析或重建过程中。以下是对其各部分的解释:

1. **不同块度**:块度通常指的是在处理过程中选取的“块”或“区域”的大小。在图像处理中,这可能指的是图像分块的大小,不同的块度可以对图像的不同细节进行处理和分析。

2. **多尺度重建**:多尺度通常涉及处理和分析不同尺度上的信息,例如在图像金字塔或小波变换中,通过不同尺度的分解去分析信号或图像细节。重建则指的是从多尺度分解的信息中重建出信号或图像。

3. **结构元素尺寸选取**:指在形态学处理中,选择用于操作的“结构元素”的大小。结构元素是一个小的形状模板,用来执行形态学操作(如腐蚀、膨胀等),其尺寸会影响操作结果的细节与平滑程度。

总的来说,这个术语可能描述的是在图像或信号处理过程中,如何在多尺度下选择合适的块大小和结构元素尺寸,以便更有效地进行重建和分析。具体应用依赖于具体的算法和处理需求。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2024-11-6 15:01:35 | 显示全部楼层
以不同配比下充填料浆的灰度及纹理特征提取为标题,写三到五个个关键步骤
包括且不限于
1包括特征的选取(有哪些可以使用的特征,比如纹理,颜色)
2然后用什么方法验证,评价每一个选择的特征效果好不好
3最后得到一个结论(可以用什么特征)
@FishC
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-11-6 15:01:44 | 显示全部楼层
ShuviDoura 发表于 2024-11-06 15:01
以不同配比下充填料浆的灰度及纹理特征提取为标题,写 ...


标题:以不同配比下充填料浆的灰度及纹理特征提取

关键步骤:

1. **特征的选取**
   - 首先,需要识别出图像中的关键特征。常用的特征包括:
     - 灰度特征:计算图像中的像素级灰度值。
     - 纹理特征:使用GLCM(Gray Level Co-occurrence Matrix),LBP(Local Binary Patterns)等方法提取图像的纹理信息。
     - 颜色特征:虽然在灰度图中不明显,但如果需要,可以分析不同光照条件下的颜色反应。
     - 形状特征:检测和分析填料颗粒的形状和边界。

2. **特征验证与评价**
   - 为了验证和评价每一个选取的特征的效果,可以使用:
     - 分类算法:如支持向量机(SVM)或随机森林等机器学习方法,通过训练和测试集的准确率来判定特征的优劣。
     - 相关性分析:分析特征与料浆质量之间的相关性,例如Pearson相关系数。
     - 可视化工具:使用PCA(Principal Component Analysis)或t-SNE进行降维和可视化,以观察特征在二维空间中的分布。

3. **结果分析与选取最优特征**
   - 根据验证结果,分析哪种特征或者哪几种特征组合能够最好地区分不同配比的料浆。
   - 定量评价和定性分析结合,以确保特征选取的科学性和准确性。
   - 最终得出能够有效表征充填料浆配比差异的特征集,为后续的分析和模型应用提供基础。

通过这些步骤,可以系统地提取和验证不同配比下充填料浆的有效特征。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2024-11-6 15:14:40 | 显示全部楼层
FishC 发表于 2024-11-6 15:01
标题:以不同配比下充填料浆的灰度及纹理特征提取

关键步骤:

传统的图像识别(选择特征,然后使用分类器分类)和现在流行的卷积神经网络、bp神经网络、深度学习这些有什么本质上的区别
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2024-11-6 15:16:50 | 显示全部楼层
FishC 发表于 2024-11-6 15:01
标题:以不同配比下充填料浆的灰度及纹理特征提取

关键步骤:

传统的图像识别(选择特征,然后使用分类器分类)和现在流行的卷积神经网络、bp神经网络、深度学习这些有什么本质上的区别
@FishC
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-11-6 15:26:20 | 显示全部楼层
ShuviDoura 发表于 2024-11-06 15:14
传统的图像识别(选择特征,然后使用分类器分类)和现 ...


传统的图像识别方法和现代的深度学习方法(如卷积神经网络、BP神经网络)在本质上有几个关键区别:

1. **特征提取方式**:
   - **传统方法**:通常需要手动设计和选择特征。这些特征可能包括颜色直方图、边缘检测、纹理分析等。特征提取是一个独立于分类器的步骤,依赖于领域专家的知识。
   - **深度学习方法**:特征提取和分类是一个端到端的过程。网络通过学习自动提取特征,尤其是卷积神经网络(CNN),能够在不同层次上自动学习图像的低级和高级特征。

2. **模型复杂性和能力**:
   - **传统方法**:通常使用简单的分类器,如支持向量机(SVM)、K近邻(KNN)等。这些方法在处理高维数据时可能表现不佳。
   - **深度学习方法**:使用多层神经网络,能够处理复杂的非线性关系。深度学习模型(如CNN、RNN)具有更强的表达能力,能够捕捉数据中的复杂模式。

3. **数据需求**:
   - **传统方法**:通常在小数据集上也能表现良好,因为特征是手动设计的。
   - **深度学习方法**:通常需要大量的数据来训练,以便学习到有效的特征和模型参数。

4. **计算资源**:
   - **传统方法**:计算需求相对较低,适合在普通计算机上运行。
   - **深度学习方法**:需要大量的计算资源,通常需要使用GPU来加速训练过程。

5. **适应性和泛化能力**:
   - **传统方法**:特征的选择和分类器的设计通常是针对特定任务的,适应性较差。
   - **深度学习方法**:具有更好的泛化能力,能够在不同任务和数据集上表现良好,尤其是通过迁移学习。

这些区别使得深度学习方法在许多图像识别任务中表现优于传统方法,尤其是在处理复杂和大规模数据时。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-11-6 15:45:20 | 显示全部楼层
ShuviDoura 发表于 2024-11-06 15:16
传统的图像识别(选择特征,然后使用分类器分类)和现 ...


传统的图像识别方法和现代的深度学习技术在处理图像的方式上有几个本质上的区别:

1. **特征提取方式**:
   - **传统方法**:通常需要人为选择和设计特征,比如边缘、形状、纹理等,再通过算法进行分类。这需要对领域有深刻理解,且高度依赖于特征的质量。
   - **深度学习**:尤其是卷积神经网络(CNN),可以自动从数据中学习特征,不需要人工干预。这使得模型能够发现更深层次、复杂的特征。

2. **层次结构**:
   - **传统方法**:特征提取和分类是两个独立的步骤。
   - **深度学习**:特征提取和分类是集成在一个端到端的模型中,CNN通过多层卷积和池化层提取特征,然后通过全连接层进行分类。

3. **非线性表示**:
   - **传统方法**:通常线性处理特征,容易受限于特征表示能力。
   - **深度学习**:尤其是深度神经网络(如CNN和BP神经网络),通过多层非线性变换得到更加丰富的特征表示能力。

4. **适应性和性能**:
   - **传统方法**:性能有限,在复杂任务中表现不佳。
   - **深度学习**:适应性强,尤其在处理海量数据和复杂模式时表现出色。

5. **计算资源**:
   - **传统方法**:相对来说计算要求较低。
   - **深度学习**:需要大量的数据和计算资源(GPU等),进行训练和优化。

这些特点使得深度学习技术,尤其是卷积神经网络,在视觉识别任务中得到了广泛应用和显著的成功。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2024-11-13 14:51:16 | 显示全部楼层
FishC 发表于 2024-11-6 15:45
传统的图像识别方法和现代的深度学习技术在处理图像的方式上有几个本质上的区别:

1. **特征提取方 ...

怎么求一张图片的灰度均值,灰度方差,灰度峰态
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-11-13 14:51:28 | 显示全部楼层
ShuviDoura 发表于 2024-11-13 14:51
怎么求一张图片的灰度均值,灰度方差,灰度峰态


要计算一张图片的灰度均值、灰度方差和灰度峰态(kurtosis),可以使用 Python 的 `OpenCV` 和 `SciPy` 库。以下是一个示例代码:
import cv2
import numpy as np
from scipy.stats import kurtosis

# 读取图片并转换为灰度图
image = cv2.imread('path_to_your_image.jpg', cv2.IMREAD_GRAYSCALE)

# 计算灰度均值
mean = np.mean(image)

# 计算灰度方差
variance = np.var(image)

# 将灰度值展平为一维数组以计算峰态
flattened_image = image.flatten()
kurt = kurtosis(flattened_image, fisher=True)

print(f"灰度均值: {mean}")
print(f"灰度方差: {variance}")
print(f"灰度峰态: {kurt}")
### 说明:
- **灰度均值**:通过 `np.mean` 方法直接计算。
- **灰度方差**:使用 `np.var` 计算图像中灰度值的差异。
- **灰度峰态**:通过 `scipy.stats.kurtosis` 计算,`fisher=True` 参数用于返回Fisher定义的峰态,其中正态分布的峰态为0。

确保你的环境中已安装 `opencv-python` 和 `scipy`,你可以通过 `pip install opencv-python scipy` 来安装。希望这能帮到你进行图像特性分析!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2024-11-13 14:53:40 | 显示全部楼层
FishC 发表于 2024-11-13 14:51
要计算一张图片的灰度均值、灰度方差和灰度峰态(kurtosis),可以使用 Python 的 `OpenCV` 和 `SciPy` ...

  File "<__array_function__ internals>", line 5, in mean
  File "C:\Users\shiro\Desktop\01\conda\envs\skyzero\lib\site-packages\numpy\core\fromnumeric.py", line 3440, in mean
    return _methods._mean(a, axis=axis, dtype=dtype,
  File "C:\Users\shiro\Desktop\01\conda\envs\skyzero\lib\site-packages\numpy\core\_methods.py", line 191, in _mean
    ret = ret / rcount
TypeError: unsupported operand type(s) for /: 'NoneType' and 'int'
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-11-13 14:53:53 | 显示全部楼层
ShuviDoura 发表于 2024-11-13 14:53
File "", line 5, in mean
  File "C:\Users\shiro\D ...


这个错误通常表示在执行计算时,由于输入数据类型不正确,导致无法进行除法运算。可能的原因是图像加载失败,导致 `image` 变量为 `None`。以下是检查和解决方案:

1. **确认图片路径正确**:
   - 确保`cv2.imread('path_to_your_image.jpg', cv2.IMREAD_GRAYSCALE)`中的路径是正确的。你可以打印`image`变量,确保它不为`None`。

2. **检查 OpenCV 版本及安装**:
   - 确保安装的OpenCV版本支持你的Python和系统环境。使用 `pip install opencv-python` 确保正确安装。

3. **调试步骤**:
   - 添加断点或打印语句检查 `image`。
   
image = cv2.imread('path_to_your_image.jpg', cv2.IMREAD_GRAYSCALE)
if image is None:
    print("Failed to load image. Check the file path.")
else:
    mean = np.mean(image)
    variance = np.var(image)
    flattened_image = image.flatten()
    kurt = kurtosis(flattened_image, fisher=True)

    print(f"灰度均值: {mean}")
    print(f"灰度方差: {variance}")
    print(f"灰度峰态: {kurt}")

确保路径正确且文件存在,这可以帮助解决类型不匹配的问题。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2024-11-13 15:53:26 | 显示全部楼层
FishC 发表于 2024-11-13 14:53
这个错误通常表示在执行计算时,由于输入数据类型不正确,导致无法进行除法运算。可能的原因是图像加载 ...

怎么求一张图片对比度、相关性、角二阶矩及同质性
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-11-13 15:53:44 | 显示全部楼层
ShuviDoura 发表于 2024-11-13 15:53
怎么求一张图片对比度、相关性、角二阶矩及同质性


要计算一张图片的对比度、相关性、角二阶矩及同质性,可以借助Python库`scikit-image`和`numpy`来实现,特别是使用灰度共生矩阵(GLCM)来提取这些特征。下面是一个示例代码:
import numpy as np
import cv2
from skimage.feature import greycomatrix, greycoprops

# 读取灰度图像
image = cv2.imread('path_to_your_image.jpg', cv2.IMREAD_GRAYSCALE)

# 计算共生矩阵
glcm = greycomatrix(image, distances=[1], angles=[0], levels=256, symmetric=True, normed=True)

# 计算特征
contrast = greycoprops(glcm, 'contrast')[0, 0]
correlation = greycoprops(glcm, 'correlation')[0, 0]
energy = greycoprops(glcm, 'energy')[0, 0]  # 角二阶矩有时指 energy
homogeneity = greycoprops(glcm, 'homogeneity')[0, 0]

print(f'Contrast: {contrast}')
print(f'Correlation: {correlation}')
print(f'Energy (Angular Second Moment): {energy}')
print(f'Homogeneity: {homogeneity}')

### 说明:
- **灰度共生矩阵 (GLCM)**:是用来表示图像灰度级之间空间关系的一种统计方法。
- **对比度 (Contrast)**:衡量图像灰度值之间的差异。
- **相关性 (Correlation)**:反映相邻像素灰度级的相关程度。
- **角二阶矩 (Energy)**:反映纹理的稠密程度。
- **同质性 (Homogeneity)**:衡量矩阵的局部一致性。

确保在安装`scikit-image`前已经安装了必要的依赖项(如`numpy`、`scipy`等)。如果未安装`scikit-image`,可以通过`pip install scikit-image`来进行安装。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2024-11-13 17:27:33 | 显示全部楼层
FishC 发表于 2024-11-13 15:53
要计算一张图片的对比度、相关性、角二阶矩及同质性,可以借助Python库`scikit-image`和`numpy`来实现 ...

Traceback (most recent call last):
  File "C:\Users\shiro\Desktop\digital image\1.0 传统识别\1.0 gray level.py", line 30, in <module>
    glcm = greycomatrix(img, distances=[1], angles=[0], levels=256, symmetric=True, normed=True)
  File "C:\Users\shiro\Desktop\01\conda\envs\skyzero\lib\site-packages\skimage\feature\texture.py", line 102, in greycomatrix
    check_nD(image, 2)
  File "C:\Users\shiro\Desktop\01\conda\envs\skyzero\lib\site-packages\skimage\_shared\utils.py", line 183, in check_nD
    raise ValueError(msg_incorrect_dim % (arg_name, '-or-'.join([str(n) for n in ndim])))
ValueError: The parameter `image` must be a 2-dimensional array
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-11-13 17:27:46 | 显示全部楼层
ShuviDoura 发表于 2024-11-13 17:27
Traceback (most recent call last):
  File "C:\Use ...


这个错误表明函数 `greycomatrix` 期望输入的是一个二维数组(即灰度图像),而你提供的可能不是。例如,输入可能是一个三通道的彩色图像。以下是如何解决这个问题:

1. **确保图像为灰度图像**:
   在使用`greycomatrix`之前,将图像转换为灰度图像。你可以使用`OpenCV`来实现:
import cv2
import numpy as np
from skimage.feature import greycomatrix, greycoprops

# 读取图像并转换为灰度图
img_path = 'your_image_path.jpg'
img_color = cv2.imread(img_path)

# 检查图片是否存在
if img_color is None:
    raise FileNotFoundError(f'无法找到图片: {img_path}')

# 将图片转换为灰度图像
img_gray = cv2.cvtColor(img_color, cv2.COLOR_BGR2GRAY)

# 使用scikit-image库的greycomatrix计算灰度共生矩阵
distances = [1]  # 可以根据需求调整
angles = [0, np.pi/4, np.pi/2, 3*np.pi/4]  # 方向角
glcm = greycomatrix(img_gray, distances=distances, angles=angles, levels=256,
                    symmetric=True, normed=True)

# 计算对比度、相关性、角二阶矩及同质性
contrast = greycoprops(glcm, 'contrast')
correlation = greycoprops(glcm, 'correlation')
energy = greycoprops(glcm, 'energy')
homogeneity = greycoprops(glcm, 'homogeneity')

print('对比度:', contrast)
print('相关性:', correlation)
print('角二阶矩:', energy)
print('同质性:', homogeneity)

2. **调整参数**:
   确保`distances`和`angles`参数是以列表形式传递的,即 `distances=[1]` 和 `angles=[0]`。

3. **检查图像路径和格式**:
   确保提供的图像路径正确,并且读取的图像是有效文件。

这样的代码能够帮助你提取所需的图像纹理特征。同时,记得检查并设置某些参数以匹配所需的分析深度和方向。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2024-11-13 20:35:58 | 显示全部楼层
FishC 发表于 2024-11-13 17:27
这个错误表明函数 `greycomatrix` 期望输入的是一个二维数组(即灰度图像),而你提供的可能不是。例如 ...

import math

def test():
    vector1 = [1,2,3]
    vector2 = [1, 2, 3]
    return vector1,vector2

def pearson(vector1, vector2):
    n = len(vector1)
    #simple sums
    sum1 = sum(float(vector1[i]) for i in range(n))
    sum2 = sum(float(vector2[i]) for i in range(n))
    #sum up the squares
    sum1_pow = sum([pow(v, 2.0) for v in vector1])
    sum2_pow = sum([pow(v, 2.0) for v in vector2])
    #sum up the products
    p_sum = sum([vector1[i]*vector2[i] for i in range(n)])
    #分子num,分母den
    num = p_sum - (sum1*sum2/n)
    den = math.sqrt((sum1_pow-pow(sum1, 2)/n)*(sum2_pow-pow(sum2, 2)/n))
    if den == 0:
        return 0.0
    return num/den

if __name__=='__main__':
    a = pearson(test())
    print(a)

帮我修改一下错误
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-24 05:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表