我在加载/读取
vector<vector< bitset<32> >
(在我的代码中称为/类型定义为人口)
它使用以下代码存储:
void genetic_algorithm::save_generation(population pop_to_save, string filename){
std::ofstream file(filename, std::ofstream::binary);
unsigned long n;
for(size_t i = 0; i < pop_to_save.size(); i++ )
{
if ( pop_to_save[i].size() > 0 )
{
n = pop_to_save[i][0].to_ulong();
const char* buffer = reinterpret_cast<const char*>(&n);
file.write(buffer, pop_to_save[i].size());
}
}
}
因此,我需要的是一个可以加载的函数,即:
population genetic_algorithm::load_generation(string filename){
// TODO
}
此致敬意
马蒂亚斯。
编辑
我已经自己解决了这个问题(在评论的帮助下) 以下是可能面临相同问题的任何内容的最终代码:
void genetic_algorithm::save_generation(population pop_to_save, string filename){
std::ofstream file(filename, std::ofstream::binary);
unsigned long n;
for(size_t i = 0; i < pop_to_save.size(); i++ ) {
for (size_t j = 0; j < pop_to_save[i].size(); j++) {
n = pop_to_save[i][j].to_ulong();
file.write(reinterpret_cast<const char*>(&n), sizeof(n));
}
}
std::cout << "Saved population to: " << filename << 'n';
}
population genetic_algorithm::load_generation(string filename){
std::ifstream file(filename, std::ofstream::binary);
population loaded_pop (20, std::vector<bitset<32>> (394,0));
unsigned long n;
for(size_t i = 0; i < 20; i++ ) {
for (size_t j = 0; j < 394; j++) {
file.read( reinterpret_cast<char*>(&n), sizeof(n) );
loaded_pop[i][j] = n;
}
}
std::cout << "Loaded population from: " << filename << 'n';
return loaded_pop;
}
我genetic_algorithm::save_generation()
检查了你的方法,我发现了:
-
bitset<32>
以打包形式存储 32 位(可能是具有 32 位或类似内容的unsigned int
)。 -
vector<bitset<32> >
存储此类位集的动态数组。 -
vector<vector<bitset<32> > >
存储此类位集动态数组的动态数组。
目前为止,一切都好。在方法genetic_algorithm::save_generation()
中,循环遍历外部向量的所有元素以转储每个内部向量的内容(如果不是空的)。
file.write(buffer, pop_to_save[i].size());
可能不是您想要的。std::ostream::write()
的第二个参数是字符数。传递 resp. 内部向量的size()
,该向量返回元素的数量(但不返回以字节为单位的大小)。但是元素大小(bitset<32>
)可能大于字符。更好的方法(尽管不是最好的)是使用代替file.write(buffer, 4 * pop_to_save[i].size());
。(sizeof (char)
: 1,sizeof bitset<32>
: 希望是 4 但我会检查这个。
因此,更安全的是使用file.write(buffer, pop_to_save[i].size() * sizeof pop_to_save[i][0]);
.这更好,但仍然不完美。如果要在多个平台上使用应用程序,这可能会失败,因为文件格式现在变得依赖于平台。(这取决于sizeof pop_to_save[i][0]
。
因此,最好的方法是也为内部向量创建一个嵌套循环,并使用一种独立于平台的大小单独存储它们的元素(例如std::uint32_t
)。
但是,我真正关心的是设计问题:
如果存储动态数组的动态数组(其中每个内部数组可能具有任意大小),则还必须存储这些内部数组的元素数。这就是我在你的方法中错过的genetic_algorithm::save_generation()
.
可能是,您的加载问题是由以下事实引起的:您必须保留或调整内部向量的大小才能加载位,但您不知道使用哪种大小。我的回答是:你不可能知道。此信息丢失(并且必须以某种方式提供,例如由文件本身提供)。