[转载]matlab与VS2010混合编程时,char16_t redefine

matlab与VS2010混合编程时,会有char16_t 重定义的错误。

原文在 http://blog.csdn.net/jkhere/article/details/8910321

error C2371: 'char16_t' : redefinition; different basic types   

在混合编程中,也许会出现如下错误:
—————————————————————————————————————————————————
C:\Microsoft Visual Studio 10.0\VC\INCLUDE\yvals.h(576) : error C2371: 'char16_t' : redefinition; different basic types

C:\Matlab\r2010a\extern\include\matrix.h(330) : see declaration of 'char16_t'

—————————————————————————————————————————————————
原因是VS2010中的yvals.h添加了char16_t的定义,而Matlab的matrix.h也包含对char16_t的定义,所以同时包含这两个头文件的话,会导致重复定义char16_t的错误。
解决方案:
完全没有必要修改这两个头文件(以防修改之后,会在将来导致一些问题),只需要在包含matrix.h之前包含yvals.h即可。例如:
#include <yvals.h>
#if (_MSC_VER >= 1600)
#define __STDC_UTF_16__
#endif

#include "mex.h"

注:mex.h 包含matrix.h。这就要求我们必须知道所包含的头文件是否包含matrix.h。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很高兴回答你的问题!以下是针对diamonds数据集的代码实现: 1. 对diamonds数据集生成一个新变量id,用于储存每条观测值所在的行数。挑选出id,x,y,z四个变量,将宽数据转换成长数据;将x,y,z变量名存为新变量dimension,将x,y,z的值存为新变量length,转换后的长数据存为xyz_long。 ```R # 生成新变量id diamonds$id <- 1:nrow(diamonds) # 将宽数据转换成长数据 library(tidyr) xyz_long <- pivot_longer(diamonds, cols = c("x", "y", "z"), names_to = "dimension", values_to = "length", values_drop_na = TRUE, id_cols = "id") ``` 2. 将xyz_long数据集转换回宽数据xyz_wide。宽数据xyz_wide包含id,x,y,z四个变量。 ```R # 将长数据转换为宽数据 xyz_wide <- pivot_wider(xyz_long, names_from = "dimension", values_from = "length", id_cols = c("id")) ``` 3. 写代码找出diamonds中最常见和最不常见的color,即出现次数最少和最多的color,然后按下列规则对color列重新定义:将color中其它颜色的因子合并为“othercolor”,最常见和最不常见的color分别设置为“comon”和“rare”,将新生成的数据框保存为diamonds_color_redefine,最后再将“comon”设置为diamonds_color_redefine中color因子的基准水平(referen level)。 ```R # 找出最常见和最不常见的color most_common_color <- names(sort(table(diamonds$color), decreasing = TRUE))[1] least_common_color <- names(sort(table(diamonds$color), decreasing = FALSE))[1] # 对color列重新定义 diamonds$color_redefine <- ifelse(diamonds$color %in% c(most_common_color, least_common_color), ifelse(diamonds$color == most_common_color, "common", "rare"), "othercolor") # 将新生成的数据框保存为diamonds_color_redefine diamonds_color_redefine <- diamonds[, c("id", "color_redefine")] # 将“common”设置为diamonds_color_redefine中color因子的基准水平 diamonds_color_redefine$color_redefine <- factor(diamonds_color_redefine$color_redefine, levels = c("common", "othercolor", "rare")) ``` 希望这些代码能够帮助你对diamonds数据集进行探索!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值