Peckoltia brevis

Peckoltia brevis is a small species of Peckoltia belonging to the catfish family Loricariidae. Peckoltia brevis possesses the L-number L205.

Map showing the position of the Purus river in the Amazon Basin.

Peckoltia brevis
Scientific classification
Kingdom: Animalia
Phylum: Chordata
Class: Actinopterygii
Order: Siluriformes
Family: Loricariidae
Subfamily: Hypostominae
Tribe: Ancistrini
Genus: Peckoltia
Species:
P. brevis
Binomial name
Peckoltia brevis
(La Monte, 1935)

Distribution

Peckoltia brevis is found in the middle and upper Amazon within the Purus river basin.

Appearance

Peckoltia brevis grows to around 11 cm and has numerous black spots and stripes on its yellow coloured body. Males can be distinguished from females by their slimmer profile and small teeth-like projections or odontodes across the back half of their body.

Habits

Peckoltia brevis inhabits tangled woody backwaters and feeds primarily on small meaty foods (such as carrion) and algae.

In the aquarium

Peckoltia brevis requires a tropical softwater aquarium with temperatures of 22–26 °C (72–79 °F) and a pH of around 6. Its behaviour is typical of other Loricariidae species; being very peaceful and sometimes inactive. The species is not exceptionally common in the aquarium trade.

gollark: ```rusttype Items = HashMap<ItemType, u32>;fn quantity(items: &Items, desired: &ItemType) -> u32 { if let Some(available_quantity) = items.get(desired) { *available_quantity } else { 0 }}fn contains(items: &Items, desired: &Item) -> bool { quantity(items, &to_item_type(desired)) >= desired.quantity}fn satisfies(available: &Items, desired: &Items) -> bool { for (typ, desired_quantity) in desired.iter() { if quantity(available, typ) < *desired_quantity { return false } } true}fn to_map(is: &Vec<Item>) -> Items { let out = HashMap::new(); for i in is.iter() { out.entry(to_item_type_clone(i)) .and_modify(|e| { *e += 1 }) .or_insert(0); } out}fn one_item(i: Item) -> Items { let out = HashMap::new(); out.insert(to_item_type(&i), i.quantity); out}#[derive(Debug, Deserialize, PartialEq, Eq, Serialize, Clone)]pub struct CraftingResult { pub tasks: Vec<Recipe>, pub costs: Items, pub outputs: Items}fn solve(desired: Item, available: Items, recipes: &MultiMap<ItemType, Recipe>) -> CraftingResult { if contains(&available, &desired) { // If our available items list already contains the desired item, yay, we can just do nothing return CraftingResult { tasks: vec![], costs: one_item(desired), outputs: one_item(desired) } } if let Some(recipes) = recipes.get_vec(&to_item_type(&desired)) { for recipe in recipes.iter() { let result = solve() // ??? } } else { CraftingResult { tasks: vec![], costs: HashMap::new(), outputs: HashMap::new() } }}```My code, or at least part of it.
gollark: That is NOT THE HARD PART.
gollark: (I'm still confused though)
gollark: People have already given helpful suggestions how to, soo...
gollark: Parsing a recipe dump and figuring out the steps to autocraft an item.

References

This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.