本文整理汇总了C#中SparseArray.ValidIndexies方法的典型用法代码示例。如果您正苦于以下问题:C# SparseArray.ValidIndexies方法的具体用法?C# SparseArray.ValidIndexies怎么用?C# SparseArray.ValidIndexies使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类SparseArray
的用法示例。
在下文中一共展示了SparseArray.ValidIndexies方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Generate
public void Generate(SparseArray<float> production, SparseArray<float> attractions)
{
float totalProduction = 0;
float totalAttraction = 0;
foreach (var zone in production.ValidIndexies())
{
float prod, attr;
production[zone] = (prod = this.PopulationFactor * production[zone]);
attractions[zone] = (attr = this.EmploymentFactor * attractions[zone]);
totalProduction += prod;
totalAttraction += attr;
}
if (totalAttraction <= 0)
{
throw new XTMF.XTMFRuntimeException("There is no employment in the zone system!");
}
else if (totalProduction <= 0)
{
throw new XTMF.XTMFRuntimeException("There is no population in the zone system!");
}
// Normalize the attractions
var inverseTotalAttraction = 1 / totalAttraction; // inverse totalAttraction to save on divisions
foreach (var zone in Root.ZoneSystem.ZoneArray.ValidIndexies())
{
attractions[zone] = (attractions[zone] * inverseTotalAttraction) * totalProduction;
}
}
示例2: LoadLocationChoiceCache
public void LoadLocationChoiceCache()
{
ZoneArray = Root.ZoneSystem.ZoneArray;
ValidZones = ZoneArray.ValidIndexies().ToArray();
LoadProbabilityTables();
}
示例3: AssignOccupationAndLicenese
private void AssignOccupationAndLicenese(Person[] people, int ageOffset, int employmentOffset, SparseArray<int> OccupationSplit, int numberOfEmploymentClassifiedPeople,
int numberOfLicenses, Random r)
{
int[] personIndex = new int[numberOfEmploymentClassifiedPeople];
for ( int i = 0; i < numberOfEmploymentClassifiedPeople; i++ )
{
personIndex[i] = i;
}
// Randomize the population for assignment (Card shuffle algorithm)
for ( int i = 0; i < numberOfEmploymentClassifiedPeople; i++ )
{
var selectedIndex = r.Next( i, numberOfEmploymentClassifiedPeople );
var temp = personIndex[selectedIndex];
personIndex[selectedIndex] = personIndex[i];
personIndex[i] = temp;
}
// assign the occupations
int occOffset = 0;
foreach ( var occIndex in OccupationSplit.ValidIndexies() )
{
var occPop = OccupationSplit[occIndex];
for ( int i = 0; i < occPop; i++ )
{
people[personIndex[occOffset + i] + ageOffset + employmentOffset].Occupation = occIndex;
}
occOffset += occPop;
}
// Randomize the population for assignment (Card shuffle algorithm)
for ( int i = 0; i < numberOfEmploymentClassifiedPeople; i++ )
{
var selectedIndex = r.Next( i, numberOfEmploymentClassifiedPeople );
var temp = personIndex[selectedIndex];
personIndex[selectedIndex] = personIndex[i];
personIndex[i] = temp;
}
// assign the occupations
for ( int i = 0; i < numberOfLicenses; i++ )
{
people[personIndex[i] + ageOffset + employmentOffset].DriversLicense = true;
}
}
示例4: SplitCars
private SparseArray<int> SplitCars(Person[] people, int zoneIndex, int validAgeIndex, int validOccupationIndex, bool license, int ageOffset, int agePop, Random rand, out int[] indexes)
{
SparseArray<float> ret = new SparseArray<float>( new SparseIndexing() { Indexes = new SparseSet[] { new SparseSet() { Start = 0, Stop = 2 } } } );
// Because everything is random at this point we actually need to scan to see how many people we have
List<int> indexesList = new List<int>( agePop );
if ( validOccupationIndex == this.UnemployedOccupation )
{
for ( int i = 0; i < agePop; i++ )
{
var person = people[i + ageOffset];
if ( person.DriversLicense == license )
{
var range = this.Demographics.AgeCategories[validAgeIndex];
var age = person.Age;
if ( age >= range.Start && age <= range.Stop )
{
indexesList.Add( i );
}
}
}
var data = this.Demographics.NonWorkerVehicleRates[zoneIndex];
foreach ( var validCarsIndex in ret.ValidIndexies() )
{
ret[validCarsIndex] = data[license ? 1 : 0, validAgeIndex, validCarsIndex];
}
}
else
{
for ( int i = 0; i < agePop; i++ )
{
var person = people[i + ageOffset];
if ( person.DriversLicense == license
&& person.Occupation == validOccupationIndex )
{
indexesList.Add( i );
}
}
var data = this.Demographics.WorkerVehicleRates[zoneIndex];
foreach ( var validCarsIndex in ret.ValidIndexies() )
{
ret[validCarsIndex] = data[license ? 1 : 0, validOccupationIndex, validCarsIndex];
}
}
indexes = indexesList.ToArray();
return this.SplitAndClear( indexes.Length, ret, rand );
}
示例5: AssignCars
private void AssignCars(Person[] people, int[] indexes, SparseArray<int> split, Household[] households, int ageOffset, Random rand)
{
var numberOfPeople = indexes.Length;
// randomly shuffle the indexes before we actually assign the households
for ( int i = 0; i < numberOfPeople; i++ )
{
var selectedIndex = rand.Next( i, numberOfPeople );
var temp = indexes[selectedIndex];
indexes[selectedIndex] = indexes[i];
indexes[i] = temp;
}
int typeOffset = 0;
foreach ( var carType in split.ValidIndexies() )
{
var numberInType = split[carType];
for ( int i = 0; i < numberInType; i++ )
{
people[indexes[i + typeOffset] + ageOffset].Household = households[carType];
}
typeOffset += numberInType;
}
}